Skip to content
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

Remove stub content/style section from CONTRIBUTING.md #13332

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

yangdanny97
Copy link
Contributor

python/typing#1882 has added the stub content/style guidelines from CONTRIBUTING.md to the official typing documentation (https://typing.readthedocs.io/en/latest/guides/writing_stubs.html), so we can change the contributing guide to link to that directly.

I added a special note re: omitting docstrings from typeshed, since the official docs only discusses tradeoffs (per Jelle's recommendation in python/typing#1880 (comment))

@yangdanny97 yangdanny97 marked this pull request as ready for review December 29, 2024 01:54
@Avasam
Copy link
Collaborator

Avasam commented Dec 29, 2024

This reminds me of an old PR by @srittau and reviewed by @JelleZijlstra that went unmerged https://github.com/python/typeshed/pull/7594/files
I haven't gone through the whole thing yet, I'm just wondering if there's more sections that can be updated with a link.

@yangdanny97
Copy link
Contributor Author

The only extra thing that PR deletes is the "Supported type system features" section. The comments mentioned linking to the issue tracker: project: feature tracker Tracks whether a typing feature can be used in typeshed stubs , but I don't quite understand @AlexWaygood 's comment

We could also consider using a meta-issue tracker to track the issue trackers.

Perhaps we can do that in a separate PR?

@Akuli
Copy link
Collaborator

Akuli commented Jan 5, 2025

I don't think this is a good idea.

I think CONTRIBUTING.md should be a self-contained document that you read, and then you can contribute. It should be as painless as possible to go through, so it shouldn't expect readers to follow links and read something elsewhere.

That said, "for more info see also" type of links are ok in a CONTRIBUTING.md.

it's not possible to accurately type an item using the current type system.
It should be used sparingly.

### "The `Any` trick"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the Any trick is a good example of a "for more info, see also" kind of thing. Most contributors won't need to know about it, so it is IMO a good idea to link to it from CONTRIBUTING.md, but not explain it here.

@yangdanny97
Copy link
Contributor Author

The main motivation for removing the whole section from CONTRIBUTING.md is to align on a single source of truth. If the content is duplicated across two locations, they can diverge and cause confusion if they disagree. A secondary motivation is to reduce the length of the document and to keep it focused on typeshed-specific things.

As a point of comparison, the DefinitelyTyped repo's README doesn't include detailed info on how to write typescript definitions, it links to the official docs.

https://github.com/DefinitelyTyped/DefinitelyTyped?tab=readme-ov-file#how-do-i-write-definitions-for-packages-that-can-be-used-globally-and-as-a-module

@rchen152
Copy link
Collaborator

I'm in favor of this PR; content being duplicated between typeshed and the type system guides meant that there was a fair bit of contradictory advice floating around.

With that said, I can see how needing to follow links for basic information could make CONTRIBUTING.md harder to follow. Maybe we could keep a brief high-level overview and make the links more targeted? Here's a suggestion, merging the old "Format" section and Danny's new "Stub Content and Style" section:

Format

Each Python module is represented by a .pyi "stub file". This is a
syntactically valid Python file, where all methods are empty and type annotations are used to describe function signatures and variable types.

Typeshed follows the standard type system guidelines for stub content and coding style.

@Akuli
Copy link
Collaborator

Akuli commented Jan 15, 2025

Maybe we could keep the following sections?

  • What to include (too long, everything below the code example could be removed IMO)
  • What to do when a project's documentation and implementation disagree
  • Incomplete annotations

These are all quite short, and contributors frequently run into these.

Copy link
Collaborator

@Akuli Akuli left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I like it! It explains important things without making the reader ignore a lot of noise.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants