- Notifications
You must be signed in to change notification settings - Fork 10.5k
/
Copy pathconditional_conformances_runtime.swift
67 lines (53 loc) · 1.45 KB
/
conditional_conformances_runtime.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
// RUN: %empty-directory(%t)
// RUN: %target-build-swift %s -o %t/a.out
// RUN: %target-codesign %t/a.out
// RUN: %target-run %t/a.out
// REQUIRES: executable_test
protocolP{
func foo()->Int
}
structX:P{
func foo()->Int{return1}
}
structY<T>{
varwrapped:T
}
extensionY:Pwhere T:P{
func foo()->Int{return wrapped.foo()+10}
}
func tryAsP(_ value:Any)->Int{
iflet p = value as?P{
return p.foo()
}
return0
}
extensionDictionary:Pwhere Value ==(Key)->Bool{
func foo()->Int{return2}
}
letyx=Y(wrapped:X())
precondition(tryAsP(yx)==11)
letdict:[Int:(Int)->Bool]=[:]
precondition(tryAsP(dict)==2)
letyDict=Y(wrapped: dict)
precondition(tryAsP(yDict)==12)
// <rdar://128774651> Generic argument indexing runs off the end when a key
// argument comes after a non-key argument.
structOuter<T>{}
extensionOuterwhere T ==Int{
structInner<U>{
// Add some stored properties that will have field offsets in the metadata.
// If we read past the end of the generic arguments, we'll find these and
// crash on something that's definitely not a valid pointer.
vara:T?
varb:T?
varc:T?
vard:T?
}
}
extensionOuter.Inner:Pwhere U ==String{
func foo()->Int{return1}
}
letconformingInner:Any=Outer.Inner<String>()
letnonconformingInner:Any=Outer.Inner<Int>()
precondition(conformingInner is P)
precondition(!(nonconformingInner is P))