From 5aac65484e00f78ca4c09d3b47506ed088da8366 Mon Sep 17 00:00:00 2001 From: akr Date: Mon, 15 Jun 2009 16:52:00 +0000 Subject: [PATCH] * 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 --- ChangeLog | 4 ++++ vm_eval.c | 7 +++++-- 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 + + * vm_eval.c (rb_call0): refine exception message for hidden objects. + Mon Jun 15 22:35:31 2009 Tadayoshi Funaba * 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);