-
-
Notifications
You must be signed in to change notification settings - Fork 31.5k
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
GH-118761: Expose more core interpreter types in _types
#132103
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It might be worth adding a _pytypes
module to hold the pure-Python fallbacks.
As in the following? try:
from _types import *
except ImportError:
from _pytypes import * Could you elaborate on the benefits? |
One benefit is that it reduces by one the indentation level and it's easier to read/modify I think. Also, we do it for |
Co-authored-by: Bénédikt Tran <[email protected]>
Yeah, what Bénédikt said. It seems cleaner to encapsulate each implementation. |
A |
I don't have much of a preference, it's just prettier. Are we planning to implement the other functions in C? |
I'm not personally, though Yury left a TODO comment by A |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM. Let's do a _pytypes
module in a follow-up if we decide to implement the rest of the functions in C.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just some cosmetic suggesetions. Concerning the spaces before the comments, I don't think we now need to have some column-aligned comments (it's not even clear that they are aligned in the first place).
Co-authored-by: Bénédikt Tran <[email protected]>
This was discussed in #131969 (cc @ZeroIntensity), but deferred to get the smaller change in. This PR adds all of the core interpreter types currently exposed in the
types
module to_typesmodule.c
. We then change the definition oftypes.py
to prefer these, but if the_types
module is not available, to use the pure-Python fallbacks.Strictly, this isn't needed, as
_types
is a built-in module. I think it might be helpful to keep the pure Python definitions for other implementations (PyPy, etc), and perhaps as a quick reminder of what each type looks like. Open to thoughts on this, as it would clearly be simpler to replace everything withfrom _types import *
.I've initially categorised this under #118761, as this does provide a ~15% speed-up for me (1627µs to 1403µs).
A