ruby-changes:3989
From: ko1@a...
Date: Fri, 15 Feb 2008 09:45:00 +0900 (JST)
Subject: [ruby-changes:3989] nobu - Ruby:r15479 (trunk): * parse.y (reg_compile_gen): reg_fragment_setenc might not raise an
nobu 2008-02-15 09:44:13 +0900 (Fri, 15 Feb 2008) New Revision: 15479 Modified files: trunk/ChangeLog trunk/parse.y Log: * parse.y (reg_compile_gen): reg_fragment_setenc might not raise an exception before rb_reg_compile. http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/parse.y?r1=15479&r2=15478&diff_format=u http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=15479&r2=15478&diff_format=u Index: ChangeLog =================================================================== --- ChangeLog (revision 15478) +++ ChangeLog (revision 15479) @@ -1,3 +1,8 @@ +Fri Feb 15 09:44:11 2008 Nobuyoshi Nakada <nobu@r...> + + * parse.y (reg_compile_gen): reg_fragment_setenc might not raise an + exception before rb_reg_compile. + Fri Feb 15 07:37:40 2008 Eric Hodel <drbrain@s...> * lib/rdoc/ri/paths.rb: Preserve compatibility with 1.8. Index: parse.y =================================================================== --- parse.y (revision 15478) +++ parse.y (revision 15479) @@ -8655,10 +8655,14 @@ re = rb_reg_compile(str, options & RE_OPTION_MASK); if (NIL_P(re)) { ID mesg = rb_intern("mesg"); - VALUE m = rb_attr_get(err, mesg); - rb_str_cat(m, "\n", 1); - rb_str_append(m, rb_attr_get(rb_errinfo(), mesg)); + VALUE m = rb_attr_get(rb_errinfo(), mesg); rb_set_errinfo(err); + if (!NIL_P(err)) { + rb_str_append(rb_str_cat(rb_attr_get(err, mesg), "\n", 1), m); + } + else { + compile_error(PARSER_ARG "%s", RSTRING_PTR(m)); + } return Qnil; } return re; -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/