From: Josh Bleecher Snyder Date: Wed, 24 Apr 2019 23:59:34 +0000 (-0700) Subject: cmd/compile: don't initialize blank struct fields X-Git-Tag: go1.13beta1~560 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=2693b424662580c3f4fc65e43474e4db0f9c5cf5;p=gostls13.git cmd/compile: don't initialize blank struct fields We already skipped blank field initialization in non-global contexts. This change makes the global context treatment match. Fixes #31546 Change-Id: I40acce49b0a9deb351ae0da098f4c114e425ec63 Reviewed-on: https://go-review.googlesource.com/c/go/+/173723 Run-TryBot: Josh Bleecher Snyder Reviewed-by: Matthew Dempsky TryBot-Result: Gobot Gobot --- diff --git a/src/cmd/compile/internal/gc/sinit.go b/src/cmd/compile/internal/gc/sinit.go index d755ea35cc..6666e8bb5e 100644 --- a/src/cmd/compile/internal/gc/sinit.go +++ b/src/cmd/compile/internal/gc/sinit.go @@ -1278,6 +1278,9 @@ func (s *InitSchedule) initplan(n *Node) { if a.Op != OSTRUCTKEY { Fatalf("initplan structlit") } + if a.Sym.IsBlank() { + continue + } s.addvalue(p, a.Xoffset, a.Left) } diff --git a/test/fixedbugs/issue31546.go b/test/fixedbugs/issue31546.go new file mode 100644 index 0000000000..a459d4d124 --- /dev/null +++ b/test/fixedbugs/issue31546.go @@ -0,0 +1,20 @@ +// run + +// 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. + +package main + +import ( + "reflect" +) + +var x = struct{ a, _, c int }{1, 2, 3} + +func main() { + if i := reflect.ValueOf(x).Field(1).Int(); i != 0 { + println("got", i, "want", 0) + panic("fail") + } +}