r202790 - MS ABI: Reorganize some tests

David Majnemer david.majnemer at gmail.com
Mon Mar 3 21:47:41 PST 2014


Author: majnemer
Date: Mon Mar  3 23:47:41 2014
New Revision: 202790

URL: http://llvm.org/viewvc/llvm-project?rev=202790&view=rev
Log:
MS ABI: Reorganize some tests

Move some c++11 specific tests to mangle-ms-cxx11

Modified:
    cfe/trunk/test/CodeGenCXX/mangle-ms-cxx11.cpp
    cfe/trunk/test/CodeGenCXX/mangle-ms.cpp

Modified: cfe/trunk/test/CodeGenCXX/mangle-ms-cxx11.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/mangle-ms-cxx11.cpp?rev=202790&r1=202789&r2=202790&view=diff
==============================================================================
--- cfe/trunk/test/CodeGenCXX/mangle-ms-cxx11.cpp (original)
+++ cfe/trunk/test/CodeGenCXX/mangle-ms-cxx11.cpp Mon Mar  3 23:47:41 2014
@@ -12,3 +12,92 @@ int RRef(int&& a) { return a; }
 // CHECK: "\01?Null@@YAX$$T at Z"
 namespace std { typedef decltype(__nullptr) nullptr_t; }
 void Null(std::nullptr_t) {}
