diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-12-21 23:35:11 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-12-21 23:35:11 +0000 |
commit | 988a2892302e55afa07172ed13446acc0c66d696 (patch) | |
tree | bf7737207505c9003dcde698e1109a8ec775423f /ext/dl | |
parent | 3b5540851a3f527a5d8be9bcbcd041837a520d3f (diff) |
* ext/dl/sym.c (rb_dlsym_initialize): extract internal pointers after
all argument conversion. fixed: [ruby-dev:25271]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@7631 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/dl')
-rw-r--r-- | ext/dl/sym.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/ext/dl/sym.c b/ext/dl/sym.c index c2f5434c61..59a618496f 100644 --- a/ext/dl/sym.c +++ b/ext/dl/sym.c @@ -154,8 +154,9 @@ rb_dlsym_initialize(int argc, VALUE argv[], VALUE self) rb_scan_args(argc, argv, "12", &addr, &name, &type); saddr = (void*)(DLNUM2LONG(rb_Integer(addr))); - sname = NIL_P(name) ? NULL : StringValuePtr(name); + if (!NIL_P(name)) StringValue(name); stype = NIL_P(type) ? NULL : StringValuePtr(type); + sname = NIL_P(name) ? NULL : RSTRING(name)->ptr; if( saddr ){ Data_Get_Struct(self, struct sym_data, data); |