Mercurial > hg > vamp-build-and-test
diff DEPENDENCIES/generic/include/boost/statechart/detail/memory.hpp @ 16:2665513ce2d3
Add boost headers
author | Chris Cannam |
---|---|
date | Tue, 05 Aug 2014 11:11:38 +0100 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/DEPENDENCIES/generic/include/boost/statechart/detail/memory.hpp Tue Aug 05 11:11:38 2014 +0100 @@ -0,0 +1,72 @@ +#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 + + + +namespace boost +{ +namespace statechart +{ +namespace detail +{ + + + +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 ) ); + return typename boost::detail::allocator::rebind_to< + Allocator, MostDerived + >::type().allocate( 1, static_cast< MostDerived * >( 0 ) ); +} + +template< class MostDerived, class Allocator > +void deallocate( void * pObject ) +{ + return typename boost::detail::allocator::rebind_to< + Allocator, MostDerived + >::type().deallocate( static_cast< MostDerived * >( pObject ), 1 ); +} + + + +} // namespace detail +} // namespace statechart +} // namespace boost + + + +#endif