mirror of
https://github.com/python/cpython.git
synced 2025-11-01 02:38:53 +00:00
bpo-45408: Don't override previous tokenizer errors in the second parser pass (GH-28812)
This commit is contained in:
parent
6811fdaec8
commit
0219017df7
4 changed files with 15 additions and 2 deletions
|
|
@ -1342,13 +1342,16 @@ _PyPegen_run_parser(Parser *p)
|
|||
{
|
||||
void *res = _PyPegen_parse(p);
|
||||
if (res == NULL) {
|
||||
if (PyErr_Occurred() && !PyErr_ExceptionMatches(PyExc_SyntaxError)) {
|
||||
return NULL;
|
||||
}
|
||||
Token *last_token = p->tokens[p->fill - 1];
|
||||
reset_parser_state(p);
|
||||
_PyPegen_parse(p);
|
||||
if (PyErr_Occurred()) {
|
||||
// Prioritize tokenizer errors to custom syntax errors raised
|
||||
// on the second phase only if the errors come from the parser.
|
||||
if (p->tok->done != E_ERROR && PyErr_ExceptionMatches(PyExc_SyntaxError)) {
|
||||
if (p->tok->done == E_DONE && PyErr_ExceptionMatches(PyExc_SyntaxError)) {
|
||||
_PyPegen_check_tokenizer_errors(p);
|
||||
}
|
||||
return NULL;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue