From 7d3b09acf2b38b0061654b3928b88fa281430a5a Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 30 Nov 2005 15:51:05 +0000 Subject: [PATCH] * eval.c (rb_funcall2): allow to call protected methods. fixed: [ruby-dev:27890] git-svn-id: svn+ssh://ci.ruby-lang.org/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 233d6c59f2..269119406b 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 98e60a4261..1d7ff27d78 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) {