0
1
mirror of https://github.com/golang/go synced 2025-04-03 23:25:20 +00:00
Files
go/test/fixedbugs/issue72844.go
Keith Randall deb6790fcf cmd/compile: remove implicit deref from len(p) where p is ptr-to-array
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>
2025-03-19 09:55:46 -07:00

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()
}