summaryrefslogtreecommitdiffhomepage
path: root/src/class.c
diff options
context:
space:
mode:
authorMasaki Muranaka <[email protected]>2012-06-26 16:02:38 +0900
committerMasaki Muranaka <[email protected]>2012-07-18 15:26:53 +0900
commit7bb71a7d5826accc50a521e770b5b7afe283ad90 (patch)
tree23ff923c0bfb1d6c1c3abc317f12f0a7fe77382f /src/class.c
parentfdc224ff2fd43edfcb8cbe3d60a57bbe6daf1459 (diff)
downloadmruby-7bb71a7d5826accc50a521e770b5b7afe283ad90.tar.gz
mruby-7bb71a7d5826accc50a521e770b5b7afe283ad90.zip
Remove magic numbers in mrb_funcall()
Diffstat (limited to 'src/class.c')
-rw-r--r--src/class.c28
1 files changed, 17 insertions, 11 deletions
diff --git a/src/class.c b/src/class.c
index 7f53b7a2b..bf63198dd 100644
--- a/src/class.c
+++ b/src/class.c
@@ -7,6 +7,7 @@
#include "mruby.h"
#include <stdarg.h>
#include <stdio.h>
+#include <assert.h>
#include "mruby/class.h"
#include "mruby/proc.h"
#include "mruby/string.h"
@@ -863,26 +864,31 @@ mrb_method_search(mrb_state *mrb, struct RClass* c, mrb_sym mid)
}
mrb_value
-mrb_funcall(mrb_state *mrb, mrb_value self, const char *name, int argc,...)
+mrb_funcall(mrb_state *mrb, mrb_value self, const char *name, int argc, ...)
{
- mrb_value args[16];
+ mrb_value *args;
+ mrb_value result;
va_list ap;
int i;
- if (argc == 0) {
- for (i=0; i<5; i++) {
- args[i] = mrb_nil_value();
- }
- }
- else {
+ if (argc != 0) {
+ args = mrb_malloc(mrb, sizeof(mrb_value) * argc);
+ assert(args != 0);
+
va_start(ap, argc);
- // assert(argc < 16);
- for (i=0; i<argc; i++) {
+ for (i = 0; i < argc; i++) {
args[i] = va_arg(ap, mrb_value);
}
va_end(ap);
+ } else {
+ args = NULL;
+ }
+ result = mrb_funcall_argv(mrb, self, name, argc, args);
+ if (args != NULL) {
+ mrb_free(mrb, args);
}
- return mrb_funcall_argv(mrb, self, name, argc, args);
+
+ return result;
}