-
Notifications
You must be signed in to change notification settings - Fork 243
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 content from typeshed/CONTRIBUTING.md #1882
Conversation
docs/guides/writing_stubs.rst
Outdated
@@ -113,18 +118,6 @@ Stub Content | |||
This section documents best practices on what elements to include or | |||
leave out of stub files. | |||
|
|||
Modules excluded fom stubs |
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 moved this down cuz it felt weird for the "stub content" section to start with "what you shouldn't include"
Avoid invariant collection types (`list`, `dict`) for function parameters, | ||
in favor of covariant types like `Mapping` or `Sequence`. | ||
|
||
Avoid union return types. See https://github.com/python/mypy/issues/1693 |
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.
Probably for a future PR, but it would be nice if the content of python/mypy#1693 and python/mypy#7214 below could be copied into the guides. Having pieces of general typing advice hidden away in mypy issues feels sort of odd.
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.
Looks good to me aside from a couple minor comments.
@JelleZijlstra Do you want to review this as well?
Co-authored-by: Rebecca Chen <rchen152@gmail.com>
Co-authored-by: Rebecca Chen <rchen152@gmail.com>
… suppression formats section
|
||
Keep the deprecation message concise, but try to mention the projected | ||
version when the functionality is to be removed, and a suggested | ||
replacement. |
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.
Should we say that if a deprecated feature is still very widely used and was deprecated only recently, it may be best to wait before adding @deprecated
?
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 don't think so. If the feature is still in wide use, that's an argument against deprecating the feature, but if the runtime code decides to deprecate something, the stubs should communicate that fact.
Removed repeated example, fixed formatting, removed stray "the".
Looks like all comments have been addressed. I did one more style/formatting pass. Thanks @yangdanny97! |
* main: (29 commits) Updated conformance test results for the latest versions of type chec… (python#1904) Add content from typeshed/CONTRIBUTING.md (python#1882) Fix markup in generics specification (python#1900) Specs clarification: Forbid `ClassVar` and `Final` within `TypedDict` body (python#1890) Remove paragraph mentioning minor edits through the mailing list (python#1891) Writing Stubs: Add "Overloads and Flags" section (python#1894) Fix a typo (python#1893) Update conformance tests for recent generics spec change (python#1892) Clarify some behavior around user-defined generic classes (python#1879) Modernizing guide: Mention TypeGuard/TypeIs (python#1887) Tools can perform "some" refactorings (python#1886) Mention use of cast in enum type stub example (python#1877) Update conformance results after new pyre release (python#1878) Add a label for typed dictionaries class-based syntax (python#1873) Add missing return type to generic_syntax_infer_variance.py (python#1871) Updated conformance results for mypy 1.13 and pyright 1.1.386 (python#1870) Modernizing guide: also mention `com2ann` (python#1869) Suggest `pyupgrade` or `ruff` for modernizing superseded typing features (python#1868) Updated conformance results for pyright 1.1.385. (python#1867) Updated conformance results for mypy 1.12. (python#1866) ...
This PR merges non-typeshed-specific content on writing stubs into main typing guide.
https://github.com/python/typeshed/blob/main/CONTRIBUTING.md
This would let us reference this guide from typeshed's CONTRIBUTING.md and delete the duplicate sections.
#1880