2de7f9bf82
In the following piece of code: type T1 struct { Shadowed string `json:"foo"` } type T2 struct { T1 Shadowing int `json:"foo"` } encoding/json will encode T2 using T2.Shadowing, ignoring T2.Shadowed entirely. This can be a useful feature to replace some of T1's fields when encoding it. Moreover, this feature is already in use in the wild, even though it's probably never been documented. This started being a problem, as the structtag pass started walking through embedded fields a few months ago. To keep it from complaining about these useful shadowing cases, make it only see duplicate field tag names if they are at the same embedding level, in which case no shadowing is happening. The old code indexed these tags by encoding key and name, using a [2]string. The new code needs to add a level integer, so start declaring named types for the map, and use methods to simplify the code further below. We still use a map pointer, to avoid allocating on every single struct definition. Updates golang/go#30846. Change-Id: Iae53228d4f8bd91584c59dcc982cb1300970bc8f Reviewed-on: https://go-review.googlesource.com/c/tools/+/179360 Run-TryBot: Daniel Martí <mvdan@mvdan.cc> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Michael Matloob <matloob@golang.org> |
||
---|---|---|
benchmark/parse | ||
blog | ||
cmd | ||
container/intsets | ||
cover | ||
go | ||
godoc | ||
imports | ||
internal | ||
playground | ||
present | ||
refactor | ||
.gitattributes | ||
.gitignore | ||
AUTHORS | ||
codereview.cfg | ||
CONTRIBUTING.md | ||
CONTRIBUTORS | ||
go.mod | ||
go.sum | ||
LICENSE | ||
PATENTS | ||
README.md |
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.