-
Notifications
You must be signed in to change notification settings - Fork 259
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
[wit-parser] Don't trim leading/trailing whitespace from lines in doc comments #1954
[wit-parser] Don't trim leading/trailing whitespace from lines in doc comments #1954
Conversation
@@ -4,4 +4,4 @@ Caused by: | |||
0: failed to decode world from module | |||
1: module was not valid | |||
2: failed to resolve import `a::a` | |||
3: module requires an import interface named `a` | |||
3: module requires an import interface named `a` |
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.
Could you try rebasing on main
and re-BLESS-ing tests to remove some of these changes?
Thanks for this! One thing I might recommend is to flesh out this trimming of whitespace more than what's already there. You're right that the current implementation is buggy but ideally this wouldn't pick up the whitespace from the comment itself (e.g. the leading space). The way I know I've dealt with this in the past with rustdoc is to collect the documentation block, calculating the longest longest amount of whitespace shared amongst all lines, and then drop that. That would, for example, drop the leading space here. |
Sounds good, I wasn't sure if this was an issue for the project in the first place or what behavior would be a good replacement so I wanted to keep the changes minimal to start. |
0e4b337
to
bd39d87
Compare
Sounds good, and yeah no worries! I think some git mishaps may have happened during the rebase though? |
…e minimum amount of whitespace common to all lines and strip that much, rather than going all-or-nothing.
bd39d87
to
7507a92
Compare
Yeah sorry about that, I think I rebased and pushed using |
* Rename intermediate value `d` to `contents`
I think there might need to be another BLESS=1 run, and maybe a test or two failing as well? |
@alexcrichton Sorry for the delay, got sidetracked with other work. I've been seeing one test, The problematic diff is a trailing newline at the end of the file - the output file is written without it, but then the runtime test contents include it. I noticed that I could fix this in It's a small change, but I'm not familiar enough with the project to say that it won't cause other issues. I'd love to hear what you think about this, and if you want to go in a different direction I'll keep looking into alternatives. |
(back from the holidays) thanks for investigating! That sounds like a reasonable fix to me, so if you're ok with it it'd be great to include that here and it sounds like the right way to go to me too |
…usly-generated output
Thanks! Since most tests already had a trailing newline could the "normalize" step ensure there's a single trailing newline at the end? (e.g. trimming multiple and appending one if there's 0) I think some other tests may still be failing as well too? |
…o that we actually _find_ the leading whitespace.
…ing newline. Most outputs already had this, but some had none.
Thanks for the patience, just a couple dumb mistakes on my end:
|
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.
No worries, and thanks again for this!
Trimming whitespace in doc comment lines could break custom formatting when reading and/or copying docs from
.wit
files.For example, using jco to generate Typescript definitions, we want to copy the documentation directly from .wit to .d.ts. However, a doc comment like this will be altered after parsing: