]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-45820: Fix a segfault when the parser fails without reading any input (GH-29580)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Wed, 17 Nov 2021 23:43:14 +0000 (15:43 -0800)
committerGitHub <noreply@github.com>
Wed, 17 Nov 2021 23:43:14 +0000 (15:43 -0800)
(cherry picked from commit df4ae55e66e34ea8de6a34f0b104871ddaf35d53)

Co-authored-by: Pablo Galindo Salgado <Pablogsal@gmail.com>
Misc/NEWS.d/next/Core and Builtins/2021-11-16-19-00-27.bpo-45820.2X6Psr.rst [new file with mode: 0644]
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 (file)
index 0000000..c2ec3d6
--- /dev/null
@@ -0,0 +1,2 @@
+Fix a segfault when the parser fails without reading any input. Patch by
+Pablo Galindo
index 170d28b94d4ee9517ead996b9f7a9eb0316877f3..c6570eb1bd0b4177408d498e1067212e9bb6eaff 100644 (file)
@@ -389,6 +389,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;