forked from OSchip/llvm-project
241 lines
4.6 KiB
C++
241 lines
4.6 KiB
C++
// RUN: %clang_cc1 -triple %ms_abi_triple -ast-print %s -std=gnu++11 | FileCheck %s
|
|
|
|
// CHECK: r;
|
|
// CHECK-NEXT: (r->method());
|
|
struct MyClass
|
|
{
|
|
void method() {}
|
|
};
|
|
|
|
struct Reference
|
|
{
|
|
MyClass* object;
|
|
MyClass* operator ->() { return object; }
|
|
};
|
|
|
|
void test1() {
|
|
Reference r;
|
|
(r->method());
|
|
}
|
|
|
|
// CHECK: if (int a = 1)
|
|
// CHECK: while (int a = 1)
|
|
// CHECK: switch (int a = 1)
|
|
|
|
void test2()
|
|
{
|
|
if (int a = 1) { }
|
|
while (int a = 1) { }
|
|
switch (int a = 1) { }
|
|
}
|
|
|
|
// CHECK: new (1) int;
|
|
void *operator new (typeof(sizeof(1)), int, int = 2);
|
|
void test3() {
|
|
new (1) int;
|
|
}
|
|
|
|
// CHECK: new X;
|
|
struct X {
|
|
void *operator new (typeof(sizeof(1)), int = 2);
|
|
};
|
|
void test4() { new X; }
|
|
|
|
// CHECK: for (int i = 2097, j = 42; false;)
|
|
void test5() {
|
|
for (int i = 2097, j = 42; false;) {}
|
|
}
|
|
|
|
// CHECK: test6fn((int &)y);
|
|
void test6fn(int& x);
|
|
void test6() {
|
|
unsigned int y = 0;
|
|
test6fn((int&)y);
|
|
}
|
|
|
|
// CHECK: S s(1, 2);
|
|
|
|
template <class S> void test7()
|
|
{
|
|
S s( 1,2 );
|
|
}
|
|
|
|
|
|
// CHECK: t.~T();
|
|
|
|
template <typename T> void test8(T t) { t.~T(); }
|
|
|
|
|
|
// CHECK: enum E
|
|
// CHECK-NEXT: A,
|
|
// CHECK-NEXT: B,
|
|
// CHECK-NEXT: C
|
|
// CHECK-NEXT: };
|
|
// CHECK-NEXT: {{^[ ]+}}E a = A;
|
|
|
|
struct test9
|
|
{
|
|
void f()
|
|
{
|
|
enum E { A, B, C };
|
|
E a = A;
|
|
}
|
|
};
|
|
|
|
namespace test10 {
|
|
namespace M {
|
|
template<typename T>
|
|
struct X {
|
|
enum { value };
|
|
};
|
|
}
|
|
}
|
|
|
|
typedef int INT;
|
|
|
|
// CHECK: test11
|
|
// CHECK-NEXT: return test10::M::X<INT>::value;
|
|
int test11() {
|
|
return test10::M::X<INT>::value;
|
|
}
|
|
|
|
|
|
struct DefaultArgClass
|
|
{
|
|
DefaultArgClass(int a = 1) {}
|
|
DefaultArgClass(int a, int b, int c = 1) {}
|
|
};
|
|
|
|
struct NoArgClass
|
|
{
|
|
NoArgClass() {}
|
|
};
|
|
|
|
struct VirualDestrClass
|
|
{
|
|
VirualDestrClass(int arg);
|
|
virtual ~VirualDestrClass();
|
|
};
|
|
|
|
struct ConstrWithCleanupsClass
|
|
{
|
|
ConstrWithCleanupsClass(const VirualDestrClass& cplx = VirualDestrClass(42));
|
|
};
|
|
|
|
// CHECK: test12
|
|
// CHECK-NEXT: DefaultArgClass useDefaultArg;
|
|
// CHECK-NEXT: DefaultArgClass overrideDefaultArg(1);
|
|
// CHECK-NEXT: DefaultArgClass(1, 2);
|
|
// CHECK-NEXT: DefaultArgClass(1, 2, 3);
|
|
// CHECK-NEXT: NoArgClass noArg;
|
|
// CHECK-NEXT: ConstrWithCleanupsClass cwcNoArg;
|
|
// CHECK-NEXT: ConstrWithCleanupsClass cwcOverrideArg(48);
|
|
// CHECK-NEXT: ConstrWithCleanupsClass cwcExplicitArg(VirualDestrClass(56));
|
|
void test12() {
|
|
DefaultArgClass useDefaultArg;
|
|
DefaultArgClass overrideDefaultArg(1);
|
|
DefaultArgClass tempWithDefaultArg = DefaultArgClass(1, 2);
|
|
DefaultArgClass tempWithExplictArg = DefaultArgClass(1, 2, 3);
|
|
NoArgClass noArg;
|
|
ConstrWithCleanupsClass cwcNoArg;
|
|
ConstrWithCleanupsClass cwcOverrideArg(48);
|
|
ConstrWithCleanupsClass cwcExplicitArg(VirualDestrClass(56));
|
|
}
|
|
|
|
// CHECK: void test13() {
|
|
// CHECK: _Atomic(int) i;
|
|
// CHECK: __c11_atomic_init(&i, 0);
|
|
// CHECK: __c11_atomic_load(&i, 0);
|
|
// CHECK: }
|
|
void test13() {
|
|
_Atomic(int) i;
|
|
__c11_atomic_init(&i, 0);
|
|
__c11_atomic_load(&i, 0);
|
|
}
|
|
|
|
|
|
// CHECK: void test14() {
|
|
// CHECK: struct X {
|
|
// CHECK: union {
|
|
// CHECK: int x;
|
|
// CHECK: } x;
|
|
// CHECK: };
|
|
// CHECK: }
|
|
void test14() {
|
|
struct X { union { int x; } x; };
|
|
}
|
|
|
|
|
|
// CHECK: float test15() {
|
|
// CHECK: return __builtin_asinf(1.F);
|
|
// CHECK: }
|
|
// CHECK-NOT: extern "C"
|
|
float test15() {
|
|
return __builtin_asinf(1.0F);
|
|
}
|
|
|
|
namespace PR18776 {
|
|
struct A {
|
|
operator void *();
|
|
explicit operator bool();
|
|
A operator&(A);
|
|
};
|
|
|
|
// CHECK: struct A
|
|
// CHECK-NEXT: {{^[ ]*operator}} void *();
|
|
// CHECK-NEXT: {{^[ ]*explicit}} operator bool();
|
|
|
|
void bar(void *);
|
|
|
|
void foo() {
|
|
A a, b;
|
|
bar(a & b);
|
|
// CHECK: bar(a & b);
|
|
if (a & b)
|
|
// CHECK: if (a & b)
|
|
return;
|
|
}
|
|
};
|
|
|
|
namespace {
|
|
void test(int i) {
|
|
switch (i) {
|
|
case 1:
|
|
// CHECK: {{\[\[clang::fallthrough\]\]}}
|
|
[[clang::fallthrough]];
|
|
case 2:
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
namespace {
|
|
// CHECK: struct {{\[\[gnu::visibility\(\"hidden\"\)\]\]}} S;
|
|
struct [[gnu::visibility("hidden")]] S;
|
|
}
|
|
|
|
// CHECK: struct CXXFunctionalCastExprPrint fce = CXXFunctionalCastExprPrint{};
|
|
struct CXXFunctionalCastExprPrint {} fce = CXXFunctionalCastExprPrint{};
|
|
|
|
// CHECK: struct CXXTemporaryObjectExprPrint toe = CXXTemporaryObjectExprPrint{};
|
|
struct CXXTemporaryObjectExprPrint { CXXTemporaryObjectExprPrint(); } toe = CXXTemporaryObjectExprPrint{};
|
|
|
|
namespace PR24872 {
|
|
// CHECK: template <typename T> struct Foo : T {
|
|
// CHECK: using T::operator-;
|
|
template <typename T> struct Foo : T {
|
|
using T::operator-;
|
|
};
|
|
}
|
|
|
|
namespace dont_crash_on_auto_vars {
|
|
struct T { enum E {X = 12ll }; };
|
|
struct S {
|
|
struct { int I; } ADecl;
|
|
static const auto Y = T::X;
|
|
};
|
|
//CHECK: static const auto Y = T::X;
|
|
constexpr auto var = T::X;
|
|
//CHECK: constexpr auto var = T::X;
|
|
}
|