commit | f62bfb5415380414cb751ad4556504f5eac6179d | [log] [tgz] |
---|---|---|
author | Alan Donovan <adonovan@google.com> | Wed Nov 14 21:31:18 2018 -0500 |
committer | Alan Donovan <adonovan@google.com> | Thu Nov 15 16:22:56 2018 +0000 |
tree | a34782b5d1992a3d74a2fb4d68e1844f35bcbeab | |
parent | 17409aa234eac3e745edad243c76873dd4a28619 [diff] |
go/analysis/passes/printf: fix regression in "recursive stringer" logic The recursive stringer check should report cases such as func (x T) String() string { return fmt.Sprint(x) } in which the receiver x (or possibly &x) was passed into a fmt print call. However, in translating it from the go/ast to the go/types representation, I inadvertently made it report any situation in which a value of type T was passed to fmt, even when the value is not x, as in: func (cons *cons) String() string { ... fmt.Sprint(cons.cdr) ... } Fixed and tested. Change-Id: I57e88755c9989deaaad45cc306a604f3db4ee269 Reviewed-on: https://go-review.googlesource.com/c/149616 Reviewed-by: Michael Matloob <matloob@golang.org> Run-TryBot: Michael Matloob <matloob@golang.org>
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.
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
.
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.