From cb48c5964c901bccf5d2ffcd9f3f3e4552ae2fb1 Mon Sep 17 00:00:00 2001 From: Hennadii Stepanov <32963518+hebasto@users.noreply.github.com> Date: Sat, 20 Mar 2021 05:01:27 +0200 Subject: [PATCH] qt, rpc: Do not accept command while executing another one --- src/qt/rpcconsole.cpp | 6 ++++++ src/qt/rpcconsole.h | 1 + 2 files changed, 7 insertions(+) diff --git a/src/qt/rpcconsole.cpp b/src/qt/rpcconsole.cpp index 242d6c3b5f9..b1a9ee4684c 100644 --- a/src/qt/rpcconsole.cpp +++ b/src/qt/rpcconsole.cpp @@ -922,6 +922,10 @@ void RPCConsole::on_lineEdit_returnPressed() return; } + if (m_is_executing) { + return; + } + ui->lineEdit->clear(); #ifdef ENABLE_WALLET @@ -940,6 +944,7 @@ void RPCConsole::on_lineEdit_returnPressed() message(CMD_REQUEST, QString::fromStdString(strFilteredCmd)); //: A message in the GUI console while an entered command being executed. message(CMD_REPLY, tr("Executing…")); + m_is_executing = true; Q_EMIT cmdRequest(cmd, m_last_wallet_model); cmd = QString::fromStdString(strFilteredCmd); @@ -991,6 +996,7 @@ void RPCConsole::startExecutor() ui->messagesWidget->undo(); message(category, command); scrollToEnd(); + m_is_executing = false; }); // Requests from this object must go to executor diff --git a/src/qt/rpcconsole.h b/src/qt/rpcconsole.h index 5182d60a0d7..1000e4e61fc 100644 --- a/src/qt/rpcconsole.h +++ b/src/qt/rpcconsole.h @@ -165,6 +165,7 @@ public Q_SLOTS: QCompleter *autoCompleter = nullptr; QThread thread; WalletModel* m_last_wallet_model{nullptr}; + bool m_is_executing{false}; /** Update UI with latest network info from model. */ void updateNetworkState();