summaryrefslogtreecommitdiffstats
path: root/Python/crossinterp_exceptions.h
diff options
context:
space:
mode:
authorEric Snow <ericsnowcurrently@gmail.com>2024-04-03 16:58:39 (GMT)
committerGitHub <noreply@github.com>2024-04-03 16:58:39 (GMT)
commit976bcb2379709da57073a9e07b518ff51daa617a (patch)
tree66fca9084cbae6c0b503491f627829d703df19bc /Python/crossinterp_exceptions.h
parent7ecd55d604a8fa287c1d131cac14d10260be826b (diff)
downloadcpython-976bcb2379709da57073a9e07b518ff51daa617a.zip
cpython-976bcb2379709da57073a9e07b518ff51daa617a.tar.gz
cpython-976bcb2379709da57073a9e07b518ff51daa617a.tar.bz2
gh-76785: Raise InterpreterError, Not RuntimeError (gh-117489)
I had meant to switch everything to InterpreterError when I added it a while back. At the time I missed a few key spots. As part of this, I've added print-the-exception to _PyXI_InitTypes() and fixed an error case in `_PyStaticType_InitBuiltin().
Diffstat (limited to 'Python/crossinterp_exceptions.h')
-rw-r--r--Python/crossinterp_exceptions.h17
1 files changed, 16 insertions, 1 deletions
diff --git a/Python/crossinterp_exceptions.h b/Python/crossinterp_exceptions.h
index e418cf9..0f324ba 100644
--- a/Python/crossinterp_exceptions.h
+++ b/Python/crossinterp_exceptions.h
@@ -5,6 +5,9 @@ static PyTypeObject _PyExc_InterpreterError = {
PyVarObject_HEAD_INIT(NULL, 0)
.tp_name = "interpreters.InterpreterError",
.tp_doc = PyDoc_STR("A cross-interpreter operation failed"),
+ .tp_flags = Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC,
+ //.tp_traverse = ((PyTypeObject *)PyExc_BaseException)->tp_traverse,
+ //.tp_clear = ((PyTypeObject *)PyExc_BaseException)->tp_clear,
//.tp_base = (PyTypeObject *)PyExc_BaseException,
};
PyObject *PyExc_InterpreterError = (PyObject *)&_PyExc_InterpreterError;
@@ -15,6 +18,9 @@ static PyTypeObject _PyExc_InterpreterNotFoundError = {
PyVarObject_HEAD_INIT(NULL, 0)
.tp_name = "interpreters.InterpreterNotFoundError",
.tp_doc = PyDoc_STR("An interpreter was not found"),
+ .tp_flags = Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE | Py_TPFLAGS_HAVE_GC,
+ //.tp_traverse = ((PyTypeObject *)PyExc_BaseException)->tp_traverse,
+ //.tp_clear = ((PyTypeObject *)PyExc_BaseException)->tp_clear,
.tp_base = &_PyExc_InterpreterError,
};
PyObject *PyExc_InterpreterNotFoundError = (PyObject *)&_PyExc_InterpreterNotFoundError;
@@ -55,16 +61,25 @@ _get_not_shareable_error_type(PyInterpreterState *interp)
static int
init_exceptions(PyInterpreterState *interp)
{
+ PyTypeObject *base = (PyTypeObject *)PyExc_BaseException;
+
// builtin static types
- _PyExc_InterpreterError.tp_base = (PyTypeObject *)PyExc_BaseException;
+
+ _PyExc_InterpreterError.tp_base = base;
+ _PyExc_InterpreterError.tp_traverse = base->tp_traverse;
+ _PyExc_InterpreterError.tp_clear = base->tp_clear;
if (_PyStaticType_InitBuiltin(interp, &_PyExc_InterpreterError) < 0) {
return -1;
}
+
+ _PyExc_InterpreterNotFoundError.tp_traverse = base->tp_traverse;
+ _PyExc_InterpreterNotFoundError.tp_clear = base->tp_clear;
if (_PyStaticType_InitBuiltin(interp, &_PyExc_InterpreterNotFoundError) < 0) {
return -1;
}
// heap types
+
// We would call _init_not_shareable_error_type() here too,
// but that leads to ref leaks