diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-11-21 09:49:30 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-11-21 09:49:30 +0000 |
commit | 5181fa2a558ca99fc2185475d540b36f9680532d (patch) | |
tree | 5d56854d50d449a689241361a82c3ee71f80e296 /vm_eval.c | |
parent | 75090a663baed0c88d905ed1f45feefc301c2e55 (diff) | |
download | ruby-5181fa2a558ca99fc2185475d540b36f9680532d.tar.gz |
* vm_eval.c (rb_search_method_entry): show flags and klass value in
not implemented error message.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@25882 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm_eval.c')
-rw-r--r-- | vm_eval.c | 31 |
1 files changed, 21 insertions, 10 deletions
@@ -336,22 +336,33 @@ rb_search_method_entry(VALUE recv, ID mid) VALUE klass = CLASS_OF(recv); if (!klass) { - if (!IMMEDIATE_P(recv) && RBASIC(recv)->flags != 0) { + if (IMMEDIATE_P(recv)) { + rb_raise(rb_eNotImpError, + "method `%s' called on unexpected immediate object (%p)", + rb_id2name(mid), (void *)recv); + } + if (RBASIC(recv)->flags == 0) { + rb_raise(rb_eNotImpError, + "method `%s' called on terminated object" + " (%p flags=0x%"PRIxVALUE" klass=0x%"PRIxVALUE")", + rb_id2name(mid), (void *)recv, + RBASIC(recv)->flags, RBASIC(recv)->klass); + } + else { int type = BUILTIN_TYPE(recv); const char *typestr = rb_type_str(type); if (typestr) rb_raise(rb_eNotImpError, - "method `%s' called on hidden %s object (%p)", - rb_id2name(mid), typestr, (void *)recv); + "method `%s' called on hidden %s object" + " (%p flags=0x%"PRIxVALUE" klass=0x%"PRIxVALUE")", + rb_id2name(mid), typestr, (void *)recv, + RBASIC(recv)->flags, RBASIC(recv)->klass); else rb_raise(rb_eNotImpError, - "method `%s' called on hidden T_???" "(0x%02x) object (%p)", - rb_id2name(mid), type, (void *)recv); - } - else { - rb_raise(rb_eNotImpError, - "method `%s' called on terminated object (%p)", - rb_id2name(mid), (void *)recv); + "method `%s' called on hidden T_???" "(0x%02x) object" + " (%p flags=0x%"PRIxVALUE" klass=0x%"PRIxVALUE")", + rb_id2name(mid), type, (void *)recv, + RBASIC(recv)->flags, RBASIC(recv)->klass); } } return rb_method_entry(klass, mid); |