blob: 9739bb154181fb187e5f69bfca6d972b99be31a3 [file] [log] [blame]
Nick Coghland6009512014-11-20 21:39:37 +10001/* Python interpreter top-level routines, including init/exit */
2
3#include "Python.h"
4
5#include "Python-ast.h"
Victor Stinner3bb183d2018-11-22 18:38:38 +01006#undef Yield /* undefine macro conflicting with <winbase.h> */
Victor Stinner09532fe2019-05-10 23:39:09 +02007#include "pycore_ceval.h"
Victor Stinner99fcc612019-04-29 13:04:07 +02008#include "pycore_context.h"
Victor Stinner0a28f8d2019-06-19 02:54:39 +02009#include "pycore_import.h" /* _PyImport_FindBuiltin */
Victor Stinner331a6a52019-05-27 16:39:22 +020010#include "pycore_initconfig.h"
Victor Stinner353933e2018-11-23 13:08:26 +010011#include "pycore_fileutils.h"
Victor Stinner27e2d1f2018-11-01 00:52:28 +010012#include "pycore_hamt.h"
Victor Stinnera1c249c2018-11-01 03:15:58 +010013#include "pycore_pathconfig.h"
Victor Stinnerb45d2592019-06-20 00:05:23 +020014#include "pycore_pyerrors.h"
Victor Stinner621cebe2018-11-12 16:53:38 +010015#include "pycore_pylifecycle.h"
16#include "pycore_pymem.h"
17#include "pycore_pystate.h"
Victor Stinnered488662019-05-20 00:14:57 +020018#include "pycore_traceback.h"
Nick Coghland6009512014-11-20 21:39:37 +100019#include "grammar.h"
20#include "node.h"
21#include "token.h"
22#include "parsetok.h"
23#include "errcode.h"
24#include "code.h"
25#include "symtable.h"
26#include "ast.h"
27#include "marshal.h"
28#include "osdefs.h"
29#include <locale.h>
30
31#ifdef HAVE_SIGNAL_H
32#include <signal.h>
33#endif
34
35#ifdef MS_WINDOWS
36#include "malloc.h" /* for alloca */
37#endif
38
39#ifdef HAVE_LANGINFO_H
40#include <langinfo.h>
41#endif
42
43#ifdef MS_WINDOWS
44#undef BYTE
45#include "windows.h"
Steve Dower39294992016-08-30 21:22:36 -070046
47extern PyTypeObject PyWindowsConsoleIO_Type;
48#define PyWindowsConsoleIO_Check(op) (PyObject_TypeCheck((op), &PyWindowsConsoleIO_Type))
Nick Coghland6009512014-11-20 21:39:37 +100049#endif
50
51_Py_IDENTIFIER(flush);
52_Py_IDENTIFIER(name);
53_Py_IDENTIFIER(stdin);
54_Py_IDENTIFIER(stdout);
55_Py_IDENTIFIER(stderr);
Eric Snow3f9eee62017-09-15 16:35:20 -060056_Py_IDENTIFIER(threading);
Nick Coghland6009512014-11-20 21:39:37 +100057
58#ifdef __cplusplus
59extern "C" {
60#endif
61
Nick Coghland6009512014-11-20 21:39:37 +100062extern grammar _PyParser_Grammar; /* From graminit.c */
63
Victor Stinnerb45d2592019-06-20 00:05:23 +020064/* Forward declarations */
Victor Stinner331a6a52019-05-27 16:39:22 +020065static PyStatus add_main_module(PyInterpreterState *interp);
Victor Stinnerb45d2592019-06-20 00:05:23 +020066static PyStatus init_import_site(void);
67static PyStatus init_sys_streams(PyThreadState *tstate);
68static PyStatus init_signals(PyThreadState *tstate);
69static void call_py_exitfuncs(PyThreadState *tstate);
70static void wait_for_thread_shutdown(PyThreadState *tstate);
Victor Stinner8e91c242019-04-24 17:24:01 +020071static void call_ll_exitfuncs(_PyRuntimeState *runtime);
Nick Coghland6009512014-11-20 21:39:37 +100072
Gregory P. Smith38f11cc2019-02-16 12:57:40 -080073int _Py_UnhandledKeyboardInterrupt = 0;
Victor Stinnerf7e5b562017-11-15 15:48:08 -080074_PyRuntimeState _PyRuntime = _PyRuntimeState_INIT;
Victor Stinnerfd23cfa2019-03-20 00:03:01 +010075static int runtime_initialized = 0;
Eric Snow2ebc5ce2017-09-07 23:51:28 -060076
Victor Stinner331a6a52019-05-27 16:39:22 +020077PyStatus
Eric Snow2ebc5ce2017-09-07 23:51:28 -060078_PyRuntime_Initialize(void)
79{
80 /* XXX We only initialize once in the process, which aligns with
81 the static initialization of the former globals now found in
82 _PyRuntime. However, _PyRuntime *should* be initialized with
83 every Py_Initialize() call, but doing so breaks the runtime.
84 This is because the runtime state is not properly finalized
85 currently. */
Victor Stinnerfd23cfa2019-03-20 00:03:01 +010086 if (runtime_initialized) {
Victor Stinner331a6a52019-05-27 16:39:22 +020087 return _PyStatus_OK();
Victor Stinnerf7e5b562017-11-15 15:48:08 -080088 }
Victor Stinnerfd23cfa2019-03-20 00:03:01 +010089 runtime_initialized = 1;
Victor Stinnerf7e5b562017-11-15 15:48:08 -080090
91 return _PyRuntimeState_Init(&_PyRuntime);
Eric Snow2ebc5ce2017-09-07 23:51:28 -060092}
93
94void
95_PyRuntime_Finalize(void)
96{
97 _PyRuntimeState_Fini(&_PyRuntime);
Victor Stinnerfd23cfa2019-03-20 00:03:01 +010098 runtime_initialized = 0;
Eric Snow2ebc5ce2017-09-07 23:51:28 -060099}
100
101int
102_Py_IsFinalizing(void)
103{
104 return _PyRuntime.finalizing != NULL;
105}
106
Nick Coghland6009512014-11-20 21:39:37 +1000107/* Hack to force loading of object files */
108int (*_PyOS_mystrnicmp_hack)(const char *, const char *, Py_ssize_t) = \
109 PyOS_mystrnicmp; /* Python/pystrcmp.o */
110
111/* PyModule_GetWarningsModule is no longer necessary as of 2.6
112since _warnings is builtin. This API should not be used. */
113PyObject *
114PyModule_GetWarningsModule(void)
115{
116 return PyImport_ImportModule("warnings");
117}
118
Eric Snowc7ec9982017-05-23 23:00:52 -0700119
Eric Snow1abcf672017-05-23 21:46:51 -0700120/* APIs to access the initialization flags
121 *
122 * Can be called prior to Py_Initialize.
123 */
Nick Coghland6009512014-11-20 21:39:37 +1000124
Eric Snow1abcf672017-05-23 21:46:51 -0700125int
126_Py_IsCoreInitialized(void)
127{
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600128 return _PyRuntime.core_initialized;
Eric Snow1abcf672017-05-23 21:46:51 -0700129}
Nick Coghland6009512014-11-20 21:39:37 +1000130
131int
132Py_IsInitialized(void)
133{
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600134 return _PyRuntime.initialized;
Nick Coghland6009512014-11-20 21:39:37 +1000135}
136
Nick Coghlan6ea41862017-06-11 13:16:15 +1000137
Martin Panterb4ce1fc2015-11-30 03:18:29 +0000138/* Global initializations. Can be undone by Py_FinalizeEx(). Don't
139 call this twice without an intervening Py_FinalizeEx() call. When
Nick Coghland6009512014-11-20 21:39:37 +1000140 initializations fail, a fatal error is issued and the function does
141 not return. On return, the first thread and interpreter state have
142 been created.
143
144 Locking: you must hold the interpreter lock while calling this.
145 (If the lock has not yet been initialized, that's equivalent to
146 having the lock, but you cannot use multiple threads.)
147
148*/
149
Victor Stinner331a6a52019-05-27 16:39:22 +0200150static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +0200151init_importlib(PyThreadState *tstate, PyObject *sysmod)
Nick Coghland6009512014-11-20 21:39:37 +1000152{
153 PyObject *importlib;
154 PyObject *impmod;
Nick Coghland6009512014-11-20 21:39:37 +1000155 PyObject *value;
Victor Stinnerb45d2592019-06-20 00:05:23 +0200156 PyInterpreterState *interp = tstate->interp;
Victor Stinner331a6a52019-05-27 16:39:22 +0200157 int verbose = interp->config.verbose;
Nick Coghland6009512014-11-20 21:39:37 +1000158
159 /* Import _importlib through its frozen version, _frozen_importlib. */
160 if (PyImport_ImportFrozenModule("_frozen_importlib") <= 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200161 return _PyStatus_ERR("can't import _frozen_importlib");
Nick Coghland6009512014-11-20 21:39:37 +1000162 }
Victor Stinnerc96be812019-05-14 17:34:56 +0200163 else if (verbose) {
Nick Coghland6009512014-11-20 21:39:37 +1000164 PySys_FormatStderr("import _frozen_importlib # frozen\n");
165 }
166 importlib = PyImport_AddModule("_frozen_importlib");
167 if (importlib == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200168 return _PyStatus_ERR("couldn't get _frozen_importlib from sys.modules");
Nick Coghland6009512014-11-20 21:39:37 +1000169 }
170 interp->importlib = importlib;
171 Py_INCREF(interp->importlib);
172
Serhiy Storchaka133138a2016-08-02 22:51:21 +0300173 interp->import_func = PyDict_GetItemString(interp->builtins, "__import__");
174 if (interp->import_func == NULL)
Victor Stinner331a6a52019-05-27 16:39:22 +0200175 return _PyStatus_ERR("__import__ not found");
Serhiy Storchaka133138a2016-08-02 22:51:21 +0300176 Py_INCREF(interp->import_func);
177
Victor Stinnercd6e6942015-09-18 09:11:57 +0200178 /* Import the _imp module */
Benjamin Petersonc65ef772018-01-29 11:33:57 -0800179 impmod = PyInit__imp();
Nick Coghland6009512014-11-20 21:39:37 +1000180 if (impmod == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200181 return _PyStatus_ERR("can't import _imp");
Nick Coghland6009512014-11-20 21:39:37 +1000182 }
Victor Stinnerc96be812019-05-14 17:34:56 +0200183 else if (verbose) {
Victor Stinnercd6e6942015-09-18 09:11:57 +0200184 PySys_FormatStderr("import _imp # builtin\n");
Nick Coghland6009512014-11-20 21:39:37 +1000185 }
Eric Snow3f9eee62017-09-15 16:35:20 -0600186 if (_PyImport_SetModuleString("_imp", impmod) < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200187 return _PyStatus_ERR("can't save _imp to sys.modules");
Nick Coghland6009512014-11-20 21:39:37 +1000188 }
189
Victor Stinnercd6e6942015-09-18 09:11:57 +0200190 /* Install importlib as the implementation of import */
Nick Coghland6009512014-11-20 21:39:37 +1000191 value = PyObject_CallMethod(importlib, "_install", "OO", sysmod, impmod);
192 if (value == NULL) {
Victor Stinnerb45d2592019-06-20 00:05:23 +0200193 _PyErr_Print(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200194 return _PyStatus_ERR("importlib install failed");
Nick Coghland6009512014-11-20 21:39:37 +1000195 }
196 Py_DECREF(value);
197 Py_DECREF(impmod);
198
Victor Stinner331a6a52019-05-27 16:39:22 +0200199 return _PyStatus_OK();
Nick Coghland6009512014-11-20 21:39:37 +1000200}
201
Victor Stinner331a6a52019-05-27 16:39:22 +0200202static PyStatus
Victor Stinner0a28f8d2019-06-19 02:54:39 +0200203init_importlib_external(PyThreadState *tstate)
Eric Snow1abcf672017-05-23 21:46:51 -0700204{
205 PyObject *value;
Victor Stinner0a28f8d2019-06-19 02:54:39 +0200206 value = PyObject_CallMethod(tstate->interp->importlib,
Eric Snow1abcf672017-05-23 21:46:51 -0700207 "_install_external_importers", "");
208 if (value == NULL) {
Victor Stinnerb45d2592019-06-20 00:05:23 +0200209 _PyErr_Print(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200210 return _PyStatus_ERR("external importer setup failed");
Eric Snow1abcf672017-05-23 21:46:51 -0700211 }
Stéphane Wirtelab1cb802017-06-08 13:13:20 +0200212 Py_DECREF(value);
Victor Stinner0a28f8d2019-06-19 02:54:39 +0200213 return _PyImportZip_Init(tstate);
Eric Snow1abcf672017-05-23 21:46:51 -0700214}
Nick Coghland6009512014-11-20 21:39:37 +1000215
Nick Coghlan6ea41862017-06-11 13:16:15 +1000216/* Helper functions to better handle the legacy C locale
217 *
218 * The legacy C locale assumes ASCII as the default text encoding, which
219 * causes problems not only for the CPython runtime, but also other
220 * components like GNU readline.
221 *
222 * Accordingly, when the CLI detects it, it attempts to coerce it to a
223 * more capable UTF-8 based alternative as follows:
224 *
225 * if (_Py_LegacyLocaleDetected()) {
226 * _Py_CoerceLegacyLocale();
227 * }
228 *
229 * See the documentation of the PYTHONCOERCECLOCALE setting for more details.
230 *
231 * Locale coercion also impacts the default error handler for the standard
232 * streams: while the usual default is "strict", the default for the legacy
233 * C locale and for any of the coercion target locales is "surrogateescape".
234 */
235
236int
Victor Stinner0f721472019-05-20 17:16:38 +0200237_Py_LegacyLocaleDetected(int warn)
Nick Coghlan6ea41862017-06-11 13:16:15 +1000238{
239#ifndef MS_WINDOWS
Victor Stinner0f721472019-05-20 17:16:38 +0200240 if (!warn) {
241 const char *locale_override = getenv("LC_ALL");
242 if (locale_override != NULL && *locale_override != '\0') {
243 /* Don't coerce C locale if the LC_ALL environment variable
244 is set */
245 return 0;
246 }
247 }
248
Nick Coghlan6ea41862017-06-11 13:16:15 +1000249 /* On non-Windows systems, the C locale is considered a legacy locale */
Nick Coghlaneb817952017-06-18 12:29:42 +1000250 /* XXX (ncoghlan): some platforms (notably Mac OS X) don't appear to treat
251 * the POSIX locale as a simple alias for the C locale, so
252 * we may also want to check for that explicitly.
253 */
Nick Coghlan6ea41862017-06-11 13:16:15 +1000254 const char *ctype_loc = setlocale(LC_CTYPE, NULL);
255 return ctype_loc != NULL && strcmp(ctype_loc, "C") == 0;
256#else
257 /* Windows uses code pages instead of locales, so no locale is legacy */
258 return 0;
259#endif
260}
261
Nick Coghlaneb817952017-06-18 12:29:42 +1000262static const char *_C_LOCALE_WARNING =
263 "Python runtime initialized with LC_CTYPE=C (a locale with default ASCII "
264 "encoding), which may cause Unicode compatibility problems. Using C.UTF-8, "
265 "C.utf8, or UTF-8 (if available) as alternative Unicode-compatible "
266 "locales is recommended.\n";
267
Nick Coghlaneb817952017-06-18 12:29:42 +1000268static void
Victor Stinner43125222019-04-24 18:23:53 +0200269emit_stderr_warning_for_legacy_locale(_PyRuntimeState *runtime)
Nick Coghlaneb817952017-06-18 12:29:42 +1000270{
Victor Stinner331a6a52019-05-27 16:39:22 +0200271 const PyPreConfig *preconfig = &runtime->preconfig;
Victor Stinner0f721472019-05-20 17:16:38 +0200272 if (preconfig->coerce_c_locale_warn && _Py_LegacyLocaleDetected(1)) {
Victor Stinnercf215042018-08-29 22:56:06 +0200273 PySys_FormatStderr("%s", _C_LOCALE_WARNING);
Nick Coghlaneb817952017-06-18 12:29:42 +1000274 }
275}
276
Nick Coghlan6ea41862017-06-11 13:16:15 +1000277typedef struct _CandidateLocale {
278 const char *locale_name; /* The locale to try as a coercion target */
279} _LocaleCoercionTarget;
280
281static _LocaleCoercionTarget _TARGET_LOCALES[] = {
282 {"C.UTF-8"},
283 {"C.utf8"},
Nick Coghlan18974c32017-06-30 00:48:14 +1000284 {"UTF-8"},
Nick Coghlan6ea41862017-06-11 13:16:15 +1000285 {NULL}
286};
287
Victor Stinnerdfe0dc72018-08-29 11:47:29 +0200288
289int
290_Py_IsLocaleCoercionTarget(const char *ctype_loc)
Nick Coghlan6ea41862017-06-11 13:16:15 +1000291{
Victor Stinnerdfe0dc72018-08-29 11:47:29 +0200292 const _LocaleCoercionTarget *target = NULL;
293 for (target = _TARGET_LOCALES; target->locale_name; target++) {
294 if (strcmp(ctype_loc, target->locale_name) == 0) {
295 return 1;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000296 }
Victor Stinner124b9eb2018-08-29 01:29:06 +0200297 }
Victor Stinnerdfe0dc72018-08-29 11:47:29 +0200298 return 0;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000299}
300
Victor Stinnerdfe0dc72018-08-29 11:47:29 +0200301
Nick Coghlan6ea41862017-06-11 13:16:15 +1000302#ifdef PY_COERCE_C_LOCALE
Victor Stinner94540602017-12-16 04:54:22 +0100303static const char C_LOCALE_COERCION_WARNING[] =
Nick Coghlan6ea41862017-06-11 13:16:15 +1000304 "Python detected LC_CTYPE=C: LC_CTYPE coerced to %.20s (set another locale "
305 "or PYTHONCOERCECLOCALE=0 to disable this locale coercion behavior).\n";
306
Victor Stinner0f721472019-05-20 17:16:38 +0200307static int
Victor Stinnerb2457ef2018-08-29 13:25:36 +0200308_coerce_default_locale_settings(int warn, const _LocaleCoercionTarget *target)
Nick Coghlan6ea41862017-06-11 13:16:15 +1000309{
310 const char *newloc = target->locale_name;
311
312 /* Reset locale back to currently configured defaults */
xdegaye1588be62017-11-12 12:45:59 +0100313 _Py_SetLocaleFromEnv(LC_ALL);
Nick Coghlan6ea41862017-06-11 13:16:15 +1000314
315 /* Set the relevant locale environment variable */
316 if (setenv("LC_CTYPE", newloc, 1)) {
317 fprintf(stderr,
318 "Error setting LC_CTYPE, skipping C locale coercion\n");
Victor Stinner0f721472019-05-20 17:16:38 +0200319 return 0;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000320 }
Victor Stinnerb2457ef2018-08-29 13:25:36 +0200321 if (warn) {
Victor Stinner94540602017-12-16 04:54:22 +0100322 fprintf(stderr, C_LOCALE_COERCION_WARNING, newloc);
Nick Coghlaneb817952017-06-18 12:29:42 +1000323 }
Nick Coghlan6ea41862017-06-11 13:16:15 +1000324
325 /* Reconfigure with the overridden environment variables */
xdegaye1588be62017-11-12 12:45:59 +0100326 _Py_SetLocaleFromEnv(LC_ALL);
Victor Stinner0f721472019-05-20 17:16:38 +0200327 return 1;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000328}
329#endif
330
Victor Stinner0f721472019-05-20 17:16:38 +0200331int
Victor Stinnerb2457ef2018-08-29 13:25:36 +0200332_Py_CoerceLegacyLocale(int warn)
Nick Coghlan6ea41862017-06-11 13:16:15 +1000333{
Victor Stinner0f721472019-05-20 17:16:38 +0200334 int coerced = 0;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000335#ifdef PY_COERCE_C_LOCALE
Victor Stinner8ea09112018-09-03 17:05:18 +0200336 char *oldloc = NULL;
337
338 oldloc = _PyMem_RawStrdup(setlocale(LC_CTYPE, NULL));
339 if (oldloc == NULL) {
Victor Stinner0f721472019-05-20 17:16:38 +0200340 return coerced;
Victor Stinner8ea09112018-09-03 17:05:18 +0200341 }
342
Victor Stinner94540602017-12-16 04:54:22 +0100343 const char *locale_override = getenv("LC_ALL");
344 if (locale_override == NULL || *locale_override == '\0') {
345 /* LC_ALL is also not set (or is set to an empty string) */
346 const _LocaleCoercionTarget *target = NULL;
347 for (target = _TARGET_LOCALES; target->locale_name; target++) {
348 const char *new_locale = setlocale(LC_CTYPE,
349 target->locale_name);
350 if (new_locale != NULL) {
Victor Stinnere2510952019-05-02 11:28:57 -0400351#if !defined(_Py_FORCE_UTF8_LOCALE) && defined(HAVE_LANGINFO_H) && defined(CODESET)
Victor Stinner94540602017-12-16 04:54:22 +0100352 /* Also ensure that nl_langinfo works in this locale */
353 char *codeset = nl_langinfo(CODESET);
354 if (!codeset || *codeset == '\0') {
355 /* CODESET is not set or empty, so skip coercion */
356 new_locale = NULL;
357 _Py_SetLocaleFromEnv(LC_CTYPE);
358 continue;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000359 }
Victor Stinner94540602017-12-16 04:54:22 +0100360#endif
361 /* Successfully configured locale, so make it the default */
Victor Stinner0f721472019-05-20 17:16:38 +0200362 coerced = _coerce_default_locale_settings(warn, target);
Victor Stinner8ea09112018-09-03 17:05:18 +0200363 goto done;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000364 }
365 }
366 }
367 /* No C locale warning here, as Py_Initialize will emit one later */
Victor Stinner8ea09112018-09-03 17:05:18 +0200368
369 setlocale(LC_CTYPE, oldloc);
370
371done:
372 PyMem_RawFree(oldloc);
Nick Coghlan6ea41862017-06-11 13:16:15 +1000373#endif
Victor Stinner0f721472019-05-20 17:16:38 +0200374 return coerced;
Nick Coghlan6ea41862017-06-11 13:16:15 +1000375}
376
xdegaye1588be62017-11-12 12:45:59 +0100377/* _Py_SetLocaleFromEnv() is a wrapper around setlocale(category, "") to
378 * isolate the idiosyncrasies of different libc implementations. It reads the
379 * appropriate environment variable and uses its value to select the locale for
380 * 'category'. */
381char *
382_Py_SetLocaleFromEnv(int category)
383{
Victor Stinner353933e2018-11-23 13:08:26 +0100384 char *res;
xdegaye1588be62017-11-12 12:45:59 +0100385#ifdef __ANDROID__
386 const char *locale;
387 const char **pvar;
388#ifdef PY_COERCE_C_LOCALE
389 const char *coerce_c_locale;
390#endif
391 const char *utf8_locale = "C.UTF-8";
392 const char *env_var_set[] = {
393 "LC_ALL",
394 "LC_CTYPE",
395 "LANG",
396 NULL,
397 };
398
399 /* Android setlocale(category, "") doesn't check the environment variables
400 * and incorrectly sets the "C" locale at API 24 and older APIs. We only
401 * check the environment variables listed in env_var_set. */
402 for (pvar=env_var_set; *pvar; pvar++) {
403 locale = getenv(*pvar);
404 if (locale != NULL && *locale != '\0') {
405 if (strcmp(locale, utf8_locale) == 0 ||
406 strcmp(locale, "en_US.UTF-8") == 0) {
407 return setlocale(category, utf8_locale);
408 }
409 return setlocale(category, "C");
410 }
411 }
412
413 /* Android uses UTF-8, so explicitly set the locale to C.UTF-8 if none of
414 * LC_ALL, LC_CTYPE, or LANG is set to a non-empty string.
415 * Quote from POSIX section "8.2 Internationalization Variables":
416 * "4. If the LANG environment variable is not set or is set to the empty
417 * string, the implementation-defined default locale shall be used." */
418
419#ifdef PY_COERCE_C_LOCALE
420 coerce_c_locale = getenv("PYTHONCOERCECLOCALE");
421 if (coerce_c_locale == NULL || strcmp(coerce_c_locale, "0") != 0) {
422 /* Some other ported code may check the environment variables (e.g. in
423 * extension modules), so we make sure that they match the locale
424 * configuration */
425 if (setenv("LC_CTYPE", utf8_locale, 1)) {
426 fprintf(stderr, "Warning: failed setting the LC_CTYPE "
427 "environment variable to %s\n", utf8_locale);
428 }
429 }
430#endif
Victor Stinner353933e2018-11-23 13:08:26 +0100431 res = setlocale(category, utf8_locale);
432#else /* !defined(__ANDROID__) */
433 res = setlocale(category, "");
434#endif
435 _Py_ResetForceASCII();
436 return res;
xdegaye1588be62017-11-12 12:45:59 +0100437}
438
Nick Coghlan6ea41862017-06-11 13:16:15 +1000439
Eric Snow1abcf672017-05-23 21:46:51 -0700440/* Global initializations. Can be undone by Py_Finalize(). Don't
441 call this twice without an intervening Py_Finalize() call.
442
Victor Stinner331a6a52019-05-27 16:39:22 +0200443 Every call to Py_InitializeFromConfig, Py_Initialize or Py_InitializeEx
Eric Snow1abcf672017-05-23 21:46:51 -0700444 must have a corresponding call to Py_Finalize.
445
446 Locking: you must hold the interpreter lock while calling these APIs.
447 (If the lock has not yet been initialized, that's equivalent to
448 having the lock, but you cannot use multiple threads.)
449
450*/
451
Victor Stinner331a6a52019-05-27 16:39:22 +0200452static PyStatus
Victor Stinner5edcf262019-05-23 00:57:57 +0200453pyinit_core_reconfigure(_PyRuntimeState *runtime,
Victor Stinnerb45d2592019-06-20 00:05:23 +0200454 PyThreadState **tstate_p,
Victor Stinner331a6a52019-05-27 16:39:22 +0200455 const PyConfig *config)
Victor Stinner1dc6e392018-07-25 02:49:17 +0200456{
Victor Stinner331a6a52019-05-27 16:39:22 +0200457 PyStatus status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100458 PyThreadState *tstate = _PyThreadState_GET();
459 if (!tstate) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200460 return _PyStatus_ERR("failed to read thread state");
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100461 }
Victor Stinnerb45d2592019-06-20 00:05:23 +0200462 *tstate_p = tstate;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100463
464 PyInterpreterState *interp = tstate->interp;
465 if (interp == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200466 return _PyStatus_ERR("can't make main interpreter");
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100467 }
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100468
Victor Stinner331a6a52019-05-27 16:39:22 +0200469 _PyConfig_Write(config, runtime);
Victor Stinner1dc6e392018-07-25 02:49:17 +0200470
Victor Stinner331a6a52019-05-27 16:39:22 +0200471 status = _PyConfig_Copy(&interp->config, config);
472 if (_PyStatus_EXCEPTION(status)) {
473 return status;
Victor Stinner1dc6e392018-07-25 02:49:17 +0200474 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200475 config = &interp->config;
Victor Stinner1dc6e392018-07-25 02:49:17 +0200476
Victor Stinner331a6a52019-05-27 16:39:22 +0200477 if (config->_install_importlib) {
Victor Stinner12f2f172019-09-26 15:51:50 +0200478 status = _PyConfig_WritePathConfig(config);
Victor Stinner331a6a52019-05-27 16:39:22 +0200479 if (_PyStatus_EXCEPTION(status)) {
480 return status;
Victor Stinner1dc6e392018-07-25 02:49:17 +0200481 }
482 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200483 return _PyStatus_OK();
Victor Stinner1dc6e392018-07-25 02:49:17 +0200484}
485
486
Victor Stinner331a6a52019-05-27 16:39:22 +0200487static PyStatus
Victor Stinner43125222019-04-24 18:23:53 +0200488pycore_init_runtime(_PyRuntimeState *runtime,
Victor Stinner331a6a52019-05-27 16:39:22 +0200489 const PyConfig *config)
Nick Coghland6009512014-11-20 21:39:37 +1000490{
Victor Stinner43125222019-04-24 18:23:53 +0200491 if (runtime->initialized) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200492 return _PyStatus_ERR("main interpreter already initialized");
Victor Stinner1dc6e392018-07-25 02:49:17 +0200493 }
Victor Stinnerda273412017-12-15 01:46:02 +0100494
Victor Stinner331a6a52019-05-27 16:39:22 +0200495 _PyConfig_Write(config, runtime);
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600496
Eric Snow1abcf672017-05-23 21:46:51 -0700497 /* Py_Finalize leaves _Py_Finalizing set in order to help daemon
498 * threads behave a little more gracefully at interpreter shutdown.
499 * We clobber it here so the new interpreter can start with a clean
500 * slate.
501 *
502 * However, this may still lead to misbehaviour if there are daemon
503 * threads still hanging around from a previous Py_Initialize/Finalize
504 * pair :(
505 */
Victor Stinner43125222019-04-24 18:23:53 +0200506 runtime->finalizing = NULL;
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600507
Victor Stinner331a6a52019-05-27 16:39:22 +0200508 PyStatus status = _Py_HashRandomization_Init(config);
509 if (_PyStatus_EXCEPTION(status)) {
510 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800511 }
512
Victor Stinner331a6a52019-05-27 16:39:22 +0200513 status = _PyInterpreterState_Enable(runtime);
514 if (_PyStatus_EXCEPTION(status)) {
515 return status;
Victor Stinnera7368ac2017-11-15 18:11:45 -0800516 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200517 return _PyStatus_OK();
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100518}
Victor Stinnera7368ac2017-11-15 18:11:45 -0800519
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100520
Victor Stinner331a6a52019-05-27 16:39:22 +0200521static PyStatus
Victor Stinner43125222019-04-24 18:23:53 +0200522pycore_create_interpreter(_PyRuntimeState *runtime,
Victor Stinner331a6a52019-05-27 16:39:22 +0200523 const PyConfig *config,
Victor Stinnerb45d2592019-06-20 00:05:23 +0200524 PyThreadState **tstate_p)
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100525{
526 PyInterpreterState *interp = PyInterpreterState_New();
Victor Stinnerda273412017-12-15 01:46:02 +0100527 if (interp == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200528 return _PyStatus_ERR("can't make main interpreter");
Victor Stinnerda273412017-12-15 01:46:02 +0100529 }
530
Victor Stinner331a6a52019-05-27 16:39:22 +0200531 PyStatus status = _PyConfig_Copy(&interp->config, config);
532 if (_PyStatus_EXCEPTION(status)) {
533 return status;
Victor Stinnerda273412017-12-15 01:46:02 +0100534 }
Nick Coghland6009512014-11-20 21:39:37 +1000535
Victor Stinnerd19d8d52018-07-24 13:55:48 +0200536 PyThreadState *tstate = PyThreadState_New(interp);
Victor Stinnerb45d2592019-06-20 00:05:23 +0200537 if (tstate == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200538 return _PyStatus_ERR("can't make first thread");
Victor Stinnerb45d2592019-06-20 00:05:23 +0200539 }
Nick Coghland6009512014-11-20 21:39:37 +1000540 (void) PyThreadState_Swap(tstate);
541
Victor Stinner99fcc612019-04-29 13:04:07 +0200542 /* We can't call _PyEval_FiniThreads() in Py_FinalizeEx because
543 destroying the GIL might fail when it is being referenced from
544 another running thread (see issue #9901).
Nick Coghland6009512014-11-20 21:39:37 +1000545 Instead we destroy the previously created GIL here, which ensures
Martin Panterb4ce1fc2015-11-30 03:18:29 +0000546 that we can call Py_Initialize / Py_FinalizeEx multiple times. */
Victor Stinner09532fe2019-05-10 23:39:09 +0200547 _PyEval_FiniThreads(&runtime->ceval);
Victor Stinner2914bb32018-01-29 11:57:45 +0100548
Nick Coghland6009512014-11-20 21:39:37 +1000549 /* Auto-thread-state API */
Victor Stinnerb45d2592019-06-20 00:05:23 +0200550 _PyGILState_Init(runtime, tstate);
Nick Coghland6009512014-11-20 21:39:37 +1000551
Victor Stinner2914bb32018-01-29 11:57:45 +0100552 /* Create the GIL */
553 PyEval_InitThreads();
554
Victor Stinnerb45d2592019-06-20 00:05:23 +0200555 *tstate_p = tstate;
Victor Stinner331a6a52019-05-27 16:39:22 +0200556 return _PyStatus_OK();
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100557}
Nick Coghland6009512014-11-20 21:39:37 +1000558
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100559
Victor Stinner331a6a52019-05-27 16:39:22 +0200560static PyStatus
Victor Stinner444b39b2019-11-20 01:18:11 +0100561pycore_init_types(_PyRuntimeState *runtime)
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100562{
Victor Stinner444b39b2019-11-20 01:18:11 +0100563 PyStatus status;
564
565 status = _PyGC_Init(runtime);
566 if (_PyStatus_EXCEPTION(status)) {
567 return status;
568 }
569
570 status = _PyTypes_Init();
Victor Stinner331a6a52019-05-27 16:39:22 +0200571 if (_PyStatus_EXCEPTION(status)) {
572 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100573 }
574
Victor Stinneref5aa9a2019-11-20 00:38:03 +0100575 if (!_PyLong_Init()) {
576 return _PyStatus_ERR("can't init longs");
577 }
578
Victor Stinner331a6a52019-05-27 16:39:22 +0200579 status = _PyUnicode_Init();
580 if (_PyStatus_EXCEPTION(status)) {
581 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100582 }
583
Victor Stinner331a6a52019-05-27 16:39:22 +0200584 status = _PyExc_Init();
585 if (_PyStatus_EXCEPTION(status)) {
586 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100587 }
588
589 if (!_PyFloat_Init()) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200590 return _PyStatus_ERR("can't init float");
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100591 }
Nick Coghland6009512014-11-20 21:39:37 +1000592
Victor Stinneref5aa9a2019-11-20 00:38:03 +0100593 if (_PyStructSequence_Init() < 0) {
594 return _PyStatus_ERR("can't initialize structseq");
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100595 }
Victor Stinneref9d9b62019-05-22 11:28:22 +0200596
Victor Stinner331a6a52019-05-27 16:39:22 +0200597 status = _PyErr_Init();
598 if (_PyStatus_EXCEPTION(status)) {
599 return status;
Victor Stinneref9d9b62019-05-22 11:28:22 +0200600 }
601
Victor Stinneref5aa9a2019-11-20 00:38:03 +0100602 if (!_PyContext_Init()) {
603 return _PyStatus_ERR("can't init context");
604 }
605
Victor Stinner331a6a52019-05-27 16:39:22 +0200606 return _PyStatus_OK();
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100607}
608
609
Victor Stinner331a6a52019-05-27 16:39:22 +0200610static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +0200611pycore_init_builtins(PyThreadState *tstate)
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100612{
Victor Stinnerb45d2592019-06-20 00:05:23 +0200613 PyInterpreterState *interp = tstate->interp;
614
615 PyObject *bimod = _PyBuiltin_Init(tstate);
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100616 if (bimod == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200617 return _PyStatus_ERR("can't initialize builtins modules");
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100618 }
619 _PyImport_FixupBuiltin(bimod, "builtins", interp->modules);
620
621 interp->builtins = PyModule_GetDict(bimod);
622 if (interp->builtins == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200623 return _PyStatus_ERR("can't initialize builtins dict");
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100624 }
625 Py_INCREF(interp->builtins);
626
Victor Stinner331a6a52019-05-27 16:39:22 +0200627 PyStatus status = _PyBuiltins_AddExceptions(bimod);
628 if (_PyStatus_EXCEPTION(status)) {
629 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100630 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200631 return _PyStatus_OK();
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100632}
633
634
Victor Stinner331a6a52019-05-27 16:39:22 +0200635static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +0200636pycore_init_import_warnings(PyThreadState *tstate, PyObject *sysmod)
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100637{
Victor Stinnerb45d2592019-06-20 00:05:23 +0200638 const PyConfig *config = &tstate->interp->config;
639
640 PyStatus status = _PyImport_Init(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200641 if (_PyStatus_EXCEPTION(status)) {
642 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800643 }
Nick Coghland6009512014-11-20 21:39:37 +1000644
Victor Stinnerb45d2592019-06-20 00:05:23 +0200645 status = _PyImportHooks_Init(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200646 if (_PyStatus_EXCEPTION(status)) {
647 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800648 }
Nick Coghland6009512014-11-20 21:39:37 +1000649
650 /* Initialize _warnings. */
Victor Stinner5d862462017-12-19 11:35:58 +0100651 if (_PyWarnings_Init() == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200652 return _PyStatus_ERR("can't initialize warnings");
Victor Stinner1f151112017-11-23 10:43:14 +0100653 }
Nick Coghland6009512014-11-20 21:39:37 +1000654
Victor Stinnerb45d2592019-06-20 00:05:23 +0200655 if (config->_install_importlib) {
Victor Stinner12f2f172019-09-26 15:51:50 +0200656 status = _PyConfig_WritePathConfig(config);
Victor Stinner331a6a52019-05-27 16:39:22 +0200657 if (_PyStatus_EXCEPTION(status)) {
658 return status;
Victor Stinnerb1147e42018-07-21 02:06:16 +0200659 }
660 }
661
Eric Snow1abcf672017-05-23 21:46:51 -0700662 /* This call sets up builtin and frozen import support */
Victor Stinnerb45d2592019-06-20 00:05:23 +0200663 if (config->_install_importlib) {
664 status = init_importlib(tstate, sysmod);
Victor Stinner331a6a52019-05-27 16:39:22 +0200665 if (_PyStatus_EXCEPTION(status)) {
666 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800667 }
Eric Snow1abcf672017-05-23 21:46:51 -0700668 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200669 return _PyStatus_OK();
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100670}
671
672
Victor Stinner331a6a52019-05-27 16:39:22 +0200673static PyStatus
674pyinit_config(_PyRuntimeState *runtime,
Victor Stinnerb45d2592019-06-20 00:05:23 +0200675 PyThreadState **tstate_p,
Victor Stinner331a6a52019-05-27 16:39:22 +0200676 const PyConfig *config)
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100677{
Victor Stinner331a6a52019-05-27 16:39:22 +0200678 _PyConfig_Write(config, runtime);
Victor Stinner20004952019-03-26 02:31:11 +0100679
Victor Stinner331a6a52019-05-27 16:39:22 +0200680 PyStatus status = pycore_init_runtime(runtime, config);
681 if (_PyStatus_EXCEPTION(status)) {
682 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100683 }
684
Victor Stinnerb45d2592019-06-20 00:05:23 +0200685 PyThreadState *tstate;
686 status = pycore_create_interpreter(runtime, config, &tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200687 if (_PyStatus_EXCEPTION(status)) {
688 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100689 }
Victor Stinnerb45d2592019-06-20 00:05:23 +0200690 config = &tstate->interp->config;
691 *tstate_p = tstate;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100692
Victor Stinner444b39b2019-11-20 01:18:11 +0100693 status = pycore_init_types(runtime);
Victor Stinner331a6a52019-05-27 16:39:22 +0200694 if (_PyStatus_EXCEPTION(status)) {
695 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100696 }
697
698 PyObject *sysmod;
Victor Stinnerb45d2592019-06-20 00:05:23 +0200699 status = _PySys_Create(runtime, tstate, &sysmod);
Victor Stinner331a6a52019-05-27 16:39:22 +0200700 if (_PyStatus_EXCEPTION(status)) {
701 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100702 }
703
Victor Stinnerb45d2592019-06-20 00:05:23 +0200704 status = pycore_init_builtins(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200705 if (_PyStatus_EXCEPTION(status)) {
706 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100707 }
708
Victor Stinnerb45d2592019-06-20 00:05:23 +0200709 status = pycore_init_import_warnings(tstate, sysmod);
Victor Stinner331a6a52019-05-27 16:39:22 +0200710 if (_PyStatus_EXCEPTION(status)) {
711 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100712 }
Eric Snow1abcf672017-05-23 21:46:51 -0700713
714 /* Only when we get here is the runtime core fully initialized */
Victor Stinner43125222019-04-24 18:23:53 +0200715 runtime->core_initialized = 1;
Victor Stinner331a6a52019-05-27 16:39:22 +0200716 return _PyStatus_OK();
Eric Snow1abcf672017-05-23 21:46:51 -0700717}
718
Victor Stinner7d2ef3e2019-03-06 00:36:56 +0100719
Victor Stinner331a6a52019-05-27 16:39:22 +0200720PyStatus
721_Py_PreInitializeFromPyArgv(const PyPreConfig *src_config, const _PyArgv *args)
Victor Stinnerf29084d2019-03-20 02:20:13 +0100722{
Victor Stinner331a6a52019-05-27 16:39:22 +0200723 PyStatus status;
Victor Stinnerf29084d2019-03-20 02:20:13 +0100724
Victor Stinner6d1c4672019-05-20 11:02:00 +0200725 if (src_config == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200726 return _PyStatus_ERR("preinitialization config is NULL");
Victor Stinner6d1c4672019-05-20 11:02:00 +0200727 }
728
Victor Stinner331a6a52019-05-27 16:39:22 +0200729 status = _PyRuntime_Initialize();
730 if (_PyStatus_EXCEPTION(status)) {
731 return status;
Victor Stinner7d2ef3e2019-03-06 00:36:56 +0100732 }
Victor Stinner43125222019-04-24 18:23:53 +0200733 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinner7d2ef3e2019-03-06 00:36:56 +0100734
Victor Stinnerd3b90412019-09-17 23:59:51 +0200735 if (runtime->preinitialized) {
Victor Stinnerf72346c2019-03-25 17:54:58 +0100736 /* If it's already configured: ignored the new configuration */
Victor Stinner331a6a52019-05-27 16:39:22 +0200737 return _PyStatus_OK();
Victor Stinnera6fbc4e2019-03-25 18:37:10 +0100738 }
739
Victor Stinnerd3b90412019-09-17 23:59:51 +0200740 /* Note: preinitialized remains 1 on error, it is only set to 0
741 at exit on success. */
742 runtime->preinitializing = 1;
743
Victor Stinner331a6a52019-05-27 16:39:22 +0200744 PyPreConfig config;
Victor Stinner441b10c2019-09-28 04:28:35 +0200745
746 status = _PyPreConfig_InitFromPreConfig(&config, src_config);
747 if (_PyStatus_EXCEPTION(status)) {
748 return status;
749 }
Victor Stinnerf72346c2019-03-25 17:54:58 +0100750
Victor Stinner331a6a52019-05-27 16:39:22 +0200751 status = _PyPreConfig_Read(&config, args);
752 if (_PyStatus_EXCEPTION(status)) {
753 return status;
Victor Stinnerf29084d2019-03-20 02:20:13 +0100754 }
755
Victor Stinner331a6a52019-05-27 16:39:22 +0200756 status = _PyPreConfig_Write(&config);
757 if (_PyStatus_EXCEPTION(status)) {
758 return status;
Victor Stinnerf72346c2019-03-25 17:54:58 +0100759 }
760
Victor Stinnerd3b90412019-09-17 23:59:51 +0200761 runtime->preinitializing = 0;
762 runtime->preinitialized = 1;
Victor Stinner331a6a52019-05-27 16:39:22 +0200763 return _PyStatus_OK();
Victor Stinnerf72346c2019-03-25 17:54:58 +0100764}
765
Victor Stinner70005ac2019-05-02 15:25:34 -0400766
Victor Stinner331a6a52019-05-27 16:39:22 +0200767PyStatus
768Py_PreInitializeFromBytesArgs(const PyPreConfig *src_config, Py_ssize_t argc, char **argv)
Victor Stinnerf72346c2019-03-25 17:54:58 +0100769{
Victor Stinner5ac27a52019-03-27 13:40:14 +0100770 _PyArgv args = {.use_bytes_argv = 1, .argc = argc, .bytes_argv = argv};
Victor Stinner70005ac2019-05-02 15:25:34 -0400771 return _Py_PreInitializeFromPyArgv(src_config, &args);
Victor Stinnerf29084d2019-03-20 02:20:13 +0100772}
773
774
Victor Stinner331a6a52019-05-27 16:39:22 +0200775PyStatus
776Py_PreInitializeFromArgs(const PyPreConfig *src_config, Py_ssize_t argc, wchar_t **argv)
Victor Stinner20004952019-03-26 02:31:11 +0100777{
Victor Stinner5ac27a52019-03-27 13:40:14 +0100778 _PyArgv args = {.use_bytes_argv = 0, .argc = argc, .wchar_argv = argv};
Victor Stinner70005ac2019-05-02 15:25:34 -0400779 return _Py_PreInitializeFromPyArgv(src_config, &args);
Victor Stinner20004952019-03-26 02:31:11 +0100780}
781
782
Victor Stinner331a6a52019-05-27 16:39:22 +0200783PyStatus
784Py_PreInitialize(const PyPreConfig *src_config)
Victor Stinnera6fbc4e2019-03-25 18:37:10 +0100785{
Victor Stinner70005ac2019-05-02 15:25:34 -0400786 return _Py_PreInitializeFromPyArgv(src_config, NULL);
Victor Stinnera6fbc4e2019-03-25 18:37:10 +0100787}
788
789
Victor Stinner331a6a52019-05-27 16:39:22 +0200790PyStatus
791_Py_PreInitializeFromConfig(const PyConfig *config,
792 const _PyArgv *args)
Victor Stinnerf29084d2019-03-20 02:20:13 +0100793{
Victor Stinner331a6a52019-05-27 16:39:22 +0200794 assert(config != NULL);
Victor Stinner6d1c4672019-05-20 11:02:00 +0200795
Victor Stinner331a6a52019-05-27 16:39:22 +0200796 PyStatus status = _PyRuntime_Initialize();
797 if (_PyStatus_EXCEPTION(status)) {
798 return status;
Victor Stinner6d1c4672019-05-20 11:02:00 +0200799 }
800 _PyRuntimeState *runtime = &_PyRuntime;
801
Victor Stinnerd3b90412019-09-17 23:59:51 +0200802 if (runtime->preinitialized) {
Victor Stinner6d1c4672019-05-20 11:02:00 +0200803 /* Already initialized: do nothing */
Victor Stinner331a6a52019-05-27 16:39:22 +0200804 return _PyStatus_OK();
Victor Stinner70005ac2019-05-02 15:25:34 -0400805 }
Victor Stinnercab5d072019-05-17 19:01:14 +0200806
Victor Stinner331a6a52019-05-27 16:39:22 +0200807 PyPreConfig preconfig;
Victor Stinner441b10c2019-09-28 04:28:35 +0200808
Victor Stinner3c30a762019-10-01 10:56:37 +0200809 _PyPreConfig_InitFromConfig(&preconfig, config);
Victor Stinner6d1c4672019-05-20 11:02:00 +0200810
Victor Stinner331a6a52019-05-27 16:39:22 +0200811 if (!config->parse_argv) {
812 return Py_PreInitialize(&preconfig);
Victor Stinner6d1c4672019-05-20 11:02:00 +0200813 }
814 else if (args == NULL) {
Victor Stinnercab5d072019-05-17 19:01:14 +0200815 _PyArgv config_args = {
816 .use_bytes_argv = 0,
Victor Stinner331a6a52019-05-27 16:39:22 +0200817 .argc = config->argv.length,
818 .wchar_argv = config->argv.items};
Victor Stinner6d1c4672019-05-20 11:02:00 +0200819 return _Py_PreInitializeFromPyArgv(&preconfig, &config_args);
Victor Stinnercab5d072019-05-17 19:01:14 +0200820 }
821 else {
Victor Stinner6d1c4672019-05-20 11:02:00 +0200822 return _Py_PreInitializeFromPyArgv(&preconfig, args);
Victor Stinnercab5d072019-05-17 19:01:14 +0200823 }
Victor Stinner7d2ef3e2019-03-06 00:36:56 +0100824}
825
826
Victor Stinner6d43f6f2019-01-22 21:18:05 +0100827/* Begin interpreter initialization
828 *
829 * On return, the first thread and interpreter state have been created,
830 * but the compiler, signal handling, multithreading and
831 * multiple interpreter support, and codec infrastructure are not yet
832 * available.
833 *
834 * The import system will support builtin and frozen modules only.
835 * The only supported io is writing to sys.stderr
836 *
837 * If any operation invoked by this function fails, a fatal error is
838 * issued and the function does not return.
839 *
840 * Any code invoked from this function should *not* assume it has access
841 * to the Python C API (unless the API is explicitly listed as being
842 * safe to call without calling Py_Initialize first)
843 */
Victor Stinner331a6a52019-05-27 16:39:22 +0200844static PyStatus
Victor Stinner5edcf262019-05-23 00:57:57 +0200845pyinit_core(_PyRuntimeState *runtime,
Victor Stinner331a6a52019-05-27 16:39:22 +0200846 const PyConfig *src_config,
Victor Stinnerb45d2592019-06-20 00:05:23 +0200847 PyThreadState **tstate_p)
Victor Stinner1dc6e392018-07-25 02:49:17 +0200848{
Victor Stinner331a6a52019-05-27 16:39:22 +0200849 PyStatus status;
Victor Stinner1dc6e392018-07-25 02:49:17 +0200850
Victor Stinner331a6a52019-05-27 16:39:22 +0200851 status = _Py_PreInitializeFromConfig(src_config, NULL);
852 if (_PyStatus_EXCEPTION(status)) {
853 return status;
Victor Stinner1dc6e392018-07-25 02:49:17 +0200854 }
855
Victor Stinner331a6a52019-05-27 16:39:22 +0200856 PyConfig config;
Victor Stinner8462a492019-10-01 12:06:16 +0200857 _PyConfig_InitCompatConfig(&config);
Victor Stinner5edcf262019-05-23 00:57:57 +0200858
Victor Stinner331a6a52019-05-27 16:39:22 +0200859 status = _PyConfig_Copy(&config, src_config);
860 if (_PyStatus_EXCEPTION(status)) {
Victor Stinner5edcf262019-05-23 00:57:57 +0200861 goto done;
862 }
863
Victor Stinner331a6a52019-05-27 16:39:22 +0200864 status = PyConfig_Read(&config);
865 if (_PyStatus_EXCEPTION(status)) {
Victor Stinner5edcf262019-05-23 00:57:57 +0200866 goto done;
867 }
868
869 if (!runtime->core_initialized) {
Victor Stinnerb45d2592019-06-20 00:05:23 +0200870 status = pyinit_config(runtime, tstate_p, &config);
Victor Stinner5edcf262019-05-23 00:57:57 +0200871 }
872 else {
Victor Stinnerb45d2592019-06-20 00:05:23 +0200873 status = pyinit_core_reconfigure(runtime, tstate_p, &config);
Victor Stinner5edcf262019-05-23 00:57:57 +0200874 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200875 if (_PyStatus_EXCEPTION(status)) {
Victor Stinner5edcf262019-05-23 00:57:57 +0200876 goto done;
877 }
878
879done:
Victor Stinner331a6a52019-05-27 16:39:22 +0200880 PyConfig_Clear(&config);
881 return status;
Victor Stinner1dc6e392018-07-25 02:49:17 +0200882}
883
Victor Stinner5ac27a52019-03-27 13:40:14 +0100884
Victor Stinnerfb47bca2018-07-20 17:34:23 +0200885/* Py_Initialize() has already been called: update the main interpreter
886 configuration. Example of bpo-34008: Py_Main() called after
887 Py_Initialize(). */
Victor Stinner331a6a52019-05-27 16:39:22 +0200888static PyStatus
Victor Stinner8b9dbc02019-03-27 01:36:16 +0100889_Py_ReconfigureMainInterpreter(PyInterpreterState *interp)
Victor Stinnerfb47bca2018-07-20 17:34:23 +0200890{
Victor Stinner331a6a52019-05-27 16:39:22 +0200891 PyConfig *config = &interp->config;
Victor Stinner8b9dbc02019-03-27 01:36:16 +0100892
Victor Stinner331a6a52019-05-27 16:39:22 +0200893 PyObject *argv = _PyWideStringList_AsList(&config->argv);
Victor Stinner8b9dbc02019-03-27 01:36:16 +0100894 if (argv == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200895 return _PyStatus_NO_MEMORY(); \
Victor Stinner8b9dbc02019-03-27 01:36:16 +0100896 }
897
898 int res = PyDict_SetItemString(interp->sysdict, "argv", argv);
899 Py_DECREF(argv);
900 if (res < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200901 return _PyStatus_ERR("fail to set sys.argv");
Victor Stinnerfb47bca2018-07-20 17:34:23 +0200902 }
Victor Stinner331a6a52019-05-27 16:39:22 +0200903 return _PyStatus_OK();
Victor Stinnerfb47bca2018-07-20 17:34:23 +0200904}
905
Eric Snowc7ec9982017-05-23 23:00:52 -0700906/* Update interpreter state based on supplied configuration settings
907 *
908 * After calling this function, most of the restrictions on the interpreter
909 * are lifted. The only remaining incomplete settings are those related
910 * to the main module (sys.argv[0], __main__ metadata)
911 *
912 * Calling this when the interpreter is not initializing, is already
913 * initialized or without a valid current thread state is a fatal error.
914 * Other errors should be reported as normal Python exceptions with a
915 * non-zero return code.
916 */
Victor Stinner331a6a52019-05-27 16:39:22 +0200917static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +0200918pyinit_main(_PyRuntimeState *runtime, PyThreadState *tstate)
Eric Snow1abcf672017-05-23 21:46:51 -0700919{
Victor Stinner43125222019-04-24 18:23:53 +0200920 if (!runtime->core_initialized) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200921 return _PyStatus_ERR("runtime core not initialized");
Eric Snowc7ec9982017-05-23 23:00:52 -0700922 }
Eric Snowc7ec9982017-05-23 23:00:52 -0700923
Victor Stinner1dc6e392018-07-25 02:49:17 +0200924 /* Configure the main interpreter */
Victor Stinnerb45d2592019-06-20 00:05:23 +0200925 PyInterpreterState *interp = tstate->interp;
Victor Stinner331a6a52019-05-27 16:39:22 +0200926 PyConfig *config = &interp->config;
Eric Snowc7ec9982017-05-23 23:00:52 -0700927
Victor Stinner43125222019-04-24 18:23:53 +0200928 if (runtime->initialized) {
Victor Stinner8b9dbc02019-03-27 01:36:16 +0100929 return _Py_ReconfigureMainInterpreter(interp);
Victor Stinnerfb47bca2018-07-20 17:34:23 +0200930 }
931
Victor Stinner331a6a52019-05-27 16:39:22 +0200932 if (!config->_install_importlib) {
Eric Snow1abcf672017-05-23 21:46:51 -0700933 /* Special mode for freeze_importlib: run with no import system
934 *
935 * This means anything which needs support from extension modules
936 * or pure Python code in the standard library won't work.
937 */
Victor Stinner43125222019-04-24 18:23:53 +0200938 runtime->initialized = 1;
Victor Stinner331a6a52019-05-27 16:39:22 +0200939 return _PyStatus_OK();
Eric Snow1abcf672017-05-23 21:46:51 -0700940 }
Victor Stinner9316ee42017-11-25 03:17:57 +0100941
Victor Stinner33c377e2017-12-05 15:12:41 +0100942 if (_PyTime_Init() < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200943 return _PyStatus_ERR("can't initialize time");
Victor Stinner33c377e2017-12-05 15:12:41 +0100944 }
Victor Stinner13019fd2015-04-03 13:10:54 +0200945
Victor Stinner838f2642019-06-13 22:41:23 +0200946 if (_PySys_InitMain(runtime, tstate) < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +0200947 return _PyStatus_ERR("can't finish initializing sys");
Victor Stinnerda273412017-12-15 01:46:02 +0100948 }
Victor Stinnera7368ac2017-11-15 18:11:45 -0800949
Victor Stinner0a28f8d2019-06-19 02:54:39 +0200950 PyStatus status = init_importlib_external(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200951 if (_PyStatus_EXCEPTION(status)) {
952 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800953 }
Nick Coghland6009512014-11-20 21:39:37 +1000954
955 /* initialize the faulthandler module */
Victor Stinner331a6a52019-05-27 16:39:22 +0200956 status = _PyFaulthandler_Init(config->faulthandler);
957 if (_PyStatus_EXCEPTION(status)) {
958 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800959 }
Nick Coghland6009512014-11-20 21:39:37 +1000960
Victor Stinnerb45d2592019-06-20 00:05:23 +0200961 status = _PyUnicode_InitEncodings(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200962 if (_PyStatus_EXCEPTION(status)) {
963 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800964 }
Nick Coghland6009512014-11-20 21:39:37 +1000965
Victor Stinner331a6a52019-05-27 16:39:22 +0200966 if (config->install_signal_handlers) {
Victor Stinnerb45d2592019-06-20 00:05:23 +0200967 status = init_signals(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200968 if (_PyStatus_EXCEPTION(status)) {
969 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800970 }
971 }
Nick Coghland6009512014-11-20 21:39:37 +1000972
Victor Stinner331a6a52019-05-27 16:39:22 +0200973 if (_PyTraceMalloc_Init(config->tracemalloc) < 0) {
974 return _PyStatus_ERR("can't initialize tracemalloc");
Victor Stinnerd19d8d52018-07-24 13:55:48 +0200975 }
Nick Coghland6009512014-11-20 21:39:37 +1000976
Victor Stinner331a6a52019-05-27 16:39:22 +0200977 status = add_main_module(interp);
978 if (_PyStatus_EXCEPTION(status)) {
979 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800980 }
Victor Stinnera7368ac2017-11-15 18:11:45 -0800981
Victor Stinnerb45d2592019-06-20 00:05:23 +0200982 status = init_sys_streams(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +0200983 if (_PyStatus_EXCEPTION(status)) {
984 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -0800985 }
Nick Coghland6009512014-11-20 21:39:37 +1000986
987 /* Initialize warnings. */
Victor Stinner37cd9822018-11-16 11:55:35 +0100988 PyObject *warnoptions = PySys_GetObject("warnoptions");
989 if (warnoptions != NULL && PyList_Size(warnoptions) > 0)
Victor Stinner5d862462017-12-19 11:35:58 +0100990 {
Nick Coghland6009512014-11-20 21:39:37 +1000991 PyObject *warnings_module = PyImport_ImportModule("warnings");
992 if (warnings_module == NULL) {
993 fprintf(stderr, "'import warnings' failed; traceback:\n");
Victor Stinnerb45d2592019-06-20 00:05:23 +0200994 _PyErr_Print(tstate);
Nick Coghland6009512014-11-20 21:39:37 +1000995 }
996 Py_XDECREF(warnings_module);
997 }
998
Victor Stinner43125222019-04-24 18:23:53 +0200999 runtime->initialized = 1;
Eric Snow1abcf672017-05-23 21:46:51 -07001000
Victor Stinner331a6a52019-05-27 16:39:22 +02001001 if (config->site_import) {
Victor Stinnerb45d2592019-06-20 00:05:23 +02001002 status = init_import_site();
Victor Stinner331a6a52019-05-27 16:39:22 +02001003 if (_PyStatus_EXCEPTION(status)) {
1004 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001005 }
1006 }
Victor Stinnercf215042018-08-29 22:56:06 +02001007
1008#ifndef MS_WINDOWS
Victor Stinner43125222019-04-24 18:23:53 +02001009 emit_stderr_warning_for_legacy_locale(runtime);
Victor Stinnercf215042018-08-29 22:56:06 +02001010#endif
1011
Victor Stinner331a6a52019-05-27 16:39:22 +02001012 return _PyStatus_OK();
Nick Coghland6009512014-11-20 21:39:37 +10001013}
1014
Victor Stinner9ef5dca2019-05-16 17:38:16 +02001015
Victor Stinner331a6a52019-05-27 16:39:22 +02001016PyStatus
Victor Stinner9ef5dca2019-05-16 17:38:16 +02001017_Py_InitializeMain(void)
1018{
Victor Stinner331a6a52019-05-27 16:39:22 +02001019 PyStatus status = _PyRuntime_Initialize();
1020 if (_PyStatus_EXCEPTION(status)) {
1021 return status;
Victor Stinner9ef5dca2019-05-16 17:38:16 +02001022 }
1023 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnerb45d2592019-06-20 00:05:23 +02001024 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
1025 return pyinit_main(runtime, tstate);
Victor Stinner9ef5dca2019-05-16 17:38:16 +02001026}
1027
1028
Victor Stinner331a6a52019-05-27 16:39:22 +02001029PyStatus
1030Py_InitializeFromConfig(const PyConfig *config)
Eric Snow1abcf672017-05-23 21:46:51 -07001031{
Victor Stinner6d1c4672019-05-20 11:02:00 +02001032 if (config == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001033 return _PyStatus_ERR("initialization config is NULL");
Victor Stinner6d1c4672019-05-20 11:02:00 +02001034 }
1035
Victor Stinner331a6a52019-05-27 16:39:22 +02001036 PyStatus status;
Victor Stinner43125222019-04-24 18:23:53 +02001037
Victor Stinner331a6a52019-05-27 16:39:22 +02001038 status = _PyRuntime_Initialize();
1039 if (_PyStatus_EXCEPTION(status)) {
1040 return status;
Victor Stinner43125222019-04-24 18:23:53 +02001041 }
1042 _PyRuntimeState *runtime = &_PyRuntime;
1043
Victor Stinnerb45d2592019-06-20 00:05:23 +02001044 PyThreadState *tstate = NULL;
1045 status = pyinit_core(runtime, config, &tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +02001046 if (_PyStatus_EXCEPTION(status)) {
1047 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001048 }
Victor Stinnerb45d2592019-06-20 00:05:23 +02001049 config = &tstate->interp->config;
Victor Stinnerbc8ac6b2017-11-30 18:03:55 +01001050
Victor Stinner9ef5dca2019-05-16 17:38:16 +02001051 if (config->_init_main) {
Victor Stinnerb45d2592019-06-20 00:05:23 +02001052 status = pyinit_main(runtime, tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +02001053 if (_PyStatus_EXCEPTION(status)) {
1054 return status;
Victor Stinner484f20d2019-03-27 02:04:16 +01001055 }
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001056 }
Victor Stinner484f20d2019-03-27 02:04:16 +01001057
Victor Stinner331a6a52019-05-27 16:39:22 +02001058 return _PyStatus_OK();
Victor Stinner5ac27a52019-03-27 13:40:14 +01001059}
1060
1061
Eric Snow1abcf672017-05-23 21:46:51 -07001062void
Nick Coghland6009512014-11-20 21:39:37 +10001063Py_InitializeEx(int install_sigs)
1064{
Victor Stinner331a6a52019-05-27 16:39:22 +02001065 PyStatus status;
Victor Stinner43125222019-04-24 18:23:53 +02001066
Victor Stinner331a6a52019-05-27 16:39:22 +02001067 status = _PyRuntime_Initialize();
1068 if (_PyStatus_EXCEPTION(status)) {
1069 Py_ExitStatusException(status);
Victor Stinner43125222019-04-24 18:23:53 +02001070 }
1071 _PyRuntimeState *runtime = &_PyRuntime;
1072
1073 if (runtime->initialized) {
Victor Stinner1dc6e392018-07-25 02:49:17 +02001074 /* bpo-33932: Calling Py_Initialize() twice does nothing. */
1075 return;
1076 }
1077
Victor Stinner331a6a52019-05-27 16:39:22 +02001078 PyConfig config;
Victor Stinner8462a492019-10-01 12:06:16 +02001079 _PyConfig_InitCompatConfig(&config);
Victor Stinner441b10c2019-09-28 04:28:35 +02001080
Victor Stinner1dc6e392018-07-25 02:49:17 +02001081 config.install_signal_handlers = install_sigs;
1082
Victor Stinner331a6a52019-05-27 16:39:22 +02001083 status = Py_InitializeFromConfig(&config);
1084 if (_PyStatus_EXCEPTION(status)) {
1085 Py_ExitStatusException(status);
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001086 }
Nick Coghland6009512014-11-20 21:39:37 +10001087}
1088
1089void
1090Py_Initialize(void)
1091{
1092 Py_InitializeEx(1);
1093}
1094
1095
1096#ifdef COUNT_ALLOCS
Pablo Galindo49c75a82018-10-28 15:02:17 +00001097extern void _Py_dump_counts(FILE*);
Nick Coghland6009512014-11-20 21:39:37 +10001098#endif
1099
1100/* Flush stdout and stderr */
1101
1102static int
1103file_is_closed(PyObject *fobj)
1104{
1105 int r;
1106 PyObject *tmp = PyObject_GetAttrString(fobj, "closed");
1107 if (tmp == NULL) {
1108 PyErr_Clear();
1109 return 0;
1110 }
1111 r = PyObject_IsTrue(tmp);
1112 Py_DECREF(tmp);
1113 if (r < 0)
1114 PyErr_Clear();
1115 return r > 0;
1116}
1117
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001118static int
Nick Coghland6009512014-11-20 21:39:37 +10001119flush_std_files(void)
1120{
1121 PyObject *fout = _PySys_GetObjectId(&PyId_stdout);
1122 PyObject *ferr = _PySys_GetObjectId(&PyId_stderr);
1123 PyObject *tmp;
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001124 int status = 0;
Nick Coghland6009512014-11-20 21:39:37 +10001125
1126 if (fout != NULL && fout != Py_None && !file_is_closed(fout)) {
Jeroen Demeyer762f93f2019-07-08 10:19:25 +02001127 tmp = _PyObject_CallMethodIdNoArgs(fout, &PyId_flush);
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001128 if (tmp == NULL) {
Nick Coghland6009512014-11-20 21:39:37 +10001129 PyErr_WriteUnraisable(fout);
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001130 status = -1;
1131 }
Nick Coghland6009512014-11-20 21:39:37 +10001132 else
1133 Py_DECREF(tmp);
1134 }
1135
1136 if (ferr != NULL && ferr != Py_None && !file_is_closed(ferr)) {
Jeroen Demeyer762f93f2019-07-08 10:19:25 +02001137 tmp = _PyObject_CallMethodIdNoArgs(ferr, &PyId_flush);
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001138 if (tmp == NULL) {
Nick Coghland6009512014-11-20 21:39:37 +10001139 PyErr_Clear();
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001140 status = -1;
1141 }
Nick Coghland6009512014-11-20 21:39:37 +10001142 else
1143 Py_DECREF(tmp);
1144 }
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001145
1146 return status;
Nick Coghland6009512014-11-20 21:39:37 +10001147}
1148
1149/* Undo the effect of Py_Initialize().
1150
1151 Beware: if multiple interpreter and/or thread states exist, these
1152 are not wiped out; only the current thread and interpreter state
1153 are deleted. But since everything else is deleted, those other
1154 interpreter and thread states should no longer be used.
1155
1156 (XXX We should do better, e.g. wipe out all interpreters and
1157 threads.)
1158
1159 Locking: as above.
1160
1161*/
1162
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001163int
1164Py_FinalizeEx(void)
Nick Coghland6009512014-11-20 21:39:37 +10001165{
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001166 int status = 0;
Nick Coghland6009512014-11-20 21:39:37 +10001167
Victor Stinner8e91c242019-04-24 17:24:01 +02001168 _PyRuntimeState *runtime = &_PyRuntime;
1169 if (!runtime->initialized) {
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001170 return status;
Victor Stinner8e91c242019-04-24 17:24:01 +02001171 }
Nick Coghland6009512014-11-20 21:39:37 +10001172
Victor Stinnere225beb2019-06-03 18:14:24 +02001173 /* Get current thread state and interpreter pointer */
1174 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
1175 PyInterpreterState *interp = tstate->interp;
Victor Stinner8e91c242019-04-24 17:24:01 +02001176
Victor Stinnerb45d2592019-06-20 00:05:23 +02001177 // Wrap up existing "threading"-module-created, non-daemon threads.
1178 wait_for_thread_shutdown(tstate);
1179
1180 // Make any remaining pending calls.
1181 _Py_FinishPendingCalls(runtime);
1182
Nick Coghland6009512014-11-20 21:39:37 +10001183 /* The interpreter is still entirely intact at this point, and the
1184 * exit funcs may be relying on that. In particular, if some thread
1185 * or exit func is still waiting to do an import, the import machinery
1186 * expects Py_IsInitialized() to return true. So don't say the
Eric Snow842a2f02019-03-15 15:47:51 -06001187 * runtime is uninitialized until after the exit funcs have run.
Nick Coghland6009512014-11-20 21:39:37 +10001188 * Note that Threading.py uses an exit func to do a join on all the
1189 * threads created thru it, so this also protects pending imports in
1190 * the threads created via Threading.
1191 */
Nick Coghland6009512014-11-20 21:39:37 +10001192
Victor Stinnerb45d2592019-06-20 00:05:23 +02001193 call_py_exitfuncs(tstate);
Nick Coghland6009512014-11-20 21:39:37 +10001194
Victor Stinnerda273412017-12-15 01:46:02 +01001195 /* Copy the core config, PyInterpreterState_Delete() free
1196 the core config memory */
Victor Stinner5d862462017-12-19 11:35:58 +01001197#ifdef Py_REF_DEBUG
Victor Stinner331a6a52019-05-27 16:39:22 +02001198 int show_ref_count = interp->config.show_ref_count;
Victor Stinner5d862462017-12-19 11:35:58 +01001199#endif
1200#ifdef Py_TRACE_REFS
Victor Stinner331a6a52019-05-27 16:39:22 +02001201 int dump_refs = interp->config.dump_refs;
Victor Stinner5d862462017-12-19 11:35:58 +01001202#endif
1203#ifdef WITH_PYMALLOC
Victor Stinner331a6a52019-05-27 16:39:22 +02001204 int malloc_stats = interp->config.malloc_stats;
Victor Stinner5d862462017-12-19 11:35:58 +01001205#endif
Victor Stinner6bf992a2017-12-06 17:26:10 +01001206
Nick Coghland6009512014-11-20 21:39:37 +10001207 /* Remaining threads (e.g. daemon threads) will automatically exit
1208 after taking the GIL (in PyEval_RestoreThread()). */
Victor Stinner8e91c242019-04-24 17:24:01 +02001209 runtime->finalizing = tstate;
1210 runtime->initialized = 0;
1211 runtime->core_initialized = 0;
Nick Coghland6009512014-11-20 21:39:37 +10001212
Victor Stinnere0deff32015-03-24 13:46:18 +01001213 /* Flush sys.stdout and sys.stderr */
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001214 if (flush_std_files() < 0) {
1215 status = -1;
1216 }
Nick Coghland6009512014-11-20 21:39:37 +10001217
1218 /* Disable signal handling */
1219 PyOS_FiniInterrupts();
1220
1221 /* Collect garbage. This may call finalizers; it's nice to call these
1222 * before all modules are destroyed.
1223 * XXX If a __del__ or weakref callback is triggered here, and tries to
1224 * XXX import a module, bad things can happen, because Python no
1225 * XXX longer believes it's initialized.
1226 * XXX Fatal Python error: Interpreter not initialized (version mismatch?)
1227 * XXX is easy to provoke that way. I've also seen, e.g.,
1228 * XXX Exception exceptions.ImportError: 'No module named sha'
1229 * XXX in <function callback at 0x008F5718> ignored
1230 * XXX but I'm unclear on exactly how that one happens. In any case,
1231 * XXX I haven't seen a real-life report of either of these.
1232 */
Łukasz Langafef7e942016-09-09 21:47:46 -07001233 _PyGC_CollectIfEnabled();
Nick Coghland6009512014-11-20 21:39:37 +10001234#ifdef COUNT_ALLOCS
1235 /* With COUNT_ALLOCS, it helps to run GC multiple times:
1236 each collection might release some types from the type
1237 list, so they become garbage. */
Łukasz Langafef7e942016-09-09 21:47:46 -07001238 while (_PyGC_CollectIfEnabled() > 0)
Nick Coghland6009512014-11-20 21:39:37 +10001239 /* nothing */;
1240#endif
Eric Snowdae02762017-09-14 00:35:58 -07001241
Steve Dowerb82e17e2019-05-23 08:45:22 -07001242 /* Clear all loghooks */
1243 /* We want minimal exposure of this function, so define the extern
1244 * here. The linker should discover the correct function without
1245 * exporting a symbol. */
1246 extern void _PySys_ClearAuditHooks(void);
1247 _PySys_ClearAuditHooks();
1248
Nick Coghland6009512014-11-20 21:39:37 +10001249 /* Destroy all modules */
Victor Stinner987a0dc2019-06-19 10:36:10 +02001250 _PyImport_Cleanup(tstate);
Nick Coghland6009512014-11-20 21:39:37 +10001251
Inada Naoki91234a12019-06-03 21:30:58 +09001252 /* Print debug stats if any */
1253 _PyEval_Fini();
1254
Victor Stinnere0deff32015-03-24 13:46:18 +01001255 /* Flush sys.stdout and sys.stderr (again, in case more was printed) */
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001256 if (flush_std_files() < 0) {
1257 status = -1;
1258 }
Nick Coghland6009512014-11-20 21:39:37 +10001259
1260 /* Collect final garbage. This disposes of cycles created by
1261 * class definitions, for example.
1262 * XXX This is disabled because it caused too many problems. If
1263 * XXX a __del__ or weakref callback triggers here, Python code has
1264 * XXX a hard time running, because even the sys module has been
1265 * XXX cleared out (sys.stdout is gone, sys.excepthook is gone, etc).
1266 * XXX One symptom is a sequence of information-free messages
1267 * XXX coming from threads (if a __del__ or callback is invoked,
1268 * XXX other threads can execute too, and any exception they encounter
1269 * XXX triggers a comedy of errors as subsystem after subsystem
1270 * XXX fails to find what it *expects* to find in sys to help report
1271 * XXX the exception and consequent unexpected failures). I've also
1272 * XXX seen segfaults then, after adding print statements to the
1273 * XXX Python code getting called.
1274 */
1275#if 0
Łukasz Langafef7e942016-09-09 21:47:46 -07001276 _PyGC_CollectIfEnabled();
Nick Coghland6009512014-11-20 21:39:37 +10001277#endif
1278
1279 /* Disable tracemalloc after all Python objects have been destroyed,
1280 so it is possible to use tracemalloc in objects destructor. */
1281 _PyTraceMalloc_Fini();
1282
1283 /* Destroy the database used by _PyImport_{Fixup,Find}Extension */
1284 _PyImport_Fini();
1285
1286 /* Cleanup typeobject.c's internal caches. */
1287 _PyType_Fini();
1288
1289 /* unload faulthandler module */
1290 _PyFaulthandler_Fini();
1291
1292 /* Debugging stuff */
1293#ifdef COUNT_ALLOCS
Pablo Galindo49c75a82018-10-28 15:02:17 +00001294 _Py_dump_counts(stderr);
Nick Coghland6009512014-11-20 21:39:37 +10001295#endif
1296 /* dump hash stats */
1297 _PyHash_Fini();
1298
Eric Snowdae02762017-09-14 00:35:58 -07001299#ifdef Py_REF_DEBUG
Victor Stinnerda273412017-12-15 01:46:02 +01001300 if (show_ref_count) {
Victor Stinner25420fe2017-11-20 18:12:22 -08001301 _PyDebug_PrintTotalRefs();
1302 }
Eric Snowdae02762017-09-14 00:35:58 -07001303#endif
Nick Coghland6009512014-11-20 21:39:37 +10001304
1305#ifdef Py_TRACE_REFS
1306 /* Display all objects still alive -- this can invoke arbitrary
1307 * __repr__ overrides, so requires a mostly-intact interpreter.
1308 * Alas, a lot of stuff may still be alive now that will be cleaned
1309 * up later.
1310 */
Victor Stinnerda273412017-12-15 01:46:02 +01001311 if (dump_refs) {
Nick Coghland6009512014-11-20 21:39:37 +10001312 _Py_PrintReferences(stderr);
Victor Stinner6bf992a2017-12-06 17:26:10 +01001313 }
Nick Coghland6009512014-11-20 21:39:37 +10001314#endif /* Py_TRACE_REFS */
1315
1316 /* Clear interpreter state and all thread states. */
1317 PyInterpreterState_Clear(interp);
1318
1319 /* Now we decref the exception classes. After this point nothing
1320 can raise an exception. That's okay, because each Fini() method
1321 below has been checked to make sure no exceptions are ever
1322 raised.
1323 */
1324
1325 _PyExc_Fini();
1326
1327 /* Sundry finalizers */
Victor Stinnerbed48172019-08-27 00:12:32 +02001328 _PyMethod_Fini();
1329 _PyFrame_Fini();
1330 _PyCFunction_Fini();
1331 _PyTuple_Fini();
1332 _PyList_Fini();
1333 _PySet_Fini();
1334 _PyBytes_Fini();
1335 _PyLong_Fini();
1336 _PyFloat_Fini();
1337 _PyDict_Fini();
1338 _PySlice_Fini();
Victor Stinner8e91c242019-04-24 17:24:01 +02001339 _PyGC_Fini(runtime);
Eric Snow86ea5812019-05-10 13:29:55 -04001340 _PyWarnings_Fini(interp);
Eric Snow6b4be192017-05-22 21:36:03 -07001341 _Py_HashRandomization_Fini();
Serhiy Storchaka9171a8b2016-08-14 10:52:18 +03001342 _PyArg_Fini();
Victor Stinnerbed48172019-08-27 00:12:32 +02001343 _PyAsyncGen_Fini();
Yury Selivanovf23746a2018-01-22 19:11:18 -05001344 _PyContext_Fini();
Nick Coghland6009512014-11-20 21:39:37 +10001345
1346 /* Cleanup Unicode implementation */
1347 _PyUnicode_Fini();
1348
Victor Stinnerb2457ef2018-08-29 13:25:36 +02001349 _Py_ClearFileSystemEncoding();
Nick Coghland6009512014-11-20 21:39:37 +10001350
1351 /* XXX Still allocated:
1352 - various static ad-hoc pointers to interned strings
1353 - int and float free list blocks
1354 - whatever various modules and libraries allocate
1355 */
1356
1357 PyGrammar_RemoveAccelerators(&_PyParser_Grammar);
1358
1359 /* Cleanup auto-thread-state */
Victor Stinner8e91c242019-04-24 17:24:01 +02001360 _PyGILState_Fini(runtime);
Nick Coghland6009512014-11-20 21:39:37 +10001361
1362 /* Delete current thread. After this, many C API calls become crashy. */
1363 PyThreadState_Swap(NULL);
Victor Stinner8a1be612016-03-14 22:07:55 +01001364
Nick Coghland6009512014-11-20 21:39:37 +10001365 PyInterpreterState_Delete(interp);
1366
1367#ifdef Py_TRACE_REFS
1368 /* Display addresses (& refcnts) of all objects still alive.
1369 * An address can be used to find the repr of the object, printed
1370 * above by _Py_PrintReferences.
1371 */
Victor Stinnerda273412017-12-15 01:46:02 +01001372 if (dump_refs) {
Nick Coghland6009512014-11-20 21:39:37 +10001373 _Py_PrintReferenceAddresses(stderr);
Victor Stinner6bf992a2017-12-06 17:26:10 +01001374 }
Nick Coghland6009512014-11-20 21:39:37 +10001375#endif /* Py_TRACE_REFS */
Victor Stinner34be8072016-03-14 12:04:26 +01001376#ifdef WITH_PYMALLOC
Victor Stinnerda273412017-12-15 01:46:02 +01001377 if (malloc_stats) {
Victor Stinner6bf992a2017-12-06 17:26:10 +01001378 _PyObject_DebugMallocStats(stderr);
Victor Stinner34be8072016-03-14 12:04:26 +01001379 }
Nick Coghland6009512014-11-20 21:39:37 +10001380#endif
1381
Victor Stinner8e91c242019-04-24 17:24:01 +02001382 call_ll_exitfuncs(runtime);
Victor Stinner9316ee42017-11-25 03:17:57 +01001383
Eric Snow2ebc5ce2017-09-07 23:51:28 -06001384 _PyRuntime_Finalize();
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001385 return status;
1386}
1387
1388void
1389Py_Finalize(void)
1390{
1391 Py_FinalizeEx();
Nick Coghland6009512014-11-20 21:39:37 +10001392}
1393
1394/* Create and initialize a new interpreter and thread, and return the
1395 new thread. This requires that Py_Initialize() has been called
1396 first.
1397
1398 Unsuccessful initialization yields a NULL pointer. Note that *no*
1399 exception information is available even in this case -- the
1400 exception information is held in the thread, and there is no
1401 thread.
1402
1403 Locking: as above.
1404
1405*/
1406
Victor Stinner331a6a52019-05-27 16:39:22 +02001407static PyStatus
Victor Stinnera7368ac2017-11-15 18:11:45 -08001408new_interpreter(PyThreadState **tstate_p)
Nick Coghland6009512014-11-20 21:39:37 +10001409{
Victor Stinner331a6a52019-05-27 16:39:22 +02001410 PyStatus status;
Nick Coghland6009512014-11-20 21:39:37 +10001411
Victor Stinner331a6a52019-05-27 16:39:22 +02001412 status = _PyRuntime_Initialize();
1413 if (_PyStatus_EXCEPTION(status)) {
1414 return status;
Victor Stinner43125222019-04-24 18:23:53 +02001415 }
1416 _PyRuntimeState *runtime = &_PyRuntime;
1417
1418 if (!runtime->initialized) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001419 return _PyStatus_ERR("Py_Initialize must be called first");
Victor Stinnera7368ac2017-11-15 18:11:45 -08001420 }
Nick Coghland6009512014-11-20 21:39:37 +10001421
Victor Stinner8a1be612016-03-14 22:07:55 +01001422 /* Issue #10915, #15751: The GIL API doesn't work with multiple
1423 interpreters: disable PyGILState_Check(). */
1424 _PyGILState_check_enabled = 0;
1425
Victor Stinner43125222019-04-24 18:23:53 +02001426 PyInterpreterState *interp = PyInterpreterState_New();
Victor Stinnera7368ac2017-11-15 18:11:45 -08001427 if (interp == NULL) {
1428 *tstate_p = NULL;
Victor Stinner331a6a52019-05-27 16:39:22 +02001429 return _PyStatus_OK();
Victor Stinnera7368ac2017-11-15 18:11:45 -08001430 }
Nick Coghland6009512014-11-20 21:39:37 +10001431
Victor Stinner43125222019-04-24 18:23:53 +02001432 PyThreadState *tstate = PyThreadState_New(interp);
Nick Coghland6009512014-11-20 21:39:37 +10001433 if (tstate == NULL) {
1434 PyInterpreterState_Delete(interp);
Victor Stinnera7368ac2017-11-15 18:11:45 -08001435 *tstate_p = NULL;
Victor Stinner331a6a52019-05-27 16:39:22 +02001436 return _PyStatus_OK();
Nick Coghland6009512014-11-20 21:39:37 +10001437 }
1438
Victor Stinner43125222019-04-24 18:23:53 +02001439 PyThreadState *save_tstate = PyThreadState_Swap(tstate);
Nick Coghland6009512014-11-20 21:39:37 +10001440
Eric Snow1abcf672017-05-23 21:46:51 -07001441 /* Copy the current interpreter config into the new interpreter */
Victor Stinner331a6a52019-05-27 16:39:22 +02001442 PyConfig *config;
Eric Snow1abcf672017-05-23 21:46:51 -07001443 if (save_tstate != NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001444 config = &save_tstate->interp->config;
Eric Snow1abcf672017-05-23 21:46:51 -07001445 } else {
1446 /* No current thread state, copy from the main interpreter */
1447 PyInterpreterState *main_interp = PyInterpreterState_Main();
Victor Stinner331a6a52019-05-27 16:39:22 +02001448 config = &main_interp->config;
Victor Stinnerda273412017-12-15 01:46:02 +01001449 }
1450
Victor Stinner331a6a52019-05-27 16:39:22 +02001451 status = _PyConfig_Copy(&interp->config, config);
1452 if (_PyStatus_EXCEPTION(status)) {
1453 return status;
Victor Stinnerda273412017-12-15 01:46:02 +01001454 }
Victor Stinner331a6a52019-05-27 16:39:22 +02001455 config = &interp->config;
Eric Snow1abcf672017-05-23 21:46:51 -07001456
Victor Stinner444b39b2019-11-20 01:18:11 +01001457 status = pycore_init_types(runtime);
Victor Stinneref9d9b62019-05-22 11:28:22 +02001458
Nick Coghland6009512014-11-20 21:39:37 +10001459 /* XXX The following is lax in error checking */
Eric Snowd393c1b2017-09-14 12:18:12 -06001460 PyObject *modules = PyDict_New();
Victor Stinnera7368ac2017-11-15 18:11:45 -08001461 if (modules == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001462 return _PyStatus_ERR("can't make modules dictionary");
Victor Stinnera7368ac2017-11-15 18:11:45 -08001463 }
Eric Snowd393c1b2017-09-14 12:18:12 -06001464 interp->modules = modules;
Nick Coghland6009512014-11-20 21:39:37 +10001465
Victor Stinner0a28f8d2019-06-19 02:54:39 +02001466 PyObject *sysmod = _PyImport_FindBuiltin(tstate, "sys");
Eric Snowd393c1b2017-09-14 12:18:12 -06001467 if (sysmod != NULL) {
1468 interp->sysdict = PyModule_GetDict(sysmod);
Victor Stinner43125222019-04-24 18:23:53 +02001469 if (interp->sysdict == NULL) {
Eric Snowd393c1b2017-09-14 12:18:12 -06001470 goto handle_error;
Victor Stinner43125222019-04-24 18:23:53 +02001471 }
Eric Snowd393c1b2017-09-14 12:18:12 -06001472 Py_INCREF(interp->sysdict);
1473 PyDict_SetItemString(interp->sysdict, "modules", modules);
Victor Stinner838f2642019-06-13 22:41:23 +02001474 if (_PySys_InitMain(runtime, tstate) < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001475 return _PyStatus_ERR("can't finish initializing sys");
Victor Stinnerab672812019-01-23 15:04:40 +01001476 }
Eric Snowd393c1b2017-09-14 12:18:12 -06001477 }
Victor Stinnerb45d2592019-06-20 00:05:23 +02001478 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchaka8905fcc2018-12-11 08:38:03 +02001479 goto handle_error;
1480 }
Eric Snowd393c1b2017-09-14 12:18:12 -06001481
Victor Stinner0a28f8d2019-06-19 02:54:39 +02001482 PyObject *bimod = _PyImport_FindBuiltin(tstate, "builtins");
Nick Coghland6009512014-11-20 21:39:37 +10001483 if (bimod != NULL) {
1484 interp->builtins = PyModule_GetDict(bimod);
1485 if (interp->builtins == NULL)
1486 goto handle_error;
1487 Py_INCREF(interp->builtins);
1488 }
Victor Stinnerb45d2592019-06-20 00:05:23 +02001489 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchaka8905fcc2018-12-11 08:38:03 +02001490 goto handle_error;
1491 }
Nick Coghland6009512014-11-20 21:39:37 +10001492
Nick Coghland6009512014-11-20 21:39:37 +10001493 if (bimod != NULL && sysmod != NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001494 status = _PyBuiltins_AddExceptions(bimod);
1495 if (_PyStatus_EXCEPTION(status)) {
1496 return status;
Victor Stinner6d43f6f2019-01-22 21:18:05 +01001497 }
Nick Coghland6009512014-11-20 21:39:37 +10001498
Victor Stinner331a6a52019-05-27 16:39:22 +02001499 status = _PySys_SetPreliminaryStderr(interp->sysdict);
1500 if (_PyStatus_EXCEPTION(status)) {
1501 return status;
Victor Stinnera7368ac2017-11-15 18:11:45 -08001502 }
Nick Coghland6009512014-11-20 21:39:37 +10001503
Victor Stinnerb45d2592019-06-20 00:05:23 +02001504 status = _PyImportHooks_Init(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +02001505 if (_PyStatus_EXCEPTION(status)) {
1506 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001507 }
Nick Coghland6009512014-11-20 21:39:37 +10001508
Victor Stinnerb45d2592019-06-20 00:05:23 +02001509 status = init_importlib(tstate, sysmod);
Victor Stinner331a6a52019-05-27 16:39:22 +02001510 if (_PyStatus_EXCEPTION(status)) {
1511 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001512 }
Nick Coghland6009512014-11-20 21:39:37 +10001513
Victor Stinner0a28f8d2019-06-19 02:54:39 +02001514 status = init_importlib_external(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +02001515 if (_PyStatus_EXCEPTION(status)) {
1516 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001517 }
Nick Coghland6009512014-11-20 21:39:37 +10001518
Victor Stinnerb45d2592019-06-20 00:05:23 +02001519 status = _PyUnicode_InitEncodings(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +02001520 if (_PyStatus_EXCEPTION(status)) {
1521 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001522 }
1523
Victor Stinnerb45d2592019-06-20 00:05:23 +02001524 status = init_sys_streams(tstate);
Victor Stinner331a6a52019-05-27 16:39:22 +02001525 if (_PyStatus_EXCEPTION(status)) {
1526 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001527 }
1528
Victor Stinner331a6a52019-05-27 16:39:22 +02001529 status = add_main_module(interp);
1530 if (_PyStatus_EXCEPTION(status)) {
1531 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001532 }
1533
Victor Stinner331a6a52019-05-27 16:39:22 +02001534 if (config->site_import) {
Victor Stinnerb45d2592019-06-20 00:05:23 +02001535 status = init_import_site();
Victor Stinner331a6a52019-05-27 16:39:22 +02001536 if (_PyStatus_EXCEPTION(status)) {
1537 return status;
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001538 }
1539 }
Nick Coghland6009512014-11-20 21:39:37 +10001540 }
1541
Victor Stinnerb45d2592019-06-20 00:05:23 +02001542 if (_PyErr_Occurred(tstate)) {
Victor Stinnera7368ac2017-11-15 18:11:45 -08001543 goto handle_error;
1544 }
Nick Coghland6009512014-11-20 21:39:37 +10001545
Victor Stinnera7368ac2017-11-15 18:11:45 -08001546 *tstate_p = tstate;
Victor Stinner331a6a52019-05-27 16:39:22 +02001547 return _PyStatus_OK();
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001548
Nick Coghland6009512014-11-20 21:39:37 +10001549handle_error:
1550 /* Oops, it didn't work. Undo it all. */
1551
1552 PyErr_PrintEx(0);
1553 PyThreadState_Clear(tstate);
1554 PyThreadState_Swap(save_tstate);
1555 PyThreadState_Delete(tstate);
1556 PyInterpreterState_Delete(interp);
1557
Victor Stinnera7368ac2017-11-15 18:11:45 -08001558 *tstate_p = NULL;
Victor Stinner331a6a52019-05-27 16:39:22 +02001559 return _PyStatus_OK();
Victor Stinnera7368ac2017-11-15 18:11:45 -08001560}
1561
1562PyThreadState *
1563Py_NewInterpreter(void)
1564{
Stéphane Wirtel9e06d2b2019-03-18 17:10:29 +01001565 PyThreadState *tstate = NULL;
Victor Stinner331a6a52019-05-27 16:39:22 +02001566 PyStatus status = new_interpreter(&tstate);
1567 if (_PyStatus_EXCEPTION(status)) {
1568 Py_ExitStatusException(status);
Victor Stinnera7368ac2017-11-15 18:11:45 -08001569 }
1570 return tstate;
1571
Nick Coghland6009512014-11-20 21:39:37 +10001572}
1573
1574/* Delete an interpreter and its last thread. This requires that the
1575 given thread state is current, that the thread has no remaining
1576 frames, and that it is its interpreter's only remaining thread.
1577 It is a fatal error to violate these constraints.
1578
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001579 (Py_FinalizeEx() doesn't have these constraints -- it zaps
Nick Coghland6009512014-11-20 21:39:37 +10001580 everything, regardless.)
1581
1582 Locking: as above.
1583
1584*/
1585
1586void
1587Py_EndInterpreter(PyThreadState *tstate)
1588{
1589 PyInterpreterState *interp = tstate->interp;
1590
Victor Stinnerb45d2592019-06-20 00:05:23 +02001591 if (tstate != _PyThreadState_GET()) {
Nick Coghland6009512014-11-20 21:39:37 +10001592 Py_FatalError("Py_EndInterpreter: thread is not current");
Victor Stinnerb45d2592019-06-20 00:05:23 +02001593 }
1594 if (tstate->frame != NULL) {
Nick Coghland6009512014-11-20 21:39:37 +10001595 Py_FatalError("Py_EndInterpreter: thread still has a frame");
Victor Stinnerb45d2592019-06-20 00:05:23 +02001596 }
Eric Snow5be45a62019-03-08 22:47:07 -07001597 interp->finalizing = 1;
Nick Coghland6009512014-11-20 21:39:37 +10001598
Eric Snow842a2f02019-03-15 15:47:51 -06001599 // Wrap up existing "threading"-module-created, non-daemon threads.
Victor Stinnerb45d2592019-06-20 00:05:23 +02001600 wait_for_thread_shutdown(tstate);
Nick Coghland6009512014-11-20 21:39:37 +10001601
Victor Stinnerb45d2592019-06-20 00:05:23 +02001602 call_py_exitfuncs(tstate);
Marcel Plch776407f2017-12-20 11:17:58 +01001603
Victor Stinnerb45d2592019-06-20 00:05:23 +02001604 if (tstate != interp->tstate_head || tstate->next != NULL) {
Nick Coghland6009512014-11-20 21:39:37 +10001605 Py_FatalError("Py_EndInterpreter: not the last thread");
Victor Stinnerb45d2592019-06-20 00:05:23 +02001606 }
Nick Coghland6009512014-11-20 21:39:37 +10001607
Victor Stinner987a0dc2019-06-19 10:36:10 +02001608 _PyImport_Cleanup(tstate);
Nick Coghland6009512014-11-20 21:39:37 +10001609 PyInterpreterState_Clear(interp);
1610 PyThreadState_Swap(NULL);
1611 PyInterpreterState_Delete(interp);
1612}
1613
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001614/* Add the __main__ module */
Nick Coghland6009512014-11-20 21:39:37 +10001615
Victor Stinner331a6a52019-05-27 16:39:22 +02001616static PyStatus
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001617add_main_module(PyInterpreterState *interp)
Nick Coghland6009512014-11-20 21:39:37 +10001618{
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07001619 PyObject *m, *d, *loader, *ann_dict;
Nick Coghland6009512014-11-20 21:39:37 +10001620 m = PyImport_AddModule("__main__");
1621 if (m == NULL)
Victor Stinner331a6a52019-05-27 16:39:22 +02001622 return _PyStatus_ERR("can't create __main__ module");
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001623
Nick Coghland6009512014-11-20 21:39:37 +10001624 d = PyModule_GetDict(m);
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07001625 ann_dict = PyDict_New();
1626 if ((ann_dict == NULL) ||
1627 (PyDict_SetItemString(d, "__annotations__", ann_dict) < 0)) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001628 return _PyStatus_ERR("Failed to initialize __main__.__annotations__");
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07001629 }
1630 Py_DECREF(ann_dict);
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001631
Nick Coghland6009512014-11-20 21:39:37 +10001632 if (PyDict_GetItemString(d, "__builtins__") == NULL) {
1633 PyObject *bimod = PyImport_ImportModule("builtins");
1634 if (bimod == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001635 return _PyStatus_ERR("Failed to retrieve builtins module");
Nick Coghland6009512014-11-20 21:39:37 +10001636 }
1637 if (PyDict_SetItemString(d, "__builtins__", bimod) < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001638 return _PyStatus_ERR("Failed to initialize __main__.__builtins__");
Nick Coghland6009512014-11-20 21:39:37 +10001639 }
1640 Py_DECREF(bimod);
1641 }
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001642
Nick Coghland6009512014-11-20 21:39:37 +10001643 /* Main is a little special - imp.is_builtin("__main__") will return
1644 * False, but BuiltinImporter is still the most appropriate initial
1645 * setting for its __loader__ attribute. A more suitable value will
1646 * be set if __main__ gets further initialized later in the startup
1647 * process.
1648 */
1649 loader = PyDict_GetItemString(d, "__loader__");
1650 if (loader == NULL || loader == Py_None) {
1651 PyObject *loader = PyObject_GetAttrString(interp->importlib,
1652 "BuiltinImporter");
1653 if (loader == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001654 return _PyStatus_ERR("Failed to retrieve BuiltinImporter");
Nick Coghland6009512014-11-20 21:39:37 +10001655 }
1656 if (PyDict_SetItemString(d, "__loader__", loader) < 0) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001657 return _PyStatus_ERR("Failed to initialize __main__.__loader__");
Nick Coghland6009512014-11-20 21:39:37 +10001658 }
1659 Py_DECREF(loader);
1660 }
Victor Stinner331a6a52019-05-27 16:39:22 +02001661 return _PyStatus_OK();
Nick Coghland6009512014-11-20 21:39:37 +10001662}
1663
Nick Coghland6009512014-11-20 21:39:37 +10001664/* Import the site module (not into __main__ though) */
1665
Victor Stinner331a6a52019-05-27 16:39:22 +02001666static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +02001667init_import_site(void)
Nick Coghland6009512014-11-20 21:39:37 +10001668{
1669 PyObject *m;
1670 m = PyImport_ImportModule("site");
1671 if (m == NULL) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001672 return _PyStatus_ERR("Failed to import the site module");
Nick Coghland6009512014-11-20 21:39:37 +10001673 }
Victor Stinnerf7e5b562017-11-15 15:48:08 -08001674 Py_DECREF(m);
Victor Stinner331a6a52019-05-27 16:39:22 +02001675 return _PyStatus_OK();
Nick Coghland6009512014-11-20 21:39:37 +10001676}
1677
Victor Stinner874dbe82015-09-04 17:29:57 +02001678/* Check if a file descriptor is valid or not.
1679 Return 0 if the file descriptor is invalid, return non-zero otherwise. */
1680static int
1681is_valid_fd(int fd)
1682{
Victor Stinner3092d6b2019-04-17 18:09:12 +02001683/* dup() is faster than fstat(): fstat() can require input/output operations,
1684 whereas dup() doesn't. There is a low risk of EMFILE/ENFILE at Python
1685 startup. Problem: dup() doesn't check if the file descriptor is valid on
1686 some platforms.
1687
1688 bpo-30225: On macOS Tiger, when stdout is redirected to a pipe and the other
1689 side of the pipe is closed, dup(1) succeed, whereas fstat(1, &st) fails with
1690 EBADF. FreeBSD has similar issue (bpo-32849).
1691
1692 Only use dup() on platforms where dup() is enough to detect invalid FD in
1693 corner cases: on Linux and Windows (bpo-32849). */
1694#if defined(__linux__) || defined(MS_WINDOWS)
1695 if (fd < 0) {
1696 return 0;
1697 }
1698 int fd2;
1699
1700 _Py_BEGIN_SUPPRESS_IPH
1701 fd2 = dup(fd);
1702 if (fd2 >= 0) {
1703 close(fd2);
1704 }
1705 _Py_END_SUPPRESS_IPH
1706
1707 return (fd2 >= 0);
1708#else
Victor Stinner1c4670e2017-05-04 00:45:56 +02001709 struct stat st;
1710 return (fstat(fd, &st) == 0);
Victor Stinner1c4670e2017-05-04 00:45:56 +02001711#endif
Victor Stinner874dbe82015-09-04 17:29:57 +02001712}
1713
1714/* returns Py_None if the fd is not valid */
Nick Coghland6009512014-11-20 21:39:37 +10001715static PyObject*
Victor Stinner331a6a52019-05-27 16:39:22 +02001716create_stdio(const PyConfig *config, PyObject* io,
Serhiy Storchakaef1585e2015-12-25 20:01:53 +02001717 int fd, int write_mode, const char* name,
Victor Stinner709d23d2019-05-02 14:56:30 -04001718 const wchar_t* encoding, const wchar_t* errors)
Nick Coghland6009512014-11-20 21:39:37 +10001719{
1720 PyObject *buf = NULL, *stream = NULL, *text = NULL, *raw = NULL, *res;
1721 const char* mode;
1722 const char* newline;
Serhiy Storchaka77732be2017-10-04 20:25:40 +03001723 PyObject *line_buffering, *write_through;
Nick Coghland6009512014-11-20 21:39:37 +10001724 int buffering, isatty;
1725 _Py_IDENTIFIER(open);
1726 _Py_IDENTIFIER(isatty);
1727 _Py_IDENTIFIER(TextIOWrapper);
1728 _Py_IDENTIFIER(mode);
Victor Stinnerfbca9082018-08-30 00:50:45 +02001729 const int buffered_stdio = config->buffered_stdio;
Nick Coghland6009512014-11-20 21:39:37 +10001730
Victor Stinner874dbe82015-09-04 17:29:57 +02001731 if (!is_valid_fd(fd))
1732 Py_RETURN_NONE;
1733
Nick Coghland6009512014-11-20 21:39:37 +10001734 /* stdin is always opened in buffered mode, first because it shouldn't
1735 make a difference in common use cases, second because TextIOWrapper
1736 depends on the presence of a read1() method which only exists on
1737 buffered streams.
1738 */
Victor Stinnerfbca9082018-08-30 00:50:45 +02001739 if (!buffered_stdio && write_mode)
Nick Coghland6009512014-11-20 21:39:37 +10001740 buffering = 0;
1741 else
1742 buffering = -1;
1743 if (write_mode)
1744 mode = "wb";
1745 else
1746 mode = "rb";
Serhiy Storchaka1f21eaa2019-09-01 12:16:51 +03001747 buf = _PyObject_CallMethodId(io, &PyId_open, "isiOOOO",
Nick Coghland6009512014-11-20 21:39:37 +10001748 fd, mode, buffering,
Martin Panterb4ce1fc2015-11-30 03:18:29 +00001749 Py_None, Py_None, /* encoding, errors */
Serhiy Storchaka1f21eaa2019-09-01 12:16:51 +03001750 Py_None, Py_False); /* newline, closefd */
Nick Coghland6009512014-11-20 21:39:37 +10001751 if (buf == NULL)
1752 goto error;
1753
1754 if (buffering) {
1755 _Py_IDENTIFIER(raw);
1756 raw = _PyObject_GetAttrId(buf, &PyId_raw);
1757 if (raw == NULL)
1758 goto error;
1759 }
1760 else {
1761 raw = buf;
1762 Py_INCREF(raw);
1763 }
1764
Steve Dower39294992016-08-30 21:22:36 -07001765#ifdef MS_WINDOWS
1766 /* Windows console IO is always UTF-8 encoded */
1767 if (PyWindowsConsoleIO_Check(raw))
Victor Stinner709d23d2019-05-02 14:56:30 -04001768 encoding = L"utf-8";
Steve Dower39294992016-08-30 21:22:36 -07001769#endif
1770
Nick Coghland6009512014-11-20 21:39:37 +10001771 text = PyUnicode_FromString(name);
1772 if (text == NULL || _PyObject_SetAttrId(raw, &PyId_name, text) < 0)
1773 goto error;
Jeroen Demeyer762f93f2019-07-08 10:19:25 +02001774 res = _PyObject_CallMethodIdNoArgs(raw, &PyId_isatty);
Nick Coghland6009512014-11-20 21:39:37 +10001775 if (res == NULL)
1776 goto error;
1777 isatty = PyObject_IsTrue(res);
1778 Py_DECREF(res);
1779 if (isatty == -1)
1780 goto error;
Victor Stinnerfbca9082018-08-30 00:50:45 +02001781 if (!buffered_stdio)
Serhiy Storchaka77732be2017-10-04 20:25:40 +03001782 write_through = Py_True;
1783 else
1784 write_through = Py_False;
Victor Stinnerfbca9082018-08-30 00:50:45 +02001785 if (isatty && buffered_stdio)
Nick Coghland6009512014-11-20 21:39:37 +10001786 line_buffering = Py_True;
1787 else
1788 line_buffering = Py_False;
1789
1790 Py_CLEAR(raw);
1791 Py_CLEAR(text);
1792
1793#ifdef MS_WINDOWS
1794 /* sys.stdin: enable universal newline mode, translate "\r\n" and "\r"
1795 newlines to "\n".
1796 sys.stdout and sys.stderr: translate "\n" to "\r\n". */
1797 newline = NULL;
1798#else
1799 /* sys.stdin: split lines at "\n".
1800 sys.stdout and sys.stderr: don't translate newlines (use "\n"). */
1801 newline = "\n";
1802#endif
1803
Victor Stinner709d23d2019-05-02 14:56:30 -04001804 PyObject *encoding_str = PyUnicode_FromWideChar(encoding, -1);
1805 if (encoding_str == NULL) {
1806 Py_CLEAR(buf);
1807 goto error;
1808 }
1809
1810 PyObject *errors_str = PyUnicode_FromWideChar(errors, -1);
1811 if (errors_str == NULL) {
1812 Py_CLEAR(buf);
1813 Py_CLEAR(encoding_str);
1814 goto error;
1815 }
1816
1817 stream = _PyObject_CallMethodId(io, &PyId_TextIOWrapper, "OOOsOO",
1818 buf, encoding_str, errors_str,
Serhiy Storchaka77732be2017-10-04 20:25:40 +03001819 newline, line_buffering, write_through);
Nick Coghland6009512014-11-20 21:39:37 +10001820 Py_CLEAR(buf);
Victor Stinner709d23d2019-05-02 14:56:30 -04001821 Py_CLEAR(encoding_str);
1822 Py_CLEAR(errors_str);
Nick Coghland6009512014-11-20 21:39:37 +10001823 if (stream == NULL)
1824 goto error;
1825
1826 if (write_mode)
1827 mode = "w";
1828 else
1829 mode = "r";
1830 text = PyUnicode_FromString(mode);
1831 if (!text || _PyObject_SetAttrId(stream, &PyId_mode, text) < 0)
1832 goto error;
1833 Py_CLEAR(text);
1834 return stream;
1835
1836error:
1837 Py_XDECREF(buf);
1838 Py_XDECREF(stream);
1839 Py_XDECREF(text);
1840 Py_XDECREF(raw);
Nick Coghland6009512014-11-20 21:39:37 +10001841
Victor Stinner874dbe82015-09-04 17:29:57 +02001842 if (PyErr_ExceptionMatches(PyExc_OSError) && !is_valid_fd(fd)) {
1843 /* Issue #24891: the file descriptor was closed after the first
1844 is_valid_fd() check was called. Ignore the OSError and set the
1845 stream to None. */
1846 PyErr_Clear();
1847 Py_RETURN_NONE;
1848 }
1849 return NULL;
Nick Coghland6009512014-11-20 21:39:37 +10001850}
1851
1852/* Initialize sys.stdin, stdout, stderr and builtins.open */
Victor Stinner331a6a52019-05-27 16:39:22 +02001853static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +02001854init_sys_streams(PyThreadState *tstate)
Nick Coghland6009512014-11-20 21:39:37 +10001855{
1856 PyObject *iomod = NULL, *wrapper;
1857 PyObject *bimod = NULL;
1858 PyObject *m;
1859 PyObject *std = NULL;
Victor Stinnera7368ac2017-11-15 18:11:45 -08001860 int fd;
Nick Coghland6009512014-11-20 21:39:37 +10001861 PyObject * encoding_attr;
Victor Stinner331a6a52019-05-27 16:39:22 +02001862 PyStatus res = _PyStatus_OK();
Victor Stinnerb45d2592019-06-20 00:05:23 +02001863 const PyConfig *config = &tstate->interp->config;
Victor Stinnerdfe0dc72018-08-29 11:47:29 +02001864
Victor Stinnerbf4ac2d2019-01-22 17:39:03 +01001865 /* Check that stdin is not a directory
1866 Using shell redirection, you can redirect stdin to a directory,
1867 crashing the Python interpreter. Catch this common mistake here
1868 and output a useful error message. Note that under MS Windows,
1869 the shell already prevents that. */
1870#ifndef MS_WINDOWS
1871 struct _Py_stat_struct sb;
1872 if (_Py_fstat_noraise(fileno(stdin), &sb) == 0 &&
1873 S_ISDIR(sb.st_mode)) {
Victor Stinner331a6a52019-05-27 16:39:22 +02001874 return _PyStatus_ERR("<stdin> is a directory, cannot continue");
Victor Stinnerbf4ac2d2019-01-22 17:39:03 +01001875 }
1876#endif
1877
Nick Coghland6009512014-11-20 21:39:37 +10001878 /* Hack to avoid a nasty recursion issue when Python is invoked
1879 in verbose mode: pre-import the Latin-1 and UTF-8 codecs */
1880 if ((m = PyImport_ImportModule("encodings.utf_8")) == NULL) {
1881 goto error;
1882 }
1883 Py_DECREF(m);
1884
1885 if (!(m = PyImport_ImportModule("encodings.latin_1"))) {
1886 goto error;
1887 }
1888 Py_DECREF(m);
1889
1890 if (!(bimod = PyImport_ImportModule("builtins"))) {
1891 goto error;
1892 }
1893
1894 if (!(iomod = PyImport_ImportModule("io"))) {
1895 goto error;
1896 }
1897 if (!(wrapper = PyObject_GetAttrString(iomod, "OpenWrapper"))) {
1898 goto error;
1899 }
1900
1901 /* Set builtins.open */
1902 if (PyObject_SetAttrString(bimod, "open", wrapper) == -1) {
1903 Py_DECREF(wrapper);
1904 goto error;
1905 }
1906 Py_DECREF(wrapper);
1907
Nick Coghland6009512014-11-20 21:39:37 +10001908 /* Set sys.stdin */
1909 fd = fileno(stdin);
1910 /* Under some conditions stdin, stdout and stderr may not be connected
1911 * and fileno() may point to an invalid file descriptor. For example
1912 * GUI apps don't have valid standard streams by default.
1913 */
Victor Stinnerfbca9082018-08-30 00:50:45 +02001914 std = create_stdio(config, iomod, fd, 0, "<stdin>",
Victor Stinnerdfe0dc72018-08-29 11:47:29 +02001915 config->stdio_encoding,
1916 config->stdio_errors);
Victor Stinner874dbe82015-09-04 17:29:57 +02001917 if (std == NULL)
1918 goto error;
Nick Coghland6009512014-11-20 21:39:37 +10001919 PySys_SetObject("__stdin__", std);
1920 _PySys_SetObjectId(&PyId_stdin, std);
1921 Py_DECREF(std);
1922
1923 /* Set sys.stdout */
1924 fd = fileno(stdout);
Victor Stinnerfbca9082018-08-30 00:50:45 +02001925 std = create_stdio(config, iomod, fd, 1, "<stdout>",
Victor Stinnerdfe0dc72018-08-29 11:47:29 +02001926 config->stdio_encoding,
1927 config->stdio_errors);
Victor Stinner874dbe82015-09-04 17:29:57 +02001928 if (std == NULL)
1929 goto error;
Nick Coghland6009512014-11-20 21:39:37 +10001930 PySys_SetObject("__stdout__", std);
1931 _PySys_SetObjectId(&PyId_stdout, std);
1932 Py_DECREF(std);
1933
1934#if 1 /* Disable this if you have trouble debugging bootstrap stuff */
1935 /* Set sys.stderr, replaces the preliminary stderr */
1936 fd = fileno(stderr);
Victor Stinnerfbca9082018-08-30 00:50:45 +02001937 std = create_stdio(config, iomod, fd, 1, "<stderr>",
Victor Stinnerdfe0dc72018-08-29 11:47:29 +02001938 config->stdio_encoding,
Victor Stinner709d23d2019-05-02 14:56:30 -04001939 L"backslashreplace");
Victor Stinner874dbe82015-09-04 17:29:57 +02001940 if (std == NULL)
1941 goto error;
Nick Coghland6009512014-11-20 21:39:37 +10001942
1943 /* Same as hack above, pre-import stderr's codec to avoid recursion
1944 when import.c tries to write to stderr in verbose mode. */
1945 encoding_attr = PyObject_GetAttrString(std, "encoding");
1946 if (encoding_attr != NULL) {
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02001947 const char *std_encoding = PyUnicode_AsUTF8(encoding_attr);
Nick Coghland6009512014-11-20 21:39:37 +10001948 if (std_encoding != NULL) {
1949 PyObject *codec_info = _PyCodec_Lookup(std_encoding);
1950 Py_XDECREF(codec_info);
1951 }
1952 Py_DECREF(encoding_attr);
1953 }
Victor Stinnerb45d2592019-06-20 00:05:23 +02001954 _PyErr_Clear(tstate); /* Not a fatal error if codec isn't available */
Nick Coghland6009512014-11-20 21:39:37 +10001955
1956 if (PySys_SetObject("__stderr__", std) < 0) {
1957 Py_DECREF(std);
1958 goto error;
1959 }
1960 if (_PySys_SetObjectId(&PyId_stderr, std) < 0) {
1961 Py_DECREF(std);
1962 goto error;
1963 }
1964 Py_DECREF(std);
1965#endif
1966
Victor Stinnera7368ac2017-11-15 18:11:45 -08001967 goto done;
Nick Coghland6009512014-11-20 21:39:37 +10001968
Victor Stinnera7368ac2017-11-15 18:11:45 -08001969error:
Victor Stinner331a6a52019-05-27 16:39:22 +02001970 res = _PyStatus_ERR("can't initialize sys standard streams");
Victor Stinnera7368ac2017-11-15 18:11:45 -08001971
1972done:
Victor Stinner124b9eb2018-08-29 01:29:06 +02001973 _Py_ClearStandardStreamEncoding();
Victor Stinner31e99082017-12-20 23:41:38 +01001974
Nick Coghland6009512014-11-20 21:39:37 +10001975 Py_XDECREF(bimod);
1976 Py_XDECREF(iomod);
Victor Stinnera7368ac2017-11-15 18:11:45 -08001977 return res;
Nick Coghland6009512014-11-20 21:39:37 +10001978}
1979
1980
Victor Stinner10dc4842015-03-24 12:01:30 +01001981static void
Victor Stinner1ce16fb2019-09-18 01:35:33 +02001982_Py_FatalError_DumpTracebacks(int fd, PyInterpreterState *interp,
1983 PyThreadState *tstate)
Victor Stinner10dc4842015-03-24 12:01:30 +01001984{
Victor Stinner10dc4842015-03-24 12:01:30 +01001985 fputc('\n', stderr);
1986 fflush(stderr);
1987
1988 /* display the current Python stack */
Victor Stinner1ce16fb2019-09-18 01:35:33 +02001989 _Py_DumpTracebackThreads(fd, interp, tstate);
Victor Stinner10dc4842015-03-24 12:01:30 +01001990}
Victor Stinner791da1c2016-03-14 16:53:12 +01001991
1992/* Print the current exception (if an exception is set) with its traceback,
1993 or display the current Python stack.
1994
1995 Don't call PyErr_PrintEx() and the except hook, because Py_FatalError() is
1996 called on catastrophic cases.
1997
1998 Return 1 if the traceback was displayed, 0 otherwise. */
1999
2000static int
2001_Py_FatalError_PrintExc(int fd)
2002{
Victor Stinnerb45d2592019-06-20 00:05:23 +02002003 PyThreadState *tstate = _PyThreadState_GET();
Victor Stinner791da1c2016-03-14 16:53:12 +01002004 PyObject *ferr, *res;
2005 PyObject *exception, *v, *tb;
2006 int has_tb;
2007
Victor Stinnerb45d2592019-06-20 00:05:23 +02002008 _PyErr_Fetch(tstate, &exception, &v, &tb);
Victor Stinner791da1c2016-03-14 16:53:12 +01002009 if (exception == NULL) {
2010 /* No current exception */
2011 return 0;
2012 }
2013
2014 ferr = _PySys_GetObjectId(&PyId_stderr);
2015 if (ferr == NULL || ferr == Py_None) {
2016 /* sys.stderr is not set yet or set to None,
2017 no need to try to display the exception */
2018 return 0;
2019 }
2020
Victor Stinnerb45d2592019-06-20 00:05:23 +02002021 _PyErr_NormalizeException(tstate, &exception, &v, &tb);
Victor Stinner791da1c2016-03-14 16:53:12 +01002022 if (tb == NULL) {
2023 tb = Py_None;
2024 Py_INCREF(tb);
2025 }
2026 PyException_SetTraceback(v, tb);
2027 if (exception == NULL) {
2028 /* PyErr_NormalizeException() failed */
2029 return 0;
2030 }
2031
2032 has_tb = (tb != Py_None);
2033 PyErr_Display(exception, v, tb);
2034 Py_XDECREF(exception);
2035 Py_XDECREF(v);
2036 Py_XDECREF(tb);
2037
2038 /* sys.stderr may be buffered: call sys.stderr.flush() */
Jeroen Demeyer762f93f2019-07-08 10:19:25 +02002039 res = _PyObject_CallMethodIdNoArgs(ferr, &PyId_flush);
Victor Stinnerb45d2592019-06-20 00:05:23 +02002040 if (res == NULL) {
2041 _PyErr_Clear(tstate);
2042 }
2043 else {
Victor Stinner791da1c2016-03-14 16:53:12 +01002044 Py_DECREF(res);
Victor Stinnerb45d2592019-06-20 00:05:23 +02002045 }
Victor Stinner791da1c2016-03-14 16:53:12 +01002046
2047 return has_tb;
2048}
2049
Nick Coghland6009512014-11-20 21:39:37 +10002050/* Print fatal error message and abort */
2051
Victor Stinner8d5a3aa2017-10-04 09:50:12 -07002052#ifdef MS_WINDOWS
2053static void
2054fatal_output_debug(const char *msg)
2055{
2056 /* buffer of 256 bytes allocated on the stack */
2057 WCHAR buffer[256 / sizeof(WCHAR)];
2058 size_t buflen = Py_ARRAY_LENGTH(buffer) - 1;
2059 size_t msglen;
2060
2061 OutputDebugStringW(L"Fatal Python error: ");
2062
2063 msglen = strlen(msg);
2064 while (msglen) {
2065 size_t i;
2066
2067 if (buflen > msglen) {
2068 buflen = msglen;
2069 }
2070
2071 /* Convert the message to wchar_t. This uses a simple one-to-one
2072 conversion, assuming that the this error message actually uses
2073 ASCII only. If this ceases to be true, we will have to convert. */
2074 for (i=0; i < buflen; ++i) {
2075 buffer[i] = msg[i];
2076 }
2077 buffer[i] = L'\0';
2078 OutputDebugStringW(buffer);
2079
2080 msg += buflen;
2081 msglen -= buflen;
2082 }
2083 OutputDebugStringW(L"\n");
2084}
2085#endif
2086
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002087
2088static void
2089fatal_error_dump_runtime(FILE *stream, _PyRuntimeState *runtime)
2090{
2091 fprintf(stream, "Python runtime state: ");
2092 if (runtime->finalizing) {
2093 fprintf(stream, "finalizing (tstate=%p)", runtime->finalizing);
2094 }
2095 else if (runtime->initialized) {
2096 fprintf(stream, "initialized");
2097 }
2098 else if (runtime->core_initialized) {
2099 fprintf(stream, "core initialized");
2100 }
2101 else if (runtime->preinitialized) {
2102 fprintf(stream, "preinitialized");
2103 }
2104 else if (runtime->preinitializing) {
2105 fprintf(stream, "preinitializing");
2106 }
2107 else {
2108 fprintf(stream, "unknown");
2109 }
2110 fprintf(stream, "\n");
2111 fflush(stream);
2112}
2113
2114
Benjamin Petersoncef88b92017-11-25 13:02:55 -08002115static void _Py_NO_RETURN
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002116fatal_error(const char *prefix, const char *msg, int status)
Nick Coghland6009512014-11-20 21:39:37 +10002117{
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002118 FILE *stream = stderr;
2119 const int fd = fileno(stream);
Victor Stinner53345a42015-03-25 01:55:14 +01002120 static int reentrant = 0;
Victor Stinner53345a42015-03-25 01:55:14 +01002121
2122 if (reentrant) {
2123 /* Py_FatalError() caused a second fatal error.
2124 Example: flush_std_files() raises a recursion error. */
2125 goto exit;
2126 }
2127 reentrant = 1;
Nick Coghland6009512014-11-20 21:39:37 +10002128
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002129 fprintf(stream, "Fatal Python error: ");
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002130 if (prefix) {
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002131 fputs(prefix, stream);
2132 fputs(": ", stream);
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002133 }
2134 if (msg) {
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002135 fputs(msg, stream);
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002136 }
2137 else {
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002138 fprintf(stream, "<message not set>");
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002139 }
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002140 fputs("\n", stream);
2141 fflush(stream); /* it helps in Windows debug build */
2142
2143 _PyRuntimeState *runtime = &_PyRuntime;
2144 fatal_error_dump_runtime(stream, runtime);
2145
2146 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
2147 PyInterpreterState *interp = NULL;
2148 if (tstate != NULL) {
2149 interp = tstate->interp;
2150 }
Victor Stinner10dc4842015-03-24 12:01:30 +01002151
Victor Stinner3a228ab2018-11-01 00:26:41 +01002152 /* Check if the current thread has a Python thread state
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002153 and holds the GIL.
Victor Stinner3a228ab2018-11-01 00:26:41 +01002154
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002155 tss_tstate is NULL if Py_FatalError() is called from a C thread which
2156 has no Python thread state.
2157
2158 tss_tstate != tstate if the current Python thread does not hold the GIL.
2159 */
2160 PyThreadState *tss_tstate = PyGILState_GetThisThreadState();
2161 int has_tstate_and_gil = (tss_tstate != NULL && tss_tstate == tstate);
Victor Stinner3a228ab2018-11-01 00:26:41 +01002162 if (has_tstate_and_gil) {
2163 /* If an exception is set, print the exception with its traceback */
2164 if (!_Py_FatalError_PrintExc(fd)) {
2165 /* No exception is set, or an exception is set without traceback */
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002166 _Py_FatalError_DumpTracebacks(fd, interp, tss_tstate);
Victor Stinner3a228ab2018-11-01 00:26:41 +01002167 }
2168 }
2169 else {
Victor Stinner1ce16fb2019-09-18 01:35:33 +02002170 _Py_FatalError_DumpTracebacks(fd, interp, tss_tstate);
Victor Stinner8d5a3aa2017-10-04 09:50:12 -07002171 }
Victor Stinner10dc4842015-03-24 12:01:30 +01002172
Victor Stinner8d5a3aa2017-10-04 09:50:12 -07002173 /* The main purpose of faulthandler is to display the traceback.
2174 This function already did its best to display a traceback.
2175 Disable faulthandler to prevent writing a second traceback
2176 on abort(). */
Victor Stinner2025d782016-03-16 23:19:15 +01002177 _PyFaulthandler_Fini();
2178
Victor Stinner791da1c2016-03-14 16:53:12 +01002179 /* Check if the current Python thread hold the GIL */
Victor Stinner3a228ab2018-11-01 00:26:41 +01002180 if (has_tstate_and_gil) {
Victor Stinner791da1c2016-03-14 16:53:12 +01002181 /* Flush sys.stdout and sys.stderr */
2182 flush_std_files();
2183 }
Victor Stinnere0deff32015-03-24 13:46:18 +01002184
Nick Coghland6009512014-11-20 21:39:37 +10002185#ifdef MS_WINDOWS
Victor Stinner8d5a3aa2017-10-04 09:50:12 -07002186 fatal_output_debug(msg);
Victor Stinner53345a42015-03-25 01:55:14 +01002187#endif /* MS_WINDOWS */
2188
2189exit:
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002190 if (status < 0) {
Victor Stinner53345a42015-03-25 01:55:14 +01002191#if defined(MS_WINDOWS) && defined(_DEBUG)
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002192 DebugBreak();
Nick Coghland6009512014-11-20 21:39:37 +10002193#endif
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002194 abort();
2195 }
2196 else {
2197 exit(status);
2198 }
2199}
2200
Victor Stinner19760862017-12-20 01:41:59 +01002201void _Py_NO_RETURN
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002202Py_FatalError(const char *msg)
2203{
2204 fatal_error(NULL, msg, -1);
2205}
2206
Victor Stinner19760862017-12-20 01:41:59 +01002207void _Py_NO_RETURN
Victor Stinner331a6a52019-05-27 16:39:22 +02002208Py_ExitStatusException(PyStatus status)
Victor Stinnerf7e5b562017-11-15 15:48:08 -08002209{
Victor Stinner331a6a52019-05-27 16:39:22 +02002210 if (_PyStatus_IS_EXIT(status)) {
2211 exit(status.exitcode);
Victor Stinnerdbacfc22019-05-16 16:39:26 +02002212 }
Victor Stinner331a6a52019-05-27 16:39:22 +02002213 else if (_PyStatus_IS_ERROR(status)) {
2214 fatal_error(status.func, status.err_msg, 1);
Victor Stinnerdfe88472019-03-01 12:14:41 +01002215 }
2216 else {
Victor Stinner331a6a52019-05-27 16:39:22 +02002217 Py_FatalError("Py_ExitStatusException() must not be called on success");
Victor Stinnerdfe88472019-03-01 12:14:41 +01002218 }
Nick Coghland6009512014-11-20 21:39:37 +10002219}
2220
2221/* Clean up and exit */
2222
Victor Stinnerd7292b52016-06-17 12:29:00 +02002223# include "pythread.h"
Nick Coghland6009512014-11-20 21:39:37 +10002224
Nick Coghland6009512014-11-20 21:39:37 +10002225/* For the atexit module. */
Marcel Plch776407f2017-12-20 11:17:58 +01002226void _Py_PyAtExit(void (*func)(PyObject *), PyObject *module)
Nick Coghland6009512014-11-20 21:39:37 +10002227{
Victor Stinnerb45d2592019-06-20 00:05:23 +02002228 PyInterpreterState *is = _PyInterpreterState_GET_UNSAFE();
Marcel Plch776407f2017-12-20 11:17:58 +01002229
Antoine Pitroufc5db952017-12-13 02:29:07 +01002230 /* Guard against API misuse (see bpo-17852) */
Marcel Plch776407f2017-12-20 11:17:58 +01002231 assert(is->pyexitfunc == NULL || is->pyexitfunc == func);
2232
2233 is->pyexitfunc = func;
2234 is->pyexitmodule = module;
Nick Coghland6009512014-11-20 21:39:37 +10002235}
2236
2237static void
Victor Stinnerb45d2592019-06-20 00:05:23 +02002238call_py_exitfuncs(PyThreadState *tstate)
Nick Coghland6009512014-11-20 21:39:37 +10002239{
Victor Stinnerb45d2592019-06-20 00:05:23 +02002240 PyInterpreterState *interp = tstate->interp;
2241 if (interp->pyexitfunc == NULL)
Nick Coghland6009512014-11-20 21:39:37 +10002242 return;
2243
Victor Stinnerb45d2592019-06-20 00:05:23 +02002244 (*interp->pyexitfunc)(interp->pyexitmodule);
2245 _PyErr_Clear(tstate);
Nick Coghland6009512014-11-20 21:39:37 +10002246}
2247
2248/* Wait until threading._shutdown completes, provided
2249 the threading module was imported in the first place.
2250 The shutdown routine will wait until all non-daemon
2251 "threading" threads have completed. */
2252static void
Victor Stinnerb45d2592019-06-20 00:05:23 +02002253wait_for_thread_shutdown(PyThreadState *tstate)
Nick Coghland6009512014-11-20 21:39:37 +10002254{
Nick Coghland6009512014-11-20 21:39:37 +10002255 _Py_IDENTIFIER(_shutdown);
2256 PyObject *result;
Eric Snow3f9eee62017-09-15 16:35:20 -06002257 PyObject *threading = _PyImport_GetModuleId(&PyId_threading);
Nick Coghland6009512014-11-20 21:39:37 +10002258 if (threading == NULL) {
Victor Stinnerb45d2592019-06-20 00:05:23 +02002259 if (_PyErr_Occurred(tstate)) {
Stefan Krah027b09c2019-03-25 21:50:58 +01002260 PyErr_WriteUnraisable(NULL);
2261 }
2262 /* else: threading not imported */
Nick Coghland6009512014-11-20 21:39:37 +10002263 return;
2264 }
Jeroen Demeyer762f93f2019-07-08 10:19:25 +02002265 result = _PyObject_CallMethodIdNoArgs(threading, &PyId__shutdown);
Nick Coghland6009512014-11-20 21:39:37 +10002266 if (result == NULL) {
2267 PyErr_WriteUnraisable(threading);
2268 }
2269 else {
2270 Py_DECREF(result);
2271 }
2272 Py_DECREF(threading);
Nick Coghland6009512014-11-20 21:39:37 +10002273}
2274
2275#define NEXITFUNCS 32
Nick Coghland6009512014-11-20 21:39:37 +10002276int Py_AtExit(void (*func)(void))
2277{
Eric Snow2ebc5ce2017-09-07 23:51:28 -06002278 if (_PyRuntime.nexitfuncs >= NEXITFUNCS)
Nick Coghland6009512014-11-20 21:39:37 +10002279 return -1;
Eric Snow2ebc5ce2017-09-07 23:51:28 -06002280 _PyRuntime.exitfuncs[_PyRuntime.nexitfuncs++] = func;
Nick Coghland6009512014-11-20 21:39:37 +10002281 return 0;
2282}
2283
2284static void
Victor Stinner8e91c242019-04-24 17:24:01 +02002285call_ll_exitfuncs(_PyRuntimeState *runtime)
Nick Coghland6009512014-11-20 21:39:37 +10002286{
Victor Stinner8e91c242019-04-24 17:24:01 +02002287 while (runtime->nexitfuncs > 0) {
Victor Stinner87d23a02019-04-26 05:49:26 +02002288 /* pop last function from the list */
2289 runtime->nexitfuncs--;
2290 void (*exitfunc)(void) = runtime->exitfuncs[runtime->nexitfuncs];
2291 runtime->exitfuncs[runtime->nexitfuncs] = NULL;
2292
2293 exitfunc();
Victor Stinner8e91c242019-04-24 17:24:01 +02002294 }
Nick Coghland6009512014-11-20 21:39:37 +10002295
2296 fflush(stdout);
2297 fflush(stderr);
2298}
2299
Victor Stinnercfc88312018-08-01 16:41:25 +02002300void _Py_NO_RETURN
Nick Coghland6009512014-11-20 21:39:37 +10002301Py_Exit(int sts)
2302{
Martin Panterb4ce1fc2015-11-30 03:18:29 +00002303 if (Py_FinalizeEx() < 0) {
2304 sts = 120;
2305 }
Nick Coghland6009512014-11-20 21:39:37 +10002306
2307 exit(sts);
2308}
2309
Victor Stinner331a6a52019-05-27 16:39:22 +02002310static PyStatus
Victor Stinnerb45d2592019-06-20 00:05:23 +02002311init_signals(PyThreadState *tstate)
Nick Coghland6009512014-11-20 21:39:37 +10002312{
2313#ifdef SIGPIPE
2314 PyOS_setsig(SIGPIPE, SIG_IGN);
2315#endif
2316#ifdef SIGXFZ
2317 PyOS_setsig(SIGXFZ, SIG_IGN);
2318#endif
2319#ifdef SIGXFSZ
2320 PyOS_setsig(SIGXFSZ, SIG_IGN);
2321#endif
2322 PyOS_InitInterrupts(); /* May imply initsignal() */
Victor Stinnerb45d2592019-06-20 00:05:23 +02002323 if (_PyErr_Occurred(tstate)) {
Victor Stinner331a6a52019-05-27 16:39:22 +02002324 return _PyStatus_ERR("can't import signal");
Nick Coghland6009512014-11-20 21:39:37 +10002325 }
Victor Stinner331a6a52019-05-27 16:39:22 +02002326 return _PyStatus_OK();
Nick Coghland6009512014-11-20 21:39:37 +10002327}
2328
2329
2330/* Restore signals that the interpreter has called SIG_IGN on to SIG_DFL.
2331 *
2332 * All of the code in this function must only use async-signal-safe functions,
2333 * listed at `man 7 signal` or
2334 * http://www.opengroup.org/onlinepubs/009695399/functions/xsh_chap02_04.html.
2335 */
2336void
2337_Py_RestoreSignals(void)
2338{
2339#ifdef SIGPIPE
2340 PyOS_setsig(SIGPIPE, SIG_DFL);
2341#endif
2342#ifdef SIGXFZ
2343 PyOS_setsig(SIGXFZ, SIG_DFL);
2344#endif
2345#ifdef SIGXFSZ
2346 PyOS_setsig(SIGXFSZ, SIG_DFL);
2347#endif
2348}
2349
2350
2351/*
2352 * The file descriptor fd is considered ``interactive'' if either
2353 * a) isatty(fd) is TRUE, or
2354 * b) the -i flag was given, and the filename associated with
2355 * the descriptor is NULL or "<stdin>" or "???".
2356 */
2357int
2358Py_FdIsInteractive(FILE *fp, const char *filename)
2359{
2360 if (isatty((int)fileno(fp)))
2361 return 1;
2362 if (!Py_InteractiveFlag)
2363 return 0;
2364 return (filename == NULL) ||
2365 (strcmp(filename, "<stdin>") == 0) ||
2366 (strcmp(filename, "???") == 0);
2367}
2368
2369
Nick Coghland6009512014-11-20 21:39:37 +10002370/* Wrappers around sigaction() or signal(). */
2371
2372PyOS_sighandler_t
2373PyOS_getsig(int sig)
2374{
2375#ifdef HAVE_SIGACTION
2376 struct sigaction context;
2377 if (sigaction(sig, NULL, &context) == -1)
2378 return SIG_ERR;
2379 return context.sa_handler;
2380#else
2381 PyOS_sighandler_t handler;
2382/* Special signal handling for the secure CRT in Visual Studio 2005 */
2383#if defined(_MSC_VER) && _MSC_VER >= 1400
2384 switch (sig) {
2385 /* Only these signals are valid */
2386 case SIGINT:
2387 case SIGILL:
2388 case SIGFPE:
2389 case SIGSEGV:
2390 case SIGTERM:
2391 case SIGBREAK:
2392 case SIGABRT:
2393 break;
2394 /* Don't call signal() with other values or it will assert */
2395 default:
2396 return SIG_ERR;
2397 }
2398#endif /* _MSC_VER && _MSC_VER >= 1400 */
2399 handler = signal(sig, SIG_IGN);
2400 if (handler != SIG_ERR)
2401 signal(sig, handler);
2402 return handler;
2403#endif
2404}
2405
2406/*
2407 * All of the code in this function must only use async-signal-safe functions,
2408 * listed at `man 7 signal` or
2409 * http://www.opengroup.org/onlinepubs/009695399/functions/xsh_chap02_04.html.
2410 */
2411PyOS_sighandler_t
2412PyOS_setsig(int sig, PyOS_sighandler_t handler)
2413{
2414#ifdef HAVE_SIGACTION
2415 /* Some code in Modules/signalmodule.c depends on sigaction() being
2416 * used here if HAVE_SIGACTION is defined. Fix that if this code
2417 * changes to invalidate that assumption.
2418 */
2419 struct sigaction context, ocontext;
2420 context.sa_handler = handler;
2421 sigemptyset(&context.sa_mask);
2422 context.sa_flags = 0;
2423 if (sigaction(sig, &context, &ocontext) == -1)
2424 return SIG_ERR;
2425 return ocontext.sa_handler;
2426#else
2427 PyOS_sighandler_t oldhandler;
2428 oldhandler = signal(sig, handler);
2429#ifdef HAVE_SIGINTERRUPT
2430 siginterrupt(sig, 1);
2431#endif
2432 return oldhandler;
2433#endif
2434}
2435
2436#ifdef __cplusplus
2437}
2438#endif