-
Notifications
You must be signed in to change notification settings - Fork 2.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
Standardize type comments #4467
base: main
Are you sure you want to change the base?
Conversation
51c5134
to
92a7bfa
Compare
CHANGES.md
Outdated
@@ -22,6 +22,7 @@ | |||
- Fix crashes involving comments in parenthesised return types or `X | Y` style unions. | |||
(#4453) | |||
- Fix skipping Jupyter cells with unknown `%%` magic (#4462) | |||
- Standardize type comments to always have one space (#4467) |
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.
This has to be in the preview style, not the stable style. You'll have to add a new member to the Preview enum and branch on that check; you can look for recent PRs that added preview features for examples.
This means that in the preview style we will normalize type comments on the next release, but in the stable style we will not, and when we release stable Black 25.0 in January this change will likely move to the stable style.
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.
I believe I’ve figured it out after following some recent PRs. However, I’m still unclear about your reference to adding a new member to the Preview branch. Are you referring to a Git branch? The PR I followed was merged directly into main
, so I don’t think that’s the case. Could you clarify?
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.
By "branch" I mean an if statement, something like "if Preview.something in mode: do one thing; else: do another thing".
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.
Got it! That clarifies how my changes only impact the preview mode.
Currently, neither of the functions I'm modifying includes mode
in their parameters. Should I update the function signatures to incorporate it?
I also have a question regarding testing. I’ve made changes to the type_comment_syntax_error
file to test the new standardized type comments with the --preview
flag, removing the old tests in the process. Would it be better to create a new file and retain the old tests, or is there a preferred approach for handling this?
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.
Yes, you should add a mode parameter. And yes, it would be better to add a new file.
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.
I've injected the mode
as requested and added tests for the stable version. During this process, I had to make the Mode
class hashable, as injecting mode
into the call chain triggered multiple TypeError: unhashable type: 'Mode'
errors in the unit tests.
However, I’m concerned that adding a hash function to the Mode
class might introduce unintended side effects.
Would you consider the creation of this hash
function appropriate, or is there a better way to address the TypeError: unhashable type: 'Mode'
issue?
I am also facing some issues with the readthedocs
build, it successfully runs on my local machine (MacOS), but on GitHub it seems to fail. The log says "Failed to checkout revision: aeca4e4", which is indeed the commit hash. Maybe some issue since I force pushed?
Thank you for your guidance!
92a7bfa
to
ccdde24
Compare
ccdde24
to
aeca4e4
Compare
|
||
is_type_comment = ( | ||
re.match(r"^\s*type:", content) | ||
if Preview.type_comments_standardization in mode |
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.
Aren't the two branches of this if-else equivalent?
@@ -251,13 +252,6 @@ class Mode: | |||
enabled_features: set[Preview] = field(default_factory=set) | |||
|
|||
def __contains__(self, feature: Preview) -> bool: | |||
""" |
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.
Why was this docstring removed?
@@ -298,3 +292,18 @@ def get_cache_key(self) -> str: | |||
features_and_magics, | |||
] | |||
return ".".join(parts) | |||
|
|||
def __hash__(self) -> int: |
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.
Why is this necessary? And could we instead make dataclass generate the hash method?
@@ -1,11 +0,0 @@ | |||
def foo( |
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.
Why was this test deleted?
@@ -0,0 +1,57 @@ | |||
# flags: --preview |
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.
Add tests with # type: ignore
since there is code treating it specially.
Description
Issue #2097 - Type comments with extra (or zero) spaces after
#
and/or after:
will be detected.Pull Request #4152 - Type comments will also be formatted in a standardized way.
Since it's my first contribution, I am not sure if the creation of
test_nodes.py
to test theis_type_comment
is correct, or if I should have tested it somewhere else.I am also not sure whether this should be on preview or stable, or if I should change the documentation to point out this standardization.
Any feedback or suggestions for improvement are welcome.
Checklist - did you ...
CHANGES.md
if necessary