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);