diff options
author | Eric Snow <ericsnowcurrently@gmail.com> | 2023-03-21 16:49:12 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-21 16:49:12 (GMT) |
commit | 3bb475662ba998e1b2d26fa370794d0804e33927 (patch) | |
tree | 47cc612ffac4eb4dda24b4eb51c6796142695ce6 /Python/pylifecycle.c | |
parent | 910a64e3013bce821bfac75377cbe88bedf265de (diff) | |
download | cpython-3bb475662ba998e1b2d26fa370794d0804e33927.zip cpython-3bb475662ba998e1b2d26fa370794d0804e33927.tar.gz cpython-3bb475662ba998e1b2d26fa370794d0804e33927.tar.bz2 |
gh-98608: Stop Treating All Errors from _Py_NewInterpreterFromConfig() as Fatal (gh-102657)
Prior to this change, errors in _Py_NewInterpreterFromConfig() were always fatal. Instead, callers should be able to handle such errors and keep going. That's what this change supports. (This was an oversight in the original implementation of _Py_NewInterpreterFromConfig().) Note that the existing [fatal] behavior of the public Py_NewInterpreter() is preserved.
https://github.com/python/cpython/issues/98608
Diffstat (limited to 'Python/pylifecycle.c')
-rw-r--r-- | Python/pylifecycle.c | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/Python/pylifecycle.c b/Python/pylifecycle.c index 731f340..8b58a14 100644 --- a/Python/pylifecycle.c +++ b/Python/pylifecycle.c @@ -2065,22 +2065,23 @@ error: return status; } -PyThreadState * -_Py_NewInterpreterFromConfig(const _PyInterpreterConfig *config) +PyStatus +_Py_NewInterpreterFromConfig(PyThreadState **tstate_p, + const _PyInterpreterConfig *config) { - PyThreadState *tstate = NULL; - PyStatus status = new_interpreter(&tstate, config); - if (_PyStatus_EXCEPTION(status)) { - Py_ExitStatusException(status); - } - return tstate; + return new_interpreter(tstate_p, config); } PyThreadState * Py_NewInterpreter(void) { + PyThreadState *tstate = NULL; const _PyInterpreterConfig config = _PyInterpreterConfig_LEGACY_INIT; - return _Py_NewInterpreterFromConfig(&config); + PyStatus status = _Py_NewInterpreterFromConfig(&tstate, &config); + if (_PyStatus_EXCEPTION(status)) { + Py_ExitStatusException(status); + } + return tstate; } /* Delete an interpreter and its last thread. This requires that the |