mirror of
https://github.com/golang/go
synced 2025-04-07 23:54:28 +00:00
cmd/compile: fix missing walk pass for static initialization slice
CL 403995 fixed static init of literal contains dynamic exprs, by ensuring their init are ordered properly. However, we still need to walk the generated init codes before appending to parent init. Otherwise, codes that requires desugaring will be unhandled, causing the compiler backend crashing. Fixes #56105 Change-Id: Ic25fd4017473f5412c8e960a91467797a234edfd Reviewed-on: https://go-review.googlesource.com/c/go/+/440455 Reviewed-by: Matthew Dempsky <mdempsky@google.com> Auto-Submit: Cuong Manh Le <cuong.manhle.vn@gmail.com> TryBot-Result: Gopher Robot <gobot@golang.org> Reviewed-by: Keith Randall <khr@google.com> Run-TryBot: Cuong Manh Le <cuong.manhle.vn@gmail.com> Reviewed-by: Keith Randall <khr@golang.org>
This commit is contained in:
committed by
Gopher Robot
parent
506e690a26
commit
fce449680a
@ -243,6 +243,7 @@ func fixedlit(ctxt initContext, kind initKind, n *ir.CompLitExpr, var_ ir.Node,
|
||||
// confuses about variables lifetime. So making sure those expressions
|
||||
// are ordered correctly here. See issue #52673.
|
||||
orderBlock(&sinit, map[string][]*ir.Name{})
|
||||
walkStmtList(sinit)
|
||||
}
|
||||
init.Append(sinit...)
|
||||
continue
|
||||
|
11
test/fixedbugs/issue56105.go
Normal file
11
test/fixedbugs/issue56105.go
Normal file
@ -0,0 +1,11 @@
|
||||
// compile -d=libfuzzer
|
||||
|
||||
// Copyright 2022 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 p
|
||||
|
||||
func f() {
|
||||
_ = [...][]int{{}, {}, {}, {}, {}}
|
||||
}
|
Reference in New Issue
Block a user