]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Patch #443337: Fix incompatibilities in imputil's behavior.
authorMartin v. Löwis <martin@v.loewis.de>
Sat, 28 Jul 2001 20:33:41 +0000 (20:33 +0000)
committerMartin v. Löwis <martin@v.loewis.de>
Sat, 28 Jul 2001 20:33:41 +0000 (20:33 +0000)
Lib/imputil.py

index 6017f6cb230fa73d25ac7f428d8e460a3fb5be0c..eb53e070e5eb1456f345ed4ce2f2d04d381b1120 100644 (file)
@@ -125,6 +125,10 @@ class ImportManager:
         if importer:
             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
         # importer means that something else imported the module, and we have
         # no knowledge of how to get sub-modules out of the thing.
@@ -290,7 +294,11 @@ class Importer:
             exec code in module.__dict__
 
         # 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):
         """Import the rest of the modules, down from the top-level module.