-
Notifications
You must be signed in to change notification settings - Fork 205
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add mypy type hints? #68
Comments
I am open to it. Pull request welcome. |
Fair enough. If I can get some time to devote to it I'll see what I can do. |
If this is still desired, I would like to take this issue on. |
I wrote a stubfile for SortedList and SortedListWithKeys. I've never written a type hints for someone else's project so I'm hoping to get some feedback before I continue with the remaining classes. https://github.com/ssbothwell/sorted_containers/blob/master/sortedcontainers/sortedlist.pyi Thanks! |
Off the bat I think it's probably wrong to use the The class should probably extend |
Thanks for the feedback. The Orderable type alias seemed questionable to me but I went with it as an initial draft. I'm assuming that in this type of situation the type hints are meant mainly for IDE support rather then static analysis. Given that, maybe Iterable[Any] is not a big problem. I could also alias Iterable[Any] to Orderable as a hint for developers that the method is actually taking an orderable object while still not breaking static analysis. What do you think? |
PEP484 has a solution using a Type Variable with an upper bound. Any type replacing the type variable must implement the This ensures only types with inequality are passed but not that they all can be compared to each other. It sounds like this is the best solution we are going to get for the time being. I updated my stub file to include this. On another note, mypy throws some "incompatible with supertype" errors for methods in SortedListWithKey that overload those in SortedList. An example is I also get an error about |
Sorry for the silence on this issue. I don't remember getting email updates. I've been working on V2 which will adopt Python 3 semantics for some APIs while still being backwards-compatible with Python 2. I'm afraid I've changed some of the parameter names which will require updating in your pyi file. I'm also not sure how to test your pyi file. |
If you're still open to this, I can work up a PR |
I'm open to it. Still prefer pyi over source changes. And I'm not sure how to test it. It'll be a learning experience for me. |
I'm not actively doing python at the moment but do feel free to ping me with any questions, I'd be happy to help you work through any issues you come across. |
@grantjenks Oh, I just saw this thread after I submitted #136 . What do you think of the pull request? |
I'd just like to express my interest in this feature. Has there been any more progress with the pull request? |
I think the realistic timeline for me understanding type hints and merging these is still months away. Given that it's already been years, I'd suggest contributing them to the typeshed at https://github.com/python/typeshed/blob/master/CONTRIBUTING.md Is there anyone willing to pursue maintaining type hints there? |
Worth noting that the main problem with adding type hints to this is the dynamic structure of all the The biggest problem here is the complicated methods involved in It probably is possible to hack together some sort of solution together, but this is really not ideal. Doing so makes it harder for those using type hints to figure out what the expected type is trying to say, which arguably defeats much of the purpose. Likewise, the use of There are ways to redesign this package in such a way that adding type hints is more sensible.
For the second point, the idea is that one would add the following: # If key is None, which it is by default, then return a SortedList.
@overload
def sorted_list(
iterable: Optional[Iterable[T]] = ..., key: None = ...
) -> SortedList[T]: ...
# Otherwise key should be a function accepting values and returning keys.
# If provided, the iterable should match the necessary values.
# This case returns a sorted key list with the appropriate key and value types.
@overload
def sorted_list(
iterable: Optional[Iterable[VT]] = ..., key: Callable[[VT], KT]
) -> SortedKeyList[KT, VT]: ...
# The type hints above would be added to typeshed,
# while the below implementation would be added here.
def sorted_list(iterable=None, key=None):
if key is None:
return SortedList(iterable)
else:
return SortedKeyList(iterable, key) These constructor functions can be added without removing the current approach with |
For those looking for something to use today, see these: https://github.com/h4l/sortedcontainers-stubs They work very well for me! |
I ended up writing my own
|
Hi! What's new?! Still no typing from 2017?!... :/ |
This would help people who'd like to use sortedcontainers in a project with mypy type checking.
https://github.com/python/mypy/wiki/Creating-Stubs-For-Python-Modules
The text was updated successfully, but these errors were encountered: