mirror of
https://github.com/dashpay/dash.git
synced 2024-12-29 13:59:06 +01:00
42c784dc7a
* net: a few small cleanups before replacing boost threads - Drop the interruption point directly after the pnode allocation. This would be leaky if hit. - Rearrange thread creation so that the socket handler comes first * net: add CThreadInterrupt and InterruptibleSleep * net: make net interruptible Also now that net threads are interruptible, switch them to use std threads/binds/mutexes/condvars. * net: make net processing interruptible * net: remove thread_interrupted catch This is now a std::thread, so there's no hope of catching a boost interruption point. * net: make proxy receives interruptible * net: misc header cleanups
42 lines
1.1 KiB
C++
42 lines
1.1 KiB
C++
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
|
// Copyright (c) 2009-2016 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#include "threadinterrupt.h"
|
|
|
|
CThreadInterrupt::operator bool() const
|
|
{
|
|
return flag.load(std::memory_order_acquire);
|
|
}
|
|
|
|
void CThreadInterrupt::reset()
|
|
{
|
|
flag.store(false, std::memory_order_release);
|
|
}
|
|
|
|
void CThreadInterrupt::operator()()
|
|
{
|
|
{
|
|
std::unique_lock<std::mutex> lock(mut);
|
|
flag.store(true, std::memory_order_release);
|
|
}
|
|
cond.notify_all();
|
|
}
|
|
|
|
bool CThreadInterrupt::sleep_for(std::chrono::milliseconds rel_time)
|
|
{
|
|
std::unique_lock<std::mutex> lock(mut);
|
|
return !cond.wait_for(lock, rel_time, [this]() { return flag.load(std::memory_order_acquire); });
|
|
}
|
|
|
|
bool CThreadInterrupt::sleep_for(std::chrono::seconds rel_time)
|
|
{
|
|
return sleep_for(std::chrono::duration_cast<std::chrono::milliseconds>(rel_time));
|
|
}
|
|
|
|
bool CThreadInterrupt::sleep_for(std::chrono::minutes rel_time)
|
|
{
|
|
return sleep_for(std::chrono::duration_cast<std::chrono::milliseconds>(rel_time));
|
|
}
|