diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-11-04 07:27:10 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2015-11-04 07:27:10 +0000 |
commit | 2731cdfd9d98358c4e4f7ec9ede8e675477fb73f (patch) | |
tree | 9a96e1d3ccc6de7a94b8d884ddb946b3c3701de3 /ext/fiddle/closure.c | |
parent | 6b1c4e9f98a3041de843a176bb946ecf500453da (diff) | |
download | ruby-2731cdfd9d98358c4e4f7ec9ede8e675477fb73f.tar.gz |
ext: use RARRAY_CONST_PTR
* ext/bigdecimal/bigdecimal.c: use RARRAY_CONST_PTR just fore
reference instead of RARRAY_PTR, to keep the array WB-protected.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52448 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/fiddle/closure.c')
-rw-r--r-- | ext/fiddle/closure.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/ext/fiddle/closure.c b/ext/fiddle/closure.c index ca1b10a61b..502f47f037 100644 --- a/ext/fiddle/closure.c +++ b/ext/fiddle/closure.c @@ -70,7 +70,7 @@ callback(ffi_cif *cif, void *resp, void **args, void *ctx) cPointer = rb_const_get(mFiddle, rb_intern("Pointer")); for (i = 0; i < argc; i++) { - type = NUM2INT(RARRAY_PTR(rbargs)[i]); + type = NUM2INT(RARRAY_CONST_PTR(rbargs)[i]); switch (type) { case TYPE_VOID: argc = 0; @@ -123,7 +123,7 @@ callback(ffi_cif *cif, void *resp, void **args, void *ctx) } } - ret = rb_funcall2(self, rb_intern("call"), argc, RARRAY_PTR(params)); + ret = rb_funcall2(self, rb_intern("call"), argc, RARRAY_CONST_PTR(params)); RB_GC_GUARD(params); type = NUM2INT(ctype); @@ -210,7 +210,7 @@ initialize(int rbargc, VALUE argv[], VALUE self) cl->argv = (ffi_type **)xcalloc(argc + 1, sizeof(ffi_type *)); for (i = 0; i < argc; i++) { - int type = NUM2INT(RARRAY_PTR(args)[i]); + int type = NUM2INT(RARRAY_CONST_PTR(args)[i]); cl->argv[i] = INT2FFI_TYPE(type); } cl->argv[argc] = NULL; |