forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			334 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			334 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			C++
		
	
	
	
| // RUN: %clang_cc1 -fsyntax-only -verify %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s
 | |
| // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s
 | |
| 
 | |
| template<typename T>
 | |
| class C { C(int a0 = 0); };
 | |
| 
 | |
| template<>
 | |
| C<char>::C(int a0);
 | |
| 
 | |
| struct S { }; // expected-note 3 {{candidate constructor (the implicit copy constructor)}}
 | |
| #if __cplusplus >= 201103L // C++11 or later
 | |
| // expected-note@-2 3 {{candidate constructor (the implicit move constructor) not viable}}
 | |
| #endif
 | |
| 
 | |
| template<typename T> void f1(T a, T b = 10) { } // expected-error{{no viable conversion}} \
 | |
| // expected-note{{passing argument to parameter 'b' here}}
 | |
| 
 | |
| template<typename T> void f2(T a, T b = T()) { }
 | |
| 
 | |
| template<typename T> void f3(T a, T b = T() + T()); // expected-error{{invalid operands to binary expression ('S' and 'S')}}
 | |
| 
 | |
| void g() {
 | |
|   f1(10);
 | |
|   f1(S()); // expected-note{{in instantiation of default function argument expression for 'f1<S>' required here}}
 | |
|   
 | |
|   f2(10);
 | |
|   f2(S());
 | |
|   
 | |
|   f3(10);
 | |
|   f3(S()); // expected-note{{in instantiation of default function argument expression for 'f3<S>' required here}}
 | |
| }
 | |
| 
 | |
| template<typename T> struct F {
 | |
|   F(T t = 10); // expected-error{{no viable conversion}} \
 | |
|   // expected-note{{passing argument to parameter 't' here}}
 | |
|   void f(T t = 10); // expected-error{{no viable conversion}} \
 | |
|   // expected-note{{passing argument to parameter 't' here}}
 | |
| };
 | |
| 
 | |
| struct FD : F<int> { };
 | |
| 
 | |
| void g2() {
 | |
|   F<int> f;
 | |
|   FD fd;
 | |
| }
 | |
| 
 | |
| void g3(F<int> f, F<struct S> s) {
 | |
|   f.f();
 | |
|   s.f(); // expected-note{{in instantiation of default function argument expression for 'f<S>' required here}}
 | |
|   
 | |
|   F<int> f2;
 | |
|   F<S> s2; // expected-note{{in instantiation of default function argument expression for 'F<S>' required here}}
 | |
| }
 | |
| 
 | |
| template<typename T> struct G {
 | |
|   G(T) {}
 | |
| };
 | |
| 
 | |
| void s(G<int> flags = 10) { }
 | |
| 
 | |
| // Test default arguments
 | |
| template<typename T>
 | |
| struct X0 {
 | |
|   void f(T = T()); // expected-error{{no matching}}
 | |
| };
 | |
| 
 | |
| template<typename U>
 | |
| void X0<U>::f(U) { }
 | |
| 
 | |
| void test_x0(X0<int> xi) {
 | |
|   xi.f();
 | |
|   xi.f(17);
 | |
| }
 | |
| 
 | |
| struct NotDefaultConstructible { // expected-note 2 {{candidate constructor (the implicit copy constructor) not viable}}
 | |
| #if __cplusplus >= 201103L // C++11 or later
 | |
| // expected-note@-2 2 {{candidate constructor (the implicit move constructor) not viable}}
 | |
| #endif
 | |
|   NotDefaultConstructible(int); // expected-note 2{{candidate}}
 | |
| };
 | |
| 
 | |
| void test_x0_not_default_constructible(X0<NotDefaultConstructible> xn) {
 | |
|   xn.f(NotDefaultConstructible(17));
 | |
|   xn.f(42);
 | |
|   xn.f(); // expected-note{{in instantiation of default function argument}}
 | |
| }
 | |
| 
 | |
| template<typename T>
 | |
| struct X1 {
 | |
|   typedef T value_type;
 | |
|   X1(const value_type& value = value_type());
 | |
| };
 | |
