diff --git a/ChangeLog b/ChangeLog index 5f2ef59bd7..a107dc8b53 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Tue Aug 19 00:56:01 2008 Tanaka Akira + + * re.c (rb_reg_inspect): don't raise for uninitialized Regexp. + Tue Aug 19 00:34:24 2008 Tanaka Akira * io.c (rb_io_check_readable): side effect for STDIN removed. diff --git a/re.c b/re.c index ff82636a46..de7ebeb41b 100644 --- a/re.c +++ b/re.c @@ -435,7 +435,9 @@ rb_reg_source(VALUE re) static VALUE rb_reg_inspect(VALUE re) { - rb_reg_check(re); + if (!RREGEXP(re)->ptr || !RREGEXP_SRC(re) || !RREGEXP_SRC_PTR(re)) { + return rb_any_to_s(re); + } return rb_reg_desc(RREGEXP_SRC_PTR(re), RREGEXP_SRC_LEN(re), re); } diff --git a/test/ruby/test_regexp.rb b/test/ruby/test_regexp.rb index bce362e34f..ad222c5483 100644 --- a/test/ruby/test_regexp.rb +++ b/test/ruby/test_regexp.rb @@ -686,7 +686,7 @@ class TestRegexp < Test::Unit::TestCase assert_nil(~Regexp.allocate) assert_raise(TypeError) { Regexp.allocate.match("") } assert_raise(TypeError) { Regexp.allocate.to_s } - assert_raise(TypeError) { Regexp.allocate.inspect } + assert_match(/^#$/, Regexp.allocate.inspect) assert_raise(TypeError) { Regexp.allocate.source } assert_raise(TypeError) { Regexp.allocate.casefold? } assert_raise(TypeError) { Regexp.allocate.options }