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

ruby-changes:57233

From: Nobuyoshi <ko1@a...>
Date: Sat, 24 Aug 2019 01:41:09 +0900 (JST)
Subject: [ruby-changes:57233] Nobuyoshi Nakada: d5b917d500 (master): Named numbered parameter indexes

https://git.ruby-lang.org/ruby.git/commit/?id=d5b917d500

From d5b917d50062559efb5b90ed093293d37e8a40b9 Mon Sep 17 00:00:00 2001
From: Nobuyoshi Nakada <nobu@r...>
Date: Sat, 24 Aug 2019 01:10:42 +0900
Subject: Named numbered parameter indexes


diff --git a/parse.y b/parse.y
index a6a9a41..d33032d 100644
--- a/parse.y
+++ b/parse.y
@@ -167,7 +167,11 @@ struct local_vars { https://github.com/ruby/ruby/blob/trunk/parse.y#L167
     struct local_vars *prev;
 };
 
-#define NUMPARAM_MAX 100 /* INT_MAX */
+enum {
+    ORDINAL_PARM = -1,
+    NO_PARAM = 0,
+    NUMPARAM_MAX = 100,
+};
 
 #define DVARS_INHERIT ((void*)1)
 #define DVARS_TOPSCOPE NULL
@@ -3366,7 +3370,7 @@ opt_block_param	: none https://github.com/ruby/ruby/blob/trunk/parse.y#L3370
 block_param_def	: '|' opt_bv_decl '|'
 		    {
 			p->cur_arg = 0;
-			p->max_numparam = -1;
+			p->max_numparam = ORDINAL_PARM;
 		    /*%%%*/
 			$$ = 0;
 		    /*% %*/
@@ -3374,7 +3378,7 @@ block_param_def	: '|' opt_bv_decl '|' https://github.com/ruby/ruby/blob/trunk/parse.y#L3378
 		    }
 		| tOROP
 		    {
-			p->max_numparam = -1;
+			p->max_numparam = ORDINAL_PARM;
 		    /*%%%*/
 			$$ = 0;
 		    /*% %*/
@@ -3383,7 +3387,7 @@ block_param_def	: '|' opt_bv_decl '|' https://github.com/ruby/ruby/blob/trunk/parse.y#L3387
 		| '|' block_param opt_bv_decl '|'
 		    {
 			p->cur_arg = 0;
-			p->max_numparam = -1;
+			p->max_numparam = ORDINAL_PARM;
 		    /*%%%*/
 			$$ = $2;
 		    /*% %*/
@@ -3461,7 +3465,7 @@ f_larglist	: '(' f_args opt_bv_decl ')' https://github.com/ruby/ruby/blob/trunk/parse.y#L3465
 		    {
 		    /*%%%*/
 			$$ = $2;
-			p->max_numparam = -1;
+			p->max_numparam = ORDINAL_PARM;
 		    /*% %*/
 		    /*% ripper: paren!($2) %*/
 		    }
@@ -3469,7 +3473,7 @@ f_larglist	: '(' f_args opt_bv_decl ')' https://github.com/ruby/ruby/blob/trunk/parse.y#L3473
 		    {
 		    /*%%%*/
 			if (!args_info_empty_p($1->nd_ainfo))
-			    p->max_numparam = -1;
+			    p->max_numparam = ORDINAL_PARM;
 		    /*% %*/
 			$$ = $1;
 		    }
@@ -4858,7 +4862,7 @@ f_norm_arg	: f_bad_arg https://github.com/ruby/ruby/blob/trunk/parse.y#L4862
 		| tIDENTIFIER
 		    {
 			formal_argument(p, get_id($1));
-			p->max_numparam = -1;
+			p->max_numparam = ORDINAL_PARM;
 			$$ = $1;
 		    }
 		;
@@ -4921,7 +4925,7 @@ f_label 	: tLABEL https://github.com/ruby/ruby/blob/trunk/parse.y#L4925
 			ID id = get_id($1);
 			arg_var(p, formal_argument(p, id));
 			p->cur_arg = id;
-			p->max_numparam = -1;
+			p->max_numparam = ORDINAL_PARM;
 			$$ = $1;
 		    }
 		;
@@ -8450,7 +8454,7 @@ parser_numbered_param(struct parser_params *p, unsigned long n) https://github.com/ruby/ruby/blob/trunk/parse.y#L8454
 	compile_error(p, "numbered parameter outside block");
 	return false;
     }
-    if (p->max_numparam < 0) {
+    if (p->max_numparam < NO_PARAM) {
 	compile_error(p, "ordinary parameter is defined");
 	return false;
     }
@@ -11213,7 +11217,7 @@ new_args_tail(struct parser_params *p, NODE *kw_args, ID kw_rest_arg, ID block, https://github.com/ruby/ruby/blob/trunk/parse.y#L11217
 static NODE *
 args_with_numbered(struct parser_params *p, NODE *args, int max_numparam)
 {
-    if (max_numparam > 0) {
+    if (max_numparam > NO_PARAM) {
 	if (!args) args = new_args_tail(p, 0, 0, 0, 0);
 	args->nd_ainfo->pre_args_num = max_numparam;
 	args->nd_ainfo->rest_arg = NODE_SPECIAL_EXCESSIVE_COMMA;
-- 
cgit v0.10.2


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

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