static PyStatus
-pyinit_config(_PyRuntimeState *runtime,
- PyThreadState **tstate_p,
- const PyConfig *config)
+pycore_interp_init(PyThreadState *tstate)
{
- _PyConfig_Write(config, runtime);
+ PyStatus status;
- PyStatus status = pycore_init_runtime(runtime, config);
+ status = pycore_init_types(tstate);
if (_PyStatus_EXCEPTION(status)) {
return status;
}
- PyThreadState *tstate;
- status = pycore_create_interpreter(runtime, config, &tstate);
+ PyObject *sysmod;
+ status = _PySys_Create(tstate, &sysmod);
if (_PyStatus_EXCEPTION(status)) {
return status;
}
- config = &tstate->interp->config;
- *tstate_p = tstate;
- status = pycore_init_types(tstate);
+ status = pycore_init_builtins(tstate);
if (_PyStatus_EXCEPTION(status)) {
return status;
}
- PyObject *sysmod;
- status = _PySys_Create(tstate, &sysmod);
+ return pycore_init_import_warnings(tstate, sysmod);
+}
+
+
+static PyStatus
+pyinit_config(_PyRuntimeState *runtime,
+ PyThreadState **tstate_p,
+ const PyConfig *config)
+{
+ _PyConfig_Write(config, runtime);
+
+ PyStatus status = pycore_init_runtime(runtime, config);
if (_PyStatus_EXCEPTION(status)) {
return status;
}
- status = pycore_init_builtins(tstate);
+ PyThreadState *tstate;
+ status = pycore_create_interpreter(runtime, config, &tstate);
if (_PyStatus_EXCEPTION(status)) {
return status;
}
+ config = &tstate->interp->config;
+ *tstate_p = tstate;
- status = pycore_init_import_warnings(tstate, sysmod);
+ status = pycore_interp_init(tstate);
if (_PyStatus_EXCEPTION(status)) {
return status;
}
if (_PyStatus_EXCEPTION(status)) {
goto error;
}
- config = &interp->config;
-
- status = pycore_init_types(tstate);
- if (_PyStatus_EXCEPTION(status)) {
- goto error;
- }
-
- PyObject *sysmod;
- status = _PySys_Create(tstate, &sysmod);
- if (_PyStatus_EXCEPTION(status)) {
- return status;
- }
-
- status = pycore_init_builtins(tstate);
- if (_PyStatus_EXCEPTION(status)) {
- goto error;
- }
- status = pycore_init_import_warnings(tstate, sysmod);
+ status = pycore_interp_init(tstate);
if (_PyStatus_EXCEPTION(status)) {
goto error;
}