Skip to content
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

doc: add guidelines for comment directives #43776

Closed
mvdan opened this issue Jan 19, 2021 · 10 comments
Closed

doc: add guidelines for comment directives #43776

mvdan opened this issue Jan 19, 2021 · 10 comments
Labels
Documentation Issues describing a change to documentation. FrozenDueToAge NeedsInvestigation Someone must examine and confirm this is a valid issue and not a duplicate of an existing one. Tools This label describes issues relating to any tools in the x/tools repository.
Milestone

Comments

@mvdan
Copy link
Member

mvdan commented Jan 19, 2021

This issue shares some resemblance with #13560. It is about properly documenting a pretty widespread convention regarding comment text.

In Go, //go: is reserved for the Go toolchain. This is documented at https://golang.org/cmd/compile/.

It is unofficially encouraged that other Go tools use a similar "namespace" prefix for their comment directives. For example, //gccgo: or //llgo: for other compilers, //lint: for staticcheck, //go-sumtype: for another tool, and so on. See https://groups.google.com/g/golang-dev/c/r4rdPdsH1Fg/m/tNZazPenX5cJ, as well as those two tools or others for examples out in the wild.

I think we should more formally define what this format should look like, so that one can programmatically tell if a comment line is a directive. For example, one could imagine ^[a-z-]+: as a regular expression.

This would help tools which use directives be more consistent, as well as tools which want to inspect all comments and directives in source code. For example, gofumpt does this now, and it takes some effort to tell if a comment is a directive.

I don't really mind where this is documented, as long as it's somewhere relatively authoritative. The wording doesn't have to be strong - after all, a Go comment can contain any plaintext. But it should still encourage tools to follow the format, for the sake of consistency.

@mvdan mvdan added Documentation Issues describing a change to documentation. Tools This label describes issues relating to any tools in the x/tools repository. labels Jan 19, 2021
@dmitshur dmitshur added the NeedsInvestigation Someone must examine and confirm this is a valid issue and not a duplicate of an existing one. label Jan 19, 2021
@dmitshur dmitshur added this to the Backlog milestone Jan 19, 2021
@bcmills
Copy link
Contributor

bcmills commented Feb 10, 2021

CC @stevetraut

@marat-rkh
Copy link

Hey! Is there any progress on this one? If not, I would be happy to help with something. For example, collecting existing use cases and forming some kind of proposal based on them. I am from the GoLand team, and our users would definitely benefit from comment directives.

@ianlancetaylor
Copy link
Member

There is a formal definition at #37974 (comment), which is implemented by isDirective in go/printer/comment.go and by isDirective in go/ast/ast.go.

This could now perhaps be documented at https://go.dev/doc/comment.

@findleyr
Copy link
Member

Just encountered this via a user report in golang/vscode-go#2477. I agree that this should be better documented, and doing so at https://go.dev/doc/comment makes the most sense.

Given that this will elevate the directive comment convention to a standard that we will continue to support, does this issue need to be a proposal?

@mvdan
Copy link
Member Author

mvdan commented Sep 23, 2022

@findleyr I guess that depends on whether or not we think this unwritten rule is already a standard across Go or not. My thinking is that it already is a standard in practice, but if we're not sure or if we want to play it safe, using a proposal sounds fine to me.

@findleyr findleyr changed the title doc: guidelines for comment directives proposal: doc: add guidelines for comment directives Oct 3, 2022
@findleyr
Copy link
Member

findleyr commented Oct 3, 2022

@mvdan I agree this is borderline, but a formal definition of comment directives is likely to have significant impact on the ecosystem. Notably, in the past tools such as golangci-lint have used different syntax for comment directives, which gofmt subsequently broke. By documenting a standard, we are both committing ourselves to avoiding such breakage in the future, and implicitly endorsing the use of comment directives by tools outside of the standard Go toolchain. That seems worth escalating to the proposal committee.

@seankhliao
Copy link
Member

We also had 2 other reports for //nolint which seems to have been the only one to use that format: #53835 #54349

@ianlancetaylor ianlancetaylor moved this to Incoming in Proposals Oct 5, 2022
@rsc
Copy link
Contributor

rsc commented Oct 12, 2022

As Ian pointed out, we decided on #43776 (comment).
We should document this better.

@rsc
Copy link
Contributor

rsc commented Oct 12, 2022

Removed from the proposal process.
This was determined not to be a “significant change to the language, libraries, or tools”
or otherwise of significant importance or interest to the broader Go community.
— rsc for the proposal review group

@rsc rsc removed this from Proposals Oct 12, 2022
@gopherbot
Copy link
Contributor

Change https://go.dev/cl/442516 mentions this issue: _content/doc/comment: document form of directive comments

@seankhliao seankhliao changed the title proposal: doc: add guidelines for comment directives doc: add guidelines for comment directives Oct 12, 2022
@golang golang locked and limited conversation to collaborators Nov 2, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Documentation Issues describing a change to documentation. FrozenDueToAge NeedsInvestigation Someone must examine and confirm this is a valid issue and not a duplicate of an existing one. Tools This label describes issues relating to any tools in the x/tools repository.
Projects
None yet
Development

No branches or pull requests

9 participants