Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / SemaCXX / switch.cpp
blobc37a75bd3e8e2b949a02dfdbee75a1e6197281bc
1 // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
3 void test() {
4 bool x = true;
5 switch (x) { // expected-warning {{bool}}
6 case 0:
7 break;
10 int n = 3;
11 switch (n && true) { // expected-warning {{bool}}
12 case 1:
13 break;
17 // PR5518
18 struct A {
19 operator int(); // expected-note{{conversion to integral type}}
22 void x() {
23 switch(A()) {
27 enum E { e1, e2 };
28 struct B : A {
29 operator E() const; // expected-note{{conversion to enumeration type}}
32 void x2() {
33 switch (B()) { // expected-error{{multiple conversions}}
37 struct C; // expected-note{{forward declaration}}
39 void x3(C &c) {
40 switch (c) { // expected-error{{incomplete class type}}
44 namespace test3 {
45 enum En { A, B, C };
46 template <En how> void foo() {
47 int x = 0, y = 5;
49 switch (how) { //expected-warning {{no case matching constant switch condition '2'}}
50 case A: x *= y; break;
51 case B: x += y; break;
52 // No case for C, but it's okay because we have a constant condition.
56 template void foo<A>();
57 template void foo<B>();
58 template void foo<C>(); //expected-note {{in instantiation}}
61 // PR9304
62 void click_check_header_sizes() {
63 switch (0 == 8) { // expected-warning {{switch condition has boolean value}}
64 case 0: ;
68 void local_class(int n) {
69 for (;;) switch (n) {
70 case 0:
71 struct S {
72 void f() {
73 case 1: // expected-error {{'case' statement not in switch statement}}
74 break; // expected-error {{'break' statement not in loop or switch statement}}
75 default: // expected-error {{'default' statement not in switch statement}}
76 continue; // expected-error {{'continue' statement not in loop statement}}
79 S().f();
80 []{
81 case 2: // expected-error {{'case' statement not in switch statement}}
82 break; // expected-error {{'break' statement not in loop or switch statement}}
83 default: // expected-error {{'default' statement not in switch statement}}
84 continue; // expected-error {{'continue' statement not in loop statement}}
85 }();
89 namespace Conversion {
90 struct S {
91 explicit operator int(); // expected-note {{conversion}}
93 template<typename T> void f(T t) {
94 switch (t) { // expected-error {{explicit conversion}}
95 case 0:
96 return;
97 default:
98 break;
101 template void f(S); // expected-note {{instantiation of}}
104 namespace OpaqueEnumWarnings {
106 enum Opaque : int;
107 enum class OpaqueClass : int;
109 enum class Defined : int;
110 enum class Defined : int { a };
112 void test(Opaque o, OpaqueClass oc, Defined d) {
113 // Don't warn that case value is not present in opaque enums.
114 switch (o) {
115 case (Opaque)1:
116 break;
118 switch (oc) {
119 case (OpaqueClass)1:
120 break;
123 switch (d) {
124 case Defined::a:
125 break;
126 case (Defined)2: // expected-warning {{case value not in enumerated type 'Defined'}}
127 break;
133 namespace EmptyEnum {
135 enum Empty : int {};
136 void test(Empty e) {
137 switch (e) {
138 case (Empty)0:
139 break;
141 switch (e) {
142 default:
143 break;
147 } // namespace EmptyEnum