Skip to content

Commit 235af84

Browse files
committed
merge revision(s) r46463: [Backport ruby#9957]
* vm_core.h: add VM_FRAME_MAGIC_RESCUE to recognize normal block or rescue clause. * vm.c (vm_exec): use VM_FRAME_MAGIC_RESCUE on at rescue/ensure. * test/ruby/test_settracefunc.rb: should not invoke b_return at rescue clause. [Bug ruby#9957] * vm_dump.c (control_frame_dump): check VM_FRAME_MAGIC_RESCUE. * vm_dump.c (vm_stack_dump_each): ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_1@47012 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
1 parent 75a999b commit 235af84

File tree

6 files changed

+66
-8
lines changed

6 files changed

+66
-8
lines changed

ChangeLog

Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,18 @@
1+
Thu Jul 31 01:12:55 2014 Koichi Sasada <[email protected]>
2+
3+
* vm_core.h: add VM_FRAME_MAGIC_RESCUE to recognize normal block or
4+
rescue clause.
5+
6+
* vm.c (vm_exec): use VM_FRAME_MAGIC_RESCUE on at rescue/ensure.
7+
8+
* test/ruby/test_settracefunc.rb: should not invoke b_return at rescue
9+
clause.
10+
[Bug #9957]
11+
12+
* vm_dump.c (control_frame_dump): check VM_FRAME_MAGIC_RESCUE.
13+
14+
* vm_dump.c (vm_stack_dump_each): ditto.
15+
116
Thu Jul 31 00:44:34 2014 Koichi Sasada <[email protected]>
217

318
* vm_trace.c: clear and restore recursive checking thread local data

test/ruby/test_settracefunc.rb

Lines changed: 36 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1196,4 +1196,40 @@ def test_recursive
11961196
raise if stack != [:p, :hash, :inspect]
11971197
}, '[Bug #9940]'
11981198
end
1199+
1200+
def method_test_rescue_should_not_cause_b_return
1201+
begin
1202+
raise
1203+
rescue
1204+
return
1205+
end
1206+
end
1207+
1208+
def method_test_ensure_should_not_cause_b_return
1209+
begin
1210+
raise
1211+
ensure
1212+
return
1213+
end
1214+
end
1215+
1216+
def test_rescue_and_ensure_should_not_cause_b_return
1217+
curr_thread = Thread.current
1218+
trace = TracePoint.new(:b_call, :b_return){
1219+
next if curr_thread != Thread.current
1220+
flunk("Should not reach here because there is no block.")
1221+
}
1222+
1223+
begin
1224+
trace.enable
1225+
method_test_rescue_should_not_cause_b_return
1226+
begin
1227+
method_test_ensure_should_not_cause_b_return
1228+
rescue
1229+
# ignore
1230+
end
1231+
ensure
1232+
trace.disable
1233+
end
1234+
end
11991235
end

version.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
#define RUBY_VERSION "2.1.2"
22
#define RUBY_RELEASE_DATE "2014-07-31"
3-
#define RUBY_PATCHLEVEL 183
3+
#define RUBY_PATCHLEVEL 184
44

55
#define RUBY_RELEASE_YEAR 2014
66
#define RUBY_RELEASE_MONTH 7

vm.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1214,6 +1214,7 @@ vm_frametype_name(const rb_control_frame_t *cfp)
12141214
case VM_FRAME_MAGIC_IFUNC: return "ifunc";
12151215
case VM_FRAME_MAGIC_EVAL: return "eval";
12161216
case VM_FRAME_MAGIC_LAMBDA: return "lambda";
1217+
case VM_FRAME_MAGIC_RESCUE: return "rescue";
12171218
default:
12181219
rb_bug("unknown frame");
12191220
}
@@ -1518,7 +1519,7 @@ vm_exec(rb_thread_t *th)
15181519

15191520
/* push block frame */
15201521
cfp->sp[0] = err;
1521-
vm_push_frame(th, catch_iseq, VM_FRAME_MAGIC_BLOCK,
1522+
vm_push_frame(th, catch_iseq, VM_FRAME_MAGIC_RESCUE,
15221523
cfp->self, cfp->klass,
15231524
VM_ENVVAL_PREV_EP_PTR(cfp->ep),
15241525
catch_iseq->iseq_encoded,

vm_core.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -764,7 +764,8 @@ enum vm_special_object_type {
764764
#define VM_FRAME_MAGIC_IFUNC 0x81
765765
#define VM_FRAME_MAGIC_EVAL 0x91
766766
#define VM_FRAME_MAGIC_LAMBDA 0xa1
767-
#define VM_FRAME_MAGIC_MASK_BITS 8
767+
#define VM_FRAME_MAGIC_RESCUE 0xb1
768+
#define VM_FRAME_MAGIC_MASK_BITS 8
768769
#define VM_FRAME_MAGIC_MASK (~(~0<<VM_FRAME_MAGIC_MASK_BITS))
769770

770771
#define VM_FRAME_TYPE(cfp) ((cfp)->flag & VM_FRAME_MAGIC_MASK)

vm_dump.c

Lines changed: 10 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -73,6 +73,9 @@ control_frame_dump(rb_thread_t *th, rb_control_frame_t *cfp)
7373
case VM_FRAME_MAGIC_EVAL:
7474
magic = "EVAL";
7575
break;
76+
case VM_FRAME_MAGIC_RESCUE:
77+
magic = "RESCUE";
78+
break;
7679
case 0:
7780
magic = "------";
7881
break;
@@ -268,15 +271,17 @@ vm_stack_dump_each(rb_thread_t *th, rb_control_frame_t *cfp)
268271

269272
/* stack trace header */
270273

271-
if (VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_METHOD ||
272-
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_TOP ||
274+
if (VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_METHOD||
275+
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_TOP ||
273276
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_BLOCK ||
274277
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_CLASS ||
275-
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_PROC ||
276-
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_LAMBDA ||
278+
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_PROC ||
279+
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_LAMBDA||
277280
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_CFUNC ||
278281
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_IFUNC ||
279-
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_EVAL) {
282+
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_EVAL ||
283+
VM_FRAME_TYPE(cfp) == VM_FRAME_MAGIC_RESCUE)
284+
{
280285

281286
VALUE *ptr = ep - local_size;
282287

0 commit comments

Comments
 (0)