diff options
author | Benjamin Peterson <benjamin@python.org> | 2012-09-02 18:24:44 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2012-09-02 18:24:44 (GMT) |
commit | c7f447c89fdef7106089f16ea46d5f9341fa0858 (patch) | |
tree | 42cf788e63fdfae5f3442dde269b963473c5d611 /Python | |
parent | a3b84fb2f9d555e9efac556ea24f4ad75a54b4c8 (diff) | |
parent | 2e2c903700991aa9f7e96d7a7fdaed3628dc7e1e (diff) | |
download | cpython-c7f447c89fdef7106089f16ea46d5f9341fa0858.zip cpython-c7f447c89fdef7106089f16ea46d5f9341fa0858.tar.gz cpython-c7f447c89fdef7106089f16ea46d5f9341fa0858.tar.bz2 |
merge 3.2 (#15846)
Diffstat (limited to 'Python')
-rw-r--r-- | Python/ast.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/Python/ast.c b/Python/ast.c index fc6c565..5366dda 100644 --- a/Python/ast.c +++ b/Python/ast.c @@ -588,7 +588,15 @@ ast_error(const node *n, const char *errstr) PyObject *u = Py_BuildValue("zii", errstr, LINENO(n), n->n_col_offset); if (!u) return 0; + /* + * Prevent the error from being chained. PyErr_SetObject will normalize the + * exception in order to chain it. ast_error_finish, however, requires the + * error not to be normalized. + */ + PyObject *save = PyThreadState_GET()->exc_value; + PyThreadState_GET()->exc_value = NULL; PyErr_SetObject(PyExc_SyntaxError, u); + PyThreadState_GET()->exc_value = save; Py_DECREF(u); return 0; } |