+
+namespace EnumMangling {
+  extern enum Enum01 { } Enum;
+  extern enum Enum02 : bool { } BoolEnum;
+  extern enum Enum03 : char { } CharEnum;
+  extern enum Enum04 : signed char { } SCharEnum;
+  extern enum Enum05 : unsigned char { } UCharEnum;
+  extern enum Enum06 : short { } SShortEnum;
+  extern enum Enum07 : unsigned short { } UShortEnum;
+  extern enum Enum08 : int { } SIntEnum;
+  extern enum Enum09 : unsigned int { } UIntEnum;
+  extern enum Enum10 : long { } SLongEnum;
+  extern enum Enum11 : unsigned long { } ULongEnum;
+  extern enum Enum12 : long long { } SLongLongEnum;
+  extern enum Enum13 : unsigned long long { } ULongLongEnum;
+// CHECK-DAG: @"\01?Enum at EnumMangling@@3W4Enum01 at 1@A"
+// CHECK-DAG: @"\01?BoolEnum at EnumMangling@@3W4Enum02 at 1@A
+// CHECK-DAG: @"\01?CharEnum at EnumMangling@@3W4Enum03 at 1@A
+// CHECK-DAG: @"\01?SCharEnum at EnumMangling@@3W4Enum04 at 1@A
+// CHECK-DAG: @"\01?UCharEnum at EnumMangling@@3W4Enum05 at 1@A
+// CHECK-DAG: @"\01?SShortEnum at EnumMangling@@3W4Enum06 at 1@A"
+// CHECK-DAG: @"\01?UShortEnum at EnumMangling@@3W4Enum07 at 1@A"
+// CHECK-DAG: @"\01?SIntEnum at EnumMangling@@3W4Enum08 at 1@A"
+// CHECK-DAG: @"\01?UIntEnum at EnumMangling@@3W4Enum09 at 1@A"
+// CHECK-DAG: @"\01?SLongEnum at EnumMangling@@3W4Enum10 at 1@A"
+// CHECK-DAG: @"\01?ULongEnum at EnumMangling@@3W4Enum11 at 1@A"
+// CHECK-DAG: @"\01?SLongLongEnum at EnumMangling@@3W4Enum12 at 1@A"
+// CHECK-DAG: @"\01?ULongLongEnum at EnumMangling@@3W4Enum13 at 1@A"
+  decltype(Enum) *UseEnum() { return &Enum; }
+  decltype(BoolEnum) *UseBoolEnum() { return &BoolEnum; }
+  decltype(CharEnum) *UseCharEnum() { return &CharEnum; }
+  decltype(SCharEnum) *UseSCharEnum() { return &SCharEnum; }
+  decltype(UCharEnum) *UseUCharEnum() { return &UCharEnum; }
+  decltype(SShortEnum) *UseSShortEnum() { return &SShortEnum; }
+  decltype(UShortEnum) *UseUShortEnum() { return &UShortEnum; }
+  decltype(SIntEnum) *UseSIntEnum() { return &SIntEnum; }
+  decltype(UIntEnum) *UseUIntEnum() { return &UIntEnum; }
+  decltype(SLongEnum) *UseSLongEnum() { return &SLongEnum; }
+  decltype(ULongEnum) *UseULongEnum() { return &ULongEnum; }
+  decltype(SLongLongEnum) *UseSLongLongEnum() { return &SLongLongEnum; }
+  decltype(ULongLongEnum) *UseULongLongEnum() { return &ULongLongEnum; }
+  extern enum class EnumClass01 { } EnumClass;
+  extern enum class EnumClass02 : bool { } BoolEnumClass;
+  extern enum class EnumClass03 : char { } CharEnumClass;
+  extern enum class EnumClass04 : signed char { } SCharEnumClass;
+  extern enum class EnumClass05 : unsigned char { } UCharEnumClass;
+  extern enum class EnumClass06 : short { } SShortEnumClass;
+  extern enum class EnumClass07 : unsigned short { } UShortEnumClass;
+  extern enum class EnumClass08 : int { } SIntEnumClass;
+  extern enum class EnumClass09 : unsigned int { } UIntEnumClass;
+  extern enum class EnumClass10 : long { } SLongEnumClass;
+  extern enum class EnumClass11 : unsigned long { } ULongEnumClass;
+  extern enum class EnumClass12 : long long { } SLongLongEnumClass;
+  extern enum class EnumClass13 : unsigned long long { } ULongLongEnumClass;
+// CHECK-DAG: @"\01?EnumClass at EnumMangling@@3W4EnumClass01 at 1@A"
+// CHECK-DAG: @"\01?BoolEnumClass at EnumMangling@@3W4EnumClass02 at 1@A
+// CHECK-DAG: @"\01?CharEnumClass at EnumMangling@@3W4EnumClass03 at 1@A
+// CHECK-DAG: @"\01?SCharEnumClass at EnumMangling@@3W4EnumClass04 at 1@A
+// CHECK-DAG: @"\01?UCharEnumClass at EnumMangling@@3W4EnumClass05 at 1@A
+// CHECK-DAG: @"\01?SShortEnumClass at EnumMangling@@3W4EnumClass06 at 1@A"
+// CHECK-DAG: @"\01?UShortEnumClass at EnumMangling@@3W4EnumClass07 at 1@A"
+// CHECK-DAG: @"\01?SIntEnumClass at EnumMangling@@3W4EnumClass08 at 1@A"
+// CHECK-DAG: @"\01?UIntEnumClass at EnumMangling@@3W4EnumClass09 at 1@A"
+// CHECK-DAG: @"\01?SLongEnumClass at EnumMangling@@3W4EnumClass10 at 1@A"
+// CHECK-DAG: @"\01?ULongEnumClass at EnumMangling@@3W4EnumClass11 at 1@A"
+// CHECK-DAG: @"\01?SLongLongEnumClass at EnumMangling@@3W4EnumClass12 at 1@A"
+// CHECK-DAG: @"\01?ULongLongEnumClass at EnumMangling@@3W4EnumClass13 at 1@A"
+  decltype(EnumClass) *UseEnumClass() { return &EnumClass; }
+  decltype(BoolEnumClass) *UseBoolEnumClass() { return &BoolEnumClass; }
+  decltype(CharEnumClass) *UseCharEnumClass() { return &CharEnumClass; }
+  decltype(SCharEnumClass) *UseSCharEnumClass() { return &SCharEnumClass; }
+  decltype(UCharEnumClass) *UseUCharEnumClass() { return &UCharEnumClass; }
+  decltype(SShortEnumClass) *UseSShortEnumClass() { return &SShortEnumClass; }
+  decltype(UShortEnumClass) *UseUShortEnumClass() { return &UShortEnumClass; }
+  decltype(SIntEnumClass) *UseSIntEnumClass() { return &SIntEnumClass; }
+  decltype(UIntEnumClass) *UseUIntEnumClass() { return &UIntEnumClass; }
+  decltype(SLongEnumClass) *UseSLongEnumClass() { return &SLongEnumClass; }
+  decltype(ULongEnumClass) *UseULongEnumClass() { return &ULongEnumClass; }
+  decltype(SLongLongEnumClass) *UseSLongLongEnumClass() { return &SLongLongEnumClass; }
+  decltype(ULongLongEnumClass) *UseULongLongEnumClass() { return &ULongLongEnumClass; }
+}
+
+namespace PR18022 {
+
+struct { } a;
+decltype(a) fun(decltype(a) x, decltype(a)) { return x; }
+// CHECK-DAG: ?fun at PR18022@@YA?AU<unnamed-type-a>@1 at U21@0 at Z
+
+}

