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: gopls doc viewer failed with "package not found" error #70453

Closed
hyangah opened this issue Nov 19, 2024 · 6 comments
Closed

x/tools/gopls: gopls doc viewer failed with "package not found" error #70453

hyangah opened this issue Nov 19, 2024 · 6 comments
Assignees
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

@hyangah
Copy link
Contributor

hyangah commented Nov 19, 2024

gopls version

Build info

golang.org/x/tools/gopls v0.17.0-pre.2
golang.org/x/tools/[email protected] h1:y6wuA4lucYh1D/La5Rs6/aaR1YDLuT1UPygLfmKyBuI=
github.com/BurntSushi/[email protected] h1:pxW6RcqyfI9/kWtOwnv/G+AzdKuy2ZrqINhenH4HyNs=
github.com/google/[email protected] h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI=
golang.org/x/exp/[email protected] h1:1P7xPZEwZMoBoz0Yze5Nx2/4pxj6nw9ZqHWXqP0iRgQ=
golang.org/x/[email protected] h1:D4nJWe9zXqHOmWqj4VMOJhvzj7bEZg4wEYa759z1pH4=
golang.org/x/[email protected] h1:fEo0HyrW1GIgZdpbhCRO0PkJajUS5H9IFUztCgEo2jQ=
golang.org/x/[email protected] h1:TCDqnvbBsFapViksHcHySl/sW4+rTGNIAoJJesHRuMM=
golang.org/x/[email protected] h1:gK/Kv2otX8gz+wn7Rmb3vT96ZwuoxnQlY+HlJVj7Qug=
golang.org/x/[email protected] h1:3ufSKdb6bs9yNyF0YIdrRQjzlObIct/11gv96ANGmZA=
golang.org/x/[email protected] h1:SP0mPeg2PmGCu03V+61EcQiOjmpri2XijexKdzv8Z1I=
honnef.co/go/[email protected] h1:4bH5o3b5ZULQ4UrBmP+63W9r7qIkqJClEA9ko5YKx+I=
mvdan.cc/[email protected] h1:bg91ttqXmi9y2xawvkuMXyvAA/1ZGJqYAEGjXuP0JXU=
mvdan.cc/xurls/[email protected] h1:lyBNOm8Wo71UknhUs4QTFUNNMyxy2JEIaKKo0RWOh+8=
go: go1.23.3

go env

go env
GO111MODULE=''
GOARCH='amd64'
GOBIN=''
GOCACHE='/Users/hakim/Library/Caches/go-build'
GOENV='/Users/hakim/Library/Application Support/go/env'
GOEXE=''
GOEXPERIMENT=''
GOFLAGS=''
GOHOSTARCH='amd64'
GOHOSTOS='darwin'
GOINSECURE=''
GOMODCACHE='/Users/hakim/go/pkg/mod'
GONOPROXY=''
GONOSUMDB=''
GOOS='darwin'
GOPATH='/Users/hakim/go'
GOPRIVATE=''
GOPROXY='https://proxy.golang.org,direct'
GOROOT='/usr/local/go'
GOSUMDB='sum.golang.org'
GOTMPDIR=''
GOTOOLCHAIN='auto'
GOTOOLDIR='/usr/local/go/pkg/tool/darwin_amd64'
GOVCS=''
GOVERSION='go1.22.6'
GCCGO='gccgo'
GOAMD64='v1'
AR='ar'
CC='clang'
CXX='clang++'
CGO_ENABLED='1'
GOMOD='/Users/hakim/projects/build/go.mod'
GOWORK=''
CGO_CFLAGS='-O2 -g'
CGO_CPPFLAGS=''
CGO_CXXFLAGS='-O2 -g'
CGO_FFLAGS='-O2 -g'
CGO_LDFLAGS='-O2 -g'
PKG_CONFIG='pkg-config'
GOGCCFLAGS='-fPIC -arch x86_64 -m64 -pthread -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -ffile-prefix-map=/var/folders/5p/zn7ykc111kn3lm09h_47mz2w001py5/T/go-build2749575289=/tmp/go-build -gno-record-gcc-switches -fno-common'

What did you do?

  • Clone golang.org/x/build
  • Settings:
"gopls": {
        "ui.documentation.linksInHover": "gopls",
}
  • Open maintner/github.go, and hover over *github.Label in line 418.
  • Click "github.Label in gopls doc viewer" link.

What did you see happen?

"package not found" on browser

What did you expect to see?

Package doc

Editor and settings

"gopls": {
        "ui.documentation.linksInHover": "gopls",
}

VS Code

Logs

No response

@hyangah hyangah 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 Nov 19, 2024
@gopherbot gopherbot added this to the Unreleased milestone Nov 19, 2024
@hyangah
Copy link
Contributor Author

hyangah commented Nov 19, 2024

It's possible that #68223 can be the same issue.
The issue is present in gopls v0.16 too.

@adonovan adonovan self-assigned this Nov 19, 2024
@adonovan
Copy link
Member

Thanks, I can reproduce the problem. The URL is lacking the final /github segment of the package path. If you instead use Source Action > Browse Documentation, it computes the correct URL. Will investigate.

@adonovan
Copy link
Member

adonovan commented Nov 19, 2024

Ah, the logic in golang.formatLink is to blame:

	if pkgURL != nil { // LinksInHover == "gopls"
		path, _, _ := strings.Cut(h.LinkPath, "@") // remove optional module version suffix
		url = pkgURL(PackagePath(path), h.LinkAnchor)

LinkPath is github.com/google/go-github/[email protected]/github, and the Cut yields github.com/google/go-github/v48.

It should probably use something like https://pkg.go.dev/golang.org/x/mod/module#SplitPathVersion to parse the path.

@findleyr
Copy link
Member

Seems like an easy fix, thanks Alan for investigating. I'll put this in the v0.17.0 milestone, but we can of course fix it later.

@findleyr findleyr modified the milestones: Unreleased, gopls/v0.17.0 Nov 20, 2024
@gopherbot
Copy link
Contributor

Change https://go.dev/cl/630077 mentions this issue: gopls/internal/golang: fix gopls hover doc link

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