summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro Matsumoto <[email protected]>2012-06-01 02:18:30 +0900
committerYukihiro Matsumoto <[email protected]>2012-06-01 02:18:30 +0900
commitf56abcbb5a78b51b0edf0603b4e0e54ed70fd0d2 (patch)
tree95789bd28bdd9c3341f7d913c4cfbf071f722b1a
parent62f42705714d647159218d4743b2d036bb90bc8a (diff)
downloadmruby-f56abcbb5a78b51b0edf0603b4e0e54ed70fd0d2.tar.gz
mruby-f56abcbb5a78b51b0edf0603b4e0e54ed70fd0d2.zip
reorder mrb_ary_new_from_values() args to (argc, argv)
-rw-r--r--include/mruby/array.h2
-rw-r--r--src/array.c25
-rw-r--r--src/string.c2
-rw-r--r--src/struct.c2
4 files changed, 19 insertions, 12 deletions
diff --git a/include/mruby/array.h b/include/mruby/array.h
index 5c3098ebe..e2acee535 100644
--- a/include/mruby/array.h
+++ b/include/mruby/array.h
@@ -32,7 +32,7 @@ void mrb_ary_concat(mrb_state*, mrb_value, mrb_value);
mrb_value mrb_ary_splat(mrb_state*, mrb_value);
void mrb_ary_push(mrb_state*, mrb_value, mrb_value);
mrb_value mrb_ary_pop(mrb_state *mrb, mrb_value ary);
-mrb_value mrb_ary_new_from_values(mrb_state *mrb, mrb_value *vals, size_t size);
+mrb_value mrb_ary_new_from_values(mrb_state *mrb, size_t size, mrb_value *vals);
mrb_value mrb_ary_aget(mrb_state *mrb, mrb_value self);
mrb_value mrb_ary_ref(mrb_state *mrb, mrb_value ary, mrb_int n);
void mrb_ary_set(mrb_state *mrb, mrb_value ary, mrb_int n, mrb_value val);
diff --git a/src/array.c b/src/array.c
index 94396ccf6..187a8404d 100644
--- a/src/array.c
+++ b/src/array.c
@@ -27,8 +27,8 @@ ary_elt(mrb_value ary, long offset)
return RARRAY_PTR(ary)[offset];
}
-mrb_value
-mrb_ary_new_capa(mrb_state *mrb, size_t capa)
+static struct RArray*
+ary_new_capa(mrb_state *mrb, size_t capa)
{
struct RArray *a;
size_t blen;
@@ -52,6 +52,13 @@ mrb_ary_new_capa(mrb_state *mrb, size_t capa)
a->capa = capa;
a->len = 0;
+ return a;
+}
+
+mrb_value
+mrb_ary_new_capa(mrb_state *mrb, size_t capa)
+{
+ struct RArray *a = ary_new_capa(mrb, capa);
return mrb_obj_value(a);
}
@@ -62,7 +69,7 @@ mrb_ary_new(mrb_state *mrb)
}
mrb_value
-mrb_ary_new_from_values(mrb_state *mrb, mrb_value *vals, size_t size)
+mrb_ary_new_from_values(mrb_state *mrb, size_t size, mrb_value *vals)
{
mrb_value ary;
struct RArray *a;
@@ -81,7 +88,7 @@ mrb_assoc_new(mrb_state *mrb, mrb_value car, mrb_value cdr)
mrb_value arv[2];
arv[0] = car;
arv[1] = cdr;
- return mrb_ary_new_from_values(mrb, arv, 2);
+ return mrb_ary_new_from_values(mrb, 2, arv);
}
void
@@ -153,7 +160,7 @@ mrb_ary_s_create(mrb_state *mrb, mrb_value self)
int len;
mrb_get_args(mrb, "*", &vals, &len);
- return mrb_ary_new_from_values(mrb, vals, (size_t)len);
+ return mrb_ary_new_from_values(mrb, (size_t)len, vals);
}
void
@@ -555,7 +562,7 @@ mrb_ary_aget(mrb_state *mrb, mrb_value self)
if ((len = mrb_fixnum(argv[0])) < 0) return mrb_nil_value();
if (a->len == (size_t)index) return mrb_ary_new(mrb);
if ((size_t)len > a->len - index) len = a->len - index;
- return mrb_ary_new_from_values(mrb, a->buf + index, len);
+ return mrb_ary_new_from_values(mrb, len, a->buf + index);
default:
mrb_raise(mrb, E_ARGUMENT_ERROR, "wrong number of arguments");
@@ -640,7 +647,7 @@ mrb_ary_first(mrb_state *mrb, mrb_value self)
/* len == 1 */
size = mrb_fixnum(*vals);
if (size > a->len) size = a->len;
- return mrb_ary_new_from_values(mrb, a->buf, size);
+ return mrb_ary_new_from_values(mrb, size, a->buf);
}
mrb_value
@@ -662,7 +669,7 @@ mrb_ary_last(mrb_state *mrb, mrb_value self)
/* len == 1 */
size = mrb_fixnum(*vals);
if (size > a->len) size = a->len;
- return mrb_ary_new_from_values(mrb, a->buf + a->len - size, size);
+ return mrb_ary_new_from_values(mrb, size, a->buf + a->len - size);
}
mrb_value
@@ -702,7 +709,7 @@ mrb_ary_splat(mrb_state *mrb, mrb_value v)
return v;
}
else {
- return mrb_ary_new_from_values(mrb, &v, 1);
+ return mrb_ary_new_from_values(mrb, 1, &v);
}
}
diff --git a/src/string.c b/src/string.c
index 0714c360c..b6ca9e489 100644
--- a/src/string.c
+++ b/src/string.c
@@ -2111,7 +2111,7 @@ mrb_str_split_m(mrb_state *mrb, mrb_value str)
else if (lim == 1) {
if (RSTRING_LEN(str) == 0)
return mrb_ary_new_capa(mrb, 0);
- return mrb_ary_new_from_values(mrb, &str, 1);
+ return mrb_ary_new_from_values(mrb, 1, &str);
}
i = 1;
}
diff --git a/src/struct.c b/src/struct.c
index 699825cff..d06124b50 100644
--- a/src/struct.c
+++ b/src/struct.c
@@ -379,7 +379,7 @@ mrb_struct_s_def(mrb_state *mrb, mrb_value klass)
pargv = &argv[0];
argcnt++;
}
- rest = mrb_ary_new_from_values(mrb, pargv, argcnt);
+ rest = mrb_ary_new_from_values(mrb, argcnt, pargv);
}
st = make_struct(mrb, name, rest, struct_class(mrb));
if (!mrb_nil_p(b)) {