diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-11-24 01:23:50 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-11-24 01:23:50 +0000 |
| commit | bfaffbf00a6124ff3214cc1593210651887fb64b (patch) | |
| tree | 70311104cabc46d4d69e41be450f747629802e54 /eval.c | |
| parent | 97b130f21ffe1cd5c20c1b4ad40ce36e751d3c9b (diff) | |
| download | ruby-bfaffbf00a6124ff3214cc1593210651887fb64b.tar.gz ruby-bfaffbf00a6124ff3214cc1593210651887fb64b.tar.xz ruby-bfaffbf00a6124ff3214cc1593210651887fb64b.zip | |
* eval.c (rb_mod_define_method): set implicit visibility only when
it's called for the target class (ruby_cbase).
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@11304 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
| -rw-r--r-- | eval.c | 16 |
1 files changed, 8 insertions, 8 deletions
@@ -9552,14 +9552,14 @@ rb_mod_define_method(argc, argv, mod) rb_raise(rb_eTypeError, "wrong argument type (expected Proc/Method)"); } - if (SCOPE_TEST(SCOPE_PRIVATE)) { - noex = NOEX_PRIVATE; - } - else if (SCOPE_TEST(SCOPE_PROTECTED)) { - noex = NOEX_PROTECTED; - } - else { - noex = NOEX_PUBLIC; + noex = NOEX_PUBLIC; + if (ruby_cbase == mod) { + if (SCOPE_TEST(SCOPE_PRIVATE)) { + noex = NOEX_PRIVATE; + } + else if (SCOPE_TEST(SCOPE_PROTECTED)) { + noex = NOEX_PROTECTED; + } } rb_add_method(mod, id, node, noex); return body; |
