summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-12-03 07:47:37 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-12-03 07:47:37 +0000
commit638ba47303dbc54ea84147cbb21935b251f670da (patch)
tree997868272540a43f6927ab37128d8bb33a89bfd8
parent673f1b30646b591f0366f2bb258f43bd5ab3cbc2 (diff)
load.c: defer static linked init
* enc/encinit.c.erb (Init_enc): initialize encdb and transdb directly. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@48699 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--enc/encinit.c.erb17
-rw-r--r--load.c2
3 files changed, 19 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index d1ff3bdcc3..397abad6e5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Wed Dec 3 16:47:35 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * enc/encinit.c.erb (Init_enc): initialize encdb and transdb
+ directly.
+
Wed Dec 3 14:51:26 2014 Nobuyoshi Nakada <nobu@ruby-lang.org>
* load.c (ruby_require_internal): separate from rb_require_safe,
diff --git a/enc/encinit.c.erb b/enc/encinit.c.erb
index fd3ade0c4b..70c2a1934c 100644
--- a/enc/encinit.c.erb
+++ b/enc/encinit.c.erb
@@ -8,19 +8,30 @@
ruby_init_ext(name, func); \
}
+#define init_enc(name) init(Init_##name, "enc/"#name".so")
+#define init_trans(name) init(Init_trans_##name, "enc/trans/"#name".so")
+#define provide(func, name) { \
+ extern void Init_##func(void); \
+ Init_##func(); \
+ rb_provide(name".so"); \
+}
+
void ruby_init_ext(const char *name, void (*init)(void));
+void rb_provide(const char *feature);
void
Init_enc(void)
{
+ provide(encdb, "encdb");
% ENCS.each do |enc|
- init(Init_<%= enc %>, "enc/<%= enc %>.so");
+% next if enc == 'encdb'
+ init_enc(<%= enc %>);
% end
- init(Init_transdb, "enc/trans/transdb.so");
+ provide(transdb, "trans/transdb");
% TRANS.each do |trans|
% next if trans == 'trans/transdb'
- init(Init_trans_<%= File.basename trans %>, "enc/<%= trans %>.so");
+ init_trans(<%= File.basename trans %>);
% end
}
<%# vim: set ft=eruby sw=2 : -%>
diff --git a/load.c b/load.c
index 7095ea3b8b..5036d8bf24 100644
--- a/load.c
+++ b/load.c
@@ -1077,7 +1077,6 @@ register_init_ext(st_data_t *key, st_data_t *value, st_data_t init, int existing
else {
*value = (st_data_t)NEW_MEMO(init, 0, 0);
*key = (st_data_t)ruby_strdup(name);
- (*(void (*)(void))init)();
}
return ST_CONTINUE;
}
@@ -1093,7 +1092,6 @@ ruby_init_ext(const char *name, void (*init)(void))
GET_VM()->loading_table = loading_tbl = st_init_strtable();
}
st_update(loading_tbl, (st_data_t)name, register_init_ext, (st_data_t)init);
- rb_provide(name);
}
/*