-
Notifications
You must be signed in to change notification settings - Fork 226
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
Reorganize std
docs so that they follow the same tree structure that the std
crate does
#5797
Comments
I'd really like us to have auto-generated docs, and docs when hovering over items. My idea, to begin with, was this:
At least doc comments will start showing up in the editor. Once that's done we can start working on a doc generator (not sure if there's something we could reuse for actually presenting the docs once we process them). I'd be happy to work on this in parallel to the other stuff 😄 |
Sounds good to me. I'm not sure how much work we'd save by only saving doc comments if we're in lsp mode or generating docs but the plan sounds sensible. |
# Description ## Problem Part of #5797 ## Summary ![lsp-doc-comments](https://github.com/user-attachments/assets/9560d41a-3163-4489-820e-a0f488b98f1a) This is just an experiment! We now parse doc comments, like we parse attributes, and attach them to AST nodes. From there we store them in `NodeInterner` (for now only if in LSP mode). Then we retrieve those comments for hover and autocompletion. ## Additional Context I decided to always store the doc comments in the NodeInterner. I've been thinking and maybe the doc comments shouldn't be parsed as `String`, but instead be a `Span`. Then we wouldn't need to allocate a string for them, and only read from the source file when needed. But... that's an optimization that can be done later. After merging this, the next steps could be: 1. Copy the doc comments found in the many `.md` files into the standard library (they will be duplicated, but just for a wihle) 2. Create a script or something that generates the `.md` files from the doc comments Note: I removed the lalrpop code because I got some errors and I thought maybe it's not very useful to keep that code around if we have to make changes to it to maintain it, but it's not working (we could always revive it from git's history). But let me know if this is wrong. ## Documentation Check one: - [x] No documentation needed. - [ ] Documentation included in this PR. - [ ] **[For Experimental Features]** Documentation to be submitted in a separate PR. # PR Checklist - [x] I have tested the changes locally. - [x] I have formatted the changes with [Prettier](https://prettier.io/) and/or `cargo fmt` on default settings. --------- Co-authored-by: Tom French <15848336+TomAFrench@users.noreply.github.com>
# Description ## Problem Part of #5797 ## Summary This PR copies the docs from the `.md` file to the `.nr` file. ## Additional Context I'll be sending one PR per `.md` file. It looks like they are 36 in total so it will take some time to port all the docs, but not that much. And this way reviewing these PRs will be more manageable. For now examples are copied inline into the `.nr` file. Eventually we could maybe have `nargo test` run or at least type-check these example ## Documentation Check one: - [ ] No documentation needed. - [x] Documentation included in this PR. - [ ] **[For Experimental Features]** Documentation to be submitted in a separate PR. # PR Checklist - [x] I have tested the changes locally. - [x] I have formatted the changes with [Prettier](https://prettier.io/) and/or `cargo fmt` on default settings.
# Description ## Problem Part of #5797 ## Summary ## Additional Context ## Documentation Check one: - [ ] No documentation needed. - [x] Documentation included in this PR. - [ ] **[For Experimental Features]** Documentation to be submitted in a separate PR. # PR Checklist - [x] I have tested the changes locally. - [x] I have formatted the changes with [Prettier](https://prettier.io/) and/or `cargo fmt` on default settings.
# Description ## Problem Part of #5797 ## Summary ## Additional Context ## Documentation Check one: - [ ] No documentation needed. - [x] Documentation included in this PR. - [ ] **[For Experimental Features]** Documentation to be submitted in a separate PR. # PR Checklist - [x] I have tested the changes locally. - [x] I have formatted the changes with [Prettier](https://prettier.io/) and/or `cargo fmt` on default settings.
Problem
Organization of functions & other items in the standard library docs for Noir is arbitrary.
Happy Case
The organization should mimic the actual modules in the std crate itself. This will also give a better idea to users on how the stdlib is structured.
For bonus points these docs could be autogenerated from doc comments on stdlib items.
Workaround
None
Workaround Description
No response
Additional Context
No response
Project Impact
None
Blocker Context
No response
Would you like to submit a PR for this Issue?
None
Support Needs
No response
The text was updated successfully, but these errors were encountered: