ruby-changes:5209
From: mame <ko1@a...>
Date: Fri, 30 May 2008 22:21:17 +0900 (JST)
Subject: [ruby-changes:5209] Ruby:r16704 (trunk): * compile.c (defined_expr): fix SEGV by defined?([1]).
mame 2008-05-30 22:15:03 +0900 (Fri, 30 May 2008)
New Revision: 16704
Modified files:
trunk/ChangeLog
trunk/compile.c
Log:
* compile.c (defined_expr): fix SEGV by defined?([1]).
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/compile.c?r1=16704&r2=16703&diff_format=u
http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=16704&r2=16703&diff_format=u
Index: ChangeLog
===================================================================
--- ChangeLog (revision 16703)
+++ ChangeLog (revision 16704)
@@ -1,3 +1,7 @@
+Fri May 30 22:14:37 2008 Yusuke Endoh <mame@t...>
+
+ * compile.c (defined_expr): fix SEGV by defined?([1]).
+
Fri May 30 12:18:43 2008 Nobuyoshi Nakada <nobu@r...>
* common.mk (prelude.c): simply depends on PREP. [ruby-dev:34877]
Index: compile.c
===================================================================
--- compile.c (revision 16703)
+++ compile.c (revision 16704)
@@ -2327,18 +2327,10 @@
do {
defined_expr(iseq, ret, vals->nd_head, lfinish, Qfalse);
- if (lfinish[1]) {
- ADD_INSNL(ret, nd_line(node), branchunless, lfinish[1]);
- }
- else {
- LABEL *lcont = NEW_LABEL(nd_line(node));
+ if (!lfinish[1]) {
lfinish[1] = NEW_LABEL(nd_line(node));
- ADD_INSNL(ret, nd_line(node), branchif, lcont);
- ADD_LABEL(ret, lfinish[1]);
- ADD_INSN(ret, nd_line(node), putnil);
- ADD_INSNL(ret, nd_line(node), jump, lfinish[0]);
- ADD_LABEL(ret, lcont);
}
+ ADD_INSNL(ret, nd_line(node), branchunless, lfinish[1]);
} while ((vals = vals->nd_next) != NULL);
}
case NODE_STR:
--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/