mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
The implementation is not 100% perfect but I don’t think it’s worth putting too much effort into it passing more information down in the parser if 'repeat' and 'each' are valid if we are going to remove the current parser anyway. rdar://95725895
205 lines
9.7 KiB
Swift
205 lines
9.7 KiB
Swift
// RUN: %batch-code-completion
|
|
|
|
protocol MyProtocol {
|
|
associatedtype Mistery
|
|
}
|
|
struct MyStruct {}
|
|
enum MyEnum {}
|
|
class MyClass {}
|
|
struct ConcreteMyProtocol : MyProtocol {
|
|
typealias Mistery = MyStruct
|
|
}
|
|
|
|
// MARK: 'some' keyword.
|
|
|
|
// BEGINNING_WITH_SOME-DAG: Keyword/None: some; name=some
|
|
// BEGINNING_WITH_SOME-DAG: Keyword/None: Any[#Any#]; name=Any
|
|
// BEGINNING_WITH_SOME-DAG: Decl[Enum]/CurrModule: MyEnum[#MyEnum#]; name=MyEnum
|
|
// BEGINNING_WITH_SOME-DAG: Decl[Class]/CurrModule: MyClass[#MyClass#]; name=MyClass
|
|
// BEGINNING_WITH_SOME-DAG: Decl[Protocol]/CurrModule: MyProtocol[#MyProtocol#]; name=MyProtocol
|
|
// BEGINNING_WITH_SOME-DAG: Decl[Struct]/CurrModule: MyStruct[#MyStruct#]; name=MyStruct
|
|
|
|
func gloabalFunc() -> #^GLOBAL_FUNC?check=BEGINNING_WITH_SOME^#
|
|
var globalVar: #^GLOBAL_VAR?check=BEGINNING_WITH_SOME^#
|
|
|
|
protocol SomeProto {
|
|
associatedtype protoAssocTy: #^PROTOCOL_ASSOCIATEDTYPE?check=BEGINNING_WITH_SOME^#
|
|
func protoMethodReq() -> #^PROTOCOL_METHOD_REQUIREMENT?check=BEGINNING_WITH_SOME^#
|
|
var protoVarReq: #^PROTOCOL_VAR_REQUIREMENT?check=BEGINNING_WITH_SOME^#
|
|
subscript(req: Int) -> #^PROTOCOL_SUBSCRIPT_REQUIREMENT?check=BEGINNING_WITH_SOME^#
|
|
}
|
|
|
|
extension SomeProto {
|
|
func protoMethodExt() -> #^PROTOCOL_METHOD_EXTENSION?check=BEGINNING_WITH_SOME^#
|
|
var protoVarExt: #^PROTOCOL_VAR_EXTENSION?check=BEGINNING_WITH_SOME^#
|
|
subscript(ext: Int) -> #^PROTOCOL_SUBSCRIPT_EXTENSION?check=BEGINNING_WITH_SOME^#
|
|
}
|
|
|
|
struct SomeStruct {
|
|
typealias TyAlias = #^STRUCT_TYPEALIAS_RHS?check=BEGINNING_WITH_SOME^#
|
|
func structMethodExt() -> #^STRUCT_METHOD?check=BEGINNING_WITH_SOME^#
|
|
var structVarExt: #^STRUCT_VAR?check=BEGINNING_WITH_SOME^#
|
|
subscript(struct: Int) -> #^STRUCT_SUBSCRIPT?check=BEGINNING_WITH_SOME^#
|
|
}
|
|
|
|
// MARK: Conformance.
|
|
|
|
protocol HasAssocPlain {
|
|
associatedtype AssocPlain
|
|
func returnAssocPlain() -> AssocPlain
|
|
}
|
|
protocol HasAssocWithConformanceConstraint {
|
|
associatedtype AssocWithConformanceConstraint: MyProtocol
|
|
func returnAssocWithConformanceConstraint(fn: (Int) -> Int) -> AssocWithConformanceConstraint
|
|
}
|
|
protocol HasAssocWithSuperClassConstraint {
|
|
associatedtype AssocWithSuperClassConstraint: MyClass
|
|
var valAssocWithSuperClassConstraint: AssocWithSuperClassConstraint { get }
|
|
}
|
|
protocol HasAssocWithCompositionConstraint {
|
|
associatedtype AssocWithCompositionConstraint: MyClass & MyProtocol
|
|
subscript(idx: Int) -> AssocWithCompositionConstraint { get }
|
|
}
|
|
protocol HasAssocWithDefault {
|
|
associatedtype AssocWithDefault = MyEnum
|
|
func returnAssocWithDefault() -> AssocWithDefault
|
|
}
|
|
protocol HasAssocWithConstraintAndDefault {
|
|
associatedtype AssocWithConstraintAndDefault: MyProtocol = ConcreteMyProtocol
|
|
func returnAssocWithConstraintAndDefault() -> AssocWithConstraintAndDefault
|
|
}
|
|
protocol HasAssocWithAnyObjectConstraint {
|
|
associatedtype AssocWithAnyObjectConstraint: AnyObject & MyProtocol
|
|
func returnAssocWithAnyObjectConstraint() -> AssocWithAnyObjectConstraint
|
|
}
|
|
protocol HasAssocWithConstraintOnProto where Self.AssocWithConstraintOnProto : MyProtocol {
|
|
associatedtype AssocWithConstraintOnProto
|
|
func returnAssocWithConstraintOnProto() -> AssocWithConstraintOnProto
|
|
}
|
|
protocol HasAssocWithSameTypeConstraint where Self.AssocWithSameTypeConstraint == ConcreteMyProtocol {
|
|
associatedtype AssocWithSameTypeConstraint : MyProtocol
|
|
func returnAssocWithSameTypeConstraint() -> AssocWithSameTypeConstraint
|
|
}
|
|
protocol HasAssocWithConformanceConstraintGeneric {
|
|
associatedtype AssocWithConformanceConstraintGeneric: MyProtocol
|
|
func returnAssocWithConformanceConstraintGeneric<T>(arg: T) -> AssocWithConformanceConstraintGeneric
|
|
}
|
|
|
|
class TestClass :
|
|
HasAssocPlain,
|
|
HasAssocWithConformanceConstraint,
|
|
HasAssocWithSuperClassConstraint,
|
|
HasAssocWithCompositionConstraint,
|
|
HasAssocWithDefault,
|
|
HasAssocWithConstraintAndDefault,
|
|
HasAssocWithAnyObjectConstraint,
|
|
HasAssocWithConstraintOnProto,
|
|
HasAssocWithSameTypeConstraint,
|
|
HasAssocWithConformanceConstraintGeneric {
|
|
#^OVERRIDE_TestClass?check=OVERRIDE^#
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocPlain() -> AssocPlain {|};
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithConformanceConstraint(fn: (Int) -> Int) -> some MyProtocol {|};
|
|
// OVERRIDE-DAG: Decl[InstanceVar]/Super: var valAssocWithSuperClassConstraint: some MyClass;
|
|
// OVERRIDE-DAG: Decl[Subscript]/Super: subscript(idx: Int) -> some MyClass & MyProtocol {|};
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithDefault() -> MyEnum {|};
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithConstraintAndDefault() -> ConcreteMyProtocol {|};
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithAnyObjectConstraint() -> some MyProtocol & AnyObject {|}
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithConstraintOnProto() -> some MyProtocol {|}
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithSameTypeConstraint() -> ConcreteMyProtocol {|}
|
|
// OVERRIDE-DAG: Decl[InstanceMethod]/Super: func returnAssocWithConformanceConstraintGeneric<T>(arg: T) -> AssocWithConformanceConstraintGeneric {|}
|
|
}
|
|
|
|
struct TestStruct :
|
|
HasAssocPlain,
|
|
HasAssocWithConformanceConstraint,
|
|
HasAssocWithSuperClassConstraint,
|
|
HasAssocWithCompositionConstraint,
|
|
HasAssocWithDefault,
|
|
HasAssocWithConstraintAndDefault,
|
|
HasAssocWithAnyObjectConstraint,
|
|
HasAssocWithConstraintOnProto,
|
|
HasAssocWithSameTypeConstraint,
|
|
HasAssocWithConformanceConstraintGeneric {
|
|
#^OVERRIDE_TestStruct?check=OVERRIDE^#
|
|
}
|
|
|
|
class HasTypealias : HasAssocWithConformanceConstraint {
|
|
typealias AssocWithConformanceConstraint = ConcreteMyProtocol
|
|
#^OVERRIDE_HasTypealias^#
|
|
// OVERRIDE_HasTypealias-DAG: Decl[InstanceMethod]/Super: func returnAssocWithConformanceConstraint(fn: (Int) -> Int) -> ConcreteMyProtocol {|};
|
|
}
|
|
|
|
// MARK: Postfix expession for opaque result types.
|
|
|
|
protocol TestProtocol {
|
|
associatedtype Assoc1
|
|
associatedtype Assoc2: Comparable
|
|
|
|
func foo(arg1: Assoc1, arg2: (Assoc2) -> Assoc1) -> Assoc2
|
|
subscript(idx: Assoc1, idx2: Assoc2) -> Self { get }
|
|
var value: (Assoc1, Assoc2) { get }
|
|
}
|
|
|
|
func vendTestProtocol() -> some TestProtocol {
|
|
<#code#>
|
|
}
|
|
|
|
func postfixExpr() {
|
|
var value = vendTestProtocol()
|
|
let _ = value.#^POSTFIX_TestProtocol_DOT^#
|
|
let _ = value#^POSTFIX_TestProtocol_NODOT^#
|
|
}
|
|
// POSTFIX_TestProtocol_DOT: Begin completions, 3 items
|
|
// POSTFIX_TestProtocol_DOT-DAG: Decl[InstanceMethod]/CurrNominal: foo({#arg1: TestProtocol.Assoc1#}, {#arg2: (Comparable) -> TestProtocol.Assoc1##(Comparable) -> TestProtocol.Assoc1#})[#Comparable#]; name={{.*$}}
|
|
// POSTFIX_TestProtocol_DOT-DAG: Decl[InstanceVar]/CurrNominal: value[#(TestProtocol.Assoc1, Comparable)#]; name={{.*$}}
|
|
// POSTFIX_TestProtocol_DOT-DAG: Keyword[self]/CurrNominal: self[#TestProtocol#]; name={{.*$}}
|
|
|
|
// POSTFIX_TestProtocol_NODOT: Begin completions, 5 items
|
|
// POSTFIX_TestProtocol_NODOT-DAG: Decl[InstanceMethod]/CurrNominal: .foo({#arg1: TestProtocol.Assoc1#}, {#arg2: (Comparable) -> TestProtocol.Assoc1##(Comparable) -> TestProtocol.Assoc1#})[#Comparable#]; name={{.*$}}
|
|
// POSTFIX_TestProtocol_NODOT-DAG: Decl[Subscript]/CurrNominal: [{#(idx): TestProtocol.Assoc1#}, {#(idx2): Comparable#}][#TestProtocol#]; name={{.*$}}
|
|
// POSTFIX_TestProtocol_NODOT-DAG: Decl[InstanceVar]/CurrNominal: .value[#(TestProtocol.Assoc1, Comparable)#]; name={{.*$}}
|
|
// POSTFIX_TestProtocol_NODOT-DAG: BuiltinOperator/None: = {#TestProtocol#}; name={{.*$}}
|
|
// POSTFIX_TestProtocol_NODOT-DAG: Keyword[self]/CurrNominal: .self[#TestProtocol#]; name={{.*$}}
|
|
|
|
protocol TestProtocol2 {
|
|
associatedtype Assoc: Comparable
|
|
func foo() -> Assoc
|
|
func bar() -> Assoc
|
|
func baz(x: @autoclosure () -> Assoc) -> (Assoc) -> Assoc
|
|
}
|
|
extension TestProtocol2 {
|
|
func inExt() -> Assoc { fatalError() }
|
|
}
|
|
struct ConcreteTestProtocol2: TestProtocol2 {
|
|
func foo() -> some Comparable { 1 }
|
|
#^OVERRIDE_TestProtocol2^#
|
|
// OVERRIDE_TestProtocol2-NOT: foo()
|
|
// OVERRIDE_TestProtocol2-NOT: inExt()
|
|
// OVERRIDE_TestProtocol2-DAG: Decl[InstanceMethod]/Super: func bar() -> Assoc {|};
|
|
// OVERRIDE_TestProtocol2-DAG: Decl[InstanceMethod]/Super: func baz(x: @autoclosure () -> Assoc) -> (Assoc) -> Assoc {|};
|
|
// OVERRIDE_TestProtocol2-DAG: Decl[AssociatedType]/Super: typealias Assoc = {#(Type)#};
|
|
// OVERRIDE_TestProtocol2-NOT: foo()
|
|
// OVERRIDE_TestProtocol2-NOT: inExt()
|
|
}
|
|
func testUseTestProtocol2(value: ConcreteTestProtocol2) {
|
|
value.#^POSTFIX_ConcreteTestProtocol2^#
|
|
// POSTFIX_ConcreteTestProtocol2-DAG: Keyword[self]/CurrNominal: self[#ConcreteTestProtocol2#];
|
|
// POSTFIX_ConcreteTestProtocol2-DAG: Decl[InstanceMethod]/CurrNominal: foo()[#Comparable#];
|
|
// POSTFIX_ConcreteTestProtocol2-DAG: Decl[InstanceMethod]/Super: bar()[#ConcreteTestProtocol2.Assoc#];
|
|
// POSTFIX_ConcreteTestProtocol2-DAG: Decl[InstanceMethod]/Super: baz({#x: ConcreteTestProtocol2.Assoc#})[#(ConcreteTestProtocol2.Assoc) -> ConcreteTestProtocol2.Assoc#];
|
|
// POSTFIX_ConcreteTestProtocol2-DAG: Decl[InstanceMethod]/Super: inExt()[#ConcreteTestProtocol2.Assoc#];
|
|
}
|
|
|
|
struct Generic<T> {
|
|
func returnMyProto() -> some MyProtocol { ConcreteMyProtocol() }
|
|
}
|
|
func overloaded() -> Generic<Int> { fatalError() }
|
|
func overloaded() -> Generic<Float> { fatalError() }
|
|
// Tests that ambiguous doesn't result duplicated 'returnMyProto()'.
|
|
func testDupGenericReturningOpaque() {
|
|
overloaded().#^DupGenericReturningOpaque^#
|
|
// DupGenericReturningOpaque-NOT: returnMyProto()
|
|
// DupGenericReturningOpaque: Decl[InstanceMethod]/CurrNominal: returnMyProto()[#MyProtocol#]; name=returnMyProto()
|
|
// DupGenericReturningOpaque-NOT: returnMyProto()
|
|
}
|