summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-03-26 07:01:14 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-03-26 07:01:14 +0000
commite9b5878c4168ec6b5ed5129d897ee9be7636ca71 (patch)
tree9229296296e4a89f45b3d416b30559ee75768d44 /eval.c
parent8478ba513fd23c72b99790144be4fa17ebef3b35 (diff)
* eval.c (avalue_splat): new function to do unary * (splat)
operator. * eval.c (avalue_to_svalue,svalue_to_avalue,svalue_to_mrhs): do not use implicit "to_ary" conversion. * ext/curses/curses.c (GetWINDOW,GetMOUSE): add taint check. * ext/curses/curses.c (curses_init_screen): ditto. * ext/curses/curses.c (window_initialize): ditto. * gc.c (os_each_obj): prohibit ObjectSpace#each_object in safe mode ($SAFE >= 4). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@3616 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c67
1 files changed, 28 insertions, 39 deletions
diff --git a/eval.c b/eval.c
index e59ad61e78..e166712ed0 100644
--- a/eval.c
+++ b/eval.c
@@ -2201,28 +2201,23 @@ static VALUE
avalue_to_svalue(v)
VALUE v;
{
- VALUE tmp;
-
- if (v == Qundef) return v;
- tmp = rb_check_array_type(v);
- if (NIL_P(tmp)) {
+ if (TYPE(v) != T_ARRAY) {
return v;
}
- v = tmp;
if (RARRAY(v)->len == 0) {
return Qundef;
}
if (RARRAY(v)->len == 1) {
- tmp = rb_check_array_type(RARRAY(v)->ptr[0]);
- if (NIL_P(tmp)) {
- return RARRAY(v)->ptr[0];
+ VALUE tmp = RARRAY(v)->ptr[0];
+ if (TYPE(tmp) != T_ARRAY) {
+ return tmp;
}
if (RARRAY(tmp)->len > 1) {
return v;
}
return tmp;
}
- return tmp;
+ return v;
}
static VALUE
@@ -2232,40 +2227,29 @@ svalue_to_avalue(v)
VALUE tmp;
if (v == Qundef) return rb_ary_new2(0);
- tmp = rb_check_array_type(v);
-
- if (NIL_P(tmp)) {
+ if (TYPE(v) != T_ARRAY) {
return rb_ary_new3(1, v);
}
- v = tmp;
if (RARRAY(v)->len == 1) {
- tmp = rb_check_array_type(RARRAY(v)->ptr[0]);
- if (NIL_P(tmp)) return rb_ary_new3(1, v);
- if (RARRAY(tmp)->len > 1) return v;
- return tmp;
+ tmp = RARRAY(v)->ptr[0];
+ if (TYPE(tmp) == T_ARRAY && RARRAY(tmp)->len > 1)
+ return v;
+ return rb_ary_new3(1, v);
}
return v;
}
static VALUE
-avalue_to_mrhs(v)
+avalue_splat(v)
VALUE v;
{
- VALUE tmp;
-
- if (v == Qundef) return v;
- tmp = rb_check_array_type(v);
- if (NIL_P(tmp)) {
- return v;
- }
- v = tmp;
if (RARRAY(v)->len == 0) {
return Qundef;
}
if (RARRAY(v)->len == 1) {
return RARRAY(v)->ptr[0];
}
- return tmp;
+ return v;
}
static VALUE
@@ -2273,18 +2257,15 @@ svalue_to_mrhs(v, lhs)
VALUE v;
NODE *lhs;
{
- VALUE tmp;
-
if (v == Qundef) return rb_ary_new2(0);
- tmp = rb_check_array_type(v);
-
- if (NIL_P(tmp)) {
+ if (TYPE(v) != T_ARRAY) {
return rb_ary_new3(1, v);
}
- if (!lhs && RARRAY(tmp)->len <= 1) {
- return rb_ary_new3(1, tmp);
+ /* no lhs means splat lhs only */
+ if (!lhs && RARRAY(v)->len <= 1) {
+ return rb_ary_new3(1, v);
}
- return tmp;
+ return v;
}
static VALUE
@@ -2670,8 +2651,16 @@ rb_eval(self, n)
result = rb_ary_to_ary(rb_eval(self, node->nd_head));
break;
- case NODE_REXPAND:
- result = avalue_to_mrhs(rb_eval(self, node->nd_head));
+ case NODE_SPLAT:
+ {
+ VALUE tmp;
+
+ result = rb_eval(self, node->nd_head);
+ tmp = rb_check_array_type(result);
+ if (!NIL_P(tmp)) {
+ result = avalue_splat(tmp);
+ }
+ }
break;
case NODE_SVALUE:
@@ -3982,7 +3971,7 @@ rb_yield_0(val, self, klass, pcall, avalue)
massign(self, block->var, val, pcall);
}
else {
- if (avalue) val = avalue_to_mrhs(val);
+ if (avalue) val = avalue_splat(val);
if (val == Qundef) val = Qnil;
assign(self, block->var, val, pcall);
}