| // RUN: %clang_cc1 -fms-extensions -fsyntax-only -verify %s |
| // RUN: %clang_cc1 -fms-extensions -fdelayed-template-parsing -fsyntax-only -verify %s |
| |
| // expected-no-diagnostics |
| class A { |
| public: |
| template<class U> A(U p) {} |
| template<> A(int p) {} |
| |
| template<class U> void f(U p) {} |
| |
| template<> void f(int p) {} |
| |
| void f(int p) {} |
| }; |
| |
| void test1() { |
| A a(3); |
| char *b; |
| a.f(b); |
| a.f<int>(99); |
| a.f(100); |
| } |
| |
| template<class T> class B { |
| public: |
| template<class U> B(U p) {} |
| template<> B(int p) {} |
| |
| template<class U> void f(U p) { T y = 9; } |
| |
| template<> void f(int p) { |
| T a = 3; |
| } |
| |
| void f(int p) { T a = 3; } |
| }; |
| |
| void test2() { |
| B<char> b(3); |
| char *ptr; |
| b.f(ptr); |
| b.f<int>(99); |
| b.f(100); |
| } |
| |
| namespace PR12709 { |
| template<class T> class TemplateClass { |
| void member_function() { specialized_member_template<false>(); } |
| |
| template<bool b> void specialized_member_template() {} |
| |
| template<> void specialized_member_template<false>() {} |
| }; |
| |
| void f() { TemplateClass<int> t; } |
| } |
| |
| namespace Duplicates { |
| template<typename T> struct A { |
| template<typename U> void f(); |
| template<> void f<int>() {} |
| template<> void f<T>() {} |
| }; |
| |
| // FIXME: We should diagnose the duplicate explicit specialization definitions |
| // here. |
| template struct A<int>; |
| } |
| |
| namespace PR28082 { |
| struct S { |
| template <int> |
| int f(int = 0); |
| template <> |
| int f<0>(int); |
| }; |
| } |