From ffdb3ce9b9ca8696d04fd7319ee5f77b532b1f0b Mon Sep 17 00:00:00 2001 From: nobu Date: Thu, 27 Mar 2014 09:08:54 +0000 Subject: [PATCH] re.c: class name encoding * re.c (match_inspect): preserve class name encoding by PRIsVALUE. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@45449 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- re.c | 6 +++--- test/ruby/test_regexp.rb | 3 +++ 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/re.c b/re.c index 3e53982912..54ba47c199 100644 --- a/re.c +++ b/re.c @@ -1898,7 +1898,7 @@ match_inspect_name_iter(const OnigUChar *name, const OnigUChar *name_end, static VALUE match_inspect(VALUE match) { - const char *cname = rb_obj_classname(match); + VALUE cname = rb_class_path(rb_obj_class(match)); VALUE str; int i; struct re_registers *regs = RMATCH_REGS(match); @@ -1907,7 +1907,7 @@ match_inspect(VALUE match) VALUE regexp = RMATCH(match)->regexp; if (regexp == 0) { - return rb_sprintf("#<%s:%p>", cname, (void*)match); + return rb_sprintf("#<%"PRIsVALUE":%p>", cname, (void*)match); } names = ALLOCA_N(struct backref_name_tag, num_regs); @@ -1917,7 +1917,7 @@ match_inspect(VALUE match) match_inspect_name_iter, names); str = rb_str_buf_new2("#<"); - rb_str_buf_cat2(str, cname); + rb_str_append(str, cname); for (i = 0; i < num_regs; i++) { VALUE v; diff --git a/test/ruby/test_regexp.rb b/test/ruby/test_regexp.rb index cff2bb6d1f..de8ecdba22 100644 --- a/test/ruby/test_regexp.rb +++ b/test/ruby/test_regexp.rb @@ -887,12 +887,15 @@ class TestRegexp < Test::Unit::TestCase assert_no_match(/^\p{age=1.1}$/u, "\u2754") end + MatchData_A = eval("class MatchData_\u{3042} < MatchData; self; end") + def test_matchdata a = "haystack".match(/hay/) b = "haystack".match(/hay/) assert_equal(a, b, '[ruby-core:24748]') h = {a => 42} assert_equal(42, h[b], '[ruby-core:24748]') + assert_match(/#