summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/array.c19
-rw-r--r--src/kernel.c11
2 files changed, 21 insertions, 9 deletions
diff --git a/src/array.c b/src/array.c
index 020b661b4..f80134de4 100644
--- a/src/array.c
+++ b/src/array.c
@@ -1078,11 +1078,11 @@ mrb_ary_rindex_m(mrb_state *mrb, mrb_value self)
MRB_API mrb_value
mrb_ary_splat(mrb_state *mrb, mrb_value v)
{
- mrb_value a;
+ mrb_value ary;
+ struct RArray *a;
if (mrb_array_p(v)) {
- struct RArray *a = mrb_ary_ptr(v);
- a = ary_dup(mrb, a);
+ a = ary_dup(mrb, mrb_ary_ptr(v));
return mrb_obj_value(a);
}
@@ -1090,12 +1090,17 @@ mrb_ary_splat(mrb_state *mrb, mrb_value v)
return mrb_ary_new_from_values(mrb, 1, &v);
}
- a = mrb_funcall(mrb, v, "to_a", 0);
- if (mrb_nil_p(a)) {
+ ary = mrb_funcall(mrb, v, "to_a", 0);
+ if (mrb_nil_p(ary)) {
return mrb_ary_new_from_values(mrb, 1, &v);
}
- mrb_ensure_array_type(mrb, a);
- return a;
+ mrb_ensure_array_type(mrb, ary);
+ a = mrb_ary_ptr(ary);
+ if (mrb_frozen_p(a)) {
+ a = ary_dup(mrb, a);
+ return mrb_obj_value(a);
+ }
+ return ary;
}
static mrb_value
diff --git a/src/kernel.c b/src/kernel.c
index 34f9fd9ef..10ed9f88e 100644
--- a/src/kernel.c
+++ b/src/kernel.c
@@ -772,13 +772,20 @@ mrb_obj_ceqq(mrb_state *mrb, mrb_value self)
if (mrb_array_p(self)) {
ary = self;
}
- else if (!mrb_respond_to(mrb, v, mrb_intern_lit(mrb, "to_a"))) {
+ else if (mrb_nil_p(self)) {
+ return mrb_false_value();
+ }
+ else if (!mrb_respond_to(mrb, self, mrb_intern_lit(mrb, "to_a"))) {
mrb_value c = mrb_funcall_argv(mrb, self, eqq, 1, &v);
if (mrb_test(c)) return mrb_true_value();
return mrb_false_value();
}
else {
- ary = mrb_ary_splat(mrb, self);
+ ary = mrb_funcall(mrb, self, "to_a", 0);
+ if (mrb_nil_p(ary)) {
+ return mrb_funcall_argv(mrb, self, eqq, 1, &v);
+ }
+ mrb_ensure_array_type(mrb, ary);
}
len = RARRAY_LEN(ary);
for (i=0; i<len; i++) {