summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorjbreeden <[email protected]>2015-07-11 21:03:04 -0700
committerjbreeden <[email protected]>2015-07-11 21:03:04 -0700
commitbdbd696c486f88a2239420a027f7e1772713bbe0 (patch)
tree2979a95a0fa42cd9c83a8bce843a376776c94cca
parent39dd1822446d02f21887bf043e34ac6cf0133b6f (diff)
downloadmruby-bdbd696c486f88a2239420a027f7e1772713bbe0.tar.gz
mruby-bdbd696c486f88a2239420a027f7e1772713bbe0.zip
Patching array join
-rw-r--r--src/array.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/array.c b/src/array.c
index f48719310..ff0bb8a85 100644
--- a/src/array.c
+++ b/src/array.c
@@ -295,7 +295,7 @@ mrb_ary_plus(mrb_state *mrb, mrb_value self)
mrb_get_args(mrb, "a", &ptr, &blen);
if (ARY_MAX_SIZE - blen < a1->len) {
- mrb_raise(mrb, E_ARGUMENT_ERROR, "array size too big");
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "array size too big");
}
a2 = ary_new_capa(mrb, a1->len + blen);
array_copy(a2->ptr, a1->ptr, a1->len);
@@ -349,7 +349,7 @@ mrb_ary_times(mrb_state *mrb, mrb_value self)
}
if (times == 0) return mrb_ary_new(mrb);
if (ARY_MAX_SIZE / times < a1->len) {
- mrb_raise(mrb, E_ARGUMENT_ERROR, "array size too big");
+ mrb_raise(mrb, E_ARGUMENT_ERROR, "array size too big");
}
a2 = ary_new_capa(mrb, a1->len * times);
ptr = a2->ptr;
@@ -1031,7 +1031,13 @@ mrb_ary_join_m(mrb_state *mrb, mrb_value ary)
{
mrb_value sep = mrb_nil_value();
- mrb_get_args(mrb, "|S", &sep);
+ mrb_get_args(mrb, "|o", &sep);
+ if (mrb_nil_p(sep)) {
+ sep = mrb_str_to_str(mrb, sep);
+ } else if (mrb_type(sep) != MRB_TT_STRING) {
+ mrb_raise(mrb, E_TYPE_ERROR, "expected String");
+ return mrb_nil_value();
+ }
return mrb_ary_join(mrb, ary, sep);
}