summaryrefslogtreecommitdiffstats
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
commitf83ff724cad84bed1e887c2653d9f03563879719 (patch)
tree5b1d006f36a07e0200a12c26309b6659639ec997
parent9b8d9ed92b3d1ba145f12b01ed0f70fe94d06549 (diff)
downloadruby-f83ff724cad84bed1e887c2653d9f03563879719.tar.gz
ruby-f83ff724cad84bed1e887c2653d9f03563879719.tar.xz
ruby-f83ff724cad84bed1e887c2653d9f03563879719.zip
* eval.c (rb_eval): while/until should not capture break unless
they are destination of the break. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@4629 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--eval.c14
-rw-r--r--process.c9
-rw-r--r--regex.c2
4 files changed, 24 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 28777e064..4982b1fea 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Sep 30 09:11:43 2003 Yukihiro Matsumoto <matz@ruby-lang.org>
+
+ * eval.c (rb_eval): while/until should not capture break unless
+ they are destination of the break.
+
Tue Sep 30 03:12:02 2003 Minero Aoki <aamine@loveruby.net>
* lib/net/http.rb (finish): revert to 1.93.
diff --git a/eval.c b/eval.c
index 3ee0b4d5d..5c2ff1790 100644
--- a/eval.c
+++ b/eval.c
@@ -2650,8 +2650,11 @@ rb_eval(self, n)
state = 0;
goto while_next;
case TAG_BREAK:
- state = 0;
- result = prot_tag->retval;
+ if (TAG_DST()) {
+ state = 0;
+ result = prot_tag->retval;
+ }
+ /* fall through */
default:
break;
}
@@ -2682,8 +2685,11 @@ rb_eval(self, n)
state = 0;
goto until_next;
case TAG_BREAK:
- state = 0;
- result = prot_tag->retval;
+ if (TAG_DST()) {
+ state = 0;
+ result = prot_tag->retval;
+ }
+ /* fall through */
default:
break;
}
diff --git a/process.c b/process.c
index d1c972409..e30818d0e 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)) {
diff --git a/regex.c b/regex.c
index fea8bf9f7..d684eca83 100644
--- a/regex.c
+++ b/regex.c
@@ -3196,7 +3196,7 @@ re_search(bufp, string, size, startpos, range, regs)
}
}
if (bufp->options & RE_OPTIMIZE_ANCHOR) {
- if (bufp->options&RE_OPTION_SINGLELINE) {
+ if (bufp->options&RE_OPTION_MULTILINE && range > 0) {
goto begbuf_match;
}
anchor = 1;