mirror of
https://github.com/golang/go
synced 2024-11-19 02:34:44 -07:00
62138107df
Diagnostics were failing because of https://go-review.googlesource.com/c/tools/+/154742, where I was using the wrong *token.File for the position calculations. This should fix the problem. Change-Id: Ic44e7799da56010b5014d56029fb4e0a8a6bb0e8 Reviewed-on: https://go-review.googlesource.com/c/155479 Reviewed-by: Ian Cottrell <iancottrell@google.com>
72 lines
2.0 KiB
Go
72 lines
2.0 KiB
Go
// Copyright 2018 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package lsp
|
|
|
|
import (
|
|
"context"
|
|
"sort"
|
|
|
|
"golang.org/x/tools/internal/lsp/protocol"
|
|
"golang.org/x/tools/internal/lsp/source"
|
|
)
|
|
|
|
func (s *server) cacheAndDiagnose(ctx context.Context, uri protocol.DocumentURI, content string) {
|
|
sourceURI := fromProtocolURI(uri)
|
|
if err := s.setContent(ctx, sourceURI, []byte(content)); err != nil {
|
|
return // handle error?
|
|
}
|
|
go func() {
|
|
reports, err := source.Diagnostics(ctx, s.view, sourceURI)
|
|
if err != nil {
|
|
return // handle error?
|
|
}
|
|
for filename, diagnostics := range reports {
|
|
s.client.PublishDiagnostics(ctx, &protocol.PublishDiagnosticsParams{
|
|
URI: protocol.DocumentURI(source.ToURI(filename)),
|
|
Diagnostics: toProtocolDiagnostics(ctx, s.view, diagnostics),
|
|
})
|
|
}
|
|
}()
|
|
}
|
|
|
|
func (s *server) setContent(ctx context.Context, uri source.URI, content []byte) error {
|
|
v, err := s.view.SetContent(ctx, uri, content)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
s.viewMu.Lock()
|
|
s.view = v
|
|
s.viewMu.Unlock()
|
|
|
|
return nil
|
|
}
|
|
|
|
func toProtocolDiagnostics(ctx context.Context, v source.View, diagnostics []source.Diagnostic) []protocol.Diagnostic {
|
|
reports := []protocol.Diagnostic{}
|
|
for _, diag := range diagnostics {
|
|
tok := v.FileSet().File(diag.Start)
|
|
reports = append(reports, protocol.Diagnostic{
|
|
Message: diag.Message,
|
|
Range: toProtocolRange(tok, diag.Range),
|
|
Severity: protocol.SeverityError, // all diagnostics have error severity for now
|
|
Source: "LSP",
|
|
})
|
|
}
|
|
return reports
|
|
}
|
|
|
|
func sorted(d []protocol.Diagnostic) {
|
|
sort.Slice(d, func(i int, j int) bool {
|
|
if d[i].Range.Start.Line == d[j].Range.Start.Line {
|
|
if d[i].Range.Start.Character == d[j].Range.Start.Character {
|
|
return d[i].Message < d[j].Message
|
|
}
|
|
return d[i].Range.Start.Character < d[j].Range.Start.Character
|
|
}
|
|
return d[i].Range.Start.Line < d[j].Range.Start.Line
|
|
})
|
|
}
|