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;
 | |
| }
 |