diff options
author | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-22 10:41:43 +0000 |
---|---|---|
committer | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-22 10:41:43 +0000 |
commit | 5fe5a24586ac9a698e0a9c8f0f6d4684e1d2609d (patch) | |
tree | ad3d0872481a8aa61ba5a9aee33934fda4bfa371 /eval.c | |
parent | 4fd8847d21a2c9bac43bd713a6a43ff3417ee45e (diff) |
merge revision(s) 26534:26536:
* eval.c (proc_invoke): reverted r25975. [ruby-dev:39931]
[ruby-dev:40059]
* eval.c (rb_mod_define_method): return original block but not
bound block. [ruby-core:26984]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_7@27954 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 8 |
1 files changed, 4 insertions, 4 deletions
@@ -8868,8 +8868,7 @@ proc_invoke(proc, args, self, klass) _block = *data; _block.block_obj = bvar; if (self != Qundef) _block.frame.self = self; - _block.frame.last_class = klass; - if (!klass) _block.frame.last_func = 0; + if (klass) _block.frame.last_class = klass; _block.frame.argc = RARRAY(tmp)->len; _block.frame.flags = ruby_frame->flags; if (_block.frame.argc && DMETHOD_P()) { @@ -9967,7 +9966,7 @@ rb_mod_define_method(argc, argv, mod) VALUE mod; { ID id; - VALUE body; + VALUE body, orig; NODE *node; int noex; @@ -9986,6 +9985,7 @@ rb_mod_define_method(argc, argv, mod) else { rb_raise(rb_eArgError, "wrong number of arguments (%d for 1)", argc); } + orig = body; if (RDATA(body)->dmark == (RUBY_DATA_FUNC)bm_mark) { node = NEW_DMETHOD(method_unbind(body)); } @@ -10014,7 +10014,7 @@ rb_mod_define_method(argc, argv, mod) } } rb_add_method(mod, id, node, noex); - return body; + return orig; } /* |