You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Is your feature request related to a problem? Please describe.
deptry currently relies on the presence on __init__.py files in the directories present in the root directory to determine if a module is a first party one or not.
This covers most usages of the tool, but there are situations where __init__.py is not used at all, as it's not something that is required anymore since PEP 420.
This is the case of well known projects like Poetry and PDM, for instance.
Additionally, some projects might mangle with PYTHONPATH to make modules importable as if they are first party ones, even if they are located in a sub-directory.
Describe the solution you would like
Providing the ability to explicitly specify a list of known first party modules, additionally to what deptry will automatically guess, may help covering those use cases. This is something that isort implements through known_first_party parameter, for instance.
The text was updated successfully, but these errors were encountered:
Creating this issue makes me think that we could maybe also implement something similar to known_third_party, where instead of having a list, we would have a mapping between a dependency name and its Python module name(s) (which would mostly be required in case they don't match).
This could enable a way to run deptry without the need to have access to the virtual environment, at the cost of having a complex mapping to maintain, but maybe this is something that some users could be interested in? Tell me what you think @fpgmaas, I'd be happy to open another issue for this if you think this could be useful.
On the known first party argument; this definitely seems useful to me, agree that this would be a good addition.
On the known third party argument; I think the cost of maintaining this mapping would be quite high, and also is quite prone to user-error; it would need to be updated anytime a dependency is added. I doubt if anyone would actually use this functionality if we add it. Maybe we can/should wait until an issue is raised that would be solved by adding this functionality?
Is your feature request related to a problem? Please describe.
deptry
currently relies on the presence on__init__.py
files in the directories present in the root directory to determine if a module is a first party one or not.This covers most usages of the tool, but there are situations where
__init__.py
is not used at all, as it's not something that is required anymore since PEP 420.This is the case of well known projects like Poetry and PDM, for instance.
Additionally, some projects might mangle with
PYTHONPATH
to make modules importable as if they are first party ones, even if they are located in a sub-directory.Describe the solution you would like
Providing the ability to explicitly specify a list of known first party modules, additionally to what
deptry
will automatically guess, may help covering those use cases. This is something thatisort
implements throughknown_first_party
parameter, for instance.The text was updated successfully, but these errors were encountered: