mirror of
https://github.com/golang/go
synced 2025-04-03 23:25:20 +00:00
func f() *[4]int { return nil } _ = len(f()) should not panic. We evaluate f, but there isn't a dereference according to the spec (just "arg is evaluated"). Update #72844 Change-Id: Ia32cefc1b7aa091cd1c13016e015842b4d12d5b4 Reviewed-on: https://go-review.googlesource.com/c/go/+/658096 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Robert Griesemer <gri@google.com> Reviewed-by: Keith Randall <khr@google.com>
71 lines
1.0 KiB
Go
71 lines
1.0 KiB
Go
// run
|
|
|
|
// Copyright 2025 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
|
|
|
|
//go:noinline
|
|
func nilPtrFunc() *[4]int {
|
|
return nil
|
|
}
|
|
|
|
var nilPtrVar *[4]int
|
|
|
|
func testLen1() {
|
|
_ = len(*nilPtrFunc())
|
|
}
|
|
|
|
func testLen2() {
|
|
_ = len(nilPtrFunc())
|
|
}
|
|
|
|
func testLen3() {
|
|
_ = len(*nilPtrVar)
|
|
}
|
|
|
|
func testLen4() {
|
|
_ = len(nilPtrVar)
|
|
}
|
|
|
|
func testRange1() {
|
|
for range *nilPtrFunc() {
|
|
}
|
|
}
|
|
func testRange2() {
|
|
for range nilPtrFunc() {
|
|
}
|
|
}
|
|
func testRange3() {
|
|
for range *nilPtrVar {
|
|
}
|
|
}
|
|
func testRange4() {
|
|
for range nilPtrVar {
|
|
}
|
|
}
|
|
|
|
func main() {
|
|
//shouldPanic(testLen1)
|
|
shouldNotPanic(testLen2)
|
|
shouldNotPanic(testLen3)
|
|
shouldNotPanic(testLen4)
|
|
//shouldPanic(testRange1)
|
|
shouldNotPanic(testRange2)
|
|
shouldNotPanic(testRange3)
|
|
shouldNotPanic(testRange4)
|
|
}
|
|
|
|
func shouldPanic(f func()) {
|
|
defer func() {
|
|
if e := recover(); e == nil {
|
|
panic("should have panicked")
|
|
}
|
|
}()
|
|
f()
|
|
}
|
|
func shouldNotPanic(f func()) {
|
|
f()
|
|
}
|