summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorh2so5 <[email protected]>2013-04-11 19:47:35 +0900
committerh2so5 <[email protected]>2013-04-11 19:47:35 +0900
commit1f571dd5fcc9705c59cb782fce2d8589f4349ca8 (patch)
tree7a5dfadea0007a113dbd901a27ddb52127c3c924
parent9f3aca8f790f70a324790c518897b0ceb8b52a42 (diff)
downloadmruby-1f571dd5fcc9705c59cb782fce2d8589f4349ca8.tar.gz
mruby-1f571dd5fcc9705c59cb782fce2d8589f4349ca8.zip
Fix TypeError messages
-rw-r--r--mrbgems/mruby-array-ext/mrblib/array.rb6
-rw-r--r--src/object.c4
2 files changed, 6 insertions, 4 deletions
diff --git a/mrbgems/mruby-array-ext/mrblib/array.rb b/mrbgems/mruby-array-ext/mrblib/array.rb
index b3ff9bfca..65ea717d2 100644
--- a/mrbgems/mruby-array-ext/mrblib/array.rb
+++ b/mrbgems/mruby-array-ext/mrblib/array.rb
@@ -20,7 +20,7 @@ class Array
end
def -(elem)
- raise TypeError, "can't convert to Array" unless elem.class == Array
+ raise TypeError, "can't convert #{elem.class.to_s} into Array" unless elem.class == Array
hash = {}
array = []
@@ -30,14 +30,14 @@ class Array
end
def |(elem)
- raise TypeError, "can't convert to Array" unless elem.class == Array
+ raise TypeError, "can't convert #{elem.class.to_s} into Array" unless elem.class == Array
ary = self + elem
ary.uniq! or ary
end
def &(elem)
- raise TypeError, "can't convert to Array" unless elem.class == Array
+ raise TypeError, "can't convert #{elem.class.to_s} into Array" unless elem.class == Array
hash = {}
array = []
diff --git a/src/object.c b/src/object.c
index 23786e859..9625137f2 100644
--- a/src/object.c
+++ b/src/object.c
@@ -305,7 +305,9 @@ convert_type(mrb_state *mrb, mrb_value val, const char *tname, const char *metho
m = mrb_intern(mrb, method);
if (!mrb_respond_to(mrb, val, m)) {
if (raise) {
- mrb_raisef(mrb, E_TYPE_ERROR, "can't convert %S into %S", val, mrb_str_new_cstr(mrb, tname));
+ const char *cname = mrb_obj_classname(mrb, val);
+ mrb_raisef(mrb, E_TYPE_ERROR, "can't convert %S into %S",
+ mrb_str_new_cstr(mrb, cname), mrb_str_new_cstr(mrb, tname));
return mrb_nil_value();
}
else {