summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-08-06 18:22:57 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-08-06 18:22:57 +0000
commitb07df3826502b589e2c874e5ab8ee02ea549f3ac (patch)
tree8b13c0820378b6553f80e3632e649857679fcdfe /eval.c
parentb7aa5a41d38fe86c61cd9e69c4e60a59135de4f1 (diff)
* eval.c (rb_exc_raise, rb_exc_fatal): nil is used to reraise.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24439 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/eval.c b/eval.c
index 35669c8395..d6d2b7afc7 100644
--- a/eval.c
+++ b/eval.c
@@ -413,14 +413,18 @@ rb_longjmp(int tag, volatile VALUE mesg)
void
rb_exc_raise(VALUE mesg)
{
- mesg = rb_make_exception(1, &mesg);
+ if (!NIL_P(mesg)) {
+ mesg = rb_make_exception(1, &mesg);
+ }
rb_longjmp(TAG_RAISE, mesg);
}
void
rb_exc_fatal(VALUE mesg)
{
- mesg = rb_make_exception(1, &mesg);
+ if (!NIL_P(mesg)) {
+ mesg = rb_make_exception(1, &mesg);
+ }
rb_longjmp(TAG_FATAL, mesg);
}