Mercurial > hg > vamp-build-and-test
view DEPENDENCIES/generic/include/boost/ptr_container/clone_allocator.hpp @ 133:4acb5d8d80b6 tip
Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author | Chris Cannam |
---|---|
date | Tue, 30 Jul 2019 12:25:44 +0100 |
parents | 2665513ce2d3 |
children |
line wrap: on
line source
// // Boost.Pointer Container // // Copyright Thorsten Ottosen 2003-2005. Use, modification and // distribution is subject to 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) // // For more information, see http://www.boost.org/libs/ptr_container/ // #ifndef BOOST_PTR_CONTAINER_CLONE_ALLOCATOR_HPP #define BOOST_PTR_CONTAINER_CLONE_ALLOCATOR_HPP #include <boost/assert.hpp> #include <boost/checked_delete.hpp> #include <typeinfo> namespace boost { ///////////////////////////////////////////////////////////////////////// // Clonable concept ///////////////////////////////////////////////////////////////////////// template< class T > inline T* new_clone( const T& r ) { // // @remark: if you get a compile-error here, // it is most likely because you did not // define new_clone( const T& ) in the namespace // of T. // T* res = new T( r ); BOOST_ASSERT( typeid(r) == typeid(*res) && "Default new_clone() sliced object!" ); return res; } template< class T > inline T* new_clone( const T* r ) { return r ? new_clone( *r ) : 0; } // // @remark: to make new_clone() work // with scope_ptr/shared_ptr ect. // simply overload for those types // in the appropriate namespace. // template< class T > inline void delete_clone( const T* r ) { checked_delete( r ); } ///////////////////////////////////////////////////////////////////////// // CloneAllocator concept ///////////////////////////////////////////////////////////////////////// struct heap_clone_allocator { template< class U > static U* allocate_clone( const U& r ) { return new_clone( r ); } template< class U > static void deallocate_clone( const U* r ) { delete_clone( r ); } }; struct view_clone_allocator { template< class U > static U* allocate_clone( const U& r ) { return const_cast<U*>(&r); } template< class U > static void deallocate_clone( const U* /*r*/ ) { // do nothing } }; } // namespace 'boost' #endif