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

x/tools/gopls: iferr completion content should adjust according to return type of function in scope #65885

Open
golopot opened this issue Feb 22, 2024 · 4 comments
Labels
gopls Issues related to the Go language server, gopls. Tools This label describes issues relating to any tools in the x/tools repository.
Milestone

Comments

@golopot
Copy link

golopot commented Feb 22, 2024

gopls version

golang.org/x/tools/gopls v0.14.2 golang.org/x/tools/[email protected] h1:sIw6vjZiuQ9S7s0auUUkHlWgsCkKZFWDHmrge8LYsnc= github.com/BurntSushi/[email protected] h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak= github.com/google/[email protected] h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= github.com/sergi/[email protected] h1:we8PVUC3FE2uYfodKH/nBHMSetSfHDR6scGdBi+erh0= golang.org/x/exp/[email protected] h1:2O2DON6y3XMJiQRAS1UWU+54aec2uopH3x7MAiqGW6Y= golang.org/x/[email protected] h1:dGoOF9QVLYng8IHTm7BAyWqCqSheQ5pYWGhzW00YJr0= golang.org/x/[email protected] h1:zxkM55ReGkDlKSM+Fu41A+zmbZuaPVbGMzvvdUPznYQ= golang.org/x/[email protected] h1:Vz7Qs629MkJkGyHxUlRHizWJRG2j8fbQKjELVSNhy7Q= golang.org/x/[email protected] h1:brbkEFfGwNGAEkykUOcryE/JiHUMMJouzE0fWWmz/QU= golang.org/x/[email protected] h1:ablQoSUd0tRdKxZewP80B+BaqeKJuVhuRxj/dkrun3k= golang.org/x/[email protected] h1:Oku7E+OCrXHyst1dG1z10etCTxewCHXNFLRlyMPbh3w= golang.org/x/[email protected] h1:KUas02EjQK5LTuIx1OylBQdKKZ9jeugs+HiqO5HormU= honnef.co/go/[email protected] h1:YGD4H+SuIOOqsyoLOpZDWcieM28W47/zRO7f+9V3nvo= mvdan.cc/[email protected] h1:JVf4NN1mIpHogBj7ABpgOyZc65/UUOkKQFkoURsz4MM= mvdan.cc/xurls/[email protected] h1:tzxjVAj+wSBmDcF6zBB7/myTy3gX9xvi8Tyr28AuQgc= go: go1.21.6

go env

.

What did you do?

Accept iferr completion in a function of type func() error

What did you see happen?

Completes to
if err != nil { return nil, err }

What did you expect to see?

Completes to if err != nil { return err }

Editor and settings

No response

Logs

No response

@golopot golopot added gopls Issues related to the Go language server, gopls. Tools This label describes issues relating to any tools in the x/tools repository. labels Feb 22, 2024
@gopherbot gopherbot added this to the Unreleased milestone Feb 22, 2024
@hyangah
Copy link
Contributor

hyangah commented Feb 23, 2024

Are you using VS Code Go extension?

If so, it's likely this is coming from the vscode go extension side
https://github.com/golang/vscode-go/blob/0b3fabc4c832194f59ca913f36f048aecd1f78ae/extension/snippets/go.json#L114.
This adds one more reason to deprecate this legacy snippet (golang/vscode-go#160)

For example, this screenshot is the sign that this completion comes from vscode-go side snippets.
Screenshot 2024-02-23 at 1 02 15 PM

@golopot
Copy link
Author

golopot commented Feb 23, 2024

Yes I am using VS Code Go extension

@suzmue
Copy link
Contributor

suzmue commented Feb 29, 2024

There is a similar feature in gopls, postfix completion https://go.dev/issue/64178. It can be triggered by typing . after a variable of an error type (for example err.). It is return value aware and fills in the non-error return values as well, leaving the cursor where the returned error value will be.

iferr

This feature could be modified to work without the postfix, so will leave this open as a feature request for that.

@suzmue suzmue modified the milestones: Unreleased, gopls/backlog Mar 25, 2024
@tttoad
Copy link

tttoad commented May 25, 2024

Hi @suzmue , I'm interested in this feature, but I'm working with neovim. Is there an example or documentation on how to call this function? I just need to know how to call it by gopls, thank you.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
gopls Issues related to the Go language server, gopls. Tools This label describes issues relating to any tools in the x/tools repository.
Projects
None yet
Development

No branches or pull requests

5 participants