2021-07-14 12:03:25 +03:00
|
|
|
// Copyright (c) 2014-2021 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 <qt/initexecutor.h>
|
|
|
|
|
|
|
|
#include <interfaces/node.h>
|
|
|
|
#include <util/system.h>
|
|
|
|
#include <util/threadnames.h>
|
|
|
|
|
|
|
|
#include <exception>
|
|
|
|
|
|
|
|
#include <QDebug>
|
2022-04-16 19:18:25 +02:00
|
|
|
#include <QMetaObject>
|
2021-07-14 12:03:25 +03:00
|
|
|
#include <QObject>
|
|
|
|
#include <QString>
|
|
|
|
#include <QThread>
|
|
|
|
|
2021-07-14 12:21:54 +03:00
|
|
|
InitExecutor::InitExecutor(interfaces::Node& node)
|
|
|
|
: QObject(), m_node(node)
|
2021-07-14 12:03:25 +03:00
|
|
|
{
|
2021-09-26 15:11:46 +01:00
|
|
|
m_context.moveToThread(&m_thread);
|
2021-07-14 12:03:25 +03:00
|
|
|
m_thread.start();
|
|
|
|
}
|
|
|
|
|
|
|
|
InitExecutor::~InitExecutor()
|
|
|
|
{
|
|
|
|
qDebug() << __func__ << ": Stopping thread";
|
|
|
|
m_thread.quit();
|
|
|
|
m_thread.wait();
|
|
|
|
qDebug() << __func__ << ": Stopped thread";
|
|
|
|
}
|
|
|
|
|
2021-07-14 12:21:54 +03:00
|
|
|
void InitExecutor::handleRunawayException(const std::exception* e)
|
2021-07-14 12:03:25 +03:00
|
|
|
{
|
|
|
|
PrintExceptionContinue(e, "Runaway exception");
|
|
|
|
Q_EMIT runawayException(QString::fromStdString(m_node.getWarnings().translated));
|
|
|
|
}
|
|
|
|
|
|
|
|
void InitExecutor::initialize()
|
|
|
|
{
|
2022-04-16 19:18:25 +02:00
|
|
|
QMetaObject::invokeMethod(&m_context, [this] {
|
2021-09-26 15:11:46 +01:00
|
|
|
try {
|
|
|
|
util::ThreadRename("qt-init");
|
|
|
|
qDebug() << "Running initialization in thread";
|
|
|
|
interfaces::BlockAndHeaderTipInfo tip_info;
|
|
|
|
bool rv = m_node.appInitMain(&tip_info);
|
|
|
|
Q_EMIT initializeResult(rv, tip_info);
|
|
|
|
} catch (const std::exception& e) {
|
|
|
|
handleRunawayException(&e);
|
|
|
|
} catch (...) {
|
|
|
|
handleRunawayException(nullptr);
|
|
|
|
}
|
|
|
|
});
|
2021-07-14 12:03:25 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void InitExecutor::shutdown()
|
|
|
|
{
|
2022-04-16 19:18:25 +02:00
|
|
|
QMetaObject::invokeMethod(&m_context, [this] {
|
2021-09-26 15:11:46 +01:00
|
|
|
try {
|
|
|
|
qDebug() << "Running Shutdown in thread";
|
|
|
|
m_node.appShutdown();
|
|
|
|
qDebug() << "Shutdown finished";
|
|
|
|
Q_EMIT shutdownResult();
|
|
|
|
} catch (const std::exception& e) {
|
|
|
|
handleRunawayException(&e);
|
|
|
|
} catch (...) {
|
|
|
|
handleRunawayException(nullptr);
|
|
|
|
}
|
|
|
|
});
|
2021-07-14 12:03:25 +03:00
|
|
|
}
|