mirror of
https://github.com/golang/go
synced 2024-11-18 14:14:46 -07:00
4d5ea46c79
In addition to adding a `go mod vendor` command option, which can be exposed via an editor client frontend, we show a suggestion to users who experience the "inconsistent vendoring" error message. The main change made here is that we save the view initialization error, and we return it if the view has absolutely no metadata. This seems reasonable enough, but my fear is that it may lead to us showing outdated error messages. I will spend some time improving the handling of initialization errors in follow-up CLs. Updates golang/go#39100 Change-Id: Iba21fb3fbfa4bca956fdf63736b397c47fc7ae44 Reviewed-on: https://go-review.googlesource.com/c/tools/+/235619 Run-TryBot: Rebecca Stambler <rstambler@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Heschi Kreinick <heschi@google.com>
118 lines
3.8 KiB
Go
118 lines
3.8 KiB
Go
// Copyright 2020 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 fake
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"golang.org/x/tools/internal/lsp/protocol"
|
|
)
|
|
|
|
// ClientHooks are called to handle the corresponding client LSP method.
|
|
type ClientHooks struct {
|
|
OnLogMessage func(context.Context, *protocol.LogMessageParams) error
|
|
OnDiagnostics func(context.Context, *protocol.PublishDiagnosticsParams) error
|
|
OnWorkDoneProgressCreate func(context.Context, *protocol.WorkDoneProgressCreateParams) error
|
|
OnProgress func(context.Context, *protocol.ProgressParams) error
|
|
OnShowMessage func(context.Context, *protocol.ShowMessageParams) error
|
|
OnShowMessageRequest func(context.Context, *protocol.ShowMessageRequestParams) error
|
|
}
|
|
|
|
// Client is an adapter that converts an *Editor into an LSP Client. It mosly
|
|
// delegates functionality to hooks that can be configured by tests.
|
|
type Client struct {
|
|
editor *Editor
|
|
hooks ClientHooks
|
|
}
|
|
|
|
func (c *Client) ShowMessage(ctx context.Context, params *protocol.ShowMessageParams) error {
|
|
if c.hooks.OnShowMessage != nil {
|
|
return c.hooks.OnShowMessage(ctx, params)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) ShowMessageRequest(ctx context.Context, params *protocol.ShowMessageRequestParams) (*protocol.MessageActionItem, error) {
|
|
if c.hooks.OnShowMessageRequest != nil {
|
|
if err := c.hooks.OnShowMessageRequest(ctx, params); err != nil {
|
|
return nil, err
|
|
}
|
|
}
|
|
if len(params.Actions) == 0 || len(params.Actions) > 1 {
|
|
return nil, fmt.Errorf("fake editor cannot handle multiple action items")
|
|
}
|
|
return ¶ms.Actions[0], nil
|
|
}
|
|
|
|
func (c *Client) LogMessage(ctx context.Context, params *protocol.LogMessageParams) error {
|
|
if c.hooks.OnLogMessage != nil {
|
|
return c.hooks.OnLogMessage(ctx, params)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) Event(ctx context.Context, event *interface{}) error {
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) PublishDiagnostics(ctx context.Context, params *protocol.PublishDiagnosticsParams) error {
|
|
if c.hooks.OnDiagnostics != nil {
|
|
return c.hooks.OnDiagnostics(ctx, params)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) WorkspaceFolders(context.Context) ([]protocol.WorkspaceFolder, error) {
|
|
return []protocol.WorkspaceFolder{}, nil
|
|
}
|
|
|
|
func (c *Client) Configuration(_ context.Context, p *protocol.ParamConfiguration) ([]interface{}, error) {
|
|
results := make([]interface{}, len(p.Items))
|
|
for i, item := range p.Items {
|
|
if item.Section != "gopls" {
|
|
continue
|
|
}
|
|
results[i] = c.editor.configuration()
|
|
}
|
|
return results, nil
|
|
}
|
|
|
|
func (c *Client) RegisterCapability(context.Context, *protocol.RegistrationParams) error {
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) UnregisterCapability(context.Context, *protocol.UnregistrationParams) error {
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) Progress(ctx context.Context, params *protocol.ProgressParams) error {
|
|
if c.hooks.OnProgress != nil {
|
|
return c.hooks.OnProgress(ctx, params)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (c *Client) WorkDoneProgressCreate(ctx context.Context, params *protocol.WorkDoneProgressCreateParams) error {
|
|
if c.hooks.OnWorkDoneProgressCreate != nil {
|
|
return c.hooks.OnWorkDoneProgressCreate(ctx, params)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// ApplyEdit applies edits sent from the server. Note that as of writing gopls
|
|
// doesn't use this feature, so it is untested.
|
|
func (c *Client) ApplyEdit(ctx context.Context, params *protocol.ApplyWorkspaceEditParams) (*protocol.ApplyWorkspaceEditResponse, error) {
|
|
if len(params.Edit.Changes) != 0 {
|
|
return &protocol.ApplyWorkspaceEditResponse{FailureReason: "Edit.Changes is unsupported"}, nil
|
|
}
|
|
for _, change := range params.Edit.DocumentChanges {
|
|
path := c.editor.sandbox.Workdir.URIToPath(change.TextDocument.URI)
|
|
edits := convertEdits(change.Edits)
|
|
c.editor.EditBuffer(ctx, path, edits)
|
|
}
|
|
return &protocol.ApplyWorkspaceEditResponse{Applied: true}, nil
|
|
}
|