-
-
Notifications
You must be signed in to change notification settings - Fork 16
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
init: frontmatter support #114
base: master
Are you sure you want to change the base?
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.
Reviewed together in the docs team meeting!
Note that you could also include the arguments from the meeting into the design document.
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/2024-03-21-documentation-team-meeting-notes-114/41957/1 |
Co-authored-by: Daniel Sidhion <[email protected]>
e10882a
to
6217f2e
Compare
a2e4bde
to
47b1aa1
Compare
082435c
to
6267d6a
Compare
@infinisil I think this PR is ready from my side. If you could give it a quick revise, if all issues are addressed. Just tested it against nixpkgs with some lib functions. works really nice, didn't notice any problems or issues with the other tooling whatsoever. Note: I switched to another frontmatter parser library because the error handling wasn't expressive enough. |
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.
Haven't looked at the code. My review is purely on the design document and README.
Thanks @DanielSidhion Co-authored-by: Daniel Sidhion <[email protected]>
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.
Approving based only on documentation content, I'm leaving the code review to @infinisil since I have 0 experience on nixdoc code.
Reviewed in the docs team meeting:
(PS: @hsjobeki and @DanielSidhion your effort to improve reference documentation overall is highly laudable, so my critique of this particular pattern is not to dismiss your work.) |
This fear is justified, and I share it. Nevertheless, it would be very beneficial to provide this feature for individual edge cases with very long documentation. This should not be used extensively, and there are only a handful of places where I can imagine this. So nixdoc is just a documentation tool that offers this feature. It is not an official tool or an opinionated tool. But nixpkgs should adhere to usage guidelines. e.g. to use the doc_location feature only for certain functions. I am still demanding this feature and planning to add more features to "frontmatter" later on, which might be needed in my vision for improved documentation. But i am okay to let this PR stay open until we really need it. (e.g. when we can generate documentation for mkDerviation) |
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/2024-03-28-documentation-team-meeting-notes-115/42329/1 |
@infinisil @fricklerhandwerk
Moving documentation into the .nix source files seems not beneficial. This feature can help in some places to restructure the content of documentation into pieces that are directly related to source (hence reference) and the other pieces (guide, tutorials, ... ) Therefore i propose to merge this. |
There are some edge cases where position tracking in nix is insufficient yet. I have the following idea that some doc-comments may include the full path of the nix value they document which allows a more decoupled evolution of the doc-comments from the nix position tracking.
See also: nix-community/noogle#468 |
Add support for frontmatter
Why frontmatter is needed (sometimes)
Sometimes it is desireable to extend the content with meta information. Frontmatter is the de-facto standard of adding document specific meta tags to markdown. 1 2 3
This would allow us to keep track of references between documents that are closely related to nix code or externalized doc-comments that are no longer tracked.
This PR also includes a detailed design document.
i.e.,
Example
TODO