[#41531] [Bug #3385] ext/dbm: accept various version of db — Takahiro Kambe <redmine@...>
Bug #3385: ext/dbm: accept various version of db
2010年6月3日23:38 Takahiro Kambe <redmine@ruby-lang.org>:
2011年11月12日8:14 Tanaka Akira <akr@fsij.org>:
[#41536] RUBY_DEBUG=gc_stress [FATAL] failed to allocate memory — Tanaka Akira <akr@...>
コンパイル時に RUBY_DEBUG_ENV というマクロを定義しておくと、
[#41543] [Bug #3398] 1.9.2 SEGV during test-all — Yuki Sonoda <redmine@...>
Bug #3398: 1.9.2 SEGV during test-all
[#41597] [Bug #3433] Error that occurs by BasicSocket#sendmsg — Masaya Tarui <redmine@...>
Bug #3433: Error that occurs by BasicSocket#sendmsg
[#41600] 質問・提案:cgi.rbの後継となるライブラリについて — Dice <tetradice@...>
Diceです。cgi.rbの後継ライブラリについて質問させてください。
藤岡です。
かくたにです。
藤岡さん、かくたにさん、返信ありがとうございます。
藤岡です。
Diceです。藤岡さん、返信ありがとうございます。
[#41610] [Bug #3443] requireが遅くなる — Yusuke Endoh <redmine@...>
Bug #3443: requireが遅くなる
[#41623] [Feature:trunk] argument delegation — Nobuyoshi Nakada <nobu@...>
なかだです。
遠藤です。
まつもと ゆきひろです
前田です。
[#41672] [Bug #3463] 1.9.2-preview3 で [BUG] gc_sweep(): unknown data type 0x0 — Tomoyuki Chikanaga <redmine@...>
チケット #3463 が更新されました。 (by Tomoyuki Chikanaga)
[#41674] [Bug #3464] win32ole failure load TYPELIB on mswin64 vista — sakiyama shin <redmine@...>
Bug #3464: win32ole failure load TYPELIB on mswin64 vista
[#41702] WIN32OLE_METHOD offset_vtbl — kuwamoto shintaro <beuniv@...>
こんばんわ
助田です。
こんにちは、なかむら(う)です。
助田です。
artonです。
2010/6/24 arton <artonx@yahoo.co.jp>:
[#41705] [Bug #3471][Rejected] ./miniruby sample/test.rbで1NotOK — Shyouhei Urabe <redmine@...>
チケット #3471 が更新されました。 (by Shyouhei Urabe)
2010年6月24日16:53 Shyouhei Urabe <redmine@ruby-lang.org>:
[#41711] [Bug #3473] make clear-installed-list — Usaku NAKAMURA <redmine@...>
Bug #3473: make clear-installed-list
[#41730] (ruby/tk) ruby_1_9_2 への backport — Hidetoshi NAGAI <nagai@...>
永井@知能.九工大です.
[#41752] [Bug #3490][Assigned] test_pack_utf8 failure on mswin64 — Yusuke Endoh <redmine@...>
チケット #3490 が更新されました。 (by Yusuke Endoh)
[#41760] Hash[] の引数が Array の場合の振る舞い — とみたまさひろ <tommy@...>
とみたです。
[ruby-dev:41739] Re: respond_to?(<protected method name>) returns true
At Wed, 24 Feb 2010 01:25:45 +0900,
matz wrote:
> In message "Re: [ruby-dev:40465] Re: respond_to?(<protected method name>) returns true"
> on Wed, 24 Feb 2010 01:12:55 +0900, "Akinori MUSHA" <knu@iDaemons.org> writes:
>
> |> 前のメールでも書いたように method_missing による偽陰性は存在
> |> するので、本質的には指摘は当たっているのですが。で、偽陰性の
> |> 排除についてですが、ちょっと考えた結果、賛成します。
> |
> | ご検討ありがとうございます。賛成くださるのは偽陽性の排除ですよね。
>
> あ、そうです。protectedに対してrespond_to?が真を返しているの
> を偽に統一するということですね。
だいぶ間が空いてしまいましたが、これでどうでしょうか。
Index: vm_method.c
===================================================================
--- vm_method.c (revision 28446)
+++ vm_method.c (working copy)
@@ -566,8 +566,9 @@ rb_method_boundp(VALUE klass, ID id, int
rb_method_entry_t *me = rb_method_entry(klass, id);
if (me != 0) {
- if ((ex & ~NOEX_RESPONDS) && (me->flag & NOEX_PRIVATE)) {
- return FALSE;
+ if ((ex & NOEX_RESPONDS) && (me->flag & NOEX_PROTECTED) ||
+ (ex & ~NOEX_RESPONDS) && (me->flag & NOEX_PRIVATE)) {
+ return 0;
}
if (!me->def) return 0;
if (me->def->type == VM_METHOD_TYPE_NOTIMPLEMENTED) {
Index: test/ruby/test_method.rb
===================================================================
--- test/ruby/test_method.rb (revision 28446)
+++ test/ruby/test_method.rb (working copy)
@@ -39,6 +39,20 @@ class TestMethod < Test::Unit::TestCase
def meth; end
end
+ def mv1() end
+ def mv2() end
+ private :mv2
+ def mv3() end
+ protected :mv3
+
+ class Visibility
+ def mv1() end
+ def mv2() end
+ private :mv2
+ def mv3() end
+ protected :mv3
+ end
+
def test_arity
assert_equal(0, method(:m0).arity)
assert_equal(1, method(:m1).arity)
@@ -345,4 +359,48 @@ class TestMethod < Test::Unit::TestCase
obj.extend(m)
assert_equal([:m1, :a], obj.public_methods(false), bug)
end
+
+ def test_visibility
+ assert_equal('method', defined?(mv1))
+ assert_equal('method', defined?(mv2))
+ assert_equal('method', defined?(mv3))
+
+ assert_equal('method', defined?(self.mv1))
+ assert_equal(nil, defined?(self.mv2))
+ assert_equal('method', defined?(self.mv3))
+
+ assert_equal(true, respond_to?(:mv1))
+ assert_equal(false, respond_to?(:mv2))
+ assert_equal(false, respond_to?(:mv3))
+
+ assert_nothing_raised { mv1 }
+ assert_nothing_raised { mv2 }
+ assert_nothing_raised { mv3 }
+
+ assert_nothing_raised { self.mv1 }
+ assert_raise(NoMethodError) { self.mv2 }
+ assert_nothing_raised { self.mv3 }
+
+ v = Visibility.new
+
+ assert_equal('method', defined?(v.mv1))
+ assert_equal(nil, defined?(v.mv2))
+ assert_equal(nil, defined?(v.mv3))
+
+ assert_equal(true, v.respond_to?(:mv1))
+ assert_equal(false, v.respond_to?(:mv2))
+ assert_equal(false, v.respond_to?(:mv3))
+
+ assert_nothing_raised { v.mv1 }
+ assert_raise(NoMethodError) { v.mv2 }
+ assert_raise(NoMethodError) { v.mv3 }
+
+ assert_nothing_raised { v.__send__(:mv1) }
+ assert_nothing_raised { v.__send__(:mv2) }
+ assert_nothing_raised { v.__send__(:mv3) }
+
+ assert_nothing_raised { v.instance_eval { mv1 } }
+ assert_nothing_raised { v.instance_eval { mv2 } }
+ assert_nothing_raised { v.instance_eval { mv3 } }
+ end
end
--
Akinori MUSHA / http://akinori.org/