mirror of
https://github.com/golang/go
synced 2024-11-23 12:50:12 -07:00
febafe60d4
New special case for booleans and byte-sized integer types converted to interfaces needs to ensure that the operand is not too complex, if it were to appear in a parameter list for example. Added test, also increased the recursive node dump depth to a level that was actually useful for an actual bug. Fixes #19275. Change-Id: If36ac3115edf439e886703f32d149ee0a46eb2a5 Reviewed-on: https://go-review.googlesource.com/37470 Run-TryBot: David Chase <drchase@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Josh Bleecher Snyder <josharian@gmail.com>
73 lines
1.2 KiB
Go
73 lines
1.2 KiB
Go
// run
|
|
|
|
// Copyright 2017 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 (
|
|
"fmt"
|
|
)
|
|
|
|
type PI struct {
|
|
Enabled bool
|
|
}
|
|
|
|
type SI struct {
|
|
M map[string]*PI
|
|
}
|
|
|
|
//go:noinline
|
|
func (s *SI) test(name string) (*int, error) {
|
|
n := new(int)
|
|
*n = 99
|
|
if err := addUpdate(n, s.M[name].Enabled, "enabled"); err != nil { // this was miscompiled
|
|
return nil, fmt.Errorf(" error adding update for enable flag %t : %s",
|
|
s.M[name].Enabled, err)
|
|
}
|
|
return n, nil
|
|
}
|
|
|
|
//go:noinline
|
|
func addUpdate(n *int, in interface{}, s ...string) error {
|
|
if *n != 99 {
|
|
println("FAIL, *n should be 99, not", *n)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func main1() {
|
|
s := &SI{make(map[string]*PI)}
|
|
s.M["dog"] = &PI{}
|
|
s.test("dog")
|
|
}
|
|
|
|
//go:noinline
|
|
func g(b *byte, i interface{}) error {
|
|
if *b != 17 {
|
|
println("FAIL, *b should be 17, not", *b)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
//go:noinline
|
|
func f(x *byte, m map[string]*bool) {
|
|
if err := g(x, *m["hello"]); err != nil { // this was miscompiled
|
|
return
|
|
}
|
|
}
|
|
|
|
func main2() {
|
|
m := make(map[string]*bool)
|
|
x := false
|
|
m["hello"] = &x
|
|
b := byte(17)
|
|
f(&b, m)
|
|
}
|
|
|
|
func main() {
|
|
main2()
|
|
main1()
|
|
}
|