forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			100 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C++
		
	
	
	
| // RUN: %clang_cc1 -fsyntax-only -verify %s
 | |
| 
 | |
| template void *; // expected-error{{expected unqualified-id}}
 | |
| 
 | |
| template typedef void f0; // expected-error{{explicit instantiation of typedef}}
 | |
| 
 | |
| int v0; // expected-note{{refers here}}
 | |
| template int v0; // expected-error{{does not refer}}
 | |
| 
 | |
| template<typename T>
 | |
| struct X0 {
 | |
|   static T value;
 | |
|   
 | |
|   T f0(T x) {
 | |
|     return x + 1;  // expected-error{{invalid operands}}
 | |
|   } 
 | |
|   T* f0(T*, T*) { return T(); }
 | |
|   
 | |
|   template<typename U>
 | |
|   T f0(T, U) { return T(); }
 | |
| };
 | |
| 
 | |
| template<typename T>
 | |
| T X0<T>::value; // expected-error{{no matching constructor}}
 | |
| 
 | |
| template int X0<int>::value;
 | |
| 
 | |
| struct NotDefaultConstructible { // expected-note{{candidate constructor (the implicit copy constructor)}}
 | |
|   NotDefaultConstructible(int); // expected-note{{candidate constructor}}
 | |
| };
 | |
| 
 | |
| template NotDefaultConstructible X0<NotDefaultConstructible>::value; // expected-note{{instantiation}}
 | |
| 
 | |
| template int X0<int>::f0(int);
 | |
| template int* X0<int>::f0(int*, int*);
 | |
| template int X0<int>::f0(int, float);
 | |
| 
 | |
| template int X0<int>::f0(int) const; // expected-error{{does not refer}}
 | |
| template int* X0<int>::f0(int*, float*); // expected-error{{does not refer}}
 | |
| 
 | |
| struct X1 { };
 | |
| typedef int X1::*MemPtr;
 | |
| 
 | |
| template MemPtr X0<MemPtr>::f0(MemPtr); // expected-note{{requested here}}
 | |
| 
 | |
| struct X2 {
 | |
|   int f0(int); // expected-note{{refers here}}
 | |
|   
 | |
|   template<typename T> T f1(T) { return T(); }
 | |
|   template<typename T> T* f1(T*) { return 0; }
 | |
| 
 | |
|   template<typename T, typename U> void f2(T, U*) { } // expected-note{{candidate}}
 | |
|   template<typename T, typename U> void f2(T*, U) { } // expected-note{{candidate}}
 | |
| };
 | |
| 
 | |
| template int X2::f0(int); // expected-error{{not an instantiation}}
 | |
| 
 | |
| template int *X2::f1(int *); // okay
 | |
| 
 | |
| template void X2::f2(int *, int *); // expected-error{{ambiguous}}
 | |
| 
 | |
| 
 | |
| template<typename T> void print_type() { }
 | |
| 
 | |
| template void print_type<int>();
 | |
| template void print_type<float>();
 | |
| 
 | |
| template<typename T> void print_type(T*) { }
 | |
| 
 | |
| template void print_type(int*);
 | |
| template void print_type<int>(float*); // expected-error{{does not refer}}
 | |
| 
 | |
| void print_type(double*);
 | |
| template void print_type<double>(double*);
 | |
| 
 | |
| // PR5069
 | |
| template<int I> void foo0 (int (&)[I + 1]) { }
 | |
| template void foo0<2> (int (&)[3]);
 | |
| 
 | |
| namespace explicit_instantiation_after_implicit_instantiation {
 | |
|   template <int I> struct X0 { static int x; };
 | |
|   template <int I> int X0<I>::x;
 | |
|   void test1() { (void)&X0<1>::x; }
 | |
|   template struct X0<1>;
 | |
| }
 | |
| 
 | |
| template<typename> struct X3 { };
 | |
| inline template struct X3<int>; // expected-warning{{ignoring 'inline' keyword on explicit template instantiation}}
 | |
| static template struct X3<float>; // expected-warning{{ignoring 'static' keyword on explicit template instantiation}}
 | |
| 
 | |
| namespace PR7622 {
 | |
|   template<typename,typename=int>
 | |
|   struct basic_streambuf;
 | |
| 
 | |
|   template<typename,typename>
 | |
|   struct basic_streambuf{friend bob<>()}; // expected-error{{unknown type name 'bob'}} \
 | |
|   // expected-error{{ expected member name or ';' after declaration specifiers}}
 | |
|   template struct basic_streambuf<int>;
 | |
| }
 |