summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNick Coghlan <ncoghlan@gmail.com>2012-07-15 09:10:39 (GMT)
committerNick Coghlan <ncoghlan@gmail.com>2012-07-15 09:10:39 (GMT)
commit3f94cbf9eba7adef027cfc5d087b3660800df9d7 (patch)
tree832bb91df8040ab37576ebfc1d2950b01c3f7111
parent8dbe5b5568a9755b3e7c0f71df4b26a13893fd68 (diff)
downloadcpython-3f94cbf9eba7adef027cfc5d087b3660800df9d7.zip
cpython-3f94cbf9eba7adef027cfc5d087b3660800df9d7.tar.gz
cpython-3f94cbf9eba7adef027cfc5d087b3660800df9d7.tar.bz2
Actually initialize __main__.__loader__ with loader instances, not the corresponding type objects
-rw-r--r--Lib/test/test_cmd_line_script.py3
-rw-r--r--Python/pythonrun.c8
2 files changed, 8 insertions, 3 deletions
diff --git a/Lib/test/test_cmd_line_script.py b/Lib/test/test_cmd_line_script.py
index 849abe2..8b6083e 100644
--- a/Lib/test/test_cmd_line_script.py
+++ b/Lib/test/test_cmd_line_script.py
@@ -37,7 +37,8 @@ f()
assertEqual(result, ['Top level assignment', 'Lower level reference'])
# Check population of magic variables
assertEqual(__name__, '__main__')
-_loader = __loader__ if isinstance(__loader__, type) else type(__loader__)
+from importlib.machinery import BuiltinImporter
+_loader = __loader__ if __loader__ is BuiltinImporter else type(__loader__)
print('__loader__==%a' % _loader)
print('__file__==%a' % __file__)
assertEqual(__cached__, None)
diff --git a/Python/pythonrun.c b/Python/pythonrun.c
index 970834e..8130cc5 100644
--- a/Python/pythonrun.c
+++ b/Python/pythonrun.c
@@ -1355,11 +1355,15 @@ set_main_loader(PyObject *d, const char *filename, const char *loader_name)
{
PyInterpreterState *interp;
PyThreadState *tstate;
- PyObject *loader;
+ PyObject *loader_type, *loader;
/* Get current thread state and interpreter pointer */
tstate = PyThreadState_GET();
interp = tstate->interp;
- loader = PyObject_GetAttrString(interp->importlib, loader_name);
+ loader_type = PyObject_GetAttrString(interp->importlib, loader_name);
+ if (loader_type == NULL) {
+ return -1;
+ }
+ loader = PyObject_CallFunction(loader_type, "ss", "__main__", filename);
if (loader == NULL ||
(PyDict_SetItemString(d, "__loader__", loader) < 0)) {
return -1;