https://github.com/python/cpython/commit/1c381ec4edfa6364474fa795a93ed1cccb6df903
commit: 1c381ec4edfa6364474fa795a93ed1cccb6df903
branch: 3.11
author: Miss Islington (bot) <[email protected]>
committer: pablogsal <[email protected]>
date: 2024-01-02T13:22:39Z
summary:

[3.11] gh-113602: Bail out when the parser tries to override existing errors 
(GH-113607) (#113653)

gh-113602: Bail out when the parser tries to override existing errors 
(GH-113607)
(cherry picked from commit 9ed36d533ab8b256f0a589b5be6d7a2fdcf4aff2)

Signed-off-by: Pablo Galindo <[email protected]>
Co-authored-by: Pablo Galindo Salgado <[email protected]>

files:
A Misc/NEWS.d/next/Core and 
Builtins/2024-01-01-00-07-02.gh-issue-113602.cWuTzk.rst
M Lib/test/test_syntax.py
M Parser/pegen_errors.c

diff --git a/Lib/test/test_syntax.py b/Lib/test/test_syntax.py
index 050d084a97aed1..9dd0f745cf2c66 100644
--- a/Lib/test/test_syntax.py
+++ b/Lib/test/test_syntax.py
@@ -2143,6 +2143,8 @@ def test_error_parenthesis(self):
 """
         self._check_error(code, "parenthesis '\\)' does not match opening 
parenthesis '\\['")
 
+        self._check_error("match y:\n case e(e=v,v,", " was never closed")
+
         # Examples with dencodings
         s = b'# coding=latin\n(aaaaaaaaaaaaaaaaa\naaaaaaaaaaa\xb5'
         self._check_error(s, r"'\(' was never closed")
diff --git a/Misc/NEWS.d/next/Core and 
Builtins/2024-01-01-00-07-02.gh-issue-113602.cWuTzk.rst b/Misc/NEWS.d/next/Core 
and Builtins/2024-01-01-00-07-02.gh-issue-113602.cWuTzk.rst
new file mode 100644
index 00000000000000..5e064657348720
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and 
Builtins/2024-01-01-00-07-02.gh-issue-113602.cWuTzk.rst 
@@ -0,0 +1,2 @@
+Fix an error that was causing the parser to try to overwrite existing errors
+and crashing in the process. Patch by Pablo Galindo
diff --git a/Parser/pegen_errors.c b/Parser/pegen_errors.c
index fb9fa2909717f9..ccb0d37406181a 100644
--- a/Parser/pegen_errors.c
+++ b/Parser/pegen_errors.c
@@ -299,6 +299,10 @@ _PyPegen_raise_error_known_location(Parser *p, PyObject 
*errtype,
                                     Py_ssize_t end_lineno, Py_ssize_t 
end_col_offset,
                                     const char *errmsg, va_list va)
 {
+    // Bail out if we already have an error set.
+    if (p->error_indicator && PyErr_Occurred()) {
+        return NULL;
+    }
     PyObject *value = NULL;
     PyObject *errstr = NULL;
     PyObject *error_line = NULL;

_______________________________________________
Python-checkins mailing list -- [email protected]
To unsubscribe send an email to [email protected]
https://mail.python.org/mailman3/lists/python-checkins.python.org/
Member address: [email protected]

Reply via email to