diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-01-11 17:51:55 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-01-11 17:51:55 +0000 |
commit | 4e97586b804f6132d83cb534f16a5b6a7756e819 (patch) | |
tree | b34501ad89b921b5378b989dc735bddeb15c220e | |
parent | 5c7bf42ef16dc767615bed10f3b7b3c1265314e1 (diff) |
Add another test for [temp.func.order]p5/[temp.deduct.partial]p11,
from James Widman.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@123245 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.partial/p11.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.partial/p11.cpp b/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.partial/p11.cpp index ae9c083112..5aabebae94 100644 --- a/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.partial/p11.cpp +++ b/test/CXX/temp/temp.fct.spec/temp.deduct/temp.deduct.partial/p11.cpp @@ -20,3 +20,14 @@ template <class T, class U> 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}} + +} |