From: Keith Randall Date: Tue, 12 Aug 2025 00:29:11 +0000 (-0700) Subject: Revert "reflect: handle zero-sized fields of directly-stored structures correctly" X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=caf9fc3ccdf94b968e489d323b965fd47823e146;p=gostls13.git Revert "reflect: handle zero-sized fields of directly-stored structures correctly" This reverts commit b3388569a187ea6be48caa41265f2b4dbc2fdfd3 (CL 694195) Reason for revert: still causing compiler failures on Google test code Change-Id: I2a9b0f9a57fe2b6977238bbfbefb572545210b9f Reviewed-on: https://go-review.googlesource.com/c/go/+/694995 LUCI-TryBot-Result: Go LUCI Reviewed-by: Keith Randall Reviewed-by: Dmitri Shuralyov Reviewed-by: Dmitri Shuralyov --- diff --git a/src/reflect/value.go b/src/reflect/value.go index e2ca0d89dd..6f65ef81dc 100644 --- a/src/reflect/value.go +++ b/src/reflect/value.go @@ -1277,17 +1277,6 @@ func (v Value) Field(i int) Value { fl |= flagStickyRO } } - if fl&flagIndir == 0 && typ.Size() == 0 { - // Special case for picking a field out of a direct struct. - // A direct struct must have a pointer field and possibly a - // bunch of zero-sized fields. We must return the zero-sized - // fields indirectly, as only ptr-shaped things can be direct. - // See issue 74935. - // We use nil instead of v.ptr as it doesn't matter and - // we can avoid pinning a possibly now-unused object. - return Value{typ, nil, fl | flagIndir} - } - // Either flagIndir is set and v.ptr points at struct, // or flagIndir is not set and v.ptr is the actual struct data. // In the former case, we want v.ptr + offset. diff --git a/test/fixedbugs/issue74935.go b/test/fixedbugs/issue74935.go deleted file mode 100644 index 1f6f718b02..0000000000 --- a/test/fixedbugs/issue74935.go +++ /dev/null @@ -1,19 +0,0 @@ -// 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 - -import "reflect" - -type W struct { - E struct{} - X *byte -} - -func main() { - w := reflect.ValueOf(W{}) - _ = w.Field(0).Interface() -}