mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 02:43:41 +00:00 
			
		
		
		
	Remove asdl_seq_APPEND() and simplify asdl seq implementation.
Clarify intended use of set_context() and check errors at all call sites.
This commit is contained in:
		
							parent
							
								
									03bdedd574
								
							
						
					
					
						commit
						a829313d7b
					
				
					 3 changed files with 58 additions and 80 deletions
				
			
		|  | @ -15,33 +15,23 @@ typedef enum {false, true} bool; | ||||||
| 
 | 
 | ||||||
| /* XXX A sequence should be typed so that its use can be typechecked. */ | /* XXX A sequence should be typed so that its use can be typechecked. */ | ||||||
| 
 | 
 | ||||||
| /* XXX We shouldn't pay for offset when we don't need APPEND. */ |  | ||||||
| 
 |  | ||||||
| typedef struct { | typedef struct { | ||||||
|     int size; |     int size; | ||||||
|     int offset; |  | ||||||
|     void *elements[1]; |     void *elements[1]; | ||||||
| } asdl_seq; | } asdl_seq; | ||||||
| 
 | 
 | ||||||
| asdl_seq *asdl_seq_new(int size, PyArena *arena); | asdl_seq *asdl_seq_new(int size, PyArena *arena); | ||||||
| void asdl_seq_free(asdl_seq *); |  | ||||||
| 
 | 
 | ||||||
| #ifdef Py_DEBUG |  | ||||||
| #define asdl_seq_GET(S, I) (S)->elements[(I)] | #define asdl_seq_GET(S, I) (S)->elements[(I)] | ||||||
|  | #define asdl_seq_LEN(S) ((S) == NULL ? 0 : (S)->size) | ||||||
|  | #ifdef Py_DEBUG | ||||||
| #define asdl_seq_SET(S, I, V) { \ | #define asdl_seq_SET(S, I, V) { \ | ||||||
|         int _asdl_i = (I); \ |         int _asdl_i = (I); \ | ||||||
|         assert((S) && _asdl_i < (S)->size); \ |         assert((S) && _asdl_i < (S)->size); \ | ||||||
|         (S)->elements[_asdl_i] = (V); \ |         (S)->elements[_asdl_i] = (V); \ | ||||||
| } | } | ||||||
| #define asdl_seq_APPEND(S, V) { \ |  | ||||||
|         assert((S) && (S)->offset < (S)->size); \ |  | ||||||
|         (S)->elements[(S)->offset++] = (V); \ |  | ||||||
| } |  | ||||||
| #else | #else | ||||||
| #define asdl_seq_GET(S, I) (S)->elements[(I)] |  | ||||||
| #define asdl_seq_SET(S, I, V) (S)->elements[I] = (V) | #define asdl_seq_SET(S, I, V) (S)->elements[I] = (V) | ||||||
| #define asdl_seq_APPEND(S, V) (S)->elements[(S)->offset++] = (V) |  | ||||||
| #endif | #endif | ||||||
| #define asdl_seq_LEN(S) ((S) == NULL ? 0 : (S)->size) |  | ||||||
| 
 | 
 | ||||||
| #endif /* !Py_ASDL_H */ | #endif /* !Py_ASDL_H */ | ||||||
|  |  | ||||||
|  | @ -8,18 +8,12 @@ asdl_seq_new(int size, PyArena *arena) | ||||||
| 	size_t n = sizeof(asdl_seq) + | 	size_t n = sizeof(asdl_seq) + | ||||||
| 			(size ? (sizeof(void *) * (size - 1)) : 0); | 			(size ? (sizeof(void *) * (size - 1)) : 0); | ||||||
| 
 | 
 | ||||||
