From 6d657374dcadc67f4fedadb978cc2eab21a2eb0c Mon Sep 17 00:00:00 2001 From: jakub Date: Wed, 18 Jan 2006 08:01:02 +0000 Subject: * search.c (lookup_conversions_r): Fix a pasto. * g++.dg/parse/lookup5.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@109877 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 4 ++++ gcc/cp/search.c | 2 +- gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/g++.dg/parse/lookup5.C | 26 ++++++++++++++++++++++++++ 4 files changed, 35 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/g++.dg/parse/lookup5.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index da860eb6b38..f7201ba4520 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +2006-01-18 Jakub Jelinek + + * search.c (lookup_conversions_r): Fix a pasto. + 2006-01-17 Eric Christopher * call.c (convert_like_real): When issuing conversion diff --git a/gcc/cp/search.c b/gcc/cp/search.c index 090510b4103..90e88d6865e 100644 --- a/gcc/cp/search.c +++ b/gcc/cp/search.c @@ -2355,7 +2355,7 @@ lookup_conversions_r (tree binfo, { parent_tpl_convs = tree_cons (binfo, my_tpl_convs, parent_tpl_convs); if (virtual_depth) - TREE_STATIC (parent_convs) = 1; + TREE_STATIC (parent_tpl_convs) = 1; } child_convs = other_convs; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index dc5c57a360e..61145bc640d 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2006-01-18 Jakub Jelinek + + * g++.dg/parse/lookup5.C: New test. + 2006-01-17 Jerry DeLisle PR fortran/25697 diff --git a/gcc/testsuite/g++.dg/parse/lookup5.C b/gcc/testsuite/g++.dg/parse/lookup5.C new file mode 100644 index 00000000000..afdf023b50b --- /dev/null +++ b/gcc/testsuite/g++.dg/parse/lookup5.C @@ -0,0 +1,26 @@ +// { dg-do compile } + +struct A {}; + +template struct B +{ + T a, b; + B() {} + B(T x, T y) : a(x), b(y) {} + template operator B () const + { return B((U)(this->a), (U)(this->b)); } +}; + +template struct C : public B +{ + T *c; + inline T & operator *() { return *c; } +}; + +template struct D : virtual public C { }; + +void +foo (D x) +{ + *x; +} -- cgit v1.2.1