From 9927eddcd79ba640c502747ae2a293f2bb0cf5d4 Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 30 Nov 2005 15:51:05 +0000 Subject: * eval.c (rb_funcall2): allow to call protected methods. fixed: [ruby-dev:27890] git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@9640 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ eval.c | 6 +++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 233d6c59f..269119406 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Thu Dec 1 00:50:33 2005 Nobuyoshi Nakada + + * eval.c (rb_funcall2): allow to call protected methods. + fixed: [ruby-dev:27890] + Wed Nov 30 23:52:17 2005 Nobuyoshi Nakada * parse.y (struct parser_params): fields common to ripper must be diff --git a/eval.c b/eval.c index 98e60a426..1d7ff27d7 100644 --- a/eval.c +++ b/eval.c @@ -5768,13 +5768,13 @@ rb_call(VALUE klass, VALUE recv, ID mid, return method_missing(recv, mid, argc, argv, scope==2?CSTAT_VCALL:0); } - if (mid != missing) { + if (mid != missing && scope == 0) { /* receiver specified form for private method */ - if ((noex & NOEX_PRIVATE) && scope == 0) + if (noex & NOEX_PRIVATE) return method_missing(recv, mid, argc, argv, CSTAT_PRIV); /* self must be kind of a specified form for protected method */ - if ((noex & NOEX_PROTECTED)) { + if (noex & NOEX_PROTECTED) { VALUE defined_class = klass; if (TYPE(defined_class) == T_ICLASS) { -- cgit