mirror of https://github.com/python/cpython
bpo-44180: Report generic syntax errors in the furthest position reached in the first parser pass (GH-26253)
This commit is contained in:
parent
b11a951f16
commit
b51081c1a8
|
@ -213,6 +213,7 @@ class ExceptionTests(unittest.TestCase):
|
|||
check('[file for str(file) in []\n])', 2, 2)
|
||||
check('[\nfile\nfor str(file)\nin\n[]\n]', 3, 5)
|
||||
check('[file for\n str(file) in []]', 2, 2)
|
||||
check("ages = {'Alice'=22, 'Bob'=23}", 1, 16)
|
||||
|
||||
# Errors thrown by compile.c
|
||||
check('class foo:return 1', 1, 11)
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
The parser doesn't report generic syntax errors that happen in a position
|
||||
further away that the one it reached in the first pass. Patch by Pablo
|
||||
Galindo
|
|
@ -1281,6 +1281,7 @@ _PyPegen_run_parser(Parser *p)
|
|||
{
|
||||
void *res = _PyPegen_parse(p);
|
||||
if (res == NULL) {
|
||||
Token *last_token = p->tokens[p->fill - 1];
|
||||
reset_parser_state(p);
|
||||
_PyPegen_parse(p);
|
||||
if (PyErr_Occurred()) {
|
||||
|
@ -1307,7 +1308,11 @@ _PyPegen_run_parser(Parser *p)
|
|||
RAISE_INDENTATION_ERROR("unexpected unindent");
|
||||
}
|
||||
else {
|
||||
RAISE_SYNTAX_ERROR("invalid syntax");
|
||||
// Use the last token we found on the first pass to avoid reporting
|
||||
// incorrect locations for generic syntax errors just because we reached
|
||||
// further away when trying to find specific syntax errors in the second
|
||||
// pass.
|
||||
RAISE_SYNTAX_ERROR_KNOWN_LOCATION(last_token, "invalid syntax");
|
||||
// _PyPegen_check_tokenizer_errors will override the existing
|
||||
// generic SyntaxError we just raised if errors are found.
|
||||
_PyPegen_check_tokenizer_errors(p);
|
||||
|
|
Loading…
Reference in New Issue