From c1ca2f12d48e17441544cf8eaa442e4bd55119c0 Mon Sep 17 00:00:00 2001 From: dodji Date: Mon, 18 Jan 2010 19:11:24 +0000 Subject: [PATCH] Fix PR c++/42766 gcc/cp/ChangeLog: PR c++/42766 * cvt.c (build_expr_type_conversion): Look through OVERLOAD. gcc/testsuite/ChangeLog: PR c++/42766 * g++.dg/conversion/op6.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@156020 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 5 +++++ gcc/cp/cvt.c | 1 + gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/conversion/op6.C | 18 ++++++++++++++++++ 4 files changed, 29 insertions(+) create mode 100644 gcc/testsuite/g++.dg/conversion/op6.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ffa7b86..ccb2afe 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2010-01-18 Dodji Seketeli + + PR c++/42766 + * cvt.c (build_expr_type_conversion): Look through OVERLOAD. + 2010-01-17 Dodji Seketeli PR c++/42697 diff --git a/gcc/cp/cvt.c b/gcc/cp/cvt.c index b4cc2b3..cbe8596 100644 --- a/gcc/cp/cvt.c +++ b/gcc/cp/cvt.c @@ -1203,6 +1203,7 @@ build_expr_type_conversion (int desires, tree expr, bool complain) int win = 0; tree candidate; tree cand = TREE_VALUE (conv); + cand = OVL_CURRENT (cand); if (winner && winner == cand) continue; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 2b0d96d..11a7540 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-01-18 Dodji Seketeli + + PR c++/42766 + * g++.dg/conversion/op6.C: New test. + 2010-01-18 Uros Bizjak PR target/42774 diff --git a/gcc/testsuite/g++.dg/conversion/op6.C b/gcc/testsuite/g++.dg/conversion/op6.C new file mode 100644 index 0000000..9aec9f0 --- /dev/null +++ b/gcc/testsuite/g++.dg/conversion/op6.C @@ -0,0 +1,18 @@ +// Origin: PR c++/42766 +// { dg-do compile } + +template class smart_pointer { +public: + operator T* () const { } + operator bool () const { } + operator bool () { } +}; +class Context { }; +typedef smart_pointer ContextP; +class SvnClient { + ~SvnClient(); + ContextP svnContext; +}; +SvnClient::~SvnClient() { + delete svnContext; +} -- 2.7.4