bpo-36900: Replace global conf vars with config (GH-13299)
Replace global configuration variables with core_config read from the current interpreter. Cleanup dynload_hpux.c.
This commit is contained in:
parent
3c93153f7d
commit
c96be811fa
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#define PY_SSIZE_T_CLEAN
|
#define PY_SSIZE_T_CLEAN
|
||||||
#include "Python.h"
|
#include "Python.h"
|
||||||
|
#include "pycore_pystate.h" /* _PyInterpreterState_GET_UNSAFE() */
|
||||||
#include "structmember.h"
|
#include "structmember.h"
|
||||||
#include "_iomodule.h"
|
#include "_iomodule.h"
|
||||||
|
|
||||||
|
@ -376,7 +377,8 @@ _io_open_impl(PyObject *module, PyObject *file, const char *mode,
|
||||||
{
|
{
|
||||||
PyObject *RawIO_class = (PyObject *)&PyFileIO_Type;
|
PyObject *RawIO_class = (PyObject *)&PyFileIO_Type;
|
||||||
#ifdef MS_WINDOWS
|
#ifdef MS_WINDOWS
|
||||||
if (!Py_LegacyWindowsStdioFlag && _PyIO_get_console_type(path_or_fd) != '\0') {
|
_PyCoreConfig *config = &_PyInterpreterState_GET_UNSAFE()->core_config;
|
||||||
|
if (!config->legacy_windows_stdio && _PyIO_get_console_type(path_or_fd) != '\0') {
|
||||||
RawIO_class = (PyObject *)&PyWindowsConsoleIO_Type;
|
RawIO_class = (PyObject *)&PyWindowsConsoleIO_Type;
|
||||||
encoding = "utf-8";
|
encoding = "utf-8";
|
||||||
}
|
}
|
||||||
|
|
|
@ -403,8 +403,8 @@ static int
|
||||||
pymain_run_stdin(_PyCoreConfig *config, PyCompilerFlags *cf)
|
pymain_run_stdin(_PyCoreConfig *config, PyCompilerFlags *cf)
|
||||||
{
|
{
|
||||||
if (stdin_is_interactive(config)) {
|
if (stdin_is_interactive(config)) {
|
||||||
Py_InspectFlag = 0; /* do exit on SystemExit */
|
|
||||||
config->inspect = 0;
|
config->inspect = 0;
|
||||||
|
Py_InspectFlag = 0; /* do exit on SystemExit */
|
||||||
pymain_run_startup(config, cf);
|
pymain_run_startup(config, cf);
|
||||||
pymain_run_interactive_hook();
|
pymain_run_interactive_hook();
|
||||||
}
|
}
|
||||||
|
@ -425,17 +425,17 @@ pymain_repl(_PyCoreConfig *config, PyCompilerFlags *cf, int *exitcode)
|
||||||
{
|
{
|
||||||
/* Check this environment variable at the end, to give programs the
|
/* Check this environment variable at the end, to give programs the
|
||||||
opportunity to set it from Python. */
|
opportunity to set it from Python. */
|
||||||
if (!Py_InspectFlag && _Py_GetEnv(config->use_environment, "PYTHONINSPECT")) {
|
if (!config->inspect && _Py_GetEnv(config->use_environment, "PYTHONINSPECT")) {
|
||||||
Py_InspectFlag = 1;
|
|
||||||
config->inspect = 1;
|
config->inspect = 1;
|
||||||
|
Py_InspectFlag = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(Py_InspectFlag && stdin_is_interactive(config) && RUN_CODE(config))) {
|
if (!(config->inspect && stdin_is_interactive(config) && RUN_CODE(config))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Py_InspectFlag = 0;
|
|
||||||
config->inspect = 0;
|
config->inspect = 0;
|
||||||
|
Py_InspectFlag = 0;
|
||||||
pymain_run_interactive_hook();
|
pymain_run_interactive_hook();
|
||||||
|
|
||||||
int res = PyRun_AnyFileFlags(stdin, "<stdin>", cf);
|
int res = PyRun_AnyFileFlags(stdin, "<stdin>", cf);
|
||||||
|
|
|
@ -998,7 +998,8 @@ bytearray_repr(PyByteArrayObject *self)
|
||||||
static PyObject *
|
static PyObject *
|
||||||
bytearray_str(PyObject *op)
|
bytearray_str(PyObject *op)
|
||||||
{
|
{
|
||||||
if (Py_BytesWarningFlag) {
|
_PyCoreConfig *config = &_PyInterpreterState_GET_UNSAFE()->core_config;
|
||||||
|
if (config->bytes_warning) {
|
||||||
if (PyErr_WarnEx(PyExc_BytesWarning,
|
if (PyErr_WarnEx(PyExc_BytesWarning,
|
||||||
"str() on a bytearray instance", 1)) {
|
"str() on a bytearray instance", 1)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -1023,7 +1024,8 @@ bytearray_richcompare(PyObject *self, PyObject *other, int op)
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (rc) {
|
if (rc) {
|
||||||
if (Py_BytesWarningFlag && (op == Py_EQ || op == Py_NE)) {
|
_PyCoreConfig *config = &_PyInterpreterState_GET_UNSAFE()->core_config;
|
||||||
|
if (config->bytes_warning && (op == Py_EQ || op == Py_NE)) {
|
||||||
if (PyErr_WarnEx(PyExc_BytesWarning,
|
if (PyErr_WarnEx(PyExc_BytesWarning,
|
||||||
"Comparison between bytearray and string", 1))
|
"Comparison between bytearray and string", 1))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
|
@ -1421,7 +1421,8 @@ bytes_repr(PyObject *op)
|
||||||
static PyObject *
|
static PyObject *
|
||||||
bytes_str(PyObject *op)
|
bytes_str(PyObject *op)
|
||||||
{
|
{
|
||||||
if (Py_BytesWarningFlag) {
|
_PyCoreConfig *config = &_PyInterpreterState_GET_UNSAFE()->core_config;
|
||||||
|
if (config->bytes_warning) {
|
||||||
if (PyErr_WarnEx(PyExc_BytesWarning,
|
if (PyErr_WarnEx(PyExc_BytesWarning,
|
||||||
"str() on a bytes instance", 1)) {
|
"str() on a bytes instance", 1)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -1578,7 +1579,8 @@ bytes_richcompare(PyBytesObject *a, PyBytesObject *b, int op)
|
||||||
|
|
||||||
/* Make sure both arguments are strings. */
|
/* Make sure both arguments are strings. */
|
||||||
if (!(PyBytes_Check(a) && PyBytes_Check(b))) {
|
if (!(PyBytes_Check(a) && PyBytes_Check(b))) {
|
||||||
if (Py_BytesWarningFlag && (op == Py_EQ || op == Py_NE)) {
|
_PyCoreConfig *config = &_PyInterpreterState_GET_UNSAFE()->core_config;
|
||||||
|
if (config->bytes_warning && (op == Py_EQ || op == Py_NE)) {
|
||||||
rc = PyObject_IsInstance((PyObject*)a,
|
rc = PyObject_IsInstance((PyObject*)a,
|
||||||
(PyObject*)&PyUnicode_Type);
|
(PyObject*)&PyUnicode_Type);
|
||||||
if (!rc)
|
if (!rc)
|
||||||
|
|
|
@ -590,13 +590,15 @@ _PyModule_ClearDict(PyObject *d)
|
||||||
Py_ssize_t pos;
|
Py_ssize_t pos;
|
||||||
PyObject *key, *value;
|
PyObject *key, *value;
|
||||||
|
|
||||||
|
int verbose = _PyInterpreterState_GET_UNSAFE()->core_config.verbose;
|
||||||
|
|
||||||
/* First, clear only names starting with a single underscore */
|
/* First, clear only names starting with a single underscore */
|
||||||
pos = 0;
|
pos = 0;
|
||||||
while (PyDict_Next(d, &pos, &key, &value)) {
|
while (PyDict_Next(d, &pos, &key, &value)) {
|
||||||
if (value != Py_None && PyUnicode_Check(key)) {
|
if (value != Py_None && PyUnicode_Check(key)) {
|
||||||
if (PyUnicode_READ_CHAR(key, 0) == '_' &&
|
if (PyUnicode_READ_CHAR(key, 0) == '_' &&
|
||||||
PyUnicode_READ_CHAR(key, 1) != '_') {
|
PyUnicode_READ_CHAR(key, 1) != '_') {
|
||||||
if (Py_VerboseFlag > 1) {
|
if (verbose > 1) {
|
||||||
const char *s = PyUnicode_AsUTF8(key);
|
const char *s = PyUnicode_AsUTF8(key);
|
||||||
if (s != NULL)
|
if (s != NULL)
|
||||||
PySys_WriteStderr("# clear[1] %s\n", s);
|
PySys_WriteStderr("# clear[1] %s\n", s);
|
||||||
|
@ -617,7 +619,7 @@ _PyModule_ClearDict(PyObject *d)
|
||||||
if (PyUnicode_READ_CHAR(key, 0) != '_' ||
|
if (PyUnicode_READ_CHAR(key, 0) != '_' ||
|
||||||
!_PyUnicode_EqualToASCIIString(key, "__builtins__"))
|
!_PyUnicode_EqualToASCIIString(key, "__builtins__"))
|
||||||
{
|
{
|
||||||
if (Py_VerboseFlag > 1) {
|
if (verbose > 1) {
|
||||||
const char *s = PyUnicode_AsUTF8(key);
|
const char *s = PyUnicode_AsUTF8(key);
|
||||||
if (s != NULL)
|
if (s != NULL)
|
||||||
PySys_WriteStderr("# clear[2] %s\n", s);
|
PySys_WriteStderr("# clear[2] %s\n", s);
|
||||||
|
@ -675,8 +677,10 @@ module___init___impl(PyModuleObject *self, PyObject *name, PyObject *doc)
|
||||||
static void
|
static void
|
||||||
module_dealloc(PyModuleObject *m)
|
module_dealloc(PyModuleObject *m)
|
||||||
{
|
{
|
||||||
|
int verbose = _PyInterpreterState_GET_UNSAFE()->core_config.verbose;
|
||||||
|
|
||||||
PyObject_GC_UnTrack(m);
|
PyObject_GC_UnTrack(m);
|
||||||
if (Py_VerboseFlag && m->md_name) {
|
if (verbose && m->md_name) {
|
||||||
PySys_FormatStderr("# destroy %S\n", m->md_name);
|
PySys_FormatStderr("# destroy %S\n", m->md_name);
|
||||||
}
|
}
|
||||||
if (m->md_weaklist != NULL)
|
if (m->md_weaklist != NULL)
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include "Python.h"
|
#include "Python.h"
|
||||||
|
|
||||||
#include "Python-ast.h"
|
#include "Python-ast.h"
|
||||||
|
#include "pycore_pystate.h" /* _PyInterpreterState_GET_UNSAFE() */
|
||||||
#include "ast.h"
|
#include "ast.h"
|
||||||
#include "code.h"
|
#include "code.h"
|
||||||
#include "symtable.h"
|
#include "symtable.h"
|
||||||
|
@ -310,6 +311,7 @@ PyAST_CompileObject(mod_ty mod, PyObject *filename, PyCompilerFlags *flags,
|
||||||
PyCodeObject *co = NULL;
|
PyCodeObject *co = NULL;
|
||||||
PyCompilerFlags local_flags;
|
PyCompilerFlags local_flags;
|
||||||
int merged;
|
int merged;
|
||||||
|
_PyCoreConfig *config = &_PyInterpreterState_GET_UNSAFE()->core_config;
|
||||||
|
|
||||||
if (!__doc__) {
|
if (!__doc__) {
|
||||||
__doc__ = PyUnicode_InternFromString("__doc__");
|
__doc__ = PyUnicode_InternFromString("__doc__");
|
||||||
|
@ -338,7 +340,7 @@ PyAST_CompileObject(mod_ty mod, PyObject *filename, PyCompilerFlags *flags,
|
||||||
c.c_future->ff_features = merged;
|
c.c_future->ff_features = merged;
|
||||||
flags->cf_flags = merged;
|
flags->cf_flags = merged;
|
||||||
c.c_flags = flags;
|
c.c_flags = flags;
|
||||||
c.c_optimize = (optimize == -1) ? Py_OptimizeFlag : optimize;
|
c.c_optimize = (optimize == -1) ? config->optimization_level : optimize;
|
||||||
c.c_nestlevel = 0;
|
c.c_nestlevel = 0;
|
||||||
|
|
||||||
if (!_PyAST_Optimize(mod, arena, c.c_optimize)) {
|
if (!_PyAST_Optimize(mod, arena, c.c_optimize)) {
|
||||||
|
|
|
@ -19,48 +19,47 @@ dl_funcptr _PyImport_FindSharedFuncptr(const char *prefix,
|
||||||
const char *shortname,
|
const char *shortname,
|
||||||
const char *pathname, FILE *fp)
|
const char *pathname, FILE *fp)
|
||||||
{
|
{
|
||||||
dl_funcptr p;
|
int flags = BIND_FIRST | BIND_DEFERRED;
|
||||||
shl_t lib;
|
int verbose = _PyInterpreterState_GET_UNSAFE()->core_config.verbose;
|
||||||
int flags;
|
if (verbose) {
|
||||||
char funcname[258];
|
|
||||||
|
|
||||||
flags = BIND_FIRST | BIND_DEFERRED;
|
|
||||||
if (Py_VerboseFlag) {
|
|
||||||
flags = BIND_FIRST | BIND_IMMEDIATE |
|
flags = BIND_FIRST | BIND_IMMEDIATE |
|
||||||
BIND_NONFATAL | BIND_VERBOSE;
|
BIND_NONFATAL | BIND_VERBOSE;
|
||||||
printf("shl_load %s\n",pathname);
|
printf("shl_load %s\n",pathname);
|
||||||
}
|
}
|
||||||
lib = shl_load(pathname, flags, 0);
|
|
||||||
|
shl_t lib = shl_load(pathname, flags, 0);
|
||||||
/* XXX Chuck Blake once wrote that 0 should be BIND_NOSTART? */
|
/* XXX Chuck Blake once wrote that 0 should be BIND_NOSTART? */
|
||||||
if (lib == NULL) {
|
if (lib == NULL) {
|
||||||
char buf[256];
|
if (verbose) {
|
||||||
PyObject *pathname_ob = NULL;
|
|
||||||
PyObject *buf_ob = NULL;
|
|
||||||
PyObject *shortname_ob = NULL;
|
|
||||||
|
|
||||||
if (Py_VerboseFlag)
|
|
||||||
perror(pathname);
|
perror(pathname);
|
||||||
|
}
|
||||||
|
char buf[256];
|
||||||
PyOS_snprintf(buf, sizeof(buf), "Failed to load %.200s",
|
PyOS_snprintf(buf, sizeof(buf), "Failed to load %.200s",
|
||||||
pathname);
|
pathname);
|
||||||
buf_ob = PyUnicode_FromString(buf);
|
PyObject *buf_ob = PyUnicode_FromString(buf);
|
||||||
shortname_ob = PyUnicode_FromString(shortname);
|
PyObject *shortname_ob = PyUnicode_FromString(shortname);
|
||||||
pathname_ob = PyUnicode_FromString(pathname);
|
PyObject *pathname_ob = PyUnicode_FromString(pathname);
|
||||||
PyErr_SetImportError(buf_ob, shortname_ob, pathname_ob);
|
PyErr_SetImportError(buf_ob, shortname_ob, pathname_ob);
|
||||||
Py_DECREF(buf_ob);
|
Py_DECREF(buf_ob);
|
||||||
Py_DECREF(shortname_ob);
|
Py_DECREF(shortname_ob);
|
||||||
Py_DECREF(pathname_ob);
|
Py_DECREF(pathname_ob);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char funcname[258];
|
||||||
PyOS_snprintf(funcname, sizeof(funcname), FUNCNAME_PATTERN,
|
PyOS_snprintf(funcname, sizeof(funcname), FUNCNAME_PATTERN,
|
||||||
prefix, shortname);
|
prefix, shortname);
|
||||||
if (Py_VerboseFlag)
|
if (verbose) {
|
||||||
printf("shl_findsym %s\n", funcname);
|
printf("shl_findsym %s\n", funcname);
|
||||||
|
}
|
||||||
|
|
||||||
|
dl_funcptr p;
|
||||||
if (shl_findsym(&lib, funcname, TYPE_UNDEFINED, (void *) &p) == -1) {
|
if (shl_findsym(&lib, funcname, TYPE_UNDEFINED, (void *) &p) == -1) {
|
||||||
shl_unload(lib);
|
shl_unload(lib);
|
||||||
p = NULL;
|
p = NULL;
|
||||||
}
|
}
|
||||||
if (p == NULL && Py_VerboseFlag)
|
if (p == NULL && verbose) {
|
||||||
perror(funcname);
|
perror(funcname);
|
||||||
|
}
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
|
@ -150,12 +150,13 @@ init_importlib(PyInterpreterState *interp, PyObject *sysmod)
|
||||||
PyObject *importlib;
|
PyObject *importlib;
|
||||||
PyObject *impmod;
|
PyObject *impmod;
|
||||||
PyObject *value;
|
PyObject *value;
|
||||||
|
int verbose = interp->core_config.verbose;
|
||||||
|
|
||||||
/* Import _importlib through its frozen version, _frozen_importlib. */
|
/* Import _importlib through its frozen version, _frozen_importlib. */
|
||||||
if (PyImport_ImportFrozenModule("_frozen_importlib") <= 0) {
|
if (PyImport_ImportFrozenModule("_frozen_importlib") <= 0) {
|
||||||
return _Py_INIT_ERR("can't import _frozen_importlib");
|
return _Py_INIT_ERR("can't import _frozen_importlib");
|
||||||
}
|
}
|
||||||
else if (Py_VerboseFlag) {
|
else if (verbose) {
|
||||||
PySys_FormatStderr("import _frozen_importlib # frozen\n");
|
PySys_FormatStderr("import _frozen_importlib # frozen\n");
|
||||||
}
|
}
|
||||||
importlib = PyImport_AddModule("_frozen_importlib");
|
importlib = PyImport_AddModule("_frozen_importlib");
|
||||||
|
@ -175,7 +176,7 @@ init_importlib(PyInterpreterState *interp, PyObject *sysmod)
|
||||||
if (impmod == NULL) {
|
if (impmod == NULL) {
|
||||||
return _Py_INIT_ERR("can't import _imp");
|
return _Py_INIT_ERR("can't import _imp");
|
||||||
}
|
}
|
||||||
else if (Py_VerboseFlag) {
|
else if (verbose) {
|
||||||
PySys_FormatStderr("import _imp # builtin\n");
|
PySys_FormatStderr("import _imp # builtin\n");
|
||||||
}
|
}
|
||||||
if (_PyImport_SetModuleString("_imp", impmod) < 0) {
|
if (_PyImport_SetModuleString("_imp", impmod) < 0) {
|
||||||
|
|
|
@ -591,10 +591,12 @@ handle_system_exit(void)
|
||||||
PyObject *exception, *value, *tb;
|
PyObject *exception, *value, *tb;
|
||||||
int exitcode = 0;
|
int exitcode = 0;
|
||||||
|
|
||||||
if (Py_InspectFlag)
|
int inspect = _PyInterpreterState_GET_UNSAFE()->core_config.inspect;
|
||||||
|
if (inspect) {
|
||||||
/* Don't exit if -i flag was given. This flag is set to 0
|
/* Don't exit if -i flag was given. This flag is set to 0
|
||||||
* when entering interactive mode for inspecting. */
|
* when entering interactive mode for inspecting. */
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
PyErr_Fetch(&exception, &value, &tb);
|
PyErr_Fetch(&exception, &value, &tb);
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
|
|
Loading…
Reference in New Issue