[前][次][番号順一覧][スレッド一覧]

ruby-changes:3533

From: ko1@a...
Date: Sun, 13 Jan 2008 18:42:04 +0900 (JST)
Subject: [ruby-changes:3533] nobu - Ruby:r15023 (trunk): * encoding.c (Init_Encoding): moved initialization from encdb.h.

nobu	2008-01-13 18:41:50 +0900 (Sun, 13 Jan 2008)

  New Revision: 15023

  Modified files:
    trunk/ChangeLog
    trunk/enc/make_encdb.rb
    trunk/encoding.c

  Log:
    * encoding.c (Init_Encoding): moved initialization from encdb.h.
    
    * enc/make_encdb.rb (enc_name_list): constified.
    
    * enc/make_encdb.rb (enc_init_db): moved some functions to encoding.c.


  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/enc/make_encdb.rb?r1=15023&r2=15022&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15023&r2=15022&diff_format=u
  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/encoding.c?r1=15023&r2=15022&diff_format=u

Index: encoding.c
===================================================================
--- encoding.c	(revision 15022)
+++ encoding.c	(revision 15023)
@@ -34,6 +34,12 @@
     st_table *alias_name;
 } enc_table;
 
+#undef ENC_REPLICATE
+#undef ENC_ALIAS
+#define ENC_REPLICATE(name, orig) st_insert(enc_table.replica_name, (st_data_t)(name), (st_data_t)(orig))
+#define ENC_ALIAS(name, orig) st_insert(enc_table.alias_name, (st_data_t)(name), (st_data_t)(orig))
+#define enc_name_list_size (sizeof(enc_name_list)/sizeof(enc_name_list[0]))
+
 #include "encdb.h"
 
 #define ENC_UNINITIALIZED (&rb_cEncoding)
@@ -1033,6 +1039,9 @@
 {
     id_base_encoding = rb_intern("#base_encoding");
 
+    enc_table.replica_name = st_init_strcasetable();
+    enc_table.alias_name = st_init_strcasetable();
+
     rb_cEncoding = rb_define_class("Encoding", rb_cObject);
     rb_undef_alloc_func(rb_cEncoding);
     rb_define_method(rb_cEncoding, "to_s", enc_name, 0);
Index: ChangeLog
===================================================================
--- ChangeLog	(revision 15022)
+++ ChangeLog	(revision 15023)
@@ -1,3 +1,11 @@
+Sun Jan 13 18:41:48 2008  Nobuyoshi Nakada  <nobu@r...>
+
+	* encoding.c (Init_Encoding): moved initialization from encdb.h.
+
+	* enc/make_encdb.rb (enc_name_list): constified.
+
+	* enc/make_encdb.rb (enc_init_db): moved some functions to encoding.c.
+
 Sun Jan 13 13:53:00 2008  Nobuyoshi Nakada  <nobu@r...>
 
 	* ruby.c (load_file): local variable was not initialized when -x flag
Index: enc/make_encdb.rb
===================================================================
--- enc/make_encdb.rb	(revision 15022)
+++ enc/make_encdb.rb	(revision 15023)
@@ -35,26 +35,16 @@
 end
 p aliases
 open('encdb.h', 'wb') do |f|
-  f.puts 'static const char *enc_name_list[] = {'
+  f.puts 'static const char *const enc_name_list[] = {'
   encodings.each {|name| f.puts'    "%s",' % name}
   replicas.each_key {|name| f.puts'    "%s",' % name}
   aliases.each_key {|name| f.puts'    "%s",' % name}
-  f.puts(<<"_TEXT_")
-};
-#define enc_name_list_size (sizeof(enc_name_list)/sizeof(enc_name_list[0]))
-
-static void enc_init_db(void)
-{
-    if (!enc_table.replica_name) {
-	enc_table.replica_name = st_init_strcasetable();
-    }
-    if (!enc_table.alias_name) {
-	enc_table.alias_name = st_init_strcasetable();
-    }
-_TEXT_
+  f.puts('};', '', 'static void', 'enc_init_db(void)', '{')
   replicas.each_pair {|name, orig|
-    f.puts'    st_insert(enc_table.replica_name, (st_data_t)"%s", (st_data_t)"%s");' % [name, orig]}
+    f.puts '    ENC_REPLICATE("%s", "%s");' % [name, orig]
+  }
   aliases.each_pair {|name, orig|
-    f.puts'    st_insert(enc_table.alias_name, (st_data_t)"%s", (st_data_t)"%s");' % [name, orig]}
+    f.puts '    ENC_ALIAS("%s", "%s");' % [name, orig]
+  }
   f.puts '}'
 end

--
ML: ruby-changes@q...
Info: 

[前][次][番号順一覧][スレッド一覧]