mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	bpo-44792: Improve syntax errors for if expressions (GH-27506)
This commit is contained in:
		
							parent
							
								
									aa0894b379
								
							
						
					
					
						commit
						28b6dc9dd5
					
				
					 5 changed files with 48 additions and 0 deletions
				
			
		|  | @ -1083,6 +1083,7 @@ invalid_expression: | ||||||
|     # Soft keywords need to also be ignored because they can be parsed as NAME NAME |     # Soft keywords need to also be ignored because they can be parsed as NAME NAME | ||||||
|    | !(NAME STRING | SOFT_KEYWORD) a=disjunction b=expression_without_invalid { |    | !(NAME STRING | SOFT_KEYWORD) a=disjunction b=expression_without_invalid { | ||||||
|         RAISE_SYNTAX_ERROR_KNOWN_RANGE(a, b, "invalid syntax. Perhaps you forgot a comma?") } |         RAISE_SYNTAX_ERROR_KNOWN_RANGE(a, b, "invalid syntax. Perhaps you forgot a comma?") } | ||||||
|  |    | a=disjunction 'if' b=disjunction !'else' { RAISE_SYNTAX_ERROR_KNOWN_RANGE(a, b, "expected 'else' after 'if' expression") } | ||||||
| 
 | 
 | ||||||
| invalid_named_expression: | invalid_named_expression: | ||||||
|     | a=expression ':=' expression { |     | a=expression ':=' expression { | ||||||
|  |  | ||||||
|  | @ -140,6 +140,18 @@ | ||||||
| Traceback (most recent call last): | Traceback (most recent call last): | ||||||
| SyntaxError: cannot assign to conditional expression | SyntaxError: cannot assign to conditional expression | ||||||
| 
 | 
 | ||||||
|  | >>> a = 42 if True | ||||||
|  | Traceback (most recent call last): | ||||||
|  | SyntaxError: expected 'else' after 'if' expression | ||||||
|  | 
 | ||||||
|  | >>> a = (42 if True) | ||||||
|  | Traceback (most recent call last): | ||||||
|  | SyntaxError: expected 'else' after 'if' expression | ||||||
|  | 
 | ||||||
|  | >>> a = [1, 42 if True, 4] | ||||||
|  | Traceback (most recent call last): | ||||||
|  | SyntaxError: expected 'else' after 'if' expression | ||||||
|  | 
 | ||||||
| >>> True = True = 3 | >>> True = True = 3 | ||||||
| Traceback (most recent call last): | Traceback (most recent call last): | ||||||
| SyntaxError: cannot assign to True | SyntaxError: cannot assign to True | ||||||
|  |  | ||||||
|  | @ -227,6 +227,7 @@ Tom Bridgman | ||||||
| Anthony Briggs | Anthony Briggs | ||||||
| Keith Briggs | Keith Briggs | ||||||
| Tobias Brink | Tobias Brink | ||||||
|  | Miguel Brito | ||||||
| Dillon Brock | Dillon Brock | ||||||
| Richard Brodie | Richard Brodie | ||||||
| Michael Broghton | Michael Broghton | ||||||
|  |  | ||||||
|  | @ -0,0 +1 @@ | ||||||
|  | Improve syntax errors for if expressions. Patch by Miguel Brito | ||||||
|  | @ -18207,6 +18207,7 @@ invalid_legacy_expression_rule(Parser *p) | ||||||
| // invalid_expression:
 | // invalid_expression:
 | ||||||
| //     | invalid_legacy_expression
 | //     | invalid_legacy_expression
 | ||||||
| //     | !(NAME STRING | SOFT_KEYWORD) disjunction expression_without_invalid
 | //     | !(NAME STRING | SOFT_KEYWORD) disjunction expression_without_invalid
 | ||||||
|  | //     | disjunction 'if' disjunction !'else'
 | ||||||
| static void * | static void * | ||||||
| invalid_expression_rule(Parser *p) | invalid_expression_rule(Parser *p) | ||||||
| { | { | ||||||
|  | @ -18265,6 +18266,38 @@ invalid_expression_rule(Parser *p) | ||||||
|         D(fprintf(stderr, "%*c%s invalid_expression[%d-%d]: %s failed!\n", p->level, ' ', |         D(fprintf(stderr, "%*c%s invalid_expression[%d-%d]: %s failed!\n", p->level, ' ', | ||||||
|                   p->error_indicator ? "ERROR!" : "-", _mark, p->mark, "!(NAME STRING | SOFT_KEYWORD) disjunction expression_without_invalid")); |                   p->error_indicator ? "ERROR!" : "-", _mark, p->mark, "!(NAME STRING | SOFT_KEYWORD) disjunction expression_without_invalid")); | ||||||
|     } |     } | ||||||
|  |     { // disjunction 'if' disjunction !'else'
 | ||||||
|  |         if (p->error_indicator) { | ||||||
|  |             D(p->level--); | ||||||
|  |             return NULL; | ||||||
|  |         } | ||||||
|  |         D(fprintf(stderr, "%*c> invalid_expression[%d-%d]: %s\n", p->level, ' ', _mark, p->mark, "disjunction 'if' disjunction !'else'")); | ||||||
|  |         Token * _keyword; | ||||||
|  |         expr_ty a; | ||||||
|  |         expr_ty b; | ||||||
|  |         if ( | ||||||
|  |             (a = disjunction_rule(p))  // disjunction
 | ||||||
|  |             && | ||||||
|  |             (_keyword = _PyPegen_expect_token(p, 510))  // token='if'
 | ||||||
|  |             && | ||||||
|  |             (b = disjunction_rule(p))  // disjunction
 | ||||||
|  |             && | ||||||
|  |             _PyPegen_lookahead_with_int(0, _PyPegen_expect_token, p, 518)  // token='else'
 | ||||||
|  |         ) | ||||||
|  |         { | ||||||
|  |             D(fprintf(stderr, "%*c+ invalid_expression[%d-%d]: %s succeeded!\n", p->level, ' ', _mark, p->mark, "disjunction 'if' disjunction !'else'")); | ||||||
|  |             _res = RAISE_SYNTAX_ERROR_KNOWN_RANGE ( a , b , "expected 'else' after 'if' expression" ); | ||||||
|  |             if (_res == NULL && PyErr_Occurred()) { | ||||||
|  |                 p->error_indicator = 1; | ||||||
|  |                 D(p->level--); | ||||||
|  |                 return NULL; | ||||||
|  |             } | ||||||
|  |             goto done; | ||||||
|  |         } | ||||||
|  |         p->mark = _mark; | ||||||
|  |         D(fprintf(stderr, "%*c%s invalid_expression[%d-%d]: %s failed!\n", p->level, ' ', | ||||||
|  |                   p->error_indicator ? "ERROR!" : "-", _mark, p->mark, "disjunction 'if' disjunction !'else'")); | ||||||
|  |     } | ||||||
|     _res = NULL; |     _res = NULL; | ||||||
|   done: |   done: | ||||||
|     D(p->level--); |     D(p->level--); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Miguel Brito
						Miguel Brito