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

ruby-changes:49609

From: nobu <ko1@a...>
Date: Tue, 9 Jan 2018 21:33:43 +0900 (JST)
Subject: [ruby-changes:49609] nobu:r61724 (trunk): parse.y: insane syntax

nobu	2018-01-09 21:33:38 +0900 (Tue, 09 Jan 2018)

  New Revision: 61724

  https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=61724

  Log:
    parse.y: insane syntax
    
    * parse.y (primary): save/restore COND and CMDARG stacks at method
      definition, to distinguish do_block and do_cond properly.

  Modified files:
    trunk/parse.y
    trunk/test/ruby/test_syntax.rb
Index: test/ruby/test_syntax.rb
===================================================================
--- test/ruby/test_syntax.rb	(revision 61723)
+++ test/ruby/test_syntax.rb	(revision 61724)
@@ -1181,6 +1181,11 @@ eom https://github.com/ruby/ruby/blob/trunk/test/ruby/test_syntax.rb#L1181
     assert_equal(line, e.backtrace_locations[0].lineno)
   end
 
+  def test_methoddef_in_cond
+    assert_valid_syntax('while def foo; tap do end; end; break; end')
+    assert_valid_syntax('while def foo a = tap do end; end; break; end')
+  end
+
   private
 
   def not_label(x) @result = x; @not_label ||= nil end
Index: parse.y
===================================================================
--- parse.y	(revision 61723)
+++ parse.y	(revision 61724)
@@ -2900,22 +2900,31 @@ primary		: literal https://github.com/ruby/ruby/blob/trunk/parse.y#L2900
 			$<num>$ = in_def;
 			in_def = 1;
 		    }
+		    {
+			$<val>1 = cond_stack;
+			$<val>$ = cmdarg_stack;
+			COND_SET(0);
+			CMDARG_SET(0);
+		    }
 		  f_arglist
 		  bodystmt
 		  k_end
 		    {
 		    /*%%%*/
-			NODE *body = remove_begin($6);
+			NODE *body = remove_begin($7);
 			reduce_nodes(&body);
-			$$ = NEW_DEFN($2, $5, body, &@$);
-			nd_set_line($$->nd_defn, @7.end_pos.lineno);
+			$$ = NEW_DEFN($2, $6, body, &@$);
+			nd_set_line($$->nd_defn, @8.end_pos.lineno);
 			set_line_body(body, @1.beg_pos.lineno);
 		    /*%
-			$$ = dispatch3(def, $2, $5, $6);
+			$$ = dispatch3(def, $2, $6, $7);
 		    %*/
 			local_pop();
 			in_def = $<num>4 & 1;
 			current_arg = $<id>3;
+
+			COND_SET($<val>1);
+			CMDARG_SET($<val>5);
 		    }
 		| k_def singleton dot_or_colon {SET_LEX_STATE(EXPR_FNAME);} fname
 		    {
@@ -2926,22 +2935,31 @@ primary		: literal https://github.com/ruby/ruby/blob/trunk/parse.y#L2935
 			$<id>$ = current_arg;
 			current_arg = 0;
 		    }
+		    {
+			$<val>1 = cond_stack;
+			$<val>$ = cmdarg_stack;
+			COND_SET(0);
+			CMDARG_SET(0);
+		    }
 		  f_arglist
 		  bodystmt
 		  k_end
 		    {
 		    /*%%%*/
-			NODE *body = remove_begin($8);
+			NODE *body = remove_begin($9);
 			reduce_nodes(&body);
-			$$ = NEW_DEFS($2, $5, $7, body, &@$);
-			nd_set_line($$->nd_defn, @9.end_pos.lineno);
+			$$ = NEW_DEFS($2, $5, $8, body, &@$);
+			nd_set_line($$->nd_defn, @10.end_pos.lineno);
 			set_line_body(body, @1.beg_pos.lineno);
 		    /*%
-			$$ = dispatch5(defs, $2, $<val>3, $5, $7, $8);
+			$$ = dispatch5(defs, $2, $<val>3, $5, $8, $9);
 		    %*/
 			local_pop();
 			in_def = $<num>4 & 1;
 			current_arg = $<id>6;
+
+			COND_SET($<val>1);
+			CMDARG_SET($<val>7);
 		    }
 		| keyword_break
 		    {

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

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