Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Allow the parser to avoid nested processing of invalid rules (GH-31252) | Pablo Galindo Salgado | 2022-02-10 | 1 | -6/+5 |
| | |||||
* | bpo-46707: Avoid potential exponential backtracking in some syntax errors ↵ | Pablo Galindo Salgado | 2022-02-10 | 1 | -1/+3 |
| | | | | (GH-31241) | ||||
* | bpo-46272: Fix two heading comments in python.gram (GH-30499) | Mark Dickinson | 2022-01-09 | 1 | -3/+3 |
| | | | One typo fix and one heading change, both in comments. No functional changes. | ||||
* | bpo-45292: [PEP-654] add except* (GH-29581) | Irit Katriel | 2021-12-14 | 1 | -2/+15 |
| | |||||
* | bpo-45727: Only trigger the 'did you forgot a comma' error suggestion if ↵ | Pablo Galindo Salgado | 2021-11-24 | 1 | -1/+2 |
| | | | | inside parentheses (GH-29757) | ||||
* | bpo-45450: Improve syntax error for parenthesized arguments (GH-28906) | Pablo Galindo Salgado | 2021-11-20 | 1 | -0/+4 |
| | |||||
* | bpo-45727: Make the syntax error for missing comma more consistent (GH-29427) | Pablo Galindo Salgado | 2021-11-19 | 1 | -2/+2 |
| | |||||
* | bpo-45764: improve error message when missing '(' after 'def' (GH-29484) | Carl Friedrich Bolz-Tereick | 2021-11-09 | 1 | -2/+2 |
| | | | | | to achieve this, change the grammar to expect the '(' token after 'def' NAME. Automerge-Triggered-By: GH:pablogsal | ||||
* | bpo-45716: Improve the error message when using True/False/None as keywords ↵ | Pablo Galindo Salgado | 2021-11-05 | 1 | -0/+2 |
| | | | | in a call (GH-29413) | ||||
* | bpo-44257: fix "assigment_expr" typo + regenerate the grammar, and remove ↵ | wim glenn | 2021-11-03 | 1 | -4/+4 |
| | | | | | | unused imports (GH-29393) Co-authored-by: Wim Glenn <wglenn@jumptrading.com> | ||||
* | bpo-43914: Correctly highlight SyntaxError exceptions for invalid generator ↵ | Pablo Galindo Salgado | 2021-09-27 | 1 | -1/+1 |
| | | | | expression in function calls (GH-28576) | ||||
* | bpo-44947: Refine the syntax error for trailing commas in import statements ↵ | Pablo Galindo Salgado | 2021-08-18 | 1 | -1/+1 |
| | | | | (GH-27814) | ||||
* | bpo-44838: Refine the custom syntax errors for invalid 'if' expressions ↵ | Pablo Galindo Salgado | 2021-08-05 | 1 | -1/+1 |
| | | | | (GH-27615) | ||||
* | bpo-44792: Improve syntax errors for if expressions (GH-27506) | Miguel Brito | 2021-08-02 | 1 | -0/+1 |
| | |||||
* | bpo-34013: Don't consider a grouped expression when reporting legacy print ↵ | Pablo Galindo Salgado | 2021-08-01 | 1 | -1/+1 |
| | | | | syntax errors (GH-27521) | ||||
* | Divide the grammar into sections to improve readability (GH-27502) | Pablo Galindo Salgado | 2021-07-31 | 1 | -221/+446 |
| | |||||
* | bpo-34013: Move the Python 2 hints from the exception constructor to the ↵ | Pablo Galindo Salgado | 2021-07-27 | 1 | -3/+4 |
| | | | | parser (GH-27392) | ||||
* | bpo-34013: Generalize the invalid legacy statement error message (GH-27389) | Pablo Galindo Salgado | 2021-07-27 | 1 | -1/+6 |
| | |||||
* | Remove unnecessary 'invalid_primary' rule in the parser (GH-27186) | Pablo Galindo Salgado | 2021-07-16 | 1 | -3/+0 |
| | |||||
* | bpo-44456: Improve the syntax error when mixing keyword and positional ↵ | Pablo Galindo | 2021-06-24 | 1 | -0/+8 |
| | | | | patterns (GH-26793) | ||||
* | bpo-44368: Improve syntax errors with invalid as pattern targets (GH-26632) | Pablo Galindo | 2021-06-10 | 1 | -0/+4 |
| | |||||
* | bpo-44385: Remove unused grammar rules (GH-26655) | Lysandros Nikolaou | 2021-06-10 | 1 | -11/+0 |
| | | | Automerge-Triggered-By: GH:lysnikolaou | ||||
* | bpo-44305: Improve syntax error for try blocks without except or finally ↵ | Pablo Galindo | 2021-06-03 | 1 | -0/+1 |
| | | | | (GH-26523) | ||||
* | bpo-44180: Fix edge cases in invalid assigment rules in the parser (GH-26283) | Pablo Galindo | 2021-05-21 | 1 | -14/+24 |
| | | | | | | | | | | | | | | | The invalid assignment rules are very delicate since the parser can easily raise an invalid assignment when a keyword argument is provided. As they are very deep into the grammar tree, is very difficult to specify in which contexts these rules can be used and in which don't. For that, we need to use a different version of the rule that doesn't do error checking in those situations where we don't want the rule to raise (keyword arguments and generator expressions). We also need to check if we are in left-recursive rule, as those can try to eagerly advance the parser even if the parse will fail at the end of the expression. Failing to do this allows the parser to start parsing a call as a tuple and incorrectly identify a keyword argument as an invalid assignment, before it realizes that it was not a tuple after all. | ||||
* | bpo-44168: Fix error message in the parser for keyword arguments for invalid ↵ | Pablo Galindo | 2021-05-19 | 1 | -1/+1 |
| | | | | expressions (GH-26210) | ||||
* | bpo-43149: Correct the syntax error message for multiple exception types ↵ | Pablo Galindo | 2021-05-08 | 1 | -1/+1 |
| | | | | | (GH-25996) Automerge-Triggered-By: GH:pablogsal | ||||
* | bpo-43892: Validate the first term of complex literal value patterns (GH-25735) | Brandt Bucher | 2021-04-30 | 1 | -6/+15 |
| | |||||
* | bpo-43892: Make match patterns explicit in the AST (GH-25585) | Nick Coghlan | 2021-04-29 | 1 | -54/+101 |
| | | | Co-authored-by: Brandt Bucher <brandtbucher@gmail.com> | ||||
* | bpo-43914: Highlight invalid ranges in SyntaxErrors (#25525) | Pablo Galindo | 2021-04-23 | 1 | -24/+27 |
| | | | | | | | | | | | | | | | | | To improve the user experience understanding what part of the error messages associated with SyntaxErrors is wrong, we can highlight the whole error range and not only place the caret at the first character. In this way: >>> foo(x, z for z in range(10), t, w) File "<stdin>", line 1 foo(x, z for z in range(10), t, w) ^ SyntaxError: Generator expression must be parenthesized becomes >>> foo(x, z for z in range(10), t, w) File "<stdin>", line 1 foo(x, z for z in range(10), t, w) ^^^^^^^^^^^^^^^^^^^^ SyntaxError: Generator expression must be parenthesized | ||||
* | bpo-43859: Improve the error message for IndentationError exceptions (GH-25431) | Pablo Galindo | 2021-04-21 | 1 | -12/+58 |
| | |||||
* | bpo-43823: Fix location of one of the errors for invalid dictionary literals ↵ | Pablo Galindo | 2021-04-15 | 1 | -1/+2 |
| | | | | (GH-25427) | ||||
* | bpo-43822: Improve syntax errors for missing commas (GH-25377) | Pablo Galindo | 2021-04-15 | 2 | -0/+10 |
| | |||||
* | bpo-43823: Improve syntax errors for invalid dictionary literals (GH-25378) | Pablo Galindo | 2021-04-15 | 1 | -0/+11 |
| | |||||
* | bpo-43797: Handle correctly invalid assignments inside function calls and ↵ | Pablo Galindo | 2021-04-13 | 1 | -1/+1 |
| | | | | generators (GH-25390) | ||||
* | Ensure that early = are not matched by the parser as invalid comparisons ↵ | Pablo Galindo | 2021-04-13 | 1 | -1/+5 |
| | | | | (GH-25375) | ||||
* | bpo-43797: Improve syntax error for invalid comparisons (#25317) | Pablo Galindo | 2021-04-12 | 1 | -9/+24 |
| | | | | | | | | | | | | | * bpo-43797: Improve syntax error for invalid comparisons * Update Lib/test/test_fstring.py Co-authored-by: Guido van Rossum <gvanrossum@gmail.com> * Apply review comments * can't -> cannot Co-authored-by: Guido van Rossum <gvanrossum@gmail.com> | ||||
* | bpo-43798: Add source location attributes to alias (GH-25324) | Matthew Suozzo | 2021-04-10 | 1 | -3/+3 |
| | | | | | | | * Add source location attributes to alias. * Move alias star construction to pegen helper. Co-authored-by: blurb-it[bot] <43283697+blurb-it[bot]@users.noreply.github.com> Co-authored-by: Pablo Galindo <Pablogsal@gmail.com> | ||||
* | bpo-43244: Rename pycore_ast.h functions to _PyAST_xxx() (GH-25252) | Victor Stinner | 2021-04-07 | 1 | -148/+148 |
| | | | | | | Rename AST functions of pycore_ast.h to use the "_PyAST_" prefix. Remove macros creating aliases without prefix. For example, Module() becomes _PyAST_Module(). Update Grammar/python.gram to use _PyAST_xxx() functions. | ||||
* | bpo-41064: Improve syntax error for invalid usage of '**' in f-strings ↵ | Pablo Galindo | 2021-03-24 | 1 | -0/+2 |
| | | | | (GH-25006) | ||||
* | bpo-42128: Add 'missing :' syntax error message to match statements (GH-24733) | Pablo Galindo | 2021-03-18 | 1 | -0/+8 |
| | |||||
* | bpo-42128: Structural Pattern Matching (PEP 634) (GH-22917) | Brandt Bucher | 2021-02-26 | 1 | -1/+110 |
| | | | | | Co-authored-by: Guido van Rossum <guido@python.org> Co-authored-by: Talin <viridia@gmail.com> Co-authored-by: Pablo Galindo <pablogsal@gmail.com> | ||||
* | bpo-43149: Improve error message for exception group without parentheses ↵ | Pablo Galindo | 2021-02-07 | 1 | -2/+9 |
| | | | | (GH-24467) | ||||
* | bpo-43121: Fix incorrect SyntaxError message for missing comma (GH-24436) | Pablo Galindo | 2021-02-03 | 1 | -1/+1 |
| | |||||
* | bpo-42997: Improve error message for missing : before suites (GH-24292) | Pablo Galindo | 2021-02-02 | 1 | -16/+22 |
| | | | | | | | | * Add to the peg generator a new directive ('&&') that allows to expect a token and hard fail the parsing if the token is not found. This allows to quickly emmit syntax errors for missing tokens. * Use the new grammar element to hard-fail if the ':' is missing before suites. | ||||
* | bpo-43017: Improve error message for unparenthesised tuples in ↵ | Pablo Galindo | 2021-01-31 | 1 | -3/+5 |
| | | | | comprehensions (GH24314) | ||||
* | bpo-42860: Remove type error from grammar (GH-24156) | Lysandros Nikolaou | 2021-01-07 | 1 | -2/+8 |
| | | | | | | This is only there so that alternative implementations written in statically-typed languages can use this grammar without having type errors in the way. Automerge-Triggered-By: GH:lysnikolaou | ||||
* | bpo-40631: Disallow single parenthesized star target (GH-24027) | Lysandros Nikolaou | 2021-01-02 | 1 | -4/+9 |
| | |||||
* | bpo-30858: Improve error location for expressions with assignments (GH-23753) | Pablo Galindo | 2020-12-13 | 1 | -1/+1 |
| | | | Co-authored-by: Lysandros Nikolaou <lisandrosnik@gmail.com> | ||||
* | Refactor the grammar to match the language specification docs (GH-23574) | Pablo Galindo | 2020-11-30 | 1 | -7/+7 |
| | |||||
* | bpo-42381: Allow walrus in set literals and set comprehensions (GH-23332) | Pablo Galindo | 2020-11-17 | 1 | -3/+2 |
| | | | | | | | | | | | Currently walruses are not allowerd in set literals and set comprehensions: >>> {y := 4, 4**2, 3**3} File "<stdin>", line 1 {y := 4, 4**2, 3**3} ^ SyntaxError: invalid syntax but they should be allowed as well per PEP 572 |