Compiler projects using llvm
// 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");
  }
}