mirror of
https://github.com/boostorg/fiber.git
synced 2026-02-13 00:12:17 +00:00
use the free fm_<xyz> - functions
This commit is contained in:
@@ -23,40 +23,40 @@ namespace boost {
|
||||
namespace this_fiber {
|
||||
|
||||
disable_interruption::disable_interruption() BOOST_NOEXCEPT :
|
||||
set_( ( fibers::detail::scheduler::instance()->active()->interruption_blocked() ) )
|
||||
set_( ( fm_active( fibers::detail::scheduler::instance() )->interruption_blocked() ) )
|
||||
{
|
||||
if ( ! set_)
|
||||
fibers::detail::scheduler::instance()->active()->interruption_blocked( true);
|
||||
fm_active( fibers::detail::scheduler::instance() )->interruption_blocked( true);
|
||||
}
|
||||
|
||||
disable_interruption::~disable_interruption() BOOST_NOEXCEPT
|
||||
{
|
||||
if ( ! set_)
|
||||
fibers::detail::scheduler::instance()->active()->interruption_blocked( false);
|
||||
fm_active( fibers::detail::scheduler::instance() )->interruption_blocked( false);
|
||||
}
|
||||
|
||||
restore_interruption::restore_interruption( disable_interruption & disabler) BOOST_NOEXCEPT :
|
||||
disabler_( disabler)
|
||||
{
|
||||
if ( ! disabler_.set_)
|
||||
fibers::detail::scheduler::instance()->active()->interruption_blocked( false);
|
||||
fm_active( fibers::detail::scheduler::instance() )->interruption_blocked( false);
|
||||
}
|
||||
|
||||
restore_interruption::~restore_interruption() BOOST_NOEXCEPT
|
||||
{
|
||||
if ( ! disabler_.set_)
|
||||
fibers::detail::scheduler::instance()->active()->interruption_blocked( true);
|
||||
fm_active( fibers::detail::scheduler::instance() )->interruption_blocked( true);
|
||||
}
|
||||
|
||||
bool interruption_enabled() BOOST_NOEXCEPT
|
||||
{
|
||||
fibers::detail::worker_fiber * f = fibers::detail::scheduler::instance()->active();
|
||||
fibers::detail::worker_fiber * f = fm_active( fibers::detail::scheduler::instance() );
|
||||
return 0 != f && ! f->interruption_blocked();
|
||||
}
|
||||
|
||||
bool interruption_requested() BOOST_NOEXCEPT
|
||||
{
|
||||
fibers::detail::worker_fiber * f = fibers::detail::scheduler::instance()->active();
|
||||
fibers::detail::worker_fiber * f = fm_active( fibers::detail::scheduler::instance() );
|
||||
if ( 0 == f) return false;
|
||||
return f->interruption_requested();
|
||||
}
|
||||
@@ -65,7 +65,7 @@ void interruption_point()
|
||||
{
|
||||
if ( interruption_requested() && interruption_enabled() )
|
||||
{
|
||||
fibers::detail::scheduler::instance()->active()->request_interruption( false);
|
||||
fm_active( fibers::detail::scheduler::instance() )->request_interruption( false);
|
||||
boost::throw_exception( fibers::fiber_interrupted() );
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user