diff options
author | Guido van Rossum <guido@python.org> | 2019-02-01 15:28:13 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-02-01 15:28:13 -0800 |
commit | d2b4c19d53f5f021fb1c7c32d48033a92ac4fe49 (patch) | |
tree | b1ca771dd7a01d8b163741ab8ef841a7bc7ebf4c | |
parent | ac19081c26eaa7de3e6aabeb789ddc2e7cdd5b24 (diff) | |
download | cpython-git-d2b4c19d53f5f021fb1c7c32d48033a92ac4fe49.tar.gz |
bpo-35879: Fix type comment leaks (GH-11728)
* Fix leak for # type: ignore
* Fix the type comment leak
-rw-r--r-- | Parser/parsetok.c | 1 | ||||
-rw-r--r-- | Python/ast.c | 11 |
2 files changed, 9 insertions, 3 deletions
diff --git a/Parser/parsetok.c b/Parser/parsetok.c index 7fddc5a0e8..1fa4a1286b 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 c422e9651c..45578a850f 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) |