Kaydet (Commit) 70195da3 authored tarafından Martin v. Löwis's avatar Martin v. Löwis

Patch #443337: Fix incompatibilities in imputil's behavior.

üst d3011cd1
...@@ -125,6 +125,10 @@ class ImportManager: ...@@ -125,6 +125,10 @@ class ImportManager:
if importer: if importer:
return importer._finish_import(top_module, parts[1:], fromlist) return importer._finish_import(top_module, parts[1:], fromlist)
# Grrr, some people "import os.path"
if len(parts) == 2 and hasattr(top_module, parts[1]):
return top_module
# If the importer does not exist, then we have to bail. A missing # If the importer does not exist, then we have to bail. A missing
# importer means that something else imported the module, and we have # importer means that something else imported the module, and we have
# no knowledge of how to get sub-modules out of the thing. # no knowledge of how to get sub-modules out of the thing.
...@@ -290,7 +294,11 @@ class Importer: ...@@ -290,7 +294,11 @@ class Importer:
exec code in module.__dict__ exec code in module.__dict__
# fetch from sys.modules instead of returning module directly. # fetch from sys.modules instead of returning module directly.
return sys.modules[fqname] # also make module's __name__ agree with fqname, in case
# the "exec code in module.__dict__" played games on us.
module = sys.modules[fqname]
module.__name__ = fqname
return module
def _load_tail(self, m, parts): def _load_tail(self, m, parts):
"""Import the rest of the modules, down from the top-level module. """Import the rest of the modules, down from the top-level module.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment