summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-03-31 02:34:40 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2014-03-31 02:34:40 +0000
commit03f0ca4c81dbb3a1f8547f4d174289a477dc5196 (patch)
tree3ba6336eec723449073c4de5e4ff11383a915ab5
parent8125399c09ae3c5e433fd285326ed38d85bda891 (diff)
vm.c: avoid inadvertent pin-down
* vm.c (vm_stat): get rid of inadvertent dynamic symbol pin-down, and preserve encoding in error messages. also should not use RSTRING_PTR macro on function calls. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@45482 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--test/ruby/test_rubyvm.rb1
-rw-r--r--vm.c5
2 files changed, 4 insertions, 2 deletions
diff --git a/test/ruby/test_rubyvm.rb b/test/ruby/test_rubyvm.rb
index 613cfe2161..580f3be2e1 100644
--- a/test/ruby/test_rubyvm.rb
+++ b/test/ruby/test_rubyvm.rb
@@ -12,5 +12,6 @@ class TestRubyVM < Test::Unit::TestCase
def test_stat_unknown
assert_raise(ArgumentError){ RubyVM.stat(:unknown) }
+ assert_raise_with_message(ArgumentError, /\u{30eb 30d3 30fc}/) {RubyVM.stat(:"\u{30eb 30d3 30fc}")}
end
end
diff --git a/vm.c b/vm.c
index 5b4aa6fae0..1742cc5008 100644
--- a/vm.c
+++ b/vm.c
@@ -173,8 +173,9 @@ vm_stat(int argc, VALUE *argv, VALUE self)
SET(class_serial, ruby_vm_class_serial);
#undef SET
- if (key != Qnil) /* matched key should return above */
- rb_raise(rb_eArgError, "unknown key: %s", RSTRING_PTR(rb_id2str(SYM2ID(key))));
+ if (!NIL_P(key)) { /* matched key should return above */
+ rb_raise(rb_eArgError, "unknown key: %"PRIsVALUE, rb_sym2str(key));
+ }
return hash;
}