| Daniel Dunbar | d7d5f02 | 2009-03-24 02:24:46 +0000 | [diff] [blame] | 1 | // RUN: clang-cc -fsyntax-only -verify %s | 
| Douglas Gregor | adcac88 | 2008-12-01 23:54:00 +0000 | [diff] [blame] | 2 |  | 
 | 3 | // Errors | 
 | 4 | export class foo { };   // expected-error {{expected template}} | 
| Douglas Gregor | 4310f4e | 2009-02-16 22:38:20 +0000 | [diff] [blame] | 5 | template  x;            // expected-error {{expected '<' after 'template'}} \ | 
 | 6 | // expected-error {{C++ requires a type specifier for all declarations}} | 
| Douglas Gregor | c4b4e7b | 2008-12-24 02:52:09 +0000 | [diff] [blame] | 7 | export template x;      // expected-error {{expected '<' after 'template'}} \ | 
| Douglas Gregor | 4310f4e | 2009-02-16 22:38:20 +0000 | [diff] [blame] | 8 |                         // expected-note {{exported templates are unsupported}} \ | 
 | 9 | // expected-error {{C++ requires a type specifier for all declarations}} | 
| Sebastian Redl | a4ed0d8 | 2008-12-28 15:28:59 +0000 | [diff] [blame] | 10 | // See Sema::ParsedFreeStandingDeclSpec about the double diagnostic. This is | 
 | 11 | // because ParseNonTypeTemplateParameter starts parsing a DeclSpec. | 
 | 12 | template < ;            // expected-error {{parse error}} expected-error {{declaration does not declare anything}} | 
 | 13 | template <template X> struct Err1; // expected-error {{expected '<' after 'template'}} | 
 | 14 | template <template <typename> > struct Err2;       // expected-error {{expected 'class' before '>'}} | 
 | 15 | template <template <typename> Foo> struct Err3;    // expected-error {{expected 'class' before 'Foo'}} | 
| Douglas Gregor | adcac88 | 2008-12-01 23:54:00 +0000 | [diff] [blame] | 16 |  | 
 | 17 | // Template function declarations | 
 | 18 | template <typename T> void foo(); | 
 | 19 | template <typename T, typename U> void foo(); | 
 | 20 |  | 
| Douglas Gregor | 26236e8 | 2008-12-02 00:41:28 +0000 | [diff] [blame] | 21 | // Template function definitions. | 
 | 22 | template <typename T> void foo() { } | 
| Douglas Gregor | adcac88 | 2008-12-01 23:54:00 +0000 | [diff] [blame] | 23 |  | 
 | 24 | // Template class (forward) declarations | 
 | 25 | template <typename T> struct A; | 
 | 26 | template <typename T, typename U> struct b; | 
 | 27 | template <typename> struct C; | 
 | 28 | template <typename, typename> struct D; | 
 | 29 |  | 
 | 30 | // Forward declarations with default parameters? | 
| Douglas Gregor | 4310f4e | 2009-02-16 22:38:20 +0000 | [diff] [blame] | 31 | template <typename T = int> class X1; | 
 | 32 | template <typename = int> class X2; | 
| Douglas Gregor | adcac88 | 2008-12-01 23:54:00 +0000 | [diff] [blame] | 33 |  | 
 | 34 | // Forward declarations w/template template parameters | 
 | 35 | template <template <typename> class T> class TTP1; | 
 | 36 | template <template <typename> class> class TTP2; | 
| Douglas Gregor | d684b00 | 2009-02-10 19:49:53 +0000 | [diff] [blame] | 37 | template <template <typename> class T = foo> class TTP3; // FIXME:expected-error{{template argument for template template parameter must be a template}} | 
 | 38 | template <template <typename> class = foo> class TTP3; // FIXME:expected-error{{template argument for template template parameter must be a template}} | 
| Douglas Gregor | aaba5e3 | 2009-02-04 19:02:06 +0000 | [diff] [blame] | 39 | template <template <typename X, typename Y> class T> class TTP5; | 
| Douglas Gregor | adcac88 | 2008-12-01 23:54:00 +0000 | [diff] [blame] | 40 |  | 
 | 41 | // Forward declararations with non-type params | 
 | 42 | template <int> class NTP0; | 
 | 43 | template <int N> class NTP1; | 
 | 44 | template <int N = 5> class NTP2; | 
 | 45 | template <int = 10> class NTP3; | 
| Douglas Gregor | 4310f4e | 2009-02-16 22:38:20 +0000 | [diff] [blame] | 46 | template <unsigned int N = 12u> class NTP4;  | 
 | 47 | template <unsigned int = 12u> class NTP5; | 
 | 48 | template <unsigned = 15u> class NTP6; | 
 | 49 | template <typename T, T Obj> class NTP7; | 
| Douglas Gregor | adcac88 | 2008-12-01 23:54:00 +0000 | [diff] [blame] | 50 |  | 
 | 51 | // Template class declarations | 
 | 52 | template <typename T> struct A { }; | 
 | 53 | template <typename T, typename U> struct B { }; | 
 | 54 |  | 
| Douglas Gregor | 72c3f31 | 2008-12-05 18:15:24 +0000 | [diff] [blame] | 55 | // Template parameter shadowing | 
 | 56 | template<typename T, // expected-note{{template parameter is declared here}} | 
 | 57 | 	 typename T> // expected-error{{declaration of 'T' shadows template parameter}} | 
 | 58 |   void shadow1(); | 
 | 59 |  | 
 | 60 | template<typename T> // expected-note{{template parameter is declared here}} | 
 | 61 | void shadow2(int T); // expected-error{{declaration of 'T' shadows template parameter}} | 
 | 62 |  | 
 | 63 | template<typename T> // expected-note{{template parameter is declared here}} | 
 | 64 | class T { // expected-error{{declaration of 'T' shadows template parameter}} | 
 | 65 | }; | 
 | 66 |  | 
 | 67 | template<int Size> // expected-note{{template parameter is declared here}} | 
 | 68 | void shadow3(int Size); // expected-error{{declaration of 'Size' shadows template parameter}} | 
 | 69 |  | 
 | 70 | // Non-type template parameters in scope | 
 | 71 | template<int Size>  | 
 | 72 | void f(int& i) { | 
 | 73 |   i = Size; | 
 | 74 |   Size = i; // expected-error{{expression is not assignable}} | 
 | 75 | } | 
 | 76 |  | 
 | 77 | template<typename T> | 
 | 78 | const T& min(const T&, const T&); |