| 
 | |
| void test_X1() {
 | |
|   X1<int> x1;
 | |
| }
 | |
| 
 | |
| template<typename T>
 | |
| struct X2 {
 | |
|   void operator()(T = T()); // expected-error{{no matching}}
 | |
| };
 | |
| 
 | |
| void test_x2(X2<int> x2i, X2<NotDefaultConstructible> x2n) {
 | |
|   x2i();
 | |
|   x2i(17);
 | |
|   x2n(NotDefaultConstructible(17));
 | |
|   x2n(); // expected-note{{in instantiation of default function argument}}
 | |
| }
 | |
| 
 | |
| // PR5283
 | |
| namespace PR5283 {
 | |
| template<typename T> struct A {
 | |
|   A(T = 1); // expected-error 3 {{cannot initialize a parameter of type 'int *' with an rvalue of type 'int'}} \
 | |
|   // expected-note 3{{passing argument to parameter here}}
 | |
| };
 | |
| 
 | |
| struct B : A<int*> { 
 | |
|   B();
 | |
| };
 | |
| B::B() { } // expected-note {{in instantiation of default function argument expression for 'A<int *>' required he}}
 | |
| 
 | |
| struct C : virtual A<int*> {
 | |
|   C();
 | |
| };
 | |
| C::C() { } // expected-note {{in instantiation of default function argument expression for 'A<int *>' required he}}
 | |
| 
 | |
| struct D {
 | |
|   D();
 | |
|   
 | |
|   A<int*> a;
 | |
| };
 | |
| D::D() { } // expected-note {{in instantiation of default function argument expression for 'A<int *>' required he}}
 | |
| }
 | |
| 
 | |
| // PR5301
 | |
| namespace pr5301 {
 | |
|   void f(int, int = 0);
 | |
| 
 | |
|   template <typename T>
 | |
|   void g(T, T = 0);
 | |
| 
 | |
|   template <int I>
 | |
|   void i(int a = I);
 | |
| 
 | |
|   template <typename T>
 | |
|   void h(T t) {
 | |
|     f(0);
 | |
|     g(1);
 | |
|     g(t);
 | |
|     i<2>();
 | |
|   }
 | |
| 
 | |
|   void test() {
 | |
|     h(0);
 | |
|   }
 | |
| }
 | |
| 
 | |
| // PR5810
 | |
| namespace PR5810 {
 | |
|   template<typename T>
 | |
|   struct allocator {
 | |
|     allocator() { int a[sizeof(T) ? -1 : -1]; } // expected-error2 {{array with a negative size}}
 | |
|   };
 | |
|   
 | |
|   template<typename T>
 | |
|   struct vector {
 | |
|     vector(const allocator<T>& = allocator<T>()) {} // expected-note2 {{instantiation of}}
 | |
|   };
 | |
|   
 | |
|   struct A { };
 | |
|   struct B { };
 | |
| 
 | |
|   template<typename>
 | |
|   void FilterVTs() {
 | |
|     vector<A> Result;
 | |
|   }
 | |
|   
 | |
|   void f() {
 | |
|     vector<A> Result;
 | |
|   }
 | |
| 
 | |
|   template<typename T>
 | |
|   struct X {
 | |
|     vector<B> bs;
 | |
|     X() { }
 | |
|   };
 | |
| 
 | |
|   void f2() {
 | |
|     X<float> x; // expected-note{{member function}}
 | |
|   }
 | |
| }
 | |
| 
 | |
| template<typename T> void f4(T, int = 17);
 | |
| template<> void f4<int>(int, int);
 | |
| 
 | |
| void f4_test(int i) {
 | |
|   f4(i);
 | |
| }
 | |
| 
 | |
| // Instantiate for initialization
 | |
| namespace InstForInit {
 | |
|   template<typename T>
 | |
|   struct Ptr {
 | |
|     typedef T* type;
 | |
|     Ptr(type);
 | |
|   };
 | |
| 
 | |
|   template<typename T>
 | |
|   struct Holder {
 | |
|     Holder(int i, Ptr<T> ptr = 0);
 | |
|   };
 | |
| 
 | |
|   void test_holder(int i) {
 | |
|     Holder<int> h(i);
 | |
|   }
 | |
| };
 | |
| 
 | |
| namespace PR5810b {
 | |
|   template<typename T>
 | |
|   T broken() {
 | |
|     T t;
 | |
|     double**** not_it = t;
 | |
|   }
 | |
| 
 | |
|   void f(int = broken<int>());
 | |
|   void g() { f(17); }
 | |
| }
 | |
| 
 | |
| namespace PR5810c {
 | |
|   template<typename T>
 | |
|   struct X { 
 | |
|     X() { 
 | |
|       T t;
 | |
|       double *****p = t; // expected-error{{cannot initialize a variable of type 'double *****' with an lvalue of type 'int'}}
 | |
|     }
 | |
|     X(const X&) { }
 | |
|   };
 | |
| 
 | |
|   struct Y : X<int> { // expected-note{{instantiation of}}
 | |
|   };
 | |
| 
 | |
|   void f(Y y = Y());
 | |
| 
 | |
|   void g() { f(); }
 | |
| }
 | |
| 
 | |
| namespace PR8127 {
 | |
|   template< typename T > class PointerClass {
 | |
|   public:
 | |
|     PointerClass( T * object_p ) : p_( object_p ) {
 | |
|       p_->acquire();
 | |
|     }
 | |
|   private:    
 | |
|     T * p_;
 | |
|   };
 | |
| 
 | |
|   class ExternallyImplementedClass;
 | |
| 
 | |
|   class MyClass {
 | |
|     void foo( PointerClass<ExternallyImplementedClass> = 0 );
 | |
|   };
 | |
| }
 | |
| 
 | |
| namespace rdar8427926 {
 | |
|   template<typename T>
 | |
|   struct Boom {
 | |
|     ~Boom() {
 | |
|       T t;
 | |
|       double *******ptr = t; // expected-error 2{{cannot initialize}}
 | |
|     }
 | |
|   };
 | |
| 
 | |
|   Boom<float> *bfp;
 | |
| 
 | |
|   struct X {
 | |
|     void f(Boom<int> = Boom<int>()) { } // expected-note{{requested here}}
 | |
|     void g(int x = (delete bfp, 0)); // expected-note{{requested here}}
 | |
|   };
 | |
| 
 | |
|   void test(X *x) {
 | |
|     x->f();
 | |
|     x->g();
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace PR8401 {
 | |
|   template<typename T> 
 | |
|   struct A { 
 | |
|     A() { T* x = 1; } // expected-error{{cannot initialize a variable of type 'int *' with an rvalue of type 'int'}}
 | |
|   };
 | |
| 
 | |
|   template<typename T>
 | |
|   struct B {
 | |
|     B(const A<T>& a = A<T>()); // expected-note{{in instantiation of}}
 | |
|   };
 | |
| 
 | |
|   void f(B<int> b = B<int>());
 | |
| 
 | |
|   void g() {
 | |
|     f();
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace PR12581 {
 | |
|   const int a = 0;
 | |
|   template < typename > struct A;
 | |
|   template < typename MatrixType, int =
 | |
|   A < MatrixType >::Flags ? : A < MatrixType >::Flags & a > class B;
 | |
|   void
 | |
|   fn1 ()
 | |
|   {
 | |
|   }
 | |
| }
 | |
| 
 | |
| namespace PR13758 {
 | |
|   template <typename T> struct move_from {
 | |
|     T invalid;
 | |
|   };
 | |
|   template <class K>
 | |
|   struct unordered_map {
 | |
|     explicit unordered_map(int n = 42);
 | |
|     unordered_map(move_from<K> other);
 | |
|   };
 | |
|   template<typename T>
 | |
|   void StripedHashTable() {
 | |
|     new unordered_map<void>();
 | |
|     new unordered_map<void>;
 | |
|   }
 | |
|   void tt() {
 | |
|     StripedHashTable<int>();
 | |
|   }
 | |
| }
 |