2018-05-16 19:17:40 +00:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2021-12-30 19:36:57 +02:00
|
|
|
// Copyright (c) 2009-2021 The Bitcoin Core developers
|
2018-05-16 19:17:40 +00:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef BITCOIN_SHUTDOWN_H
|
|
|
|
#define BITCOIN_SHUTDOWN_H
|
|
|
|
|
2021-04-02 20:49:01 +02:00
|
|
|
#include <util/translation.h> // For bilingual_str
|
|
|
|
|
|
|
|
/** Abort with a message */
|
|
|
|
bool AbortNode(const std::string& strMessage, bilingual_str user_message = bilingual_str{});
|
|
|
|
|
2020-12-08 21:49:06 +01:00
|
|
|
/** Initialize shutdown state. This must be called before using either StartShutdown(),
|
|
|
|
* AbortShutdown() or WaitForShutdown(). Calling ShutdownRequested() is always safe.
|
|
|
|
*/
|
|
|
|
bool InitShutdownState();
|
|
|
|
|
|
|
|
/** Request shutdown of the application. */
|
2018-05-16 19:17:40 +00:00
|
|
|
void StartShutdown();
|
2020-12-08 21:49:06 +01:00
|
|
|
|
|
|
|
/** Clear shutdown flag. Only use this during init (before calling WaitForShutdown in any
|
|
|
|
* thread), or in the unit tests. Calling it in other circumstances will cause a race condition.
|
|
|
|
*/
|
2018-05-16 19:17:40 +00:00
|
|
|
void AbortShutdown();
|
2020-12-08 21:49:06 +01:00
|
|
|
|
|
|
|
/** Returns true if a shutdown is requested, false otherwise. */
|
2018-05-16 19:17:40 +00:00
|
|
|
bool ShutdownRequested();
|
|
|
|
|
2020-12-08 21:49:06 +01:00
|
|
|
/** Wait for StartShutdown to be called in any thread. This can only be used
|
|
|
|
* from a single thread.
|
|
|
|
*/
|
|
|
|
void WaitForShutdown();
|
|
|
|
|
2021-11-12 11:19:44 +01:00
|
|
|
#endif // BITCOIN_SHUTDOWN_H
|