From a5f729bbeb674ae331a75c4110e6da992606209d Mon Sep 17 00:00:00 2001 From: Peter Dimov Date: Sat, 28 Mar 2009 20:56:16 +0000 Subject: [PATCH] Merge [51979] to release. Closes #2849. [SVN r52041] --- include/boost/bind/bind.hpp | 9 ++++++++ test/Jamfile.v2 | 1 + test/bind_eq3_test.cpp | 45 +++++++++++++++++++++++++++++++++++++ 3 files changed, 55 insertions(+) create mode 100644 test/bind_eq3_test.cpp diff --git a/include/boost/bind/bind.hpp b/include/boost/bind/bind.hpp index 9510ffb..1e5c9e0 100644 --- a/include/boost/bind/bind.hpp +++ b/include/boost/bind/bind.hpp @@ -48,6 +48,8 @@ namespace boost { +template class weak_ptr; + namespace _bi // implementation details { @@ -126,6 +128,13 @@ private: T t_; }; +// ref_compare for weak_ptr + +template bool ref_compare( value< weak_ptr > const & a, value< weak_ptr > const & b, int ) +{ + return !(a.get() < b.get()) && !(b.get() < a.get()); +} + // type template class type {}; diff --git a/test/Jamfile.v2 b/test/Jamfile.v2 index 3149749..ea85a0b 100644 --- a/test/Jamfile.v2 +++ b/test/Jamfile.v2 @@ -41,4 +41,5 @@ test-suite "bind" [ run bind_eq2_test.cpp ] [ run mem_fn_ref_test.cpp ] [ run bind_ref_test.cpp ] + [ run bind_eq3_test.cpp ] ; diff --git a/test/bind_eq3_test.cpp b/test/bind_eq3_test.cpp new file mode 100644 index 0000000..03a5593 --- /dev/null +++ b/test/bind_eq3_test.cpp @@ -0,0 +1,45 @@ +#include + +#if defined(BOOST_MSVC) +#pragma warning(disable: 4786) // identifier truncated in debug info +#pragma warning(disable: 4710) // function not inlined +#pragma warning(disable: 4711) // function selected for automatic inline expansion +#pragma warning(disable: 4514) // unreferenced inline removed +#endif + +// +// bind_eq3_test.cpp - function_equal with bind and weak_ptr +// +// Copyright (c) 2004, 2005, 2009 Peter Dimov +// +// Distributed under the Boost Software License, Version 1.0. +// See accompanying file LICENSE_1_0.txt or copy at +// http://www.boost.org/LICENSE_1_0.txt +// + +#include +#include +#include +#include + +int f( boost::weak_ptr wp ) +{ + return wp.use_count(); +} + +template< class F > void test_self_equal( F f ) +{ +#ifdef BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP + using boost::function_equal; +#endif + + BOOST_TEST( function_equal( f, f ) ); +} + +int main() +{ + test_self_equal( boost::bind( f, _1 ) ); + test_self_equal( boost::bind( f, boost::weak_ptr() ) ); + + return boost::report_errors(); +}