[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]