diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-06-10 06:36:02 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2013-06-10 06:36:02 +0000 |
commit | 09de2b0544e2615bada18b1418efd1948bc7f869 (patch) | |
tree | 8f3a06c7fba57baca72fcf1a40ce98225e958f77 | |
parent | b82ded24cc856435a87b289890c8954d96ecea66 (diff) | |
download | ruby-09de2b0544e2615bada18b1418efd1948bc7f869.tar.gz |
eval_error.c: use checking functions
* eval_error.c (error_print): use checking functions instead of
catching exceptions.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@41206 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | eval_error.c | 6 |
2 files changed, 7 insertions, 4 deletions
@@ -1,4 +1,7 @@ -Mon Jun 10 15:35:34 2013 Nobuyoshi Nakada <nobu@ruby-lang.org> +Mon Jun 10 15:36:00 2013 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * eval_error.c (error_print): use checking functions instead of + catching exceptions. * eval_error.c (error_print): restore errinfo for the case new excecption raised while printing the message. [ruby-core:55365] diff --git a/eval_error.c b/eval_error.c index fad8c228f6..aa9d10f91d 100644 --- a/eval_error.c +++ b/eval_error.c @@ -127,9 +127,9 @@ error_print(void) } eclass = CLASS_OF(errinfo); - if (eclass != Qundef) { - e = rb_funcall(errinfo, rb_intern("message"), 0, 0); - StringValue(e); + if (eclass != Qundef && + (e = rb_check_funcall(errinfo, rb_intern("message"), 0, 0)) != Qundef && + (RB_TYPE_P(e, T_STRING) || !NIL_P(e = rb_check_string_type(e)))) { einfo = RSTRING_PTR(e); elen = RSTRING_LEN(e); } |