aboutsummaryrefslogtreecommitdiffstats
path: root/vm_eval.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-10-24 07:17:36 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-10-24 07:17:36 +0000
commit4fb24ac15ad09c36e7c12d15cb205b75c2e05fb2 (patch)
tree287779e3465de01adf6fbc81984fe2532057d707 /vm_eval.c
parent21f118125574664ee2a5eb4800b5739b4fabf1bf (diff)
downloadruby-4fb24ac15ad09c36e7c12d15cb205b75c2e05fb2.tar.gz
vm_eval.c: uncallable_object
* vm_eval.c (uncallable_object): extract error case as a no-return function. split successive ?-marks not to get confused with a trigraph. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@60392 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm_eval.c')
-rw-r--r--vm_eval.c74
1 files changed, 40 insertions, 34 deletions
diff --git a/vm_eval.c b/vm_eval.c
index 2375e2f34b..3e8e4b5c0e 100644
--- a/vm_eval.c
+++ b/vm_eval.c
@@ -475,45 +475,51 @@ rb_type_str(enum ruby_value_type type)
#undef type_case
}
+NORETURN(static void uncallable_object(VALUE recv, ID mid));
+static void
+uncallable_object(VALUE recv, ID mid)
+{
+ VALUE flags;
+ int type;
+ const char *typestr;
+ VALUE mname = rb_id2str(mid);
+
+ if (SPECIAL_CONST_P(recv)) {
+ rb_raise(rb_eNotImpError,
+ "method `%"PRIsVALUE"' called on unexpected immediate object (%p)",
+ mname, (void *)recv);
+ }
+ else if ((flags = RBASIC(recv)->flags) == 0) {
+ rb_raise(rb_eNotImpError,
+ "method `%"PRIsVALUE"' called on terminated object (%p)",
+ mname, (void *)recv);
+ }
+ else if (!(typestr = rb_type_str(type = BUILTIN_TYPE(recv)))) {
+ rb_raise(rb_eNotImpError,
+ "method `%"PRIsVALUE"' called on broken T_?""?""?(0x%02x) object"
+ " (%p flags=0x%"PRIxVALUE")",
+ mname, type, (void *)recv, flags);
+ }
+ else if (T_OBJECT <= type && type < T_NIL) {
+ rb_raise(rb_eNotImpError,
+ "method `%"PRIsVALUE"' called on hidden %s object"
+ " (%p flags=0x%"PRIxVALUE")",
+ mname, typestr, (void *)recv, flags);
+ }
+ else {
+ rb_raise(rb_eNotImpError,
+ "method `%"PRIsVALUE"' called on unexpected %s object"
+ " (%p flags=0x%"PRIxVALUE")",
+ mname, typestr, (void *)recv, flags);
+ }
+}
+
static inline const rb_callable_method_entry_t *
rb_search_method_entry(VALUE recv, ID mid)
{
VALUE klass = CLASS_OF(recv);
- if (!klass) {
- VALUE flags;
- if (SPECIAL_CONST_P(recv)) {
- rb_raise(rb_eNotImpError,
- "method `%"PRIsVALUE"' called on unexpected immediate object (%p)",
- rb_id2str(mid), (void *)recv);
- }
- flags = RBASIC(recv)->flags;
- if (flags == 0) {
- rb_raise(rb_eNotImpError,
- "method `%"PRIsVALUE"' called on terminated object"
- " (%p flags=0x%"PRIxVALUE")",
- rb_id2str(mid), (void *)recv, flags);
- }
- else {
- int type = BUILTIN_TYPE(recv);
- const char *typestr = rb_type_str(type);
- if (typestr && T_OBJECT <= type && type < T_NIL)
- rb_raise(rb_eNotImpError,
- "method `%"PRIsVALUE"' called on hidden %s object"
- " (%p flags=0x%"PRIxVALUE")",
- rb_id2str(mid), typestr, (void *)recv, flags);
- if (typestr)
- rb_raise(rb_eNotImpError,
- "method `%"PRIsVALUE"' called on unexpected %s object"
- " (%p flags=0x%"PRIxVALUE")",
- rb_id2str(mid), typestr, (void *)recv, flags);
- else
- rb_raise(rb_eNotImpError,
- "method `%"PRIsVALUE"' called on broken T_???" "(0x%02x) object"
- " (%p flags=0x%"PRIxVALUE")",
- rb_id2str(mid), type, (void *)recv, flags);
- }
- }
+ if (!klass) uncallable_object(recv, mid);
return rb_callable_method_entry(klass, mid);
}