summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gc.c4
-rw-r--r--test/ruby/test_objectspace.rb5
2 files changed, 7 insertions, 2 deletions
diff --git a/gc.c b/gc.c
index df9e919655..f070b11b64 100644
--- a/gc.c
+++ b/gc.c
@@ -2279,8 +2279,8 @@ static void
should_be_callable(VALUE block)
{
if (!rb_obj_respond_to(block, rb_intern("call"), TRUE)) {
- rb_raise(rb_eArgError, "wrong type argument %s (should be callable)",
- rb_obj_classname(block));
+ rb_raise(rb_eArgError, "wrong type argument %"PRIsVALUE" (should be callable)",
+ rb_obj_class(block));
}
}
static void
diff --git a/test/ruby/test_objectspace.rb b/test/ruby/test_objectspace.rb
index a4198f8ed4..de7c6be916 100644
--- a/test/ruby/test_objectspace.rb
+++ b/test/ruby/test_objectspace.rb
@@ -78,6 +78,11 @@ End
end
assert_in_out_err([], code[""], ["finalized"])
assert_in_out_err([], code["private "], ["finalized"])
+ c = EnvUtil.labeled_class("C\u{3042}").new
+ o = Object.new
+ assert_raise_with_message(ArgumentError, /C\u{3042}/) {
+ ObjectSpace.define_finalizer(o, c)
+ }
end
def test_each_object