From: mmitchel Date: Tue, 2 Sep 2003 20:54:07 +0000 (+0000) Subject: PR c++/11847 X-Git-Tag: upstream/4.9.2~76962 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0a74d712b12051ad604c390b0a329986e6865deb;p=platform%2Fupstream%2Flinaro-gcc.git PR c++/11847 * pt.c (convert_nontype_argument): Correct representation of REFERENCE_TYPE expressions. PR c++/11847 * g++.dg/template/class1.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@71003 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index e28ff5b..b24258b 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,9 @@ 2003-09-02 Mark Mitchell + PR c++/11847 + * pt.c (convert_nontype_argument): Correct representation of + REFERENCE_TYPE expressions. + PR c++/11808 * cp-tree.h (KOENIG_LOOKUP_P): New macro. (finish_call_expr): Change prototype. diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index ae47b60..f479901 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -3209,9 +3209,12 @@ convert_nontype_argument (tree type, tree expr) tree type_referred_to = TREE_TYPE (type); /* If this expression already has reference type, get the - underling object. */ + underlying object. */ if (TREE_CODE (expr_type) == REFERENCE_TYPE) { + if (TREE_CODE (expr) == NOP_EXPR + && TREE_CODE (TREE_OPERAND (expr, 0)) == ADDR_EXPR) + STRIP_NOPS (expr); my_friendly_assert (TREE_CODE (expr) == ADDR_EXPR, 20000604); expr = TREE_OPERAND (expr, 0); expr_type = TREE_TYPE (expr); @@ -3265,7 +3268,7 @@ convert_nontype_argument (tree type, tree expr) } cxx_mark_addressable (expr); - return build1 (ADDR_EXPR, type, expr); + return build_nop (type, build_address (expr)); } break; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f2d74d8..2cac015 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,8 @@ 2003-09-02 Mark Mitchell + PR c++/11847 + * g++.dg/template/class1.C: New test. + PR c++/11808 * g++.dg/expr/call1.C: New test. diff --git a/gcc/testsuite/g++.dg/template/class1.C b/gcc/testsuite/g++.dg/template/class1.C new file mode 100644 index 0000000..96415fb --- /dev/null +++ b/gcc/testsuite/g++.dg/template/class1.C @@ -0,0 +1,9 @@ +extern const int a; + +template class X {}; + +template struct Y { + X x; +}; + +template struct Y;