go/test/fixedbugs/issue17449.go
Dmitri Shuralyov b2fd76ab8d test: migrate remaining files to go:build syntax
Most of the test cases in the test directory use the new go:build syntax
already. Convert the rest. In general, try to place the build constraint
line below the test directive comment in more places.

For #41184.
For #60268.

Change-Id: I11c41a0642a8a26dc2eda1406da908645bbc005b
Cq-Include-Trybots: luci.golang.try:gotip-linux-386-longtest,gotip-linux-amd64-longtest,gotip-windows-amd64-longtest
Reviewed-on: https://go-review.googlesource.com/c/go/+/536236
Reviewed-by: Ian Lance Taylor <iant@google.com>
Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
Auto-Submit: Dmitri Shuralyov <dmitshur@golang.org>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
2023-10-19 23:33:25 +00:00

37 lines
1 KiB
Go

// errorcheck -0 -race
//go:build (linux && amd64) || (linux && ppc64le) || (darwin && amd64) || (freebsd && amd64) || (netbsd && amd64) || (windows && amd64)
// Copyright 2016 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 17449: race instrumentation copies over previous instrumented nodes from parents block into child's Ninit block.
// This code surfaces the duplication at compile time because of generated inline labels.
package master
type PriorityList struct {
elems []interface{}
}
func (x *PriorityList) Len() int { return len(x.elems) }
func (l *PriorityList) remove(i int) interface{} {
elem := l.elems[i]
l.elems = append(l.elems[:i], l.elems[i+1:]...)
return elem
}
func (l *PriorityList) Next() interface{} {
return l.remove(l.Len() - 1)
}
var l *PriorityList
func Foo() {
// It would fail here if instrumented code (including inline-label) was copied.
for elem := l.Next(); elem != nil; elem = l.Next() {
}
}