Now we always expect type names inside of *ast.FieldList. This expands the previous func signature logic to also work for *ast.StructType and *ast.InterfaceType. For example, we will now prefer type names in cases like: type myStruct struct { i i<> } Also, fix a check for anonymous fields to make sure the field is actually embedded. This fixes cases like this to properly have no completions: type myStruct struct { i<> i } where this will still give type name completions: type myStruct struct { i<> } I introduced a new error type source.ErrIsDefinition so source_test.go could avoid erroring out on tests that make sure definition identifiers have no completions. Fixes golang/go#34412. Change-Id: Ib56cb52af639f2e2b132274d1f04f8074c0d9353 Reviewed-on: https://go-review.googlesource.com/c/tools/+/196560 Run-TryBot: Rebecca Stambler <rstambler@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Rebecca Stambler <rstambler@golang.org>
Go Tools
This subrepository holds the source for various packages and tools that support the Go programming language.
Some of the tools, godoc
and vet
for example, are included in binary Go
distributions.
Others, including the Go guru
and the test coverage tool, can be fetched with
go get
.
Packages include a type-checker for Go and an implementation of the Static Single Assignment form (SSA) representation for Go programs.
Download/Install
The easiest way to install is to run go get -u golang.org/x/tools/...
. You can
also manually git clone the repository to $GOPATH/src/golang.org/x/tools
.
Report Issues / Send Patches
This repository uses Gerrit for code changes. To learn how to submit changes to this repository, see https://golang.org/doc/contribute.html.
The main issue tracker for the tools repository is located at https://github.com/golang/go/issues. Prefix your issue with "x/tools/(your subdir):" in the subject line, so it is easy to find.