X7ROOT File Manager
Current Path:
/opt/golang/1.19.4/src/cmd/compile/internal/types2/testdata/check
opt
/
golang
/
1.19.4
/
src
/
cmd
/
compile
/
internal
/
types2
/
testdata
/
check
/
📁
..
📄
blank.go
(203 B)
📄
builtins0.go
(23.81 KB)
📄
builtins1.go
(5.46 KB)
📄
chans.go
(1.66 KB)
📄
compliterals.go
(442 B)
📄
const0.go
(9.18 KB)
📄
const1.go
(8.56 KB)
📄
constdecl.go
(3.67 KB)
📄
conversions0.go
(1.71 KB)
📄
conversions1.go
(5.07 KB)
📄
cycles0.go
(2.85 KB)
📄
cycles1.go
(781 B)
📄
cycles2.go
(1.12 KB)
📄
cycles3.go
(675 B)
📄
cycles4.go
(2.03 KB)
📄
cycles5.go
(2.98 KB)
📄
decls0.go
(3.97 KB)
📄
decls1.go
(3.6 KB)
📁
decls2
📄
decls3.go
(4.24 KB)
📄
decls4.go
(3.1 KB)
📄
decls5.go
(363 B)
📄
errors.go
(2.16 KB)
📄
expr0.go
(3.7 KB)
📄
expr1.go
(2.61 KB)
📄
expr2.go
(4.92 KB)
📄
expr3.go
(15.42 KB)
📄
funcinference.go
(2.07 KB)
📄
go1_12.go
(1.07 KB)
📄
go1_13.go
(402 B)
📄
go1_16.go
(343 B)
📄
go1_8.go
(333 B)
📄
gotos.go
(5.77 KB)
📄
importC.go
(1.23 KB)
📁
importdecl0
📁
importdecl1
📄
init0.go
(1.91 KB)
📄
init1.go
(1.46 KB)
📄
init2.go
(3.51 KB)
📁
issue25008
📄
issues0.go
(11.44 KB)
📄
issues1.go
(6.02 KB)
📄
labels.go
(3.25 KB)
📄
linalg.go
(2.24 KB)
📄
literals.go
(2.35 KB)
📄
main0.go
(361 B)
📄
main1.go
(250 B)
📄
map0.go
(2.82 KB)
📄
map1.go
(3.4 KB)
📄
methodsets.go
(3.44 KB)
📄
shifts.go
(12.62 KB)
📄
slices.go
(1.51 KB)
📄
stmt0.go
(18.68 KB)
📄
stmt1.go
(3.31 KB)
📄
typeinference.go
(1.38 KB)
📄
typeinst0.go
(1.62 KB)
📄
typeinst1.go
(5.65 KB)
📄
typeinstcycles.go
(384 B)
📄
typeparams.go
(15.06 KB)
📄
unions.go
(2.15 KB)
📄
vardecl.go
(5.47 KB)
Editing: cycles4.go
// Copyright 2013 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 import "unsafe" // Check that all methods of T are collected before // determining the result type of m (which embeds // all methods of T). type T interface { m() interface {T} E } var _ int = T.m(nil).m().e() type E interface { e() int } // Check that unresolved forward chains are followed // (see also comment in resolver.go, checker.typeDecl). var _ int = C.m(nil).m().e() type A B type B interface { m() interface{C} E } type C A // Check that interface type comparison for identity // does not recur endlessly. type T1 interface { m() interface{T1} } type T2 interface { m() interface{T2} } func _(x T1, y T2) { // Checking for assignability of interfaces must check // if all methods of x are present in y, and that they // have identical signatures. The signatures recur via // the result type, which is an interface that embeds // a single method m that refers to the very interface // that contains it. This requires cycle detection in // identity checks for interface types. x = y } type T3 interface { m() interface{T4} } type T4 interface { m() interface{T3} } func _(x T1, y T3) { x = y } // Check that interfaces are type-checked in order of // (embedded interface) dependencies (was issue 7158). var x1 T5 = T7(nil) type T5 interface { T6 } type T6 interface { m() T7 } type T7 interface { T5 } // Actual test case from issue 7158. func wrapNode() Node { return wrapElement() } func wrapElement() Element { return nil } type EventTarget interface { AddEventListener(Event) } type Node interface { EventTarget } type Element interface { Node } type Event interface { Target() Element } // Check that accessing an interface method too early doesn't lead // to follow-on errors due to an incorrectly computed type set. type T8 interface { m() [unsafe.Sizeof(T8.m /* ERROR undefined */ )]int } var _ = T8.m // no error expected here
Upload File
Create Folder