- Notifications
You must be signed in to change notification settings - Fork 10.5k
/
Copy pathenum_floating_point_raw_value.swift
97 lines (79 loc) · 3.1 KB
/
enum_floating_point_raw_value.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
// RUN: %target-typecheck-verify-swift
// FIXME: this test only passes on platforms which have Float80.
// <rdar://problem/19508460> Floating point enum raw values are not portable
// REQUIRES: CPU=i386 || CPU=x86_64
// Windows does not support FP80
// XFAIL: OS=windows-msvc
enumRawTypeWithFloatValues:Float{ // expected-error {{'RawTypeWithFloatValues' declares raw type 'Float', but does not conform to RawRepresentable and conformance could not be synthesized}} expected-note {{add stubs for conformance}}
case Northrup =1.5
case Overton // expected-error {{enum case must declare a raw value when the preceding raw value is not an integer}}
case Pettygrove =2.25
}
enumRawTypeWithRepeatValues2:Double{
case Vaughn =22 // expected-note {{raw value previously used here}}
case Wilson =22.0 // expected-error {{raw value for enum case is not unique}}
}
enumRawTypeWithRepeatValues3:Double{
// 2^63-1
case Vaughn =9223372036854775807 // expected-note {{raw value previously used here}}
case Wilson =9223372036854775807.0 // expected-error {{raw value for enum case is not unique}}
}
enumRawTypeWithRepeatValues4:Double{
// 2^64-1
case Vaughn =18446744073709551615 // expected-note {{raw value previously used here}}
case Wilson =18446744073709551615.0 // expected-error {{raw value for enum case is not unique}}
}
enumRawTypeWithRepeatValues5:Double{
// FIXME: should reject.
// 2^65-1
case Vaughn =36893488147419103231
case Wilson =36893488147419103231.0
}
enumRawTypeWithRepeatValues6:Double{
// FIXME: should reject.
// 2^127-1
case Vaughn =170141183460469231731687303715884105727
case Wilson =170141183460469231731687303715884105727.0
}
enumRawTypeWithRepeatValues7:Double{
// FIXME: should reject.
// 2^128-1
case Vaughn =340282366920938463463374607431768211455
case Wilson =340282366920938463463374607431768211455.0
}
enumRawTypeWithNonRepeatValues:Double{
case SantaClara =3.7
case SanFernando =7.4
case SanAntonio =-3.7
case SanCarlos =-7.4
}
enumRawTypeWithRepeatValuesAutoInc:Double{
case Vaughn =22 // expected-note {{raw value auto-incremented from here}}
case Wilson // expected-note {{raw value previously used here}}
case Yeon =23 // expected-error {{raw value for enum case is not unique}}
}
enumRawTypeWithRepeatValuesAutoInc2:Double{
case Vaughn =23 // expected-note {{raw value previously used here}}
case Wilson =22 // expected-note {{raw value auto-incremented from here}}
case Yeon // expected-error {{raw value for enum case is not unique}}
}
enumRawTypeWithRepeatValuesAutoInc3:Double{
case Vaughn // expected-note {{raw value implicitly auto-incremented from zero}}
case Wilson // expected-note {{raw value previously used here}}
case Yeon =1 // expected-error {{raw value for enum case is not unique}}
}
// rdar://problem/22476643
publicprotocolRawValueA:RawRepresentable
{
varrawValue:Double{get}
}
enumRawValueATest:Double,RawValueA{
case A, B
}
publicprotocolRawValueB
{
varrawValue:Double{get}
}
enumRawValueBTest:Double,RawValueB{
case A, B
}