summaryrefslogtreecommitdiff
path: root/process.c
diff options
context:
space:
mode:
authormatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-09-30 00:21:14 +0000
committermatz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2003-09-30 00:21:14 +0000
commit13ac4447f6a11498d84f668c636fa2b8eecb5d22 (patch)
tree5b1d006f36a07e0200a12c26309b6659639ec997 /process.c
parente377a12bff690512a568b93c018ec42961ac2a48 (diff)
* eval.c (rb_eval): while/until should not capture break unless
they are destination of the break. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4629 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'process.c')
-rw-r--r--process.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/process.c b/process.c
index d1c9724094..e30818d0e7 100644
--- a/process.c
+++ b/process.c
@@ -159,7 +159,14 @@ pst_inspect(st)
snprintf(buf, sizeof(buf), "#<%s: pid=%ld", rb_class2name(CLASS_OF(st)), NUM2LONG(pid));
str = rb_str_new2(buf);
if (WIFSTOPPED(status)) {
- snprintf(buf, sizeof(buf), ",stopped(%d)", WSTOPSIG(status));
+ int stopsig = WSTOPSIG(status);
+ char *signame = ruby_signal_name(stopsig);
+ if (signame) {
+ snprintf(buf, sizeof(buf), ",signaled(SIG%s=%d)", signame, stopsig);
+ }
+ else {
+ snprintf(buf, sizeof(buf), ",signaled(%d)", stopsig);
+ }
rb_str_cat2(str, buf);
}
if (WIFSIGNALED(status)) {