diff options
author | Benjamin Peterson <benjamin@python.org> | 2015-12-29 16:08:51 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2015-12-29 16:08:51 (GMT) |
commit | 5aab44b301fff2c6a7f00e24944a3360eedd7aa8 (patch) | |
tree | ecb11e1fde51fab1d3728a05e05b7edad2931ad8 /Python | |
parent | bffa73e582c1a842d91d25ce93055f5e69074764 (diff) | |
parent | 3cc8f4b9693572e6ea423881cdbebfc981307b50 (diff) | |
download | cpython-5aab44b301fff2c6a7f00e24944a3360eedd7aa8.zip cpython-5aab44b301fff2c6a7f00e24944a3360eedd7aa8.tar.gz cpython-5aab44b301fff2c6a7f00e24944a3360eedd7aa8.tar.bz2 |
merge 3.5 (#25973)
Diffstat (limited to 'Python')
-rw-r--r-- | Python/symtable.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/Python/symtable.c b/Python/symtable.c index 806364a..9f5149f 100644 --- a/Python/symtable.c +++ b/Python/symtable.c @@ -368,15 +368,20 @@ error_at_directive(PySTEntryObject *ste, PyObject *name) Py_ssize_t i; PyObject *data; assert(ste->ste_directives); - for (i = 0; ; i++) { + for (i = 0; i < PyList_GET_SIZE(ste->ste_directives); i++) { data = PyList_GET_ITEM(ste->ste_directives, i); assert(PyTuple_CheckExact(data)); - if (PyTuple_GET_ITEM(data, 0) == name) - break; + assert(PyUnicode_CheckExact(PyTuple_GET_ITEM(data, 0))); + if (PyUnicode_Compare(PyTuple_GET_ITEM(data, 0), name) == 0) { + PyErr_SyntaxLocationObject(ste->ste_table->st_filename, + PyLong_AsLong(PyTuple_GET_ITEM(data, 1)), + PyLong_AsLong(PyTuple_GET_ITEM(data, 2))); + + return 0; + } } - PyErr_SyntaxLocationObject(ste->ste_table->st_filename, - PyLong_AsLong(PyTuple_GET_ITEM(data, 1)), - PyLong_AsLong(PyTuple_GET_ITEM(data, 2))); + PyErr_SetString(PyExc_RuntimeError, + "BUG: internal directive bookkeeping broken"); return 0; } @@ -1115,14 +1120,17 @@ symtable_new_tmpname(struct symtable *st) static int symtable_record_directive(struct symtable *st, identifier name, stmt_ty s) { - PyObject *data; + PyObject *data, *mangled; int res; if (!st->st_cur->ste_directives) { st->st_cur->ste_directives = PyList_New(0); if (!st->st_cur->ste_directives) return 0; } - data = Py_BuildValue("(Oii)", name, s->lineno, s->col_offset); + mangled = _Py_Mangle(st->st_private, name); + if (!mangled) + return 0; + data = Py_BuildValue("(Nii)", mangled, s->lineno, s->col_offset); if (!data) return 0; res = PyList_Append(st->st_cur->ste_directives, data); |