diff options
author | tenderlove <tenderlove@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-11-12 22:41:07 +0000 |
---|---|---|
committer | tenderlove <tenderlove@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-11-12 22:41:07 +0000 |
commit | 17ccd5d013fa7ffd612aea4c9babdfb37fec213d (patch) | |
tree | 9059045c3af39186da8ab06586ed45c9607ccadb | |
parent | d109e9a67fde86e1b3dc1cebdea318355c5c8a1b (diff) | |
download | ruby-17ccd5d013fa7ffd612aea4c9babdfb37fec213d.tar.gz |
* ext/dl/cptr.c (rb_dlptr_s_to_ptr): when wrapping a pointer it should
keep a reference to the object it's wrapping
* test/dl/test_func.rb use standard test methods
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25742 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ext/dl/cptr.c | 1 | ||||
-rw-r--r-- | test/dl/test_func.rb | 2 |
2 files changed, 2 insertions, 1 deletions
diff --git a/ext/dl/cptr.c b/ext/dl/cptr.c index 96f318be53..b1b156a2b2 100644 --- a/ext/dl/cptr.c +++ b/ext/dl/cptr.c @@ -608,6 +608,7 @@ rb_dlptr_s_to_ptr(VALUE self, VALUE val) ptr = rb_dlptr_new(NUM2PTR(rb_Integer(val)), 0, NULL); } OBJ_INFECT(ptr, val); + rb_iv_set(ptr, "wrapping", val); return ptr; } diff --git a/test/dl/test_func.rb b/test/dl/test_func.rb index 86ac6301a4..522cbd4257 100644 --- a/test/dl/test_func.rb +++ b/test/dl/test_func.rb @@ -36,7 +36,7 @@ module DL buff1 = CPtr["12.34"] buff2 = buff1 + 4 r = f.call(buff1, buff2) - assert_match(12.00..13.00, r) + assert_in_delta(12.34, r, 0.001) end def test_qsort1() |