summaryrefslogtreecommitdiff
path: root/insns.def
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-11-30 12:34:23 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-11-30 12:34:23 +0000
commit99bcf86ec38aee035706a0dce1990dc4b1aba31f (patch)
tree962bfc43098ffc0dc38e181f72e8bd1ca926e1f6 /insns.def
parent7caf8a508f63d6186d42a820d1bf6b4daa661a04 (diff)
merge revision(s) 50737: [Backport #11211]
* insns.def (defined): skip respond_to_missing? when a method is available. [Bug #11211] * test/ruby/test_defined.rb: add a test for this fix. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_1@52802 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'insns.def')
-rw-r--r--insns.def11
1 files changed, 4 insertions, 7 deletions
diff --git a/insns.def b/insns.def
index ad4bba6912..5a9c11ee79 100644
--- a/insns.def
+++ b/insns.def
@@ -738,15 +738,12 @@ defined
const rb_method_entry_t *me = rb_method_entry(klass, SYM2ID(obj), 0);
if (me) {
- if (!(me->flag & NOEX_PRIVATE)) {
- if (!((me->flag & NOEX_PROTECTED) &&
- !rb_obj_is_kind_of(GET_SELF(),
- rb_class_real(klass)))) {
- expr_type = DEFINED_METHOD;
- }
+ if (!(me->flag & NOEX_PRIVATE) &&
+ !((me->flag & NOEX_PROTECTED) && !rb_obj_is_kind_of(GET_SELF(), rb_class_real(klass)))) {
+ expr_type = DEFINED_METHOD;
}
}
- {
+ else {
VALUE args[2];
VALUE r;