summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog8
-rw-r--r--eval.c5
2 files changed, 11 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index f2463dce95..b3837baf77 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+Mon Feb 1 16:43:09 2010 Nobuyoshi Nakada <[email protected]>
+
+ * 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]
+
Mon Feb 1 07:36:33 2010 Hidetoshi NAGAI <[email protected]>
* ext/tk/tkutil/tkutil.c: fix SEGV on TkUtil::CallbackSubst._setup_subst_table.
diff --git a/eval.c b/eval.c
index 1c099bdd1e..f8a667bbf6 100644
--- a/eval.c
+++ b/eval.c
@@ -10089,7 +10089,7 @@ rb_mod_define_method(argc, argv, mod)
VALUE mod;
{
ID id;
- VALUE body;
+ VALUE body, orig;
NODE *node;
int noex;
@@ -10108,6 +10108,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));
}
@@ -10136,7 +10137,7 @@ rb_mod_define_method(argc, argv, mod)
}
}
rb_add_method(mod, id, node, noex);
- return body;
+ return orig;
}
/*