Commit c697e111 authored by Yukihiro Matsumoto's avatar Yukihiro Matsumoto

Merge branch 'master' of github.com:mruby/mruby

parents b60baeda a7e0f9f6
...@@ -23,6 +23,10 @@ ...@@ -23,6 +23,10 @@
#undef HAVE_UNISTD_H /* WINDOWS */ #undef HAVE_UNISTD_H /* WINDOWS */
#define HAVE_UNISTD_H /* LINUX */ #define HAVE_UNISTD_H /* LINUX */
#define MRB_FUNCALL_ARGC_MAX 16U /* Allocate arrays using auto variable. */
//#undef MRB_FUNCALL_ARGC_MAX /* Allocate arrays using mrb_malloc if undefned. */
/* end of configuration */ /* end of configuration */
#ifdef MRB_USE_FLOAT #ifdef MRB_USE_FLOAT
......
...@@ -863,26 +863,42 @@ mrb_method_search(mrb_state *mrb, struct RClass* c, mrb_sym mid) ...@@ -863,26 +863,42 @@ mrb_method_search(mrb_state *mrb, struct RClass* c, mrb_sym mid)
} }
mrb_value 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]; #if defined(MRB_FUNCALL_ARGC_MAX)
mrb_value args[MRB_FUNCALL_ARGC_MAX];
#else
mrb_value *args = NULL;
#endif
mrb_value result;
va_list ap; va_list ap;
int i; int i;
if (argc == 0) { if (argc != 0) {
for (i=0; i<5; i++) { #if !defined(MRB_FUNCALL_ARGC_MAX)
args[i] = mrb_nil_value(); args = mrb_malloc(mrb, sizeof(mrb_value) * argc);
} #else
} if (argc > MRB_FUNCALL_ARGC_MAX) {
else { mrb_raise(mrb, E_ARGUMENT_ERROR, "Too long arguments. (limit=%d)\n", MRB_FUNCALL_ARGC_MAX);
}
#endif
va_start(ap, argc); 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); args[i] = va_arg(ap, mrb_value);
} }
va_end(ap); va_end(ap);
} }
return mrb_funcall_argv(mrb, self, name, argc, args);
result = mrb_funcall_argv(mrb, self, name, argc, args);
#if !defined(MRB_FUNCALL_ARGC_MAX)
if (args != NULL) {
mrb_free(mrb, args);
}
#endif
return result;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment