| // RUN: %clang_cc1 -fsyntax-only -verify %s |
| |
| template<typename T> void f0(T) { } // expected-note{{previous}} |
| template<class U> void f0(U) { } // expected-error{{redefinition}} |
| |
| template<int I> void f0() { } // expected-note{{previous}} |
| template<int> void f0() { } // expected-error{{redefinition}} |
| |
| typedef int INT; |
| |
| template<template<class T, T Value1, INT> class X> |
| void f0() { } // expected-note{{previous}} |
| template<template<typename T, T Value1, int> class> |
| void f0() { } // expected-error{{redefinition}} |
| |
| template<typename T> |
| struct MetaFun; |
| |
| template<typename T> |
| typename MetaFun<T*>::type f0(const T&) { while (1) {} } // expected-note{{previous}} |
| template<class U> |
| typename MetaFun<U*>::type f0(const U&) { while (1) {} } // expected-error{{redefinition}} |
| |
| // FIXME: We need canonicalization of expressions for this to work |
| // template<int> struct A { }; |
| // template<int I> void f0(A<I>) { } // Xpected-note{{previous}} |
| // template<int J> void f0(A<J>) { } // Xpected-error{{redefinition}} |