// RUN: %clang_cc1 -fsyntax-only -verify %s
template <class T> T* f(int); // #1
template <class T, class U> T& f(U); // #2
void g() {
int *ip = f<int>(1); // calls #1
}
template<typename T>
struct identity {
typedef T type;
};
template <class T>
T* f2(int, typename identity<T>::type = 0);
template <class T, class U>
T& f2(U, typename identity<T>::type = 0);
void g2() {
int* ip = f2<int>(1);
}
template<class T, class U> struct A { };
template<class T, class U> inline int *f3( U, A<U,T>* p = 0 ); // #1 expected-note{{candidate function [with T = int, U = int]}}
template< class U> inline float *f3( U, A<U,U>* p = 0 ); // #2 expected-note{{candidate function [with U = int]}}
void g3() {
float *fp = f3<int>( 42, (A<int,int>*)0 ); // Ok, picks #2.
f3<int>( 42 ); // expected-error{{call to 'f3' is ambiguous}}
}
namespace PR9006 {
struct X {
template <class Get>
int &f(char const* name, Get fget, char const* docstr = 0);
template <class Get, class Set>
float &f(char const* name, Get fget, Set fset, char const* docstr = 0);
};
void test(X x) {
int &ir = x.f("blah", 0, "blah");
}
}