diff options
Diffstat (limited to 'gcc/testsuite')
-rw-r--r-- | gcc/testsuite/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/template/partial10.C | 18 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/template/partial11.C | 24 |
3 files changed, 48 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c3e0f0e..bab71b3 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2011-06-23 Jason Merrill <jason@redhat.com> + + PR c++/35255 + * g++.dg/template/partial10.C: New. + * g++.dg/template/partial11.C: New. + 2011-06-23 Jeff Law <law@redhat.com> PR middle-end/48770 diff --git a/gcc/testsuite/g++.dg/template/partial10.C b/gcc/testsuite/g++.dg/template/partial10.C new file mode 100644 index 0000000..53a48fb --- /dev/null +++ b/gcc/testsuite/g++.dg/template/partial10.C @@ -0,0 +1,18 @@ +// PR c++/35255, DR 115 +// { dg-do link } + +// 14.8.1: In contexts where deduction is done and fails, or in contexts +// where deduction is not done, if a template argument list is specified +// and it, along with any default template arguments, identifies a single +// function template specialization, then the template-id is an lvalue for +// the function template specialization. + +template <class Fn> void def(Fn fn) {} + +template <class T1, class T2> T2 fn(T1, T2); +template <class T1> int fn(T1) { } + +int main() +{ + def(fn<int>); +} diff --git a/gcc/testsuite/g++.dg/template/partial11.C b/gcc/testsuite/g++.dg/template/partial11.C new file mode 100644 index 0000000..b5ceaa8 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/partial11.C @@ -0,0 +1,24 @@ +// DR 115 + +// 14.8.1: In contexts where deduction is done and fails, or in contexts +// where deduction is not done, if a template argument list is specified +// and it, along with any default template arguments, identifies a single +// function template specialization, then the template-id is an lvalue for +// the function template specialization. + +// Here, deduction is not done to resolve fn<int> because the target type +// is a template parameter, so we resolve to the second template, and then +// the call to def fails because we deduce different values of Fn for the +// two function arguments. + +template <class Fn> void def(Fn fn, Fn fn2); + +template <class T1, class T2> T2 fn(T1, T2); +template <class T1> int fn(T1); + +int f(int,int); + +int main() +{ + def(fn<int>,f); // { dg-error "" } +} |