| // Copyright 2019 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. |
| |
| // Gopls (pronounced “go please”) is an LSP server for Go. |
| // The Language Server Protocol allows any text editor |
| // to be extended with IDE-like features; |
| // see https://langserver.org/ for details. |
| // |
| // See https://github.com/golang/tools/blob/master/gopls/README.md |
| // for the most up-to-date documentation. |
| package main // import "golang.org/x/tools/gopls" |
| |
| import ( |
| "context" |
| "golang.org/x/tools/internal/analysisinternal" |
| "os" |
| |
| "golang.org/x/tools/gopls/internal/hooks" |
| "golang.org/x/tools/gopls/internal/lsp/cmd" |
| "golang.org/x/tools/internal/tool" |
| ) |
| |
| func main() { |
| // In 1.18, diagnostics for Fuzz tests must not be used by cmd/vet. |
| // So the code for Fuzz tests diagnostics is guarded behind flag analysisinternal.DiagnoseFuzzTests |
| // Turn on analysisinternal.DiagnoseFuzzTests for gopls |
| analysisinternal.DiagnoseFuzzTests = true |
| ctx := context.Background() |
| tool.Main(ctx, cmd.New("gopls", "", nil, hooks.Options), os.Args[1:]) |
| } |