mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* compile.c (iseq_compile_each): NODE_POSTEXE should set each end
procs only once. [ruby-dev:35596] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18136 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
4e554319dd
commit
16ab763b1f
3 changed files with 29 additions and 0 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
Sun Jul 20 22:50:11 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* compile.c (iseq_compile_each): NODE_POSTEXE should set each end
|
||||||
|
procs only once. [ruby-dev:35596]
|
||||||
|
|
||||||
Sun Jul 20 16:00:37 2008 Masaki Suketa <masaki.suketa@nifty.ne.jp>
|
Sun Jul 20 16:00:37 2008 Masaki Suketa <masaki.suketa@nifty.ne.jp>
|
||||||
|
|
||||||
* ext/win32ole/win32ole.c (EVENTSINK_Invoke): use rb_protect
|
* ext/win32ole/win32ole.c (EVENTSINK_Invoke): use rb_protect
|
||||||
|
|
|
@ -4527,12 +4527,21 @@ iseq_compile_each(rb_iseq_t *iseq, LINK_ANCHOR *ret, NODE * node, int poped)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case NODE_POSTEXE:{
|
case NODE_POSTEXE:{
|
||||||
|
LABEL *lstart = NEW_LABEL(nd_line(node));
|
||||||
|
LABEL *lend = NEW_LABEL(nd_line(node));
|
||||||
VALUE block = NEW_CHILD_ISEQVAL(node->nd_body, make_name_for_block(iseq), ISEQ_TYPE_BLOCK);
|
VALUE block = NEW_CHILD_ISEQVAL(node->nd_body, make_name_for_block(iseq), ISEQ_TYPE_BLOCK);
|
||||||
|
|
||||||
|
ADD_LABEL(ret, lstart);
|
||||||
|
ADD_INSN2(ret, nd_line(node), onceinlinecache, 0, lend);
|
||||||
|
ADD_INSN(ret, nd_line(node), pop);
|
||||||
|
|
||||||
ADD_INSN1(ret, nd_line(node), putspecialobject, INT2FIX(VM_SPECIAL_OBJECT_VMCORE));
|
ADD_INSN1(ret, nd_line(node), putspecialobject, INT2FIX(VM_SPECIAL_OBJECT_VMCORE));
|
||||||
ADD_INSN1(ret, nd_line(node), putiseq, block);
|
ADD_INSN1(ret, nd_line(node), putiseq, block);
|
||||||
ADD_SEND (ret, nd_line(node), ID2SYM(id_core_set_postexe), INT2FIX(1));
|
ADD_SEND (ret, nd_line(node), ID2SYM(id_core_set_postexe), INT2FIX(1));
|
||||||
|
|
||||||
|
ADD_INSN1(ret, nd_line(node), setinlinecache, lstart);
|
||||||
|
ADD_LABEL(ret, lend);
|
||||||
|
|
||||||
if (poped) {
|
if (poped) {
|
||||||
ADD_INSN(ret, nd_line(node), pop);
|
ADD_INSN(ret, nd_line(node), pop);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,6 +14,21 @@ class TestBeginEndBlock < Test::Unit::TestCase
|
||||||
target = File.join(DIR, 'beginmainend.rb')
|
target = File.join(DIR, 'beginmainend.rb')
|
||||||
result = IO.popen([ruby, target]){|io|io.read}
|
result = IO.popen([ruby, target]){|io|io.read}
|
||||||
assert_equal(%w(b1 b2-1 b2 main b3-1 b3 b4 e1 e4 e3 e2 e4-2 e4-1 e1-1 e4-1-1), result.split)
|
assert_equal(%w(b1 b2-1 b2 main b3-1 b3 b4 e1 e4 e3 e2 e4-2 e4-1 e1-1 e4-1-1), result.split)
|
||||||
|
|
||||||
|
input = Tempfile.new(self.class.name)
|
||||||
|
inputpath = input.path
|
||||||
|
input.close
|
||||||
|
result = IO.popen([ruby, "-n", "-eBEGIN{p :begin}", "-eEND{p :end}", inputpath]){|io|io.read}
|
||||||
|
assert_equal(%w(:begin), result.split)
|
||||||
|
result = IO.popen([ruby, "-p", "-eBEGIN{p :begin}", "-eEND{p :end}", inputpath]){|io|io.read}
|
||||||
|
assert_equal(%w(:begin), result.split)
|
||||||
|
input.open
|
||||||
|
input.puts "foo\nbar"
|
||||||
|
input.close
|
||||||
|
result = IO.popen([ruby, "-n", "-eBEGIN{p :begin}", "-eEND{p :end}", inputpath]){|io|io.read}
|
||||||
|
assert_equal(%w(:begin :end), result.split)
|
||||||
|
result = IO.popen([ruby, "-p", "-eBEGIN{p :begin}", "-eEND{p :end}", inputpath]){|io|io.read}
|
||||||
|
assert_equal(%w(:begin foo bar :end), result.split)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_begininmethod
|
def test_begininmethod
|
||||||
|
|
Loading…
Reference in a new issue