[Python-checkins] bpo-45820: Fix a segfault when the parser fails without reading any input (GH-29580)

pablogsal webhook-mailer at python.org
Tue Nov 16 14:52:02 EST 2021


https://github.com/python/cpython/commit/df4ae55e66e34ea8de6a34f0b104871ddaf35d53
commit: df4ae55e66e34ea8de6a34f0b104871ddaf35d53
branch: main
author: Pablo Galindo Salgado <Pablogsal at gmail.com>
committer: pablogsal <Pablogsal at gmail.com>
date: 2021-11-16T19:51:52Z
summary:

bpo-45820: Fix a segfault when the parser fails without reading any input (GH-29580)

files:
A Misc/NEWS.d/next/Core and Builtins/2021-11-16-19-00-27.bpo-45820.2X6Psr.rst
M Parser/pegen.c

diff --git a/Misc/NEWS.d/next/Core and Builtins/2021-11-16-19-00-27.bpo-45820.2X6Psr.rst b/Misc/NEWS.d/next/Core and Builtins/2021-11-16-19-00-27.bpo-45820.2X6Psr.rst
new file mode 100644
index 0000000000000..c2ec3d690cd4b
--- /dev/null
+++ b/Misc/NEWS.d/next/Core and Builtins/2021-11-16-19-00-27.bpo-45820.2X6Psr.rst	
@@ -0,0 +1,2 @@
+Fix a segfault when the parser fails without reading any input. Patch by
+Pablo Galindo
diff --git a/Parser/pegen.c b/Parser/pegen.c
index 8a3f740c359c0..2931a40560867 100644
--- a/Parser/pegen.c
+++ b/Parser/pegen.c
@@ -368,6 +368,14 @@ tokenizer_error(Parser *p)
 void *
 _PyPegen_raise_error(Parser *p, PyObject *errtype, const char *errmsg, ...)
 {
+    if (p->fill == 0) {
+        va_list va;
+        va_start(va, errmsg);
+        _PyPegen_raise_error_known_location(p, errtype, 0, 0, 0, -1, errmsg, va);
+        va_end(va);
+        return NULL;
+    }
+
     Token *t = p->known_err_token != NULL ? p->known_err_token : p->tokens[p->fill - 1];
     Py_ssize_t col_offset;
     Py_ssize_t end_col_offset = -1;



More information about the Python-checkins mailing list