From 1e8671f733a879525232e2e2f7b77d00362032d7 Mon Sep 17 00:00:00 2001 From: Jason Merrill Date: Thu, 6 Dec 2012 15:20:52 -0500 Subject: [PATCH] re PR c++/54913 (qualified lookup in ctor of class template fails to find static member of reference type) PR c++/54913 * semantics.c (finish_qualified_id_expr): convert_from_reference after building a SCOPE_REF. From-SVN: r194266 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/semantics.c | 4 ++-- gcc/testsuite/g++.dg/template/qualified-id6.C | 14 ++++++++++++++ 3 files changed, 22 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/g++.dg/template/qualified-id6.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index d228fe2b2e9..28f8c674d76 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2012-12-06 Jason Merrill + + PR c++/54913 + * semantics.c (finish_qualified_id_expr): convert_from_reference + after building a SCOPE_REF. + 2012-12-06 Jakub Jelinek PR c++/54207 diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 24832673386..491d97c581a 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -1778,8 +1778,6 @@ finish_qualified_id_expr (tree qualifying_class, ; else { - expr = convert_from_reference (expr); - /* In a template, return a SCOPE_REF for most qualified-ids so that we can check access at instantiation time. But if we're looking at a member of the current instantiation, we @@ -1790,6 +1788,8 @@ finish_qualified_id_expr (tree qualifying_class, expr = build_qualified_name (TREE_TYPE (expr), qualifying_class, expr, template_p); + + expr = convert_from_reference (expr); } return expr; diff --git a/gcc/testsuite/g++.dg/template/qualified-id6.C b/gcc/testsuite/g++.dg/template/qualified-id6.C new file mode 100644 index 00000000000..83be874dd10 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/qualified-id6.C @@ -0,0 +1,14 @@ +// PR c++/54913 + +struct E +{ + static const int& e; +}; + +template +struct R +{ + R() { E::e; } +}; + +R r; -- 2.30.2