Boost logo

Boost-Commit :

Subject: [Boost-commit] svn:boost r82362 - in trunk: boost/intrusive/detail libs/intrusive/example libs/intrusive/test
From: igaztanaga_at_[hidden]
Date: 2013-01-05 11:39:31


Author: igaztanaga
Date: 2013-01-05 11:39:30 EST (Sat, 05 Jan 2013)
New Revision: 82362
URL: http://svn.boost.org/trac/boost/changeset/82362

Log:
Fixes #7849
Text files modified:
   trunk/boost/intrusive/detail/utilities.hpp | 8 +++++---
   trunk/libs/intrusive/example/Jamfile.v2 | 2 +-
   trunk/libs/intrusive/example/doc_erasing_and_disposing.cpp | 28 ++++++++++++++++++++++++++++
   trunk/libs/intrusive/example/doc_offset_ptr.cpp | 15 +++++++++++++++
   trunk/libs/intrusive/test/Jamfile.v2 | 9 ++-------
   5 files changed, 51 insertions(+), 11 deletions(-)

Modified: trunk/boost/intrusive/detail/utilities.hpp
==============================================================================
--- trunk/boost/intrusive/detail/utilities.hpp (original)
+++ trunk/boost/intrusive/detail/utilities.hpp 2013-01-05 11:39:30 EST (Sat, 05 Jan 2013)
@@ -28,6 +28,7 @@
 #include <iterator>
 #include <boost/cstdint.hpp>
 #include <boost/static_assert.hpp>
+#include <boost/detail/no_exceptions_support.hpp>
 
 namespace boost {
 namespace intrusive {
@@ -692,19 +693,20 @@
    {
       char *init_buf = (char*)rawbuf;
       std::size_t i = 0;
- try{
+ BOOST_TRY{
          for(; i != N; ++i){
             new(init_buf)T(init);
             init_buf += sizeof(T);
          }
       }
- catch(...){
+ BOOST_CATCH(...){
          while(i--){
             init_buf -= sizeof(T);
             ((T*)init_buf)->~T();
          }
- throw;
+ BOOST_RETHROW;
       }
+ BOOST_CATCH_END
    }
 
    operator T* ()

Modified: trunk/libs/intrusive/example/Jamfile.v2
==============================================================================
--- trunk/libs/intrusive/example/Jamfile.v2 (original)
+++ trunk/libs/intrusive/example/Jamfile.v2 2013-01-05 11:39:30 EST (Sat, 05 Jan 2013)
@@ -21,7 +21,7 @@
 
    for local fileb in [ glob *.cpp ]
    {
- all_rules += [ run $(fileb) /boost/thread//boost_thread
+ all_rules += [ run $(fileb)
       : # additional args
       : # test-files
       : # requirements

Modified: trunk/libs/intrusive/example/doc_erasing_and_disposing.cpp
==============================================================================
--- trunk/libs/intrusive/example/doc_erasing_and_disposing.cpp (original)
+++ trunk/libs/intrusive/example/doc_erasing_and_disposing.cpp 2013-01-05 11:39:30 EST (Sat, 05 Jan 2013)
@@ -9,6 +9,7 @@
 // See http://www.boost.org/libs/intrusive for documentation.
 //
 /////////////////////////////////////////////////////////////////////////////
+#include <boost/detail/no_exceptions_support.hpp>
 //[doc_erasing_and_disposing
 #include <boost/intrusive/list.hpp>
 
@@ -50,18 +51,45 @@
    //Fill all the nodes and insert them in the list
    my_class_list list;
 
+ //<-
+ #if 1
+ BOOST_TRY{
+ #else
+ //->
    try{
+ //<-
+ #endif
+ //->
       //Insert new objects in the container
       for(int i = 0; i < MaxElem; ++i) list.push_back(*new my_class(i));
 
       //Now use remove_and_dispose_if to erase and delete the objects
       list.remove_and_dispose_if(is_even(), delete_disposer());
    }
+ //<-
+ #if 1
+ BOOST_CATCH(...){
+ #else
+ //->
    catch(...){
+ //<-
+ #endif
+ //->
       //If something throws, make sure that all the memory is freed
       list.clear_and_dispose(delete_disposer());
+ //<-
+ #if 1
+ BOOST_RETHROW
+ #else
+ //->
       throw;
+ //<-
+ #endif
+ //->
    }
+ //<-
+ BOOST_CATCH_END
+ //->
 
    //Dispose remaining elements
    list.erase_and_dispose(list.begin(), list.end(), delete_disposer());

Modified: trunk/libs/intrusive/example/doc_offset_ptr.cpp
==============================================================================
--- trunk/libs/intrusive/example/doc_offset_ptr.cpp (original)
+++ trunk/libs/intrusive/example/doc_offset_ptr.cpp 2013-01-05 11:39:30 EST (Sat, 05 Jan 2013)
@@ -10,6 +10,18 @@
 //
 /////////////////////////////////////////////////////////////////////////////
 
+#include <boost/config.hpp>
+
+#ifdef BOOST_NO_EXCEPTIONS
+
+//Interprocess does not support BOOST_NO_EXCEPTIONS so nothing to test here
+int main()
+{
+ return 0;
+}
+
+#else //!BOOST_NO_EXCEPTIONS
+
 //This is needed to allow concurrent test execution in
 //several platforms. The shared memory must be unique
 //for each process...
@@ -100,3 +112,6 @@
    return 0;
 }
 //]
+
+#endif //BOOST_NO_EXCEPTIONS
+

Modified: trunk/libs/intrusive/test/Jamfile.v2
==============================================================================
--- trunk/libs/intrusive/test/Jamfile.v2 (original)
+++ trunk/libs/intrusive/test/Jamfile.v2 2013-01-05 11:39:30 EST (Sat, 05 Jan 2013)
@@ -20,19 +20,14 @@
 
    for local fileb in [ glob *.cpp ]
    {
- all_rules += [ run $(fileb) /boost/thread//boost_thread
+ all_rules += [ run $(fileb)
       : # additional args
       : # test-files
       : # requirements
- <toolset>acc:<linkflags>-lrt
- <toolset>acc-pa_risc:<linkflags>-lrt
- <toolset>gcc-mingw:<linkflags>"-lole32 -loleaut32"
- <host-os>hpux,<toolset>gcc:<linkflags>"-Wl,+as,mpas"
- <host-os>windows,<toolset>clang:<linkflags>"-lole32 -loleaut32 -lpsapi -ladvapi32"
       ] ;
    }
 
    return $(all_rules) ;
 }
 
-test-suite intrusive_test : [ test_all r ] : <threading>multi ;
\ No newline at end of file
+test-suite intrusive_test : [ test_all r ] : ;
\ No newline at end of file


Boost-Commit list run by bdawes at acm.org, david.abrahams at rcn.com, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk