-
-
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
feat: Support descriptions from comments #70
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.
Thanks for adding the test!
I'm pretty happy with the fix for #19, not entirely sure about the file:
feature yet, see inline comments.
In any case, I think I'd prefer not using magic strings inside the --description
flag (as it would technically be backwards-incompatible, and somewhat surprising), and instead add a couple flags.
Provided we decide to accept both additions, they could be --description-extract
and --description-file
, so we keep them all close to each other in --help
.
Thanks for the feedback! Just pushed a version with separate flags. Let me know if should remove ´--description-file´ |
db8692e
to
12a717c
Compare
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 does not what I expect it to do. With this PR, running
nixdoc -c test -d test --description-extract -f test.nix
on
# Some file description
{
/* Some function description */
f = x: x;
}
gives
Some file description
## `lib.test.f` {#function-library-lib.test.f}
Some function description
`x`
: Function argument
which seems wrong. The text should be under the header.
Edit: Oh I mistook the function header for the section header, so never mind this!
Furthermore, not having any description at all makes it fail:
{
/* Some function description */
f = x: x;
}
thread 'main' panicked at 'could not read description from top-level comment', src/main.rs:380:18
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
This is in contrast to the current nixdoc which always falls back to something sane in case of missing data. And in this case the default should obviously be an empty description.
Also the flag should be renamed. --description-extract
sounds like it would be related to the --description
flag, when it doesn't really seem to be.
I'd also be in favor of just not having a flag for this at all though, this seems like sane default behavior.
Regarding use cases, this would also be very useful for Nixpkgs (the primary user of nixdoc), e.g. for the new fileset library I wrote, which currently needs to have its introductory section separately from all the functions: https://nixos.org/manual/nixpkgs/unstable/#sec-fileset
The behavior you describe happens only if you explicitly pass the flag. Without that flag, there's no change to behavior. I think its preferable to raise an error if the flag is passed and there's no comment, seems less surprising than silently ignoring the flag.
Could you elaborate on this? How would you call the extracted text here and what would be the difference to a ?description"?
Happy to do this, but as @asymmetric disliked expanding an existing flag for backwards-compatibility, I assumed changing default behavior would be even less likely to get merged ;) Happy to continue with this. Another open question we've discussed at NixCon was whether it's deemed worth the effort to parse and re-serialize the descriptions in order to insert anchors to headings. I think it's fair to leave that functionality to the actual renderers, as i.e. Github and mdbook support that by themselves. |
I don't think this would be a problem for Nixpkgs. If at all, header comments in |
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/2023-11-09-documentation-team-meeting-notes-93/35244/1 |
2fe77d9
to
7e9c303
Compare
@infinisil Seeing you became the new maintainer of nixdoc - thanks! 🎉 - I don't think we need additional feedback to make it a default behavior. Let me know what you think! :) |
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.
Not sure how long-lived nixdoc will still be with RFC 145, but let's keep it working! Still waiting for @asymmetric to make the transfer though :)
Got some suggestions for now though (also the test output needs to be updated once, for an additional newline)
7e9c303
to
8f181c1
Compare
Check if the first node of a given nix file is a comment and if so, insert them after the files heading while correcting whitespace.
8f181c1
to
cd46487
Compare
If I read it correctly, RFC 145 doesn't say anything about a tool to render markdown/html documentation and neither do the linked PoCs. Am I missing something here? As stated above my primary motivation is code that lives outside of nixpkgs. |
Ah that's true. I kind of assumed that the RFC 145 shepherd team was working on their own tooling to replace this one. I created #90 to discuss this.
Haven't considered this very thoroughly, but I guess that's a valid use case, so let's continue supporting it :) |
Previously the introductory section and the function listings were in different places. But now nixdoc supports having them together with nix-community/nixdoc#70!
Previously the introductory section and the function listings were in different places. But now nixdoc supports having them together with nix-community/nixdoc#70!
Previously the introductory section and the function listings were in different places. But now nixdoc supports having them together with nix-community/nixdoc#70!
This extends the existing
--description
flag with two options:This is the most minimal implementation providing the features I was looking for. Happy to extend it w.r.t. to white-space handling and ideally getting section link anchors back for included headers; which would require us to parse the input.