bpo-43268: Pass interp rather than tstate to internal functions (GH-24580)

Pass the current interpreter (interp) rather than the current Python
thread state (tstate) to internal functions which only use the
interpreter.

Modified functions:

* _PyXXX_Fini() and _PyXXX_ClearFreeList() functions
* _PyEval_SignalAsyncExc(), make_pending_calls()
* _PySys_GetObject(), sys_set_object(), sys_set_object_id(), sys_set_object_str()
* should_audit(), set_flags_from_config(), make_flags()
* _PyAtExit_Call()
* init_stdio_encoding()
* etc.
This commit is contained in:
Victor Stinner 2021-02-19 15:10:45 +01:00 committed by GitHub
parent a486054b24
commit bcb094b41f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
29 changed files with 240 additions and 245 deletions

View file

@ -3063,9 +3063,9 @@ error:
PyStatus
_PyBytes_Init(PyThreadState *tstate)
_PyBytes_Init(PyInterpreterState *interp)
{
struct _Py_bytes_state *state = &tstate->interp->bytes;
struct _Py_bytes_state *state = &interp->bytes;
if (bytes_create_empty_string_singleton(state) < 0) {
return _PyStatus_NO_MEMORY();
}
@ -3074,9 +3074,9 @@ _PyBytes_Init(PyThreadState *tstate)
void
_PyBytes_Fini(PyThreadState *tstate)
_PyBytes_Fini(PyInterpreterState *interp)
{
struct _Py_bytes_state* state = &tstate->interp->bytes;
struct _Py_bytes_state* state = &interp->bytes;
for (int i = 0; i < UCHAR_MAX + 1; i++) {
Py_CLEAR(state->characters[i]);
}