Modified: cfe/trunk/test/CodeGenCXX/mangle-ms.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/mangle-ms.cpp?rev=202790&r1=202789&r2=202790&view=diff
==============================================================================
--- cfe/trunk/test/CodeGenCXX/mangle-ms.cpp (original)
+++ cfe/trunk/test/CodeGenCXX/mangle-ms.cpp Mon Mar  3 23:47:41 2014
@@ -1,5 +1,5 @@
-// RUN: %clang_cc1 -fblocks -emit-llvm %s -o - -triple=i386-pc-win32 -std=c++11 | FileCheck %s
-// RUN: %clang_cc1 -fblocks -emit-llvm %s -o - -triple=x86_64-pc-win32 -std=c++11| FileCheck -check-prefix X64 %s
+// RUN: %clang_cc1 -fblocks -emit-llvm %s -o - -triple=i386-pc-win32 -std=c++98 | FileCheck %s
+// RUN: %clang_cc1 -fblocks -emit-llvm %s -o - -triple=x86_64-pc-win32 -std=c++98| FileCheck -check-prefix X64 %s
 
 int a;
 // CHECK-DAG: @"\01?a@@3HA"
@@ -254,87 +254,6 @@ namespace PR13182 {
   }
 }
 
-namespace EnumMangling {
-  extern enum Enum01 { } Enum;
-  extern enum Enum02 : bool { } BoolEnum;
-  extern enum Enum03 : char { } CharEnum;
-  extern enum Enum04 : signed char { } SCharEnum;
-  extern enum Enum05 : unsigned char { } UCharEnum;
-  extern enum Enum06 : short { } SShortEnum;
-  extern enum Enum07 : unsigned short { } UShortEnum;
-  extern enum Enum08 : int { } SIntEnum;
-  extern enum Enum09 : unsigned int { } UIntEnum;
-  extern enum Enum10 : long { } SLongEnum;
-  extern enum Enum11 : unsigned long { } ULongEnum;
-  extern enum Enum12 : long long { } SLongLongEnum;
-  extern enum Enum13 : unsigned long long { } ULongLongEnum;
-// CHECK-DAG: @"\01?Enum at EnumMangling@@3W4Enum01 at 1@A"
-// CHECK-DAG: @"\01?BoolEnum at EnumMangling@@3W4Enum02 at 1@A
-// CHECK-DAG: @"\01?CharEnum at EnumMangling@@3W4Enum03 at 1@A
-// CHECK-DAG: @"\01?SCharEnum at EnumMangling@@3W4Enum04 at 1@A
-// CHECK-DAG: @"\01?UCharEnum at EnumMangling@@3W4Enum05 at 1@A
-// CHECK-DAG: @"\01?SShortEnum at EnumMangling@@3W4Enum06 at 1@A"
-// CHECK-DAG: @"\01?UShortEnum at EnumMangling@@3W4Enum07 at 1@A"
-// CHECK-DAG: @"\01?SIntEnum at EnumMangling@@3W4Enum08 at 1@A"
-// CHECK-DAG: @"\01?UIntEnum at EnumMangling@@3W4Enum09 at 1@A"
-// CHECK-DAG: @"\01?SLongEnum at EnumMangling@@3W4Enum10 at 1@A"
-// CHECK-DAG: @"\01?ULongEnum at EnumMangling@@3W4Enum11 at 1@A"
-// CHECK-DAG: @"\01?SLongLongEnum at EnumMangling@@3W4Enum12 at 1@A"
-// CHECK-DAG: @"\01?ULongLongEnum at EnumMangling@@3W4Enum13 at 1@A"
-  decltype(Enum) *UseEnum() { return &Enum; }
-  decltype(BoolEnum) *UseBoolEnum() { return &BoolEnum; }
-  decltype(CharEnum) *UseCharEnum() { return &CharEnum; }
-  decltype(SCharEnum) *UseSCharEnum() { return &SCharEnum; }
-  decltype(UCharEnum) *UseUCharEnum() { return &UCharEnum; }
-  decltype(SShortEnum) *UseSShortEnum() { return &SShortEnum; }
-  decltype(UShortEnum) *UseUShortEnum() { return &UShortEnum; }
-  decltype(SIntEnum) *UseSIntEnum() { return &SIntEnum; }
-  decltype(UIntEnum) *UseUIntEnum() { return &UIntEnum; }
-  decltype(SLongEnum) *UseSLongEnum() { return &SLongEnum; }
-  decltype(ULongEnum) *UseULongEnum() { return &ULongEnum; }
-  decltype(SLongLongEnum) *UseSLongLongEnum() { return &SLongLongEnum; }
-  decltype(ULongLongEnum) *UseULongLongEnum() { return &ULongLongEnum; }
-  extern enum class EnumClass01 { } EnumClass;
-  extern enum class EnumClass02 : bool { } BoolEnumClass;
-  extern enum class EnumClass03 : char { } CharEnumClass;
-  extern enum class EnumClass04 : signed char { } SCharEnumClass;
-  extern enum class EnumClass05 : unsigned char { } UCharEnumClass;
-  extern enum class EnumClass06 : short { } SShortEnumClass;
-  extern enum class EnumClass07 : unsigned short { } UShortEnumClass;
-  extern enum class EnumClass08 : int { } SIntEnumClass;
-  extern enum class EnumClass09 : unsigned int { } UIntEnumClass;
-  extern enum class EnumClass10 : long { } SLongEnumClass;
-  extern enum class EnumClass11 : unsigned long { } ULongEnumClass;
-  extern enum class EnumClass12 : long long { } SLongLongEnumClass;
-  extern enum class EnumClass13 : unsigned long long { } ULongLongEnumClass;
-// CHECK-DAG: @"\01?EnumClass at EnumMangling@@3W4EnumClass01 at 1@A"
-// CHECK-DAG: @"\01?BoolEnumClass at EnumMangling@@3W4EnumClass02 at 1@A
-// CHECK-DAG: @"\01?CharEnumClass at EnumMangling@@3W4EnumClass03 at 1@A
-// CHECK-DAG: @"\01?SCharEnumClass at EnumMangling@@3W4EnumClass04 at 1@A
-// CHECK-DAG: @"\01?UCharEnumClass at EnumMangling@@3W4EnumClass05 at 1@A
-// CHECK-DAG: @"\01?SShortEnumClass at EnumMangling@@3W4EnumClass06 at 1@A"
-// CHECK-DAG: @"\01?UShortEnumClass at EnumMangling@@3W4EnumClass07 at 1@A"
-// CHECK-DAG: @"\01?SIntEnumClass at EnumMangling@@3W4EnumClass08 at 1@A"
-// CHECK-DAG: @"\01?UIntEnumClass at EnumMangling@@3W4EnumClass09 at 1@A"
-// CHECK-DAG: @"\01?SLongEnumClass at EnumMangling@@3W4EnumClass10 at 1@A"
-// CHECK-DAG: @"\01?ULongEnumClass at EnumMangling@@3W4EnumClass11 at 1@A"
-// CHECK-DAG: @"\01?SLongLongEnumClass at EnumMangling@@3W4EnumClass12 at 1@A"
-// CHECK-DAG: @"\01?ULongLongEnumClass at EnumMangling@@3W4EnumClass13 at 1@A"
-  decltype(EnumClass) *UseEnumClass() { return &EnumClass; }
-  decltype(BoolEnumClass) *UseBoolEnumClass() { return &BoolEnumClass; }
-  decltype(CharEnumClass) *UseCharEnumClass() { return &CharEnumClass; }
-  decltype(SCharEnumClass) *UseSCharEnumClass() { return &SCharEnumClass; }
-  decltype(UCharEnumClass) *UseUCharEnumClass() { return &UCharEnumClass; }
-  decltype(SShortEnumClass) *UseSShortEnumClass() { return &SShortEnumClass; }
-  decltype(UShortEnumClass) *UseUShortEnumClass() { return &UShortEnumClass; }
-  decltype(SIntEnumClass) *UseSIntEnumClass() { return &SIntEnumClass; }
-  decltype(UIntEnumClass) *UseUIntEnumClass() { return &UIntEnumClass; }
-  decltype(SLongEnumClass) *UseSLongEnumClass() { return &SLongEnumClass; }
-  decltype(ULongEnumClass) *UseULongEnumClass() { return &ULongEnumClass; }
-  decltype(SLongLongEnumClass) *UseSLongLongEnumClass() { return &SLongLongEnumClass; }
-  decltype(ULongLongEnumClass) *UseULongLongEnumClass() { return &ULongLongEnumClass; }
-}
-
 extern "C" inline void extern_c_func() {
   static int local;
 // CHECK-DAG: @"\01?local@?1??extern_c_func@@9 at 4HA"
@@ -446,10 +365,3 @@ void TypedefNewDelete::operator delete[]
 // CHECK-DAG: ??3TypedefNewDelete@@SAXPAX at Z
 // CHECK-DAG: ??_VTypedefNewDelete@@SAXPAX at Z
 
-namespace PR18022 {
-
-struct { } a;
-decltype(a) fun(decltype(a) x, decltype(a)) { return x; }
-// CHECK-DAG: ?fun at PR18022@@YA?AU<unnamed-type-a>@1 at U21@0 at Z
-
-}





More information about the cfe-commits mailing list