| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | #ifndef BOOST_STATECHART_DETAIL_MEMORY_HPP_INCLUDED#define BOOST_STATECHART_DETAIL_MEMORY_HPP_INCLUDED//////////////////////////////////////////////////////////////////////////////// Copyright 2005-2006 Andreas Huber Doenni// Distributed under the Boost Software License, Version 1.0. (See accompany-// ing file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)//////////////////////////////////////////////////////////////////////////////#include <boost/statechart/detail/avoid_unused_warning.hpp>#include <boost/assert.hpp>#include <boost/detail/allocator_utilities.hpp>#include <cstddef> // std::size_t#include <memory>  // std::allocator_traitsnamespace boost{namespace statechart{#ifdef BOOST_NO_CXX11_ALLOCATORtypedef void none;#else// The specialization std::allocator<void> doesn't satisfy C++17's// allocator completeness requirements. Therefore it is deprecated// and should no longer be used. Supply a replacement type for all// the allocator default template arguments in the library.struct none {};#endifnamespace detail{// defect: 'allocate' and 'deallocate' cannot handle stateful allocators!template< class MostDerived, class Allocator >void * allocate( std::size_t size ){  avoid_unused_warning( size );  // The assert below fails when memory is allocated for an event<>,  // simple_state<> or state<> subtype object, *and* the first template  // parameter passed to one of these templates is not equal to the most-  // derived object being constructed.  // The following examples apply to all these subtypes:  // // Example 1  // struct A {};  // struct B : sc::simple_state< A, /* ... */ >  // // Above, the first template parameter must be equal to the most-  // // derived type  //   // // Example 2  // struct A : sc::event< A >  // struct B : A { /* ... */ };  // void f() { delete new B(); }  // // Above the most-derived type being constructed is B, but A was passed  // // as the most-derived type to event<>.  BOOST_ASSERT( size == sizeof( MostDerived ) );  typedef typename boost::detail::allocator::rebind_to<    Allocator, MostDerived  >::type md_allocator;  md_allocator alloc;#ifdef BOOST_NO_CXX11_ALLOCATOR  return alloc.allocate( 1, static_cast< MostDerived * >( 0 ) );#else  typedef std::allocator_traits<md_allocator> md_traits;  return md_traits::allocate( alloc, 1, static_cast< MostDerived * >( 0 ) );#endif}template< class MostDerived, class Allocator >void deallocate( void * pObject ){  typedef typename boost::detail::allocator::rebind_to<    Allocator, MostDerived  >::type md_allocator;  md_allocator alloc;#ifdef BOOST_NO_CXX11_ALLOCATOR  alloc.deallocate( static_cast< MostDerived * >( pObject ), 1 );#else  typedef std::allocator_traits<md_allocator> md_traits;  md_traits::deallocate( alloc, static_cast< MostDerived * >( pObject ), 1 );#endif}} // namespace detail} // namespace statechart} // namespace boost#endif
 |