diff options
| author | ttate <ttate@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-08-29 13:00:22 +0000 |
|---|---|---|
| committer | ttate <ttate@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-08-29 13:00:22 +0000 |
| commit | 3c8802ab86d9ee6f8a1a89eed5bede3139534f99 (patch) | |
| tree | 41618ab44af79da7696bbad15e3aa2b13054d8ba /ext | |
| parent | e9a7798217735e3613b27cc16e0881b4c6875ad5 (diff) | |
| download | ruby-3c8802ab86d9ee6f8a1a89eed5bede3139534f99.tar.gz ruby-3c8802ab86d9ee6f8a1a89eed5bede3139534f99.tar.xz ruby-3c8802ab86d9ee6f8a1a89eed5bede3139534f99.zip | |
Merged Nakada's patch [ruby-dev:18097].
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@2765 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext')
| -rw-r--r-- | ext/dl/ptr.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/ext/dl/ptr.c b/ext/dl/ptr.c index 149f33e4e..21a703c24 100644 --- a/ext/dl/ptr.c +++ b/ext/dl/ptr.c @@ -858,19 +858,21 @@ rb_dlptr_aset(int argc, VALUE argv[], VALUE self) if( TYPE(key) == T_FIXNUM || TYPE(key) == T_BIGNUM ){ void *dst, *src; - int len; - + long len; + StringValue(val); Data_Get_Struct(self, struct ptr_data, data); dst = (void*)((long)(data->ptr) + DLNUM2LONG(key)); src = RSTRING(val)->ptr; + len = RSTRING(val)->len; if( num == Qnil ){ - len = RSTRING(val)->len; + memcpy(dst, src, len); } else{ - len = NUM2INT(num); + long n = NUM2INT(num); + memcpy(dst, src, n < len ? n : len); + if( n > len ) MEMZERO((char*)dst + len, char, n - len); }; - memcpy(dst, src, len); return val; }; |
