diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-07-30 14:27:01 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-07-30 14:27:01 +0000 |
commit | fe1608a519c70cf53c6deccd52fbca4668fe56ef (patch) | |
tree | 31b01597714df86ce5a0555d2c10cb01e27fb00b | |
parent | 7639df765e1b6d3d4ad5f016a68d15c19fd870ee (diff) |
* eval.c (rb_call0): trace call/return of method defined from block.
fixed: [ruby-core:08329]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@10644 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | eval.c | 8 |
2 files changed, 12 insertions, 1 deletions
@@ -1,4 +1,7 @@ -Sun Jul 30 23:04:03 2006 Nobuyoshi Nakada <nobu@ruby-lang.org> +Sun Jul 30 23:26:22 2006 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * eval.c (rb_call0): trace call/return of method defined from block. + fixed: [ruby-core:08329] * eval.c (rb_trap_eval): make the current thread runnable to deal with exceptions which occurred within the trap. fixed: [ruby-dev:27729] @@ -5838,7 +5838,15 @@ rb_call0(klass, recv, id, oid, argc, argv, body, flags) case NODE_BMETHOD: ruby_frame->flags |= FRAME_DMETH; + if (event_hooks) { + struct BLOCK *data; + Data_Get_Struct(body->nd_cval, struct BLOCK, data); + EXEC_EVENT_HOOK(RUBY_EVENT_CALL, data->body, recv, id, klass); + } result = proc_invoke(body->nd_cval, rb_ary_new4(argc, argv), recv, klass); + if (event_hooks) { + EXEC_EVENT_HOOK(RUBY_EVENT_RETURN, body, recv, id, klass); + } break; case NODE_SCOPE: |