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
After the last mypy update v0.920, I started to notice an inconsistency with how the module variable __path__ is typed mainly across typeshed, mypy, and pyright.
`__path__` must be an iterable of strings, but it may be empty.
However the docs for pkgutil.extend_path go on say it's mostly a list (?) cpython/pkgutil.py
If the input path is not a list (as is the case for frozen
packages) it is returned unchanged. The input path is not
modified; an extended copy is returned. Items are only appended
to the copy at the end.
From my point of view, it isn't entirely clear what the "correct" type should be. Some points to consider though:
In most cases it seems to be a list[str].
It was mentioned here however that it can sometimes also be a MutableSequence[str]
The __path__ type should be valid as first argument to pkgutil.extend_path. At the moment that only applies to list[str] but obviously the argument type for extend_path could be changed to, for example, accept a TypeVar bound to Iterable[str] instead.
It seems to be fairly common (and safe ?) to access the at least the first item of __path__ via __getitem__.
The text was updated successfully, but these errors were encountered:
How we annotate ModuleType.__path__ is a harder question. (But we should definitely add a comment that it's only available for packages, not for plain modules.) We could use list[str], because that's the import system's default. But according to the comment in extend_path(), it can be another type for frozen packages. I guess our current solution of MutableSequence is also wrong for that case. According to the Python docs, we should use Iterable[str], but that prevents modifying the path when it actually is mutable. I don't have a good solution and not strong opinion, but a slight preference for Iterable[str].
After the last mypy update v0.920, I started to notice an inconsistency with how the module variable
__path__
is typed mainly across typeshed, mypy, and pyright.ModuleType
MutableSequence[str]
pkgutil.extend_path
list[str]
list[str]
Iterable[str]
In the Python docs it's mentioned as:
However the docs for
pkgutil.extend_path
go on say it's mostly a list (?) cpython/pkgutil.pyFrom my point of view, it isn't entirely clear what the "correct" type should be. Some points to consider though:
list[str]
.MutableSequence[str]
__path__
type should be valid as first argument topkgutil.extend_path
. At the moment that only applies tolist[str]
but obviously the argument type forextend_path
could be changed to, for example, accept a TypeVar bound toIterable[str]
instead.__path__
via__getitem__
.The text was updated successfully, but these errors were encountered: