79 lines
1.4 KiB
C++
79 lines
1.4 KiB
C++
|
// 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);
|
||
|
};
|
||
|
}
|