diff options
Diffstat (limited to 'ext/fiddle')
-rw-r--r-- | ext/fiddle/closure.c | 4 | ||||
-rw-r--r-- | ext/fiddle/function.c | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/ext/fiddle/closure.c b/ext/fiddle/closure.c index 502f47f..5d8a3d2 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_CONST_PTR(rbargs)[i]); + type = NUM2INT(RARRAY_AREF(rbargs, i)); switch (type) { case TYPE_VOID: argc = 0; @@ -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_CONST_PTR(args)[i]); + int type = NUM2INT(RARRAY_AREF(args, i)); cl->argv[i] = INT2FFI_TYPE(type); } cl->argv[argc] = NULL; diff --git a/ext/fiddle/function.c b/ext/fiddle/function.c index 9db29e8..209c03f 100644 --- a/ext/fiddle/function.c +++ b/ext/fiddle/function.c @@ -110,7 +110,7 @@ initialize(int argc, VALUE argv[], VALUE self) arg_types = xcalloc(RARRAY_LEN(args) + 1, sizeof(ffi_type *)); for (i = 0; i < RARRAY_LEN(args); i++) { - int type = NUM2INT(RARRAY_CONST_PTR(args)[i]); + int type = NUM2INT(RARRAY_AREF(args, i)); arg_types[i] = INT2FFI_TYPE(type); } arg_types[RARRAY_LEN(args)] = NULL; @@ -164,7 +164,7 @@ function_call(int argc, VALUE argv[], VALUE self) values = (void **)((char *)generic_args + (size_t)argc * sizeof(fiddle_generic)); for (i = 0; i < argc; i++) { - VALUE type = RARRAY_CONST_PTR(types)[i]; + VALUE type = RARRAY_AREF(types, i); VALUE src = argv[i]; if(NUM2INT(type) == TYPE_VOIDP) { |