summaryrefslogtreecommitdiffstats
path: root/ext/dl
diff options
context:
space:
mode:
authorttate <ttate@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-03-08 11:31:20 +0000
committerttate <ttate@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-03-08 11:31:20 +0000
commit5095cc0c1d2b3beef5c40d23e13f45cb9cfbb50d (patch)
tree0a9e4e0e594d75f917f029122a294a074a317c36 /ext/dl
parent8a11e856f1c025c6f3d05c4792611fdd7272205e (diff)
downloadruby-5095cc0c1d2b3beef5c40d23e13f45cb9cfbb50d.tar.gz
ruby-5095cc0c1d2b3beef5c40d23e13f45cb9cfbb50d.tar.xz
ruby-5095cc0c1d2b3beef5c40d23e13f45cb9cfbb50d.zip
changed the spec of CPtr#[]/[]= to suit String#[]/[]=.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@8123 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/dl')
-rw-r--r--ext/dl/cptr.c22
-rw-r--r--ext/dl/test/test_dl2.rb22
2 files changed, 37 insertions, 7 deletions
diff --git a/ext/dl/cptr.c b/ext/dl/cptr.c
index 66a7255ef..e8e4b8bd5 100644
--- a/ext/dl/cptr.c
+++ b/ext/dl/cptr.c
@@ -346,35 +346,38 @@ VALUE
rb_dlptr_aref(int argc, VALUE argv[], VALUE self)
{
VALUE arg0, arg1;
+ VALUE retval = Qnil;
size_t offset, len;
switch( rb_scan_args(argc, argv, "11", &arg0, &arg1) ){
case 1:
offset = NUM2ULONG(arg0);
- len = 1;
+ retval = INT2NUM(*((char*)RPTR_DATA(self)->ptr + offset));
break;
case 2:
offset = NUM2ULONG(arg0);
len = NUM2ULONG(arg1);
+ retval = rb_tainted_str_new((char *)RPTR_DATA(self)->ptr + offset, len);
break;
defualt:
- rb_bug("rb_dlptr_aset()");
+ rb_bug("rb_dlptr_aref()");
}
- return rb_tainted_str_new((char *)RPTR_DATA(self)->ptr + offset, len);
+ return retval;
}
VALUE
rb_dlptr_aset(int argc, VALUE argv[], VALUE self)
{
VALUE arg0, arg1, arg2;
+ VALUE retval = Qnil;
size_t offset, len;
void *mem;
switch( rb_scan_args(argc, argv, "21", &arg0, &arg1, &arg2) ){
case 2:
offset = NUM2ULONG(arg0);
- len = 1;
- mem = NUM2PTR(arg1);
+ ((char*)RPTR_DATA(self)->ptr)[offset] = NUM2UINT(arg1);
+ retval = arg1;
break;
case 3:
offset = NUM2ULONG(arg0);
@@ -388,12 +391,13 @@ rb_dlptr_aset(int argc, VALUE argv[], VALUE self)
else{
mem = NUM2PTR(arg2);
}
+ memcpy((char *)RPTR_DATA(self)->ptr + offset, mem, len);
+ retval = arg2;
break;
defualt:
rb_bug("rb_dlptr_aset()");
}
- memcpy((char *)RPTR_DATA(self)->ptr + offset, mem, len);
- return Qnil;
+ return retval;
}
VALUE
@@ -424,6 +428,10 @@ rb_dlptr_s_to_ptr(VALUE self, VALUE val)
#endif
return rb_dlptr_new(fp, sizeof(FILE), NULL);
}
+ else if( rb_obj_is_kind_of(val, rb_cString) == Qtrue ){
+ char *ptr = StringValuePtr(val);
+ return rb_dlptr_new(ptr, RSTRING(val)->len, NULL);
+ }
else if( rb_respond_to(val, id_to_ptr) ){
VALUE vptr = rb_funcall(val, id_to_ptr, 0);
if( rb_obj_is_kind_of(vptr, rb_cDLCPtr) ){
diff --git a/ext/dl/test/test_dl2.rb b/ext/dl/test/test_dl2.rb
index d1b18057c..e59956cf7 100644
--- a/ext/dl/test/test_dl2.rb
+++ b/ext/dl/test/test_dl2.rb
@@ -85,5 +85,27 @@ class TestDL < TestBase
ary2 = dlunwrap(addr)
assert_equal(ary, ary2)
end
+
+ def test_cptr()
+ check = Proc.new{|str,ptr|
+ assert_equal(str.size(), ptr.size())
+ assert_equal(str, ptr.to_s())
+ assert_equal(str[0,2], ptr.to_s(2))
+ assert_equal(str[0,2], ptr[0,2])
+ assert_equal(str[1,2], ptr[1,2])
+ assert_equal(str[1,0], ptr[1,0])
+ assert_equal(str[0], ptr[0])
+ assert_equal(str[1], ptr[1])
+ }
+ str = 'abc'
+ ptr = CPtr[str]
+ check.call(str, ptr)
+ str[0] = ?c
+ ptr[0] = ?c
+ check.call(str, ptr)
+ str[0,2] = "aa"
+ ptr[0,2] = "aa"
+ check.call(str, ptr)
+ end
end
end # module DL