зеркало из https://github.com/github/ruby.git
compile.c: binary logop check
* compile.c (compile_branch_condition): turn recursion at binary logical operator into loop by goto, and check the result of RHS of NODE_OR. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@58814 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
82092f4bb7
Коммит
4b39eaf4cc
11
compile.c
11
compile.c
|
@ -2902,6 +2902,7 @@ static int
|
|||
compile_branch_condition(rb_iseq_t *iseq, LINK_ANCHOR *const ret, NODE *cond,
|
||||
LABEL *then_label, LABEL *else_label)
|
||||
{
|
||||
again:
|
||||
switch (nd_type(cond)) {
|
||||
case NODE_AND:
|
||||
{
|
||||
|
@ -2909,9 +2910,8 @@ compile_branch_condition(rb_iseq_t *iseq, LINK_ANCHOR *const ret, NODE *cond,
|
|||
CHECK(compile_branch_condition(iseq, ret, cond->nd_1st, label,
|
||||
else_label));
|
||||
ADD_LABEL(ret, label);
|
||||
CHECK(compile_branch_condition(iseq, ret, cond->nd_2nd, then_label,
|
||||
else_label));
|
||||
break;
|
||||
cond = cond->nd_2nd;
|
||||
goto again;
|
||||
}
|
||||
case NODE_OR:
|
||||
{
|
||||
|
@ -2919,9 +2919,8 @@ compile_branch_condition(rb_iseq_t *iseq, LINK_ANCHOR *const ret, NODE *cond,
|
|||
CHECK(compile_branch_condition(iseq, ret, cond->nd_1st, then_label,
|
||||
label));
|
||||
ADD_LABEL(ret, label);
|
||||
compile_branch_condition(iseq, ret, cond->nd_2nd, then_label,
|
||||
else_label);
|
||||
break;
|
||||
cond = cond->nd_2nd;
|
||||
goto again;
|
||||
}
|
||||
case NODE_LIT: /* NODE_LIT is always true */
|
||||
case NODE_TRUE:
|
||||
|
|
Загрузка…
Ссылка в новой задаче