// RUN: %target-typecheck-verify-swift // N.B. Validating the pattern binding initializer for `pickMe` used to cause // recursive validation of the VarDecl. Check that we don't regress now that // this isn't the case. public struct Cyclic { static func pickMe(please: Bool) -> Int { return 42 } public static let pickMe = Cyclic.pickMe(please: true) } struct Node {} struct Parameterized { func please(_ transform: @escaping (_ otherValue: NewValue) -> Value) -> Parameterized { fatalError() } } extension Parameterized where Value == [Node], Format == String { static var pickMe: Parameterized { fatalError() } } extension Parameterized where Value == Node, Format == String { static let pickMe = Parameterized<[Node], String>.pickMe.please { [$0] } } enum Loop: Circle { struct DeLoop { } } protocol Circle { typealias DeLoop = Loop.DeLoop } class Base { static func foo(_ x: Int) {} } class Sub: Base { var foo = { () -> Int in let x = 42 // FIXME: Bogus diagnostic return foo(1) // expected-error {{cannot convert return expression of type '()' to return type 'Int'}} }() } extension Float { static let pickMe: Float = 1 } extension SIMD3 { init(_ scalar: Scalar) { self.init(repeating: scalar) } } extension SIMD3 where SIMD3.Scalar == Float { static let pickMe = SIMD3(.pickMe) } // Test case with circular overrides protocol P { associatedtype A // expected-note@-1 {{protocol requires nested type 'A'; do you want to add it?}} // expected-note@-2 {{through reference here}} func run(a: A) } class C1 { func run(a: Int) {} } class C2: C1, P { override func run(a: A) {} // expected-error@-1 {{circular reference}} // expected-note@-2 {{while resolving type 'A'}} // expected-note@-3 2{{through reference here}} } // Another crash to the above open class G1 { open func run(a: A) {} } class C3: G1, P { // expected-error@-1 {{type 'C3' does not conform to protocol 'P'}} // expected-error@-2 {{cannot find type 'A' in scope}} override func run(a: A) {} // expected-error@-1 {{method does not override any method from its superclass}} } // Another case that triggers circular override checking. protocol P1 { associatedtype X = Int // expected-note {{through reference here}} init(x: X) } class C4 { required init(x: Int) {} } class D4 : C4, P1 { // expected-note 2 {{through reference here}} required init(x: X) { // expected-error {{circular reference}} // expected-note@-1 {{while resolving type 'X'}} // expected-note@-2 2{{through reference here}} super.init(x: x) } } // SR-12236 // N.B. This used to compile in 5.1. protocol SR12236 { } class SR12236_A { // expected-note {{through reference here}} typealias Nest = SR12236 // expected-error {{circular reference}} expected-note {{through reference here}} } extension SR12236_A: SR12236_A.Nest { }