diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 485cccd22e0..4c2c72ed066 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,10 @@ 2005-08-26 Mark Mitchell + PR c++/19004 + * pt.c (uses_template_parms): Handle IDENTIFIER_NODE. + (type_dependent_expression_p): Allow BASELINKs whose associated + functions are simply a FUNCTION_DECL. + PR c++/23491 * cp-tree.h (build_vec_init): Adjust prototype. * init.c (perform_member_init): Adjust call to build_vec_init. @@ -9,11 +14,6 @@ default initialization of vector elements when set. * typeck.c (build_modify_expr): Adjust call to build_vec_init. - PR c++/19004 - * pt.c (uses_template_parms): Handle IDENTIFIER_NODE. - (type_dependent_expression_p): Allow BASELINKs whose associated - functions are simply a FUNCTION_DECL. - 2005-08-25 Nathan Sidwell PR c++/20817 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 71ac3189193..386dc2ff0d7 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -4956,6 +4956,7 @@ uses_template_parms (tree t) || TREE_CODE (t) == TEMPLATE_PARM_INDEX || TREE_CODE (t) == OVERLOAD || TREE_CODE (t) == BASELINK + || TREE_CODE (t) == IDENTIFIER_NODE || CONSTANT_CLASS_P (t)) dependent_p = (type_dependent_expression_p (t) || value_dependent_expression_p (t)); @@ -12356,7 +12357,8 @@ type_dependent_expression_p (tree expression) return true; expression = TREE_OPERAND (expression, 0); } - gcc_assert (TREE_CODE (expression) == OVERLOAD); + gcc_assert (TREE_CODE (expression) == OVERLOAD + || TREE_CODE (expression) == FUNCTION_DECL); while (expression) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cb31b6aeca1..24179e1c3aa 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2005-08-26 Mark Mitchell + PR c++/19004 + * g++.dg/template/nontype13.C: New test. + PR c++/23491 * g++.dg/init/new14.C: New test. * g++.dg/expr/anew1.C: Do not XFAIL. diff --git a/gcc/testsuite/g++.dg/template/nontype13.C b/gcc/testsuite/g++.dg/template/nontype13.C new file mode 100644 index 00000000000..5ff697a933a --- /dev/null +++ b/gcc/testsuite/g++.dg/template/nontype13.C @@ -0,0 +1,29 @@ +// PR c++/19004 + +template +struct Dummy +{ + void evil() + { + this->template tester(); + } + + template + void tester() + { + bar()(); // { dg-error "argument" } + } + template + struct bar + { + void operator()() + { } + }; +}; + +int main() +{ + Dummy d; + d.tester (); // { dg-error "instantiated" } +} +