diff options
| author | lerdsuwa <lerdsuwa@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-07-27 15:47:10 +0000 |
|---|---|---|
| committer | lerdsuwa <lerdsuwa@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-07-27 15:47:10 +0000 |
| commit | eafc797972b25c514efb3a47f7ecd6eb03431572 (patch) | |
| tree | f8e0486ef514e91ec9dffab97caca820bcbf2f22 /gcc | |
| parent | c0b35efb8cef98e8fee98cf1583a51c8e6db9e56 (diff) | |
| download | ppe42-gcc-eafc797972b25c514efb3a47f7ecd6eb03431572.tar.gz ppe42-gcc-eafc797972b25c514efb3a47f7ecd6eb03431572.zip | |
PR c++/14429
* pt.c (coerce_template_template_parms) <PARM_DECL case>: Only check
when the type of ARG is not dependent.
* g++.dg/template/ttp11.C: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@85222 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
| -rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
| -rw-r--r-- | gcc/cp/pt.c | 13 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/template/ttp11.C | 14 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/template/ttp12.C | 19 |
5 files changed, 53 insertions, 4 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 329b12e5c7b..3a270bc3fd9 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2004-07-27 Kriang Lerdsuwanakij <lerdsuwa@users.sourceforge.net> + + PR c++/14429 + * pt.c (coerce_template_template_parms) <PARM_DECL case>: Only check + when the type of ARG is not dependent. + 2004-07-26 Geoffrey Keating <geoffk@apple.com> * g++spec.c (LIBSTDCXX_PROFILE): Default to LIBSTDCXX. diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index ca84b394423..7ae18f8f120 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -3639,11 +3639,16 @@ coerce_template_template_parms (tree parm_parms, case PARM_DECL: /* The tsubst call is used to handle cases such as - template <class T, template <T> class TT> class D; + + template <int> class C {}; + template <class T, template <T> class TT> class D {}; + D<int, C> d; + i.e. the parameter list of TT depends on earlier parameters. */ - if (!same_type_p - (tsubst (TREE_TYPE (parm), outer_args, complain, in_decl), - TREE_TYPE (arg))) + if (!dependent_type_p (TREE_TYPE (arg)) + && !same_type_p + (tsubst (TREE_TYPE (parm), outer_args, complain, in_decl), + TREE_TYPE (arg))) return 0; break; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index bf237103596..bc4bea22867 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2004-07-27 Kriang Lerdsuwanakij <lerdsuwa@users.sourceforge.net> + + PR c++/14429 + * g++.dg/template/ttp11.C: New test. + 2004-07-27 Diego Novillo <dnovillo@redhat.com> * gcc.c-torture/compile/20040727-1.c: New test. diff --git a/gcc/testsuite/g++.dg/template/ttp11.C b/gcc/testsuite/g++.dg/template/ttp11.C new file mode 100644 index 00000000000..84867e1073e --- /dev/null +++ b/gcc/testsuite/g++.dg/template/ttp11.C @@ -0,0 +1,14 @@ +// { dg-do compile } + +// Origin: heinlein@informatik.uni-ulm.de + +// PR c++/14429: Matching of template template parameter containing +// non-type parameter with type that depends on earlier parameter. + +template <template <typename U, U* p> class T> +struct X {}; + +template <template <typename U, U* p> class T> +struct Y { + X<T> x; +}; diff --git a/gcc/testsuite/g++.dg/template/ttp12.C b/gcc/testsuite/g++.dg/template/ttp12.C new file mode 100644 index 00000000000..554738bf49b --- /dev/null +++ b/gcc/testsuite/g++.dg/template/ttp12.C @@ -0,0 +1,19 @@ +// Copyright (C) 2004 Free Software Foundation +// Contributed by Kriang Lerdsuwanakij <lerdsuwa@users.sourceforge.net> +// { dg-do compile } + +// Check the type of non-type parameter in template template parameter +// only if it is dependent. + +template <template <int* p> class T> +struct X {}; + +template <typename U, template <U* p> class T> +struct Y { + X<T> x; +}; + +template <int* p> struct Z {}; + +Y<int, Z> y1; +Y<char, Z> y2; // { dg-error "mismatch|expected|invalid" } |

