// errorcheck // Copyright 2020 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 p type T1 struct { // ERROR "invalid recursive type T1\n.*T1 refers to T2\n.*T2 refers to T1|invalid recursive type" f2 T2 } type T2 struct { // GCCGO_ERROR "invalid recursive type" f1 T1 } type a b // GCCGO_ERROR "invalid recursive type" type b c // ERROR "invalid recursive type b\n.*b refers to c\n.*c refers to b|invalid recursive type|invalid recursive type" type c b // GCCGO_ERROR "invalid recursive type" type d e type e f type f f // ERROR "invalid recursive type: f refers to itself|invalid recursive type|invalid recursive type" type g struct { // ERROR "invalid recursive type: g refers to itself|invalid recursive type" h struct { g } } type w x type x y // ERROR "invalid recursive type x\n.*x refers to y\n.*y refers to z\n.*z refers to x|invalid recursive type" type y struct{ z } // GCCGO_ERROR "invalid recursive type" type z [10]x type w2 w // refer to the type loop again