From 1ffe6573a9fc8c9de27d6372cd506533599fc55e Mon Sep 17 00:00:00 2001 From: Mark Mitchell Date: Mon, 22 Dec 2003 20:52:55 +0000 Subject: [PATCH] re PR c++/12397 (two-stage name lookup argument shadowed by global type) PR c++/12397 * typeck.c (finish_class_member_access_expr): Don't tree IDENTIFIER_NODEs as non-dependent expressions. PR c++/12397 * g++.dg/template/lookup3.C: New test. From-SVN: r74949 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/typeck.c | 3 +++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/template/lookup3.C | 16 ++++++++++++++++ 4 files changed, 30 insertions(+) create mode 100644 gcc/testsuite/g++.dg/template/lookup3.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index defadd5d34f0..4e4864fd24ad 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2003-12-22 Mark Mitchell + + PR c++/12397 + * typeck.c (finish_class_member_access_expr): Don't tree + IDENTIFIER_NODEs as non-dependent expressions. + 2003-12-22 Andrew Pinski PR c++/5050 diff --git a/gcc/cp/typeck.c b/gcc/cp/typeck.c index b76d5360e12a..3cdfdc297d84 100644 --- a/gcc/cp/typeck.c +++ b/gcc/cp/typeck.c @@ -1809,6 +1809,9 @@ finish_class_member_access_expr (tree object, tree name) { if (/* If OBJECT_TYPE is dependent, so is OBJECT.NAME. */ dependent_type_p (object_type) + /* If NAME is just an IDENTIFIER_NODE, then the expression + is dependent. */ + || TREE_CODE (object) == IDENTIFIER_NODE /* If NAME is "f", where either 'f' or 'args' is dependent, then the expression is dependent. */ || (TREE_CODE (name) == TEMPLATE_ID_EXPR diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 640c307d2b7a..f3765698ea9a 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2003-12-22 Mark Mitchell + + PR c++/12397 + * g++.dg/template/lookup3.C: New test. + 2003-12-22 Andrew Pinski * g++.dg/template/recurse1.C: New test diff --git a/gcc/testsuite/g++.dg/template/lookup3.C b/gcc/testsuite/g++.dg/template/lookup3.C new file mode 100644 index 000000000000..c96a0b0b981a --- /dev/null +++ b/gcc/testsuite/g++.dg/template/lookup3.C @@ -0,0 +1,16 @@ +// PR c++/12397 + +struct foo { }; + +template struct bar +{ + bar(){} + int i; + bar (const bar& foo) : i (foo.i) {} +}; + +int main() +{ + bar b1; + bar b2(b1); +}