test: new testcase for gccgo bug

Updates #33158.

Change-Id: Id87eb00ddcb104ba8e7a0d2f6cf324a77a84f4a9
Reviewed-on: https://go-review.googlesource.com/c/go/+/186717
Reviewed-by: Ian Lance Taylor <iant@golang.org>
Reviewed-by: Cherry Zhang <cherryyz@google.com>
Run-TryBot: Ian Lance Taylor <iant@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
This commit is contained in:
Than McIntosh 2019-07-18 08:18:58 -04:00
parent 196e67f95b
commit 34778e58b3
3 changed files with 45 additions and 0 deletions

View File

@ -0,0 +1,25 @@
// 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 a
var GS string
func M() string {
if s := getname("Fred"); s != "" {
return s
}
if s := getname("Joe"); s != "" {
return s
}
return string("Alex")
}
// getname can be any function returning a string, just has to be non-inlinable.
//go:noinline
func getname(s string) string {
return s + "foo"
}

View File

@ -0,0 +1,11 @@
// 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 b
import "a"
func B() string {
return a.M()
}

View File

@ -0,0 +1,9 @@
// compiledir
// 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.
// Issue 33158: gccgo duplicate def error from importing inlinable function
package ignored