Uh oh!
There was an error while loading. Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork 34k
Open
Labels
stdlibStandard Library Python modules in the Lib/ directoryStandard Library Python modules in the Lib/ directorytype-bugAn unexpected behavior, bug, or errorAn unexpected behavior, bug, or error
Description
Bug report
inspect.getfile handles all __file__ is None modules as built-in. Cf.
Lines 898 to 901 in f298ba1
| ifismodule(object): | |
| ifgetattr(object, '__file__', None): | |
| returnobject.__file__ | |
| raiseTypeError('{!r} is a built-in module'.format(object)) |
This leads to PEP 420 packages being treated as built-in, as implicit namespaces have file set to None, but __path__ set to the actual path.
Creating PEP 420 directory:
~ ❯❯❯ mkdir python_test ~ ❯❯❯ vim python_test/hello.pyPython interpreter
Python 3.9.7 (default, Oct 10 2021, 14:08:54) [GCC 8.3.0] on linux Type "help", "copyright", "credits" or "license" for more information. >>> import python_test >>> import inspect >>> inspect.getfile(python_test) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/opt/python-3.9.7/lib/python3.9/inspect.py", line 660, in getfile raise TypeError('{!r} is a built-in module'.format(object)) TypeError: <module 'python_test' (namespace)> is a built-in module >>> print(python_test.__file__) None >>> print(python_test.__path__) _NamespacePath(['/home/thetechrobo/python_test']) Your environment
- CPython versions tested on: 3.9.7
- Operating system and architecture: Elive Linux 3.8.27 64-bit (Debian Bullseye); custom Python installation
Apologies if this is a duplicate. I've searched for any related issues, but I may have missed one.
Linked PRs
Metadata
Metadata
Assignees
Labels
stdlibStandard Library Python modules in the Lib/ directoryStandard Library Python modules in the Lib/ directorytype-bugAn unexpected behavior, bug, or errorAn unexpected behavior, bug, or error
Projects
Status
No status