aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorVolker Reichelt <reichelt@igpm.rwth-aachen.de>2005-07-12 16:07:38 +0000
committerNathan Sidwell <nathan@gcc.gnu.org>2005-07-12 16:07:38 +0000
commita207780f9b958e8cf857858a658dbe9db6b68347 (patch)
tree47a081bcd8d674465343a3cedc9e1de828548dc5 /gcc
parentcac50d9410d1c110fdaacaecfaef840e3c42e1a5 (diff)
downloadgcc-a207780f9b958e8cf857858a658dbe9db6b68347.zip
gcc-a207780f9b958e8cf857858a658dbe9db6b68347.tar.gz
gcc-a207780f9b958e8cf857858a658dbe9db6b68347.tar.bz2
re PR c++/20172 (Invalid non-type template parameters not diagnosed)
cp: PR c++/20172 * pt.c (tsubst_template_parms): Check for invalid non-type parameters. testsuite: PR c++/20172 * g++.dg/template/nontype12.C : New test. Co-Authored-By: Nathan Sidwell <nathan@codesourcery.com> From-SVN: r101928
Diffstat (limited to 'gcc')
-rw-r--r--gcc/cp/ChangeLog7
-rw-r--r--gcc/cp/pt.c3
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/template/nontype12.C35
4 files changed, 50 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index 75da1b3..80a2802 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,10 @@
+2005-07-12 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
+ Nathan Sidwell <nathan@codesourcery.com>
+
+ PR c++/20172
+ * pt.c (tsubst_template_parms): Check for invalid non-type
+ parameters.
+
2005-07-09 Andrew Pinski <pinskia@physics.uc.edu>
* cp-lang.c (shadowed_var_for_decl, decl_shadowed_for_var_lookup,
diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c
index 0fcb5e8..bbf3bf9 100644
--- a/gcc/cp/pt.c
+++ b/gcc/cp/pt.c
@@ -5987,6 +5987,9 @@ tsubst_template_parms (tree parms, tree args, tsubst_flags_t complain)
tree parm_decl = TREE_VALUE (tuple);
parm_decl = tsubst (parm_decl, args, complain, NULL_TREE);
+ if (TREE_CODE (parm_decl) == PARM_DECL
+ && invalid_nontype_parm_type_p (TREE_TYPE (parm_decl), complain))
+ parm_decl = error_mark_node;
default_value = tsubst_template_arg (default_value, args,
complain, NULL_TREE);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 2a0a5f8..6502977 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2005-07-12 Volker Reichelt <reichelt@igpm.rwth-aachen.de>
+
+ PR c++/20172
+ * g++.dg/template/nontype12.C : New test.
+
2005-07-12 Zdenek Dvorak <dvorakz@suse.cz>
* gcc.dg/tree-ssa/loop-10.c: New test.
diff --git a/gcc/testsuite/g++.dg/template/nontype12.C b/gcc/testsuite/g++.dg/template/nontype12.C
new file mode 100644
index 0000000..0200e87
--- /dev/null
+++ b/gcc/testsuite/g++.dg/template/nontype12.C
@@ -0,0 +1,35 @@
+// PR c++/20172
+// Origin: Volker Reichelt <reichelt@igpm.rwth-aachen.de>
+
+template<typename T> struct A
+{
+ template<T> int foo(); // { dg-error "double" }
+ template<template<T> class> int bar(); // { dg-error "double" }
+ template<T> struct X; // { dg-error "double" }
+};
+
+A<char> a1;
+A<double> a2; // { dg-error "instantiated" }
+
+template<typename T> struct B
+{
+ template<double> int foo(); // { dg-error "double" }
+ template<template<double> class> int bar(); // { dg-error "double" }
+ template<double> struct X; // { dg-error "double" }
+};
+
+template<void> int foo(); // { dg-error "void" }
+template<template<void> class> int bar(); // { dg-error "void" }
+template<void> struct X; // { dg-error "void" }
+
+template<typename T> struct C
+{
+ template<T> int foo(); // { dg-error "double" }
+};
+
+template<typename T> int baz(T) { C<T> c; } // { dg-error "instantiated" }
+
+void foobar()
+{
+ baz(1.2); // { dg-error "instantiated" }
+}