summaryrefslogtreecommitdiffhomepage
path: root/src/class.c
diff options
context:
space:
mode:
authorYukihiro Matsumoto <[email protected]>2012-07-19 08:24:10 +0900
committerYukihiro Matsumoto <[email protected]>2012-07-19 08:24:10 +0900
commitc697e111c8a302ce13da8d25330fca07a73767fa (patch)
tree2355622dbe9b95d028158f0924c0b794335b790a /src/class.c
parentb60baedae5e1f00646987c89791d4577ae961410 (diff)
parenta7e0f9f6408f3c1a081ca221615f2e675deb2976 (diff)
downloadmruby-c697e111c8a302ce13da8d25330fca07a73767fa.tar.gz
mruby-c697e111c8a302ce13da8d25330fca07a73767fa.zip
Merge branch 'master' of github.com:mruby/mruby
Diffstat (limited to 'src/class.c')
-rw-r--r--src/class.c38
1 files changed, 27 insertions, 11 deletions
diff --git a/src/class.c b/src/class.c
index 7f53b7a2b..762fa1591 100644
--- a/src/class.c
+++ b/src/class.c
@@ -863,26 +863,42 @@ 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];
+#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;
int i;
- if (argc == 0) {
- for (i=0; i<5; i++) {
- args[i] = mrb_nil_value();
- }
- }
- else {
+ if (argc != 0) {
+#if !defined(MRB_FUNCALL_ARGC_MAX)
+ args = mrb_malloc(mrb, sizeof(mrb_value) * argc);
+#else
+ if (argc > MRB_FUNCALL_ARGC_MAX) {
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "Too long arguments. (limit=%d)\n", MRB_FUNCALL_ARGC_MAX);
+ }
+#endif
+
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);
}
- 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;
}