Boost 1.56 compatibility fix.

This commit is contained in:
Maciej Suminski 2014-08-26 11:16:56 +02:00
parent 858e222ea7
commit b30e0dd869
1 changed files with 27 additions and 5 deletions

View File

@ -28,6 +28,7 @@
#include <cstdlib> #include <cstdlib>
#include <boost/context/fcontext.hpp> #include <boost/context/fcontext.hpp>
#include <boost/version.hpp>
#include "delegate.h" #include "delegate.h"
@ -88,6 +89,11 @@ public:
if( m_saved ) if( m_saved )
delete m_saved; delete m_saved;
#if BOOST_VERSION >= 105600
if( m_self )
delete m_self;
#endif
if( m_stack ) if( m_stack )
free( m_stack ); free( m_stack );
} }
@ -101,7 +107,7 @@ public:
*/ */
void Yield() void Yield()
{ {
boost::context::jump_fcontext( m_self, m_saved, 0 ); jump( m_self, m_saved, 0 );
} }
/** /**
@ -113,7 +119,7 @@ public:
void Yield( ReturnType& aRetVal ) void Yield( ReturnType& aRetVal )
{ {
m_retVal = aRetVal; m_retVal = aRetVal;
boost::context::jump_fcontext( m_self, m_saved, 0 ); jump( m_self, m_saved, 0 );
} }
/** /**
@ -147,12 +153,17 @@ public:
assert( m_saved == NULL ); assert( m_saved == NULL );
m_args = &aArgs; m_args = &aArgs;
#if BOOST_VERSION >= 105600
m_self = new boost::context::fcontext_t();
*m_self = boost::context::make_fcontext( sp, m_stackSize, callerStub );
#else
m_self = boost::context::make_fcontext( sp, m_stackSize, callerStub ); m_self = boost::context::make_fcontext( sp, m_stackSize, callerStub );
#endif
m_saved = new boost::context::fcontext_t(); m_saved = new boost::context::fcontext_t();
m_running = true; m_running = true;
// off we go! // off we go!
boost::context::jump_fcontext( m_saved, m_self, reinterpret_cast<intptr_t>( this ) ); jump( m_saved, m_self, reinterpret_cast<intptr_t>( this ) );
return m_running; return m_running;
} }
@ -165,7 +176,7 @@ public:
*/ */
bool Resume() bool Resume()
{ {
boost::context::jump_fcontext( m_saved, m_self, 0 ); jump( m_saved, m_self, 0 );
return m_running; return m_running;
} }
@ -204,7 +215,18 @@ private:
cor->m_running = false; cor->m_running = false;
// go back to wherever we came from. // go back to wherever we came from.
boost::context::jump_fcontext( cor->m_self, cor->m_saved, 0 ); // reinterpret_cast<intptr_t>( this )); jump( cor->m_self, cor->m_saved, 0 ); // reinterpret_cast<intptr_t>( this ));
}
///> Wrapper for jump_fcontext to assure compatibility between different boost versions
static inline intptr_t jump(boost::context::fcontext_t* aOld, boost::context::fcontext_t* aNew,
intptr_t aP, bool aPreserveFPU = true )
{
#if BOOST_VERSION >= 105600
return boost::context::jump_fcontext( aOld, *aNew, aP, aPreserveFPU );
#else
return boost::context::jump_fcontext( aOld, aNew, aP, aPreserveFPU );
#endif
} }
template <typename T> template <typename T>