From: David Majnemer Date: Tue, 4 Mar 2014 05:47:41 +0000 (+0000) Subject: MS ABI: Reorganize some tests X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1425f1b3ec19c8b3ead5b7763bcf9adc38ab8330;p=clang MS ABI: Reorganize some tests Move some c++11 specific tests to mangle-ms-cxx11 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@202790 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/CodeGenCXX/mangle-ms-cxx11.cpp b/test/CodeGenCXX/mangle-ms-cxx11.cpp index fd59ae6140..c5da330a40 100644 --- a/test/CodeGenCXX/mangle-ms-cxx11.cpp +++ b/test/CodeGenCXX/mangle-ms-cxx11.cpp @@ -12,3 +12,92 @@ int RRef(int&& a) { return a; } // CHECK: "\01?Null@@YAX$$T@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@EnumMangling@@3W4Enum01@1@A" +// CHECK-DAG: @"\01?BoolEnum@EnumMangling@@3W4Enum02@1@A +// CHECK-DAG: @"\01?CharEnum@EnumMangling@@3W4Enum03@1@A +// CHECK-DAG: @"\01?SCharEnum@EnumMangling@@3W4Enum04@1@A +// CHECK-DAG: @"\01?UCharEnum@EnumMangling@@3W4Enum05@1@A +// CHECK-DAG: @"\01?SShortEnum@EnumMangling@@3W4Enum06@1@A" +// CHECK-DAG: @"\01?UShortEnum@EnumMangling@@3W4Enum07@1@A" +// CHECK-DAG: @"\01?SIntEnum@EnumMangling@@3W4Enum08@1@A" +// CHECK-DAG: @"\01?UIntEnum@EnumMangling@@3W4Enum09@1@A" +// CHECK-DAG: @"\01?SLongEnum@EnumMangling@@3W4Enum10@1@A" +// CHECK-DAG: @"\01?ULongEnum@EnumMangling@@3W4Enum11@1@A" +// CHECK-DAG: @"\01?SLongLongEnum@EnumMangling@@3W4Enum12@1@A" +// CHECK-DAG: @"\01?ULongLongEnum@EnumMangling@@3W4Enum13@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@EnumMangling@@3W4EnumClass01@1@A" +// CHECK-DAG: @"\01?BoolEnumClass@EnumMangling@@3W4EnumClass02@1@A +// CHECK-DAG: @"\01?CharEnumClass@EnumMangling@@3W4EnumClass03@1@A +// CHECK-DAG: @"\01?SCharEnumClass@EnumMangling@@3W4EnumClass04@1@A +// CHECK-DAG: @"\01?UCharEnumClass@EnumMangling@@3W4EnumClass05@1@A +// CHECK-DAG: @"\01?SShortEnumClass@EnumMangling@@3W4EnumClass06@1@A" +// CHECK-DAG: @"\01?UShortEnumClass@EnumMangling@@3W4EnumClass07@1@A" +// CHECK-DAG: @"\01?SIntEnumClass@EnumMangling@@3W4EnumClass08@1@A" +// CHECK-DAG: @"\01?UIntEnumClass@EnumMangling@@3W4EnumClass09@1@A" +// CHECK-DAG: @"\01?SLongEnumClass@EnumMangling@@3W4EnumClass10@1@A" +// CHECK-DAG: @"\01?ULongEnumClass@EnumMangling@@3W4EnumClass11@1@A" +// CHECK-DAG: @"\01?SLongLongEnumClass@EnumMangling@@3W4EnumClass12@1@A" +// CHECK-DAG: @"\01?ULongLongEnumClass@EnumMangling@@3W4EnumClass13@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@PR18022@@YA?AU@1@U21@0@Z + +} diff --git a/test/CodeGenCXX/mangle-ms.cpp b/test/CodeGenCXX/mangle-ms.cpp index 627fb54a33..3285c98546 100644 --- a/test/CodeGenCXX/mangle-ms.cpp +++ b/test/CodeGenCXX/mangle-ms.cpp @@ -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@EnumMangling@@3W4Enum01@1@A" -// CHECK-DAG: @"\01?BoolEnum@EnumMangling@@3W4Enum02@1@A -// CHECK-DAG: @"\01?CharEnum@EnumMangling@@3W4Enum03@1@A -// CHECK-DAG: @"\01?SCharEnum@EnumMangling@@3W4Enum04@1@A -// CHECK-DAG: @"\01?UCharEnum@EnumMangling@@3W4Enum05@1@A -// CHECK-DAG: @"\01?SShortEnum@EnumMangling@@3W4Enum06@1@A" -// CHECK-DAG: @"\01?UShortEnum@EnumMangling@@3W4Enum07@1@A" -// CHECK-DAG: @"\01?SIntEnum@EnumMangling@@3W4Enum08@1@A" -// CHECK-DAG: @"\01?UIntEnum@EnumMangling@@3W4Enum09@1@A" -// CHECK-DAG: @"\01?SLongEnum@EnumMangling@@3W4Enum10@1@A" -// CHECK-DAG: @"\01?ULongEnum@EnumMangling@@3W4Enum11@1@A" -// CHECK-DAG: @"\01?SLongLongEnum@EnumMangling@@3W4Enum12@1@A" -// CHECK-DAG: @"\01?ULongLongEnum@EnumMangling@@3W4Enum13@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@EnumMangling@@3W4EnumClass01@1@A" -// CHECK-DAG: @"\01?BoolEnumClass@EnumMangling@@3W4EnumClass02@1@A -// CHECK-DAG: @"\01?CharEnumClass@EnumMangling@@3W4EnumClass03@1@A -// CHECK-DAG: @"\01?SCharEnumClass@EnumMangling@@3W4EnumClass04@1@A -// CHECK-DAG: @"\01?UCharEnumClass@EnumMangling@@3W4EnumClass05@1@A -// CHECK-DAG: @"\01?SShortEnumClass@EnumMangling@@3W4EnumClass06@1@A" -// CHECK-DAG: @"\01?UShortEnumClass@EnumMangling@@3W4EnumClass07@1@A" -// CHECK-DAG: @"\01?SIntEnumClass@EnumMangling@@3W4EnumClass08@1@A" -// CHECK-DAG: @"\01?UIntEnumClass@EnumMangling@@3W4EnumClass09@1@A" -// CHECK-DAG: @"\01?SLongEnumClass@EnumMangling@@3W4EnumClass10@1@A" -// CHECK-DAG: @"\01?ULongEnumClass@EnumMangling@@3W4EnumClass11@1@A" -// CHECK-DAG: @"\01?SLongLongEnumClass@EnumMangling@@3W4EnumClass12@1@A" -// CHECK-DAG: @"\01?ULongLongEnumClass@EnumMangling@@3W4EnumClass13@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@4HA" @@ -446,10 +365,3 @@ void TypedefNewDelete::operator delete[](void *) { } // CHECK-DAG: ??3TypedefNewDelete@@SAXPAX@Z // CHECK-DAG: ??_VTypedefNewDelete@@SAXPAX@Z -namespace PR18022 { - -struct { } a; -decltype(a) fun(decltype(a) x, decltype(a)) { return x; } -// CHECK-DAG: ?fun@PR18022@@YA?AU@1@U21@0@Z - -}