-
Notifications
You must be signed in to change notification settings - Fork 17.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
proposal: x/pkgsite: package tours (additional documentation type for packages) #69265
Comments
Packages can already have a long top-level doc comment (rendered as "Overview") with detailed usage introduction and examples, see the testing package as an example. |
@fzipp That's true and arguably omitted from the top-comment. But I think a guided tour is still a qualitatively different and more helpful form of documentation, especially when considering that there might be multiple scenarios. |
My assumption is that if package maintainers aren't fully utilizing the potential of the available space already, they won't use additional space either. The real issue is that many developers prefer programming over writing documentation. |
There are several cross-cutting considerations here:
We need a multi-pronged solution to documentation. Developers who want do the right thing (there are many of us who do) simply do not have the means. |
I use the example docs extensively in my open source projects. If I could build a programmatically tested tour with the Go tool, I would probably do that instead of using a README because the README can get out of sync pretty easily. |
Proposal Details
Background
Go packages can have two distinct forms of documentation:
Comments anchored to identifiers as described by Godoc: documenting Go code and Go Doc Comments.
Runnable (API) examples as described by Testable Examples in Go
Both of these are rendered in godoc and pkgsite.
These two forms of documentation serve somewhat overlapping/disjoint purposes:
Problem
In this public discussion, it became clear that a type of documentation is missing for users: step-by-step tutorials or material that focuses on an end-to-end developer journey. This led to a thought about how we could fix this gap in a nice Go-like way.
Proposal
What if we expanded the documentation servers to enable users to create their own API tours à la A Tour of Go? A package could have multiple tours to demonstrate the journeys.
Imagine a hypothetical Go module at
github.com/matttproud/rot13
that follows a directory structure like this:We could have a directory structure like this:
Then the respective documentation servers would have some sort of internal support to run tours (e.g., use what binary tour uses). When viewing the respective package in the viewer, the table of contents for the package would also include a heading that lists sub-elements of available tours (tracer shot):
This has the advantage of keeping the documentation for extended workflows adjacent to the code so that it can be always fresh.
Perhaps this could even be extended to support the present tool, too.
Rejected Alternatives
There is technically a third form available: the blog post (e.g., Go Concurrency Patterns: Context), but …
The text was updated successfully, but these errors were encountered: