blob: dbac91df8401ddcf6d007a3ac81e484233344e7d [file] [log] [blame]
Adrian Prantlc0dd7a42013-04-19 21:52:06 +00001// RUN: %clang_cc1 -g -emit-llvm -o - %s | FileCheck %s
Adrian Prantlc60dc712013-04-19 19:56:39 +00002// The DWARF standard says the underlying data type of an enum may be
Adrian Prantlb37427f2013-04-19 21:48:07 +00003// stored in an DW_AT_type entry in the enum DIE. This is useful to have
4// so the debugger knows about the signedness of the underlying type.
Adrian Prantlc60dc712013-04-19 19:56:39 +00005
6typedef long NSInteger;
7#define NS_ENUM(_type, _name) enum _name : _type _name; enum _name : _type
8
9// Enum with no specified underlying type
10typedef enum {
11 Enum0One,
12 Enum0Two
13} Enum0;
14
15// Enum declared with the NS_ENUM macro
16typedef NS_ENUM(NSInteger, Enum1) {
17 Enum1One = -1,
18 Enum1Two
19};
20
21// Enum declared with a fixed underlying type
22typedef enum : NSInteger {
23 Enum2One = -1,
24 Enum2Two
25} Enum2;
26
27// Typedef and declaration separately
28enum : NSInteger
29{
30 Enum3One = -1,
31 Enum3Two
32};
33typedef NSInteger Enum3;
34
35int main() {
36 Enum0 e0 = Enum0One;
Duncan P. N. Exon Smithb3a66692014-12-15 19:10:08 +000037 // CHECK: call void @llvm.dbg.declare(metadata {{.*}}, metadata ![[ENUM0:[0-9]+]], metadata !{{.*}})
Adrian Prantlc60dc712013-04-19 19:56:39 +000038 Enum1 e1 = Enum1One;
Duncan P. N. Exon Smithb3a66692014-12-15 19:10:08 +000039 // CHECK: call void @llvm.dbg.declare(metadata {{.*}}, metadata ![[ENUM1:[0-9]+]], metadata !{{.*}})
Adrian Prantlc60dc712013-04-19 19:56:39 +000040 Enum2 e2 = Enum2One;
Duncan P. N. Exon Smithb3a66692014-12-15 19:10:08 +000041 // CHECK: call void @llvm.dbg.declare(metadata {{.*}}, metadata ![[ENUM2:[0-9]+]], metadata !{{.*}})
Adrian Prantlc60dc712013-04-19 19:56:39 +000042 Enum3 e3 = Enum3One;
Duncan P. N. Exon Smithb3a66692014-12-15 19:10:08 +000043 // CHECK: call void @llvm.dbg.declare(metadata {{.*}}, metadata ![[ENUM3:[0-9]+]], metadata !{{.*}})
Adrian Prantlc60dc712013-04-19 19:56:39 +000044
45 // -Werror and the following line ensures that these enums are not
46 // -treated as C++11 strongly typed enums.
47 return e0 != e1 && e1 == e2 && e2 == e3;
48}
Duncan P. N. Exon Smithf04be1f2015-03-03 17:25:55 +000049// CHECK: ![[ENUMERATOR0:[0-9]+]] = !MDCompositeType(tag: DW_TAG_enumeration_type
50// CHECK-SAME: line: 10,
51// CHECK: ![[ENUMERATOR1:[0-9]+]] = !MDCompositeType(tag: DW_TAG_enumeration_type, name: "Enum1"
52// CHECK-SAME: line: 16
53// CHECK-SAME: baseType: ![[ENUMERATOR3:[0-9]+]]
54// CHECK: ![[ENUMERATOR3]] = !MDDerivedType(tag: DW_TAG_typedef, name: "NSInteger"
55// CHECK-SAME: line: 6
56// CHECK-SAME: baseType: ![[LONGINT:[0-9]+]]
57// CHECK: ![[LONGINT]] = !MDBasicType(name: "long int"
58// CHECK: ![[ENUMERATOR2:[0-9]+]] = !MDCompositeType(tag: DW_TAG_enumeration_type,
59// CHECK-SAME: line: 22
60// CHECK-SAME: baseType: ![[ENUMERATOR3]]
Adrian Prantlc60dc712013-04-19 19:56:39 +000061
Duncan P. N. Exon Smithf04be1f2015-03-03 17:25:55 +000062// CHECK: ![[ENUM0]] = !MDLocalVariable(tag: DW_TAG_auto_variable, name: "e0"
63// CHECK-SAME: type: ![[TYPE0:[0-9]+]]
64// CHECK: ![[TYPE0]] = !MDDerivedType(tag: DW_TAG_typedef, name: "Enum0",
65// CHECK-SAME: baseType: ![[ENUMERATOR0]]
Adrian Prantlc60dc712013-04-19 19:56:39 +000066
Duncan P. N. Exon Smithf04be1f2015-03-03 17:25:55 +000067// CHECK: ![[ENUM1]] = !MDLocalVariable(tag: DW_TAG_auto_variable, name: "e1"
68// CHECK-SAME: type: ![[TYPE1:[0-9]+]]
69// CHECK: ![[TYPE1]] = !MDDerivedType(tag: DW_TAG_typedef, name: "Enum1"
70// CHECK-SAME: baseType: ![[ENUMERATOR1]]
Adrian Prantlc60dc712013-04-19 19:56:39 +000071
Duncan P. N. Exon Smithf04be1f2015-03-03 17:25:55 +000072// CHECK: ![[ENUM2]] = !MDLocalVariable(tag: DW_TAG_auto_variable, name: "e2"
73// CHECK-SAME: type: ![[TYPE2:[0-9]+]]
74// CHECK: ![[TYPE2]] = !MDDerivedType(tag: DW_TAG_typedef, name: "Enum2"
75// CHECK-SAME: baseType: ![[ENUMERATOR2]]
Adrian Prantlc60dc712013-04-19 19:56:39 +000076
Duncan P. N. Exon Smithf04be1f2015-03-03 17:25:55 +000077// CHECK: ![[ENUM3]] = !MDLocalVariable(tag: DW_TAG_auto_variable, name: "e3"
78// CHECK-SAME: type: ![[TYPE3:[0-9]+]]
79// CHECK: ![[TYPE3]] = !MDDerivedType(tag: DW_TAG_typedef, name: "Enum3"
80// CHECK-SAME: baseType: ![[ENUMERATOR3]]