diff options
| author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-09-10 00:18:39 +0000 |
|---|---|---|
| committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-09-10 00:18:39 +0000 |
| commit | 7c647031ba33abe7a4e862f9a488a0cb71e023ba (patch) | |
| tree | 9c6052b61b7e3c5f993546dc45f96a3bb62b724a /eval.c | |
| parent | 3ffcc466ebc254dafe4d98b5b60729c45d4f824a (diff) | |
| download | ruby-7c647031ba33abe7a4e862f9a488a0cb71e023ba.tar.gz ruby-7c647031ba33abe7a4e862f9a488a0cb71e023ba.tar.xz ruby-7c647031ba33abe7a4e862f9a488a0cb71e023ba.zip | |
* eval.c (rb_require_safe): prevent extension from loading twice.
fixed: [ruby-dev:29523]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@10903 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
| -rw-r--r-- | eval.c | 14 |
1 files changed, 7 insertions, 7 deletions
@@ -7068,15 +7068,15 @@ rb_require_safe(VALUE fname, int safe) } else { ruby_safe_level = 0; + /* loading ruby library should be serialized. */ + if (!loading_tbl) { + loading_tbl = st_init_strtable(); + } + /* partial state */ + ftptr = ruby_strdup(RSTRING_PTR(path)); + st_insert(loading_tbl, (st_data_t)ftptr, (st_data_t)curr_thread); switch (found) { case 'r': - /* loading ruby library should be serialized. */ - if (!loading_tbl) { - loading_tbl = st_init_strtable(); - } - /* partial state */ - ftptr = ruby_strdup(RSTRING_PTR(path)); - st_insert(loading_tbl, (st_data_t)ftptr, (st_data_t)curr_thread); rb_load(path, 0); break; |