| 	seq = (asdl_seq *)malloc(n); |     seq = (asdl_seq *)PyArena_Malloc(arena, n); | ||||||
| 	if (!seq) { | 	if (!seq) { | ||||||
| 		PyErr_NoMemory(); | 		PyErr_NoMemory(); | ||||||
| 		return NULL; | 		return NULL; | ||||||
| 	} | 	} | ||||||
|         PyArena_AddMallocPointer(arena, (void *)seq); |  | ||||||
| 	memset(seq, 0, n); | 	memset(seq, 0, n); | ||||||
| 	seq->size = size; | 	seq->size = size; | ||||||
| 	return seq; | 	return seq; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| void |  | ||||||
| asdl_seq_free(asdl_seq *seq) |  | ||||||
| { |  | ||||||
| } |  | ||||||
|  |  | ||||||
							
								
								
									
										66
									
								
								Python/ast.c
									
										
									
									
									
								
							
							
						
						
									
										66
									
								
								Python/ast.c
									
										
									
									
									
								
							|  | @ -183,7 +183,7 @@ mod_ty | ||||||
| PyAST_FromNode(const node *n, PyCompilerFlags *flags, const char *filename, | PyAST_FromNode(const node *n, PyCompilerFlags *flags, const char *filename, | ||||||
|                PyArena *arena) |                PyArena *arena) | ||||||
| { | { | ||||||
|     int i, j, num; |     int i, j, k, num; | ||||||
|     asdl_seq *stmts = NULL; |     asdl_seq *stmts = NULL; | ||||||
|     stmt_ty s; |     stmt_ty s; | ||||||
|     node *ch; |     node *ch; | ||||||
|  | @ -199,6 +199,7 @@ PyAST_FromNode(const node *n, PyCompilerFlags *flags, const char *filename, | ||||||
|     } |     } | ||||||
|     c.c_arena = arena; |     c.c_arena = arena; | ||||||
| 
 | 
 | ||||||
|  |     k = 0; | ||||||
|     switch (TYPE(n)) { |     switch (TYPE(n)) { | ||||||
|         case file_input: |         case file_input: | ||||||
|             stmts = asdl_seq_new(num_stmts(n), arena); |             stmts = asdl_seq_new(num_stmts(n), arena); | ||||||
|  | @ -214,7 +215,7 @@ PyAST_FromNode(const node *n, PyCompilerFlags *flags, const char *filename, | ||||||
|                     s = ast_for_stmt(&c, ch); |                     s = ast_for_stmt(&c, ch); | ||||||
|                     if (!s) |                     if (!s) | ||||||
|                         goto error; |                         goto error; | ||||||
|                     asdl_seq_APPEND(stmts, s); |                     asdl_seq_SET(stmts, k++, s); | ||||||
|                 } |                 } | ||||||
|                 else { |                 else { | ||||||
|                     ch = CHILD(ch, 0); |                     ch = CHILD(ch, 0); | ||||||
|  | @ -223,7 +224,7 @@ PyAST_FromNode(const node *n, PyCompilerFlags *flags, const char *filename, | ||||||
|                         s = ast_for_stmt(&c, CHILD(ch, j * 2)); |                         s = ast_for_stmt(&c, CHILD(ch, j * 2)); | ||||||
|                         if (!s) |                         if (!s) | ||||||
|                             goto error; |                             goto error; | ||||||
|                         asdl_seq_APPEND(stmts, s); |                         asdl_seq_SET(stmts, k++, s); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | @ -314,15 +315,11 @@ get_operator(const node *n) | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* Set the context ctx for expr_ty e returning 1 on success, 0 on error.
 | /* Set the context ctx for expr_ty e, recursively traversing e.
 | ||||||
| 
 | 
 | ||||||
|    Only sets context for expr kinds that "can appear in assignment context" |    Only sets context for expr kinds that "can appear in assignment context" | ||||||
|    (according to ../Parser/Python.asdl).  For other expr kinds, it sets |    (according to ../Parser/Python.asdl).  For other expr kinds, it sets | ||||||
|    an appropriate syntax error and returns false. |    an appropriate syntax error and returns false. | ||||||
| 
 |  | ||||||
|    If e is a sequential type, items in sequence will also have their context |  | ||||||
|    set. |  | ||||||
| 
 |  | ||||||
| */ | */ | ||||||
| 
 | 
 | ||||||
| static int | static int | ||||||
|  | @ -416,7 +413,7 @@ set_context(expr_ty e, expr_context_ty ctx, const node *n) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* If the LHS is a list or tuple, we need to set the assignment
 |     /* If the LHS is a list or tuple, we need to set the assignment
 | ||||||
|        context for all the tuple elements.   |        context for all the contained elements.   | ||||||
|     */ |     */ | ||||||
|     if (s) { |     if (s) { | ||||||
| 	int i; | 	int i; | ||||||
|  | @ -559,7 +556,6 @@ compiler_complex_args(struct compiling *c, const node *n) | ||||||
|         return NULL; |         return NULL; | ||||||
| 
 | 
 | ||||||
|     REQ(n, fplist); |     REQ(n, fplist); | ||||||
| 
 |  | ||||||
|     for (i = 0; i < len; i++) { |     for (i = 0; i < len; i++) { | ||||||
|         const node *child = CHILD(CHILD(n, 2*i), 0); |         const node *child = CHILD(CHILD(n, 2*i), 0); | ||||||
|         expr_ty arg; |         expr_ty arg; | ||||||
|  | @ -571,22 +567,20 @@ compiler_complex_args(struct compiling *c, const node *n) | ||||||
|             arg = Name(NEW_IDENTIFIER(child), Store, LINENO(child), |             arg = Name(NEW_IDENTIFIER(child), Store, LINENO(child), | ||||||
|                        c->c_arena); |                        c->c_arena); | ||||||
| 	    } | 	    } | ||||||
|         else |         else { | ||||||
|             arg = compiler_complex_args(c, CHILD(CHILD(n, 2*i), 1)); |             arg = compiler_complex_args(c, CHILD(CHILD(n, 2*i), 1)); | ||||||
| 	set_context(arg, Store, n); |         } | ||||||
|         asdl_seq_SET(args, i, arg); |         asdl_seq_SET(args, i, arg); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     result = Tuple(args, Store, LINENO(n), c->c_arena); |     result = Tuple(args, Store, LINENO(n), c->c_arena); | ||||||
|     set_context(result, Store, n); |     if (!set_context(result, Store, n)) | ||||||
|  |         return NULL; | ||||||
|     return result; |     return result; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* Create AST for argument list.
 |  | ||||||
| 
 | 
 | ||||||
|    XXX TO DO: | /* Create AST for argument list. */ | ||||||
|        - check for invalid argument lists like normal after default |  | ||||||
| */ |  | ||||||
| 
 | 
 | ||||||
| static arguments_ty | static arguments_ty | ||||||
| ast_for_arguments(struct compiling *c, const node *n) | ast_for_arguments(struct compiling *c, const node *n) | ||||||
|  | @ -595,7 +589,7 @@ ast_for_arguments(struct compiling *c, const node *n) | ||||||
|        varargslist: (fpdef ['=' test] ',')* ('*' NAME [',' '**' NAME] |        varargslist: (fpdef ['=' test] ',')* ('*' NAME [',' '**' NAME] | ||||||
|             | '**' NAME) | fpdef ['=' test] (',' fpdef ['=' test])* [','] |             | '**' NAME) | fpdef ['=' test] (',' fpdef ['=' test])* [','] | ||||||
|     */ |     */ | ||||||
|     int i, n_args = 0, n_defaults = 0, found_default = 0; |     int i, j, k, n_args = 0, n_defaults = 0, found_default = 0; | ||||||
|     asdl_seq *args, *defaults; |     asdl_seq *args, *defaults; | ||||||
|     identifier vararg = NULL, kwarg = NULL; |     identifier vararg = NULL, kwarg = NULL; | ||||||
|     node *ch; |     node *ch; | ||||||
|  | @ -626,6 +620,8 @@ ast_for_arguments(struct compiling *c, const node *n) | ||||||
|        fplist: fpdef (',' fpdef)* [','] |        fplist: fpdef (',' fpdef)* [','] | ||||||
|     */ |     */ | ||||||
|     i = 0; |     i = 0; | ||||||
|  |     j = 0;  /* index for defaults */ | ||||||
|  |     k = 0;  /* index for args */ | ||||||
|     while (i < NCH(n)) { |     while (i < NCH(n)) { | ||||||
| 	ch = CHILD(n, i); | 	ch = CHILD(n, i); | ||||||
| 	switch (TYPE(ch)) { | 	switch (TYPE(ch)) { | ||||||
|  | @ -634,7 +630,7 @@ ast_for_arguments(struct compiling *c, const node *n) | ||||||
|                    anything other than EQUAL or a comma? */ |                    anything other than EQUAL or a comma? */ | ||||||
|                 /* XXX Should NCH(n) check be made a separate check? */ |                 /* XXX Should NCH(n) check be made a separate check? */ | ||||||
|                 if (i + 1 < NCH(n) && TYPE(CHILD(n, i + 1)) == EQUAL) { |                 if (i + 1 < NCH(n) && TYPE(CHILD(n, i + 1)) == EQUAL) { | ||||||
|                     asdl_seq_APPEND(defaults,  |                     asdl_seq_SET(defaults, j++,  | ||||||
| 				    ast_for_expr(c, CHILD(n, i + 2))); | 				    ast_for_expr(c, CHILD(n, i + 2))); | ||||||
|                     i += 2; |                     i += 2; | ||||||
| 		    found_default = 1; | 		    found_default = 1; | ||||||
|  | @ -644,9 +640,8 @@ ast_for_arguments(struct compiling *c, const node *n) | ||||||
| 			     "non-default argument follows default argument"); | 			     "non-default argument follows default argument"); | ||||||
| 		    goto error; | 		    goto error; | ||||||
| 		} | 		} | ||||||
| 
 |  | ||||||
|                 if (NCH(ch) == 3) { |                 if (NCH(ch) == 3) { | ||||||
|                     asdl_seq_APPEND(args,  |                     asdl_seq_SET(args, k++,  | ||||||
|                                     compiler_complex_args(c, CHILD(ch, 1)));  |                                     compiler_complex_args(c, CHILD(ch, 1)));  | ||||||
| 		} | 		} | ||||||
|                 else if (TYPE(CHILD(ch, 0)) == NAME) { |                 else if (TYPE(CHILD(ch, 0)) == NAME) { | ||||||
|  | @ -659,7 +654,7 @@ ast_for_arguments(struct compiling *c, const node *n) | ||||||
|                                 Param, LINENO(ch), c->c_arena); |                                 Param, LINENO(ch), c->c_arena); | ||||||
|                     if (!name) |                     if (!name) | ||||||
|                         goto error; |                         goto error; | ||||||
|                     asdl_seq_APPEND(args, name); |                     asdl_seq_SET(args, k++, name); | ||||||
| 					  | 					  | ||||||
| 		} | 		} | ||||||
|                 i += 2; /* the name and the comma */ |                 i += 2; /* the name and the comma */ | ||||||
|  | @ -767,7 +762,6 @@ ast_for_decorators(struct compiling *c, const node *n) | ||||||
|     int i; |     int i; | ||||||
|      |      | ||||||
|     REQ(n, decorators); |     REQ(n, decorators); | ||||||
| 
 |  | ||||||
|     decorator_seq = asdl_seq_new(NCH(n), c->c_arena); |     decorator_seq = asdl_seq_new(NCH(n), c->c_arena); | ||||||
|     if (!decorator_seq) |     if (!decorator_seq) | ||||||
|         return NULL; |         return NULL; | ||||||
|  | @ -776,7 +770,7 @@ ast_for_decorators(struct compiling *c, const node *n) | ||||||
|         d = ast_for_decorator(c, CHILD(n, i)); |         d = ast_for_decorator(c, CHILD(n, i)); | ||||||
| 	    if (!d) | 	    if (!d) | ||||||
| 	        return NULL; | 	        return NULL; | ||||||
| 	asdl_seq_APPEND(decorator_seq, d); | 	    asdl_seq_SET(decorator_seq, i, d); | ||||||
|     } |     } | ||||||
|     return decorator_seq; |     return decorator_seq; | ||||||
| } | } | ||||||
|  | @ -994,11 +988,10 @@ ast_for_listcomp(struct compiling *c, const node *n) | ||||||
| 
 | 
 | ||||||
| 	    for (j = 0; j < n_ifs; j++) { | 	    for (j = 0; j < n_ifs; j++) { | ||||||
|             REQ(ch, list_iter); |             REQ(ch, list_iter); | ||||||
| 
 |  | ||||||
| 		    ch = CHILD(ch, 0); | 		    ch = CHILD(ch, 0); | ||||||
| 		    REQ(ch, list_if); | 		    REQ(ch, list_if); | ||||||
| 
 | 
 | ||||||
| 		asdl_seq_APPEND(ifs, ast_for_expr(c, CHILD(ch, 1))); |     		asdl_seq_SET(ifs, j, ast_for_expr(c, CHILD(ch, 1))); | ||||||
|     		if (NCH(ch) == 3) |     		if (NCH(ch) == 3) | ||||||
| 	    	    ch = CHILD(ch, 2); | 	    	    ch = CHILD(ch, 2); | ||||||
| 	        } | 	        } | ||||||
|  | @ -1007,7 +1000,7 @@ ast_for_listcomp(struct compiling *c, const node *n) | ||||||
| 		        ch = CHILD(ch, 0); | 		        ch = CHILD(ch, 0); | ||||||
|             lc->ifs = ifs; |             lc->ifs = ifs; | ||||||
| 	    } | 	    } | ||||||
| 	asdl_seq_APPEND(listcomps, lc); | 	    asdl_seq_SET(listcomps, i, lc); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return ListComp(elt, listcomps, LINENO(n), c->c_arena); |     return ListComp(elt, listcomps, LINENO(n), c->c_arena); | ||||||
|  | @ -1075,6 +1068,7 @@ count_gen_ifs(const node *n) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /* TODO(jhylton): Combine with list comprehension code? */ | ||||||
| static expr_ty | static expr_ty | ||||||
| ast_for_genexp(struct compiling *c, const node *n) | ast_for_genexp(struct compiling *c, const node *n) | ||||||
| { | { | ||||||
|  | @ -1146,7 +1140,7 @@ ast_for_genexp(struct compiling *c, const node *n) | ||||||
|                 expression = ast_for_expr(c, CHILD(ch, 1)); |                 expression = ast_for_expr(c, CHILD(ch, 1)); | ||||||
|                 if (!expression) |                 if (!expression) | ||||||
|                     return NULL; |                     return NULL; | ||||||
|                 asdl_seq_APPEND(ifs, expression); |                 asdl_seq_SET(ifs, j, expression); | ||||||
|                 if (NCH(ch) == 3) |                 if (NCH(ch) == 3) | ||||||
|                     ch = CHILD(ch, 2); |                     ch = CHILD(ch, 2); | ||||||
|             } |             } | ||||||
|  | @ -1155,7 +1149,7 @@ ast_for_genexp(struct compiling *c, const node *n) | ||||||
|                 ch = CHILD(ch, 0); |                 ch = CHILD(ch, 0); | ||||||
|             ge->ifs = ifs; |             ge->ifs = ifs; | ||||||
|         } |         } | ||||||
|         asdl_seq_APPEND(genexps, ge); |         asdl_seq_SET(genexps, i, ge); | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     return GeneratorExp(elt, genexps, LINENO(n), c->c_arena); |     return GeneratorExp(elt, genexps, LINENO(n), c->c_arena); | ||||||
|  | @ -1948,7 +1942,7 @@ ast_for_print_stmt(struct compiling *c, const node *n) | ||||||
|     expr_ty dest = NULL, expression; |     expr_ty dest = NULL, expression; | ||||||
|     asdl_seq *seq; |     asdl_seq *seq; | ||||||
|     bool nl; |     bool nl; | ||||||
|     int i, start = 1; |     int i, j, start = 1; | ||||||
| 
 | 
 | ||||||
