Skip to content

Commit dda1721

Browse files
findleyrgopherbot
authored andcommitted
[gopls-release-branch.0.15] gopls/internal/cache: avoid panic when the primary diagnostic is broken
If the primary diagnostic has invalid position information (due to a bug in the parser or AST fix logic), gopls may panics when linking primary and related information. Avoid this panic. Updates golang/go#66731 Updates golang/go#66730 Change-Id: Ie2f95d158a1c93d00603a7ce4d38d8097bd8cb08 Reviewed-on: https://go-review.googlesource.com/c/tools/+/577259 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Alan Donovan <adonovan@google.com> (cherry picked from commit f41d27e) Reviewed-on: https://go-review.googlesource.com/c/tools/+/577303 Auto-Submit: Robert Findley <rfindley@google.com>
1 parent 4bdbdca commit dda1721

File tree

1 file changed

+4
-1
lines changed

1 file changed

+4
-1
lines changed

gopls/internal/cache/check.go

+4-1
Original file line numberDiff line numberDiff line change
@@ -1936,7 +1936,10 @@ func typeErrorsToDiagnostics(pkg *syntaxPackage, errs []types.Error, linkTarget
19361936
// This is because go/types assumes that errors are read top-down, such as
19371937
// in the cycle error "A refers to...". The structure of the secondary
19381938
// error set likely only makes sense for the primary error.
1939-
if i > 0 {
1939+
//
1940+
// NOTE: len(diags) == 0 if the primary diagnostic has invalid positions.
1941+
// See also golang/go#66731.
1942+
if i > 0 && len(diags) > 0 {
19401943
primary := diags[0]
19411944
primary.Related = append(primary.Related, protocol.DiagnosticRelatedInformation{
19421945
Location: protocol.Location{URI: diag.URI, Range: diag.Range},

0 commit comments

Comments
 (0)