$include_dir="/home/hyper-archives/boost-commit/include"; include("$include_dir/msg-header.inc") ?>
Subject: [Boost-commit] svn:boost r51907 - in branches/release: boost/utility libs/utility libs/utility/test
From: pdimov_at_[hidden]
Date: 2009-03-22 16:05:03
Author: pdimov
Date: 2009-03-22 16:05:02 EDT (Sun, 22 Mar 2009)
New Revision: 51907
URL: http://svn.boost.org/trac/boost/changeset/51907
Log:
Merge [51872], [51891] to release. Closes #2878.
Added:
   branches/release/libs/utility/addressof_fn_test.cpp
      - copied unchanged from r51872, /trunk/libs/utility/addressof_fn_test.cpp
   branches/release/libs/utility/addressof_test2.cpp
      - copied unchanged from r51872, /trunk/libs/utility/addressof_test2.cpp
Text files modified: 
   branches/release/boost/utility/addressof.hpp  |    16 ++++++++++++++++                        
   branches/release/libs/utility/test/Jamfile.v2 |     2 ++                                      
   2 files changed, 18 insertions(+), 0 deletions(-)
Modified: branches/release/boost/utility/addressof.hpp
==============================================================================
--- branches/release/boost/utility/addressof.hpp	(original)
+++ branches/release/boost/utility/addressof.hpp	2009-03-22 16:05:02 EDT (Sun, 22 Mar 2009)
@@ -21,6 +21,14 @@
 namespace detail
 {
 
+template<class T> struct addr_impl_ref
+{
+    T & v_;
+
+    inline addr_impl_ref( T & v ): v_( v ) {}
+    inline operator T& () const { return v_; }
+};
+
 template<class T> struct addressof_impl
 {
     static inline T * f( T & v, long )
@@ -39,7 +47,15 @@
 
 template<class T> T * addressof( T & v )
 {
+#if BOOST_WORKAROUND( __BORLANDC__, BOOST_TESTED_AT( 0x610 ) )
+
     return boost::detail::addressof_impl<T>::f( v, 0 );
+
+#else
+
+    return boost::detail::addressof_impl<T>::f( boost::detail::addr_impl_ref<T>( v ), 0 );
+
+#endif
 }
 
 // Borland doesn't like casting an array reference to a char reference
Modified: branches/release/libs/utility/test/Jamfile.v2
==============================================================================
--- branches/release/libs/utility/test/Jamfile.v2	(original)
+++ branches/release/libs/utility/test/Jamfile.v2	2009-03-22 16:05:02 EDT (Sun, 22 Mar 2009)
@@ -11,7 +11,9 @@
 # Please keep the tests ordered by filename
 test-suite utility
     :
+        [ run ../addressof_fn_test.cpp ]
         [ run ../addressof_test.cpp ]
+        [ run ../addressof_test2.cpp ]
         [ run ../assert_test.cpp ]
         [ run ../base_from_member_test.cpp ]
         [ run ../binary_search_test.cpp ]