mirror of
https://github.com/golang/go
synced 2024-11-25 09:07:58 -07:00
45320c23f2
Range over integer is enabled now without the GOEXPERIMENT. The GOEXPERIMENT is only for range over func. Rename it to rangefunc. For #61405. Change-Id: I9405fb8e2e30827875716786823856090a1a0cad Reviewed-on: https://go-review.googlesource.com/c/go/+/539277 Reviewed-by: Russ Cox <rsc@golang.org> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
25 lines
830 B
Go
25 lines
830 B
Go
// errorcheck -goexperiment rangefunc
|
|
|
|
// Copyright 2023 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.
|
|
|
|
// See ../internal/types/testdata/spec/range.go for most tests.
|
|
// The ones in this file cannot be expressed in that framework
|
|
// due to conflicts between that framework's error location pickiness
|
|
// and gofmt's comment location pickiness.
|
|
|
|
package p
|
|
|
|
type T struct{}
|
|
|
|
func (*T) PM() {}
|
|
func (T) M() {}
|
|
|
|
func test() {
|
|
for range T.M { // ERROR "cannot range over T.M \(value of type func\(T\)\): func must be func\(yield func\(...\) bool\): argument is not func"
|
|
}
|
|
for range (*T).PM { // ERROR "cannot range over \(\*T\).PM \(value of type func\(\*T\)\): func must be func\(yield func\(...\) bool\): argument is not func"
|
|
}
|
|
}
|