summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2019-02-01 23:28:13 (GMT)
committerGitHub <noreply@github.com>2019-02-01 23:28:13 (GMT)
commitd2b4c19d53f5f021fb1c7c32d48033a92ac4fe49 (patch)
treeb1ca771dd7a01d8b163741ab8ef841a7bc7ebf4c
parentac19081c26eaa7de3e6aabeb789ddc2e7cdd5b24 (diff)
downloadcpython-d2b4c19d53f5f021fb1c7c32d48033a92ac4fe49.zip
cpython-d2b4c19d53f5f021fb1c7c32d48033a92ac4fe49.tar.gz
cpython-d2b4c19d53f5f021fb1c7c32d48033a92ac4fe49.tar.bz2
bpo-35879: Fix type comment leaks (GH-11728)
* Fix leak for # type: ignore * Fix the type comment leak
-rw-r--r--Parser/parsetok.c1
-rw-r--r--Python/ast.c11
2 files changed, 9 insertions, 3 deletions
diff --git a/Parser/parsetok.c b/Parser/parsetok.c
index 7fddc5a..1fa4a12 100644
--- a/Parser/parsetok.c
+++ b/Parser/parsetok.c
@@ -330,6 +330,7 @@ parsetok(struct tok_state *tok, grammar *g, int start, perrdetail *err_ret,
}
if (type == TYPE_IGNORE) {
+ PyObject_FREE(str);
if (!growable_int_array_add(&type_ignores, tok->lineno)) {
err_ret->error = E_NOMEM;
break;
diff --git a/Python/ast.c b/Python/ast.c
index c422e96..45578a8 100644
--- a/Python/ast.c
+++ b/Python/ast.c
@@ -699,11 +699,16 @@ ast_error(struct compiling *c, const node *n, const char *errmsg, ...)
*/
static string
-new_type_comment(const char *s)
+new_type_comment(const char *s, struct compiling *c)
{
- return PyUnicode_DecodeUTF8(s, strlen(s), NULL);
+ PyObject *res = PyUnicode_DecodeUTF8(s, strlen(s), NULL);
+ if (PyArena_AddPyObject(c->c_arena, res) < 0) {
+ Py_DECREF(res);
+ return NULL;
+ }
+ return res;
}
-#define NEW_TYPE_COMMENT(n) new_type_comment(STR(n))
+#define NEW_TYPE_COMMENT(n) new_type_comment(STR(n), c)
static int
num_stmts(const node *n)