Bug #7502
closedObjectSpace.each_object で inspect できないオブジェクトが渡ってくる
Description
西山さんに,
http://bugs.ruby-lang.org/issues/7435#note-4
のコードが動かない,と教えて貰って調べてみると,
64bit 環境で 4 な VALUE が入った Array オブジェクトが
辿れることがわかりました.
(64bit flonum 環境では,4 はあり得ない値)
どこかと調べてみると,compile.c で
#define ADD_CATCH_ENTRY(type, ls, le, iseqv, lc)
(rb_ary_push(iseq->compile_data->catch_table_ary,
rb_ary_new3(5, (type),
(VALUE)(ls) | 1, (VALUE)(le) | 1,
(VALUE)(iseqv), (VALUE)(lc) | 1)))
とあるところで type が 4 だった,というオチでした.type には
iseq_catch_table_entry::catch_type が入っており,こいつらは指定のない
enum なので,4 が入ったという感じです.
iseq_catch_table_entry::catch_type の各値を Fixnum にすることで解決しようと思います.
ここを tmp ary にするなり,別の方法もありますが,とりあえず.
今回のことで得た教訓:
- ARRAY_PTR[x] = y というコードは死ぬべきである
(こうなっているところを探し回って 4 が代入されたところを探した)
2.1 では,ここをマクロ化したい(ライトバリアとかにも役立つ). - ObjectSpace.reachable_objects_from() が役に立つか! と思ったけど,
今回は役立てられなかった.
Updated by ko1 (Koichi Sasada) almost 12 years ago
- Status changed from Open to Closed
- % Done changed from 0 to 100
This issue was solved with changeset r38156.
Koichi, thank you for reporting this issue.
Your contribution to Ruby is greatly appreciated.
May Ruby be with you.
- iseq.h: iseq_catch_table_entry::catch_type should be
Fixnum because they are pushed into Array in a compiler.
[Bug #7502] - test/ruby/test_objectspace.rb: add a test of this issue.