|     REQ(n, print_stmt); |     REQ(n, print_stmt); | ||||||
|     if (NCH(n) >= 2 && TYPE(CHILD(n, 1)) == RIGHTSHIFT) { |     if (NCH(n) >= 2 && TYPE(CHILD(n, 1)) == RIGHTSHIFT) { | ||||||
|  | @ -1960,12 +1954,11 @@ ast_for_print_stmt(struct compiling *c, const node *n) | ||||||
|     seq = asdl_seq_new((NCH(n) + 1 - start) / 2, c->c_arena); |     seq = asdl_seq_new((NCH(n) + 1 - start) / 2, c->c_arena); | ||||||
|     if (!seq) |     if (!seq) | ||||||
|     	return NULL; |     	return NULL; | ||||||
|     for (i = start; i < NCH(n); i += 2) { |     for (i = start, j = 0; i < NCH(n); i += 2, ++j) { | ||||||
|         expression = ast_for_expr(c, CHILD(n, i)); |         expression = ast_for_expr(c, CHILD(n, i)); | ||||||
|         if (!expression) |         if (!expression) | ||||||
|             return NULL; |             return NULL; | ||||||
| 
 |     	asdl_seq_SET(seq, j, expression); | ||||||
| 	asdl_seq_APPEND(seq, expression); |  | ||||||
|     } |     } | ||||||
|     nl = (TYPE(CHILD(n, NCH(n) - 1)) == COMMA) ? false : true; |     nl = (TYPE(CHILD(n, NCH(n) - 1)) == COMMA) ? false : true; | ||||||
|     return Print(dest, seq, nl, LINENO(n), c->c_arena); |     return Print(dest, seq, nl, LINENO(n), c->c_arena); | ||||||
|  | @ -2252,14 +2245,15 @@ ast_for_import_stmt(struct compiling *c, const node *n) | ||||||
|             alias_ty import_alias = alias_for_import_name(c, n); |             alias_ty import_alias = alias_for_import_name(c, n); | ||||||
|             if (!import_alias) |             if (!import_alias) | ||||||
|                 return NULL; |                 return NULL; | ||||||
| 	    asdl_seq_APPEND(aliases, import_alias); | 	        asdl_seq_SET(aliases, 0, import_alias); | ||||||
|         } |         } | ||||||
| 
 |         else { | ||||||
|     	    for (i = 0; i < NCH(n); i += 2) { |     	    for (i = 0; i < NCH(n); i += 2) { | ||||||
|                 alias_ty import_alias = alias_for_import_name(c, CHILD(n, i)); |                 alias_ty import_alias = alias_for_import_name(c, CHILD(n, i)); | ||||||
|                 if (!import_alias) |                 if (!import_alias) | ||||||
|                     return NULL; |                     return NULL; | ||||||
| 	    asdl_seq_APPEND(aliases, import_alias); | 	            asdl_seq_SET(aliases, i / 2, import_alias); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         if (mod != NULL) |         if (mod != NULL) | ||||||
|             modname = mod->name; |             modname = mod->name; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Jeremy Hylton
						Jeremy Hylton