* eval.c (rb_eval, rb_iterate, block_pass): reduce PUSH/POP_TAG and
EXEC_TAG() for retry. [ruby-dev:21216] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4430 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
fcaadb96af
commit
0124af9063
@ -1,5 +1,9 @@
|
|||||||
Sat Aug 23 02:32:33 2003 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Sat Aug 23 15:59:58 2003 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* eval.c (rb_eval, rb_iterate, block_pass): reduce PUSH/POP_TAG and
|
||||||
|
EXEC_TAG() for retry. [ruby-dev:21216]
|
||||||
|
|
||||||
|
Sat Aug 23 02:32:33 2003 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
* eval.c (rb_yield_splat): should check if "values" is array.
|
* eval.c (rb_yield_splat): should check if "values" is array.
|
||||||
|
|
||||||
* enum.c (each_with_index_i): typo.
|
* enum.c (each_with_index_i): typo.
|
||||||
|
74
eval.c
74
eval.c
@ -2710,12 +2710,12 @@ rb_eval(self, n)
|
|||||||
case NODE_ITER:
|
case NODE_ITER:
|
||||||
case NODE_FOR:
|
case NODE_FOR:
|
||||||
{
|
{
|
||||||
iter_retry:
|
|
||||||
PUSH_TAG(PROT_FUNC);
|
PUSH_TAG(PROT_FUNC);
|
||||||
PUSH_BLOCK(node->nd_var, node->nd_body);
|
PUSH_BLOCK(node->nd_var, node->nd_body);
|
||||||
|
|
||||||
state = EXEC_TAG();
|
state = EXEC_TAG();
|
||||||
if (state == 0) {
|
if (state == 0) {
|
||||||
|
iter_retry:
|
||||||
PUSH_ITER(ITER_PRE);
|
PUSH_ITER(ITER_PRE);
|
||||||
if (nd_type(node) == NODE_ITER) {
|
if (nd_type(node) == NODE_ITER) {
|
||||||
result = rb_eval(self, node->nd_iter);
|
result = rb_eval(self, node->nd_iter);
|
||||||
@ -2733,21 +2733,24 @@ rb_eval(self, n)
|
|||||||
}
|
}
|
||||||
POP_ITER();
|
POP_ITER();
|
||||||
}
|
}
|
||||||
else if (_block.tag->dst == state) {
|
else {
|
||||||
|
if (_block.tag->dst == state) {
|
||||||
state &= TAG_MASK;
|
state &= TAG_MASK;
|
||||||
if (state == TAG_RETURN || state == TAG_BREAK) {
|
if (state == TAG_RETURN || state == TAG_BREAK) {
|
||||||
result = prot_tag->retval;
|
result = prot_tag->retval;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (state == TAG_RETRY) {
|
||||||
|
state = 0;
|
||||||
|
goto iter_retry;
|
||||||
|
}
|
||||||
|
}
|
||||||
POP_BLOCK();
|
POP_BLOCK();
|
||||||
POP_TAG();
|
POP_TAG();
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case 0:
|
case 0:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TAG_RETRY:
|
|
||||||
goto iter_retry;
|
|
||||||
|
|
||||||
case TAG_BREAK:
|
case TAG_BREAK:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -2807,47 +2810,46 @@ rb_eval(self, n)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case NODE_RESCUE:
|
case NODE_RESCUE:
|
||||||
retry_entry:
|
|
||||||
{
|
{
|
||||||
volatile VALUE e_info = ruby_errinfo;
|
volatile VALUE e_info = ruby_errinfo;
|
||||||
|
volatile int rescuing = 0;
|
||||||
|
|
||||||
PUSH_TAG(PROT_NONE);
|
PUSH_TAG(PROT_NONE);
|
||||||
if ((state = EXEC_TAG()) == 0) {
|
if ((state = EXEC_TAG()) == 0) {
|
||||||
result = rb_eval(self, node->nd_head);
|
result = rb_eval(self, node->nd_head);
|
||||||
}
|
}
|
||||||
POP_TAG();
|
else if (rescuing) {
|
||||||
if (state == TAG_RAISE) {
|
if (state == TAG_RETRY) {
|
||||||
NODE * volatile resq = node->nd_resq;
|
rescuing = state = 0;
|
||||||
|
e_info = ruby_errinfo = Qnil;
|
||||||
|
result = rb_eval(self, node->nd_head);
|
||||||
|
}
|
||||||
|
else if (state != TAG_RAISE) {
|
||||||
|
ruby_errinfo = e_info;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (state == TAG_RAISE) {
|
||||||
|
NODE *resq = node->nd_resq;
|
||||||
|
|
||||||
while (resq) {
|
while (resq) {
|
||||||
ruby_current_node = resq;
|
ruby_current_node = resq;
|
||||||
if (handle_rescue(self, resq)) {
|
if (handle_rescue(self, resq)) {
|
||||||
state = 0;
|
state = 0;
|
||||||
PUSH_TAG(PROT_NONE);
|
rescuing = 1;
|
||||||
if ((state = EXEC_TAG()) == 0) {
|
|
||||||
result = rb_eval(self, resq->nd_body);
|
result = rb_eval(self, resq->nd_body);
|
||||||
}
|
|
||||||
POP_TAG();
|
|
||||||
if (state == TAG_RETRY) {
|
|
||||||
state = 0;
|
|
||||||
ruby_errinfo = Qnil;
|
|
||||||
goto retry_entry;
|
|
||||||
}
|
|
||||||
if (state != TAG_RAISE) {
|
|
||||||
ruby_errinfo = e_info;
|
ruby_errinfo = e_info;
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
resq = resq->nd_head; /* next rescue */
|
resq = resq->nd_head; /* next rescue */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (node->nd_else) { /* else clause given */
|
POP_TAG();
|
||||||
if (!state) { /* no exception raised */
|
if (state) JUMP_TAG(state);
|
||||||
|
/* no exception raised */
|
||||||
|
if (node->nd_else) { /* else clause given */
|
||||||
result = rb_eval(self, node->nd_else);
|
result = rb_eval(self, node->nd_else);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (state) JUMP_TAG(state);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NODE_ENSURE:
|
case NODE_ENSURE:
|
||||||
@ -4435,21 +4437,27 @@ rb_iterate(it_proc, data1, bl_proc, data2)
|
|||||||
NODE *node = NEW_IFUNC(bl_proc, data2);
|
NODE *node = NEW_IFUNC(bl_proc, data2);
|
||||||
VALUE self = ruby_top_self;
|
VALUE self = ruby_top_self;
|
||||||
|
|
||||||
iter_retry:
|
|
||||||
PUSH_ITER(ITER_PRE);
|
PUSH_ITER(ITER_PRE);
|
||||||
PUSH_BLOCK(0, node);
|
PUSH_BLOCK(0, node);
|
||||||
PUSH_TAG(PROT_NONE);
|
PUSH_TAG(PROT_NONE);
|
||||||
|
|
||||||
state = EXEC_TAG();
|
state = EXEC_TAG();
|
||||||
if (state == 0) {
|
if (state == 0) {
|
||||||
|
iter_retry:
|
||||||
retval = (*it_proc)(data1);
|
retval = (*it_proc)(data1);
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
if (ruby_block->tag->dst == state) {
|
if (ruby_block->tag->dst == state) {
|
||||||
state &= TAG_MASK;
|
state &= TAG_MASK;
|
||||||
if (state == TAG_RETURN || state == TAG_BREAK) {
|
if (state == TAG_RETURN || state == TAG_BREAK) {
|
||||||
retval = prot_tag->retval;
|
retval = prot_tag->retval;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (state == TAG_RETRY) {
|
||||||
|
state = 0;
|
||||||
|
goto iter_retry;
|
||||||
|
}
|
||||||
|
}
|
||||||
POP_TAG();
|
POP_TAG();
|
||||||
POP_BLOCK();
|
POP_BLOCK();
|
||||||
POP_ITER();
|
POP_ITER();
|
||||||
@ -4458,9 +4466,6 @@ rb_iterate(it_proc, data1, bl_proc, data2)
|
|||||||
case 0:
|
case 0:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case TAG_RETRY:
|
|
||||||
goto iter_retry;
|
|
||||||
|
|
||||||
case TAG_BREAK:
|
case TAG_BREAK:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -7045,7 +7050,6 @@ proc_invoke(proc, args, self, klass)
|
|||||||
if (klass) _block.frame.last_class = klass;
|
if (klass) _block.frame.last_class = klass;
|
||||||
ruby_block = &_block;
|
ruby_block = &_block;
|
||||||
|
|
||||||
again:
|
|
||||||
PUSH_ITER(ITER_CUR);
|
PUSH_ITER(ITER_CUR);
|
||||||
ruby_frame->iter = ITER_CUR;
|
ruby_frame->iter = ITER_CUR;
|
||||||
PUSH_TAG(PROT_NONE);
|
PUSH_TAG(PROT_NONE);
|
||||||
@ -7259,7 +7263,6 @@ block_pass(self, node)
|
|||||||
Data_Get_Struct(proc, struct BLOCK, data);
|
Data_Get_Struct(proc, struct BLOCK, data);
|
||||||
orphan = block_orphan(data);
|
orphan = block_orphan(data);
|
||||||
|
|
||||||
retry:
|
|
||||||
/* PUSH BLOCK from data */
|
/* PUSH BLOCK from data */
|
||||||
old_block = ruby_block;
|
old_block = ruby_block;
|
||||||
_block = *data;
|
_block = *data;
|
||||||
@ -7271,13 +7274,12 @@ block_pass(self, node)
|
|||||||
PUSH_TAG(PROT_NONE);
|
PUSH_TAG(PROT_NONE);
|
||||||
state = EXEC_TAG();
|
state = EXEC_TAG();
|
||||||
if (state == 0) {
|
if (state == 0) {
|
||||||
|
retry:
|
||||||
proc_set_safe_level(proc);
|
proc_set_safe_level(proc);
|
||||||
if (safe > ruby_safe_level)
|
if (safe > ruby_safe_level)
|
||||||
ruby_safe_level = safe;
|
ruby_safe_level = safe;
|
||||||
result = rb_eval(self, node->nd_iter);
|
result = rb_eval(self, node->nd_iter);
|
||||||
}
|
}
|
||||||
POP_TAG();
|
|
||||||
POP_ITER();
|
|
||||||
if (_block.tag->dst == state) {
|
if (_block.tag->dst == state) {
|
||||||
if (orphan) {
|
if (orphan) {
|
||||||
state &= TAG_MASK;
|
state &= TAG_MASK;
|
||||||
@ -7297,6 +7299,12 @@ block_pass(self, node)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (state == TAG_RETRY) {
|
||||||
|
state = 0;
|
||||||
|
goto retry;
|
||||||
|
}
|
||||||
|
POP_TAG();
|
||||||
|
POP_ITER();
|
||||||
ruby_block = old_block;
|
ruby_block = old_block;
|
||||||
ruby_safe_level = safe;
|
ruby_safe_level = safe;
|
||||||
|
|
||||||
@ -7306,8 +7314,6 @@ block_pass(self, node)
|
|||||||
case TAG_BREAK:
|
case TAG_BREAK:
|
||||||
result = prot_tag->retval;
|
result = prot_tag->retval;
|
||||||
break;
|
break;
|
||||||
case TAG_RETRY:
|
|
||||||
goto retry;
|
|
||||||
case TAG_RETURN:
|
case TAG_RETURN:
|
||||||
if (orphan) {
|
if (orphan) {
|
||||||
localjump_error("return from proc-closure", prot_tag->retval, state);
|
localjump_error("return from proc-closure", prot_tag->retval, state);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user