summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-06-15 16:52:00 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-06-15 16:52:00 +0000
commit5aac65484e00f78ca4c09d3b47506ed088da8366 (patch)
treed1b8e558466dd9116f844759af6f79a90e25e4a2
parent04388f9f9dae3dc6af0ff7b30495760a8dc352b4 (diff)
* vm_eval.c (rb_call0): refine exception message for hidden objects.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@23696 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--vm_eval.c7
2 files changed, 9 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index ef628f4f21..1f72b4d13f 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Tue Jun 16 01:50:02 2009 Tanaka Akira <akr@fsij.org>
+
+ * vm_eval.c (rb_call0): refine exception message for hidden objects.
+
Mon Jun 15 22:35:31 2009 Tadayoshi Funaba <tadf@dotrb.org>
* bignum.c (rb_big2db): (-Float::MAX.to_i*2).to_f should return
diff --git a/vm_eval.c b/vm_eval.c
index 2dff373e42..096c0565ba 100644
--- a/vm_eval.c
+++ b/vm_eval.c
@@ -187,9 +187,12 @@ rb_call0(VALUE klass, VALUE recv, ID mid, int argc, const VALUE *argv,
rb_thread_t *th = GET_THREAD();
if (!klass) {
+ const char *adj = "terminated";
+ if (!IMMEDIATE_P(recv) && RBASIC(recv)->flags != 0)
+ adj = "hidden";
rb_raise(rb_eNotImpError,
- "method `%s' called on terminated object (%p)",
- rb_id2name(mid), (void *)recv);
+ "method `%s' called on %s object (%p)",
+ rb_id2name(mid), adj, (void *)recv);
}
/* is it in the method cache? */
ent = cache + EXPR1(klass, mid);