mirror of
https://github.com/dashpay/dash.git
synced 2024-12-27 21:12:48 +01:00
e269fa44c5
519cae8fd6e44aef3470415d7c5e12acb0acd9f4 gui: Delay interfaces::Node initialization (Russell Yanofsky) 102abff9eb6c267af64f2a3560712147d1896e13 gui: Replace interface::Node references with pointers (Russell Yanofsky) 91aced7c7e6e75c1f5896b7e3843015177f32748 gui: Remove unused interfaces::Node references (Russell Yanofsky) e1336316250ab5cb0ed654b1e593378a6e0769ce gui: Partially revert #10244 gArgs and Params changes (Russell Yanofsky) Pull request description: This PR is part of the [process separation project](https://github.com/bitcoin/bitcoin/projects/10). --- This is a partial revert of https://github.com/bitcoin/bitcoin/pull/10244. It changes gui code to go back to using gArgs and Params() functions directly instead of using interfaces::Node to handle arguments. These changes were originally pushed as part of https://github.com/bitcoin/bitcoin/pull/19461. Motivation is to support a new GUI process connecting to an already running node process. Details are explained in commit messages, but in addition to spawning a new bitcoin-node process, we want bitcoin-gui to connect to an existing bitcoin-node process. So for that reason it should be able to parse its own parameters, rather than rely on the node. ACKs for top commit: MarcoFalke: re-ACK 519cae8fd6, only change is rebase and addressed nits of my previous review last week 🌄 Tree-SHA512: 9c339dd82ba78bcc7b887b84d872f35ccc7dfa3d271691e6eafe8a2048cbbe3bdde1e810ce33d0714d75d048c9de3470e9e9b6f8306a6047d1cb3548f6858dc8
217 lines
8.7 KiB
C++
217 lines
8.7 KiB
C++
// Copyright (c) 2011-2020 The Bitcoin Core developers
|
|
// Copyright (c) 2014-2022 The Dash Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#if defined(HAVE_CONFIG_H)
|
|
#include <config/bitcoin-config.h>
|
|
#endif
|
|
|
|
#include <qt/utilitydialog.h>
|
|
|
|
#include <qt/forms/ui_helpmessagedialog.h>
|
|
|
|
#include <qt/guiutil.h>
|
|
|
|
#include <clientversion.h>
|
|
#include <init.h>
|
|
#include <util/system.h>
|
|
#include <util/strencodings.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <QCloseEvent>
|
|
#include <QLabel>
|
|
#include <QMainWindow>
|
|
#include <QRegExp>
|
|
#include <QTextCursor>
|
|
#include <QTextTable>
|
|
#include <QVBoxLayout>
|
|
|
|
/** "Help message" or "About" dialog box */
|
|
HelpMessageDialog::HelpMessageDialog(QWidget *parent, HelpMode helpMode) :
|
|
QDialog(parent, GUIUtil::dialog_flags),
|
|
ui(new Ui::HelpMessageDialog)
|
|
{
|
|
ui->setupUi(this);
|
|
|
|
GUIUtil::updateFonts();
|
|
|
|
QString version = QString{PACKAGE_NAME} + " " + tr("version") + " " + QString::fromStdString(FormatFullVersion());
|
|
|
|
if (helpMode == about)
|
|
{
|
|
setWindowTitle(tr("About %1").arg(PACKAGE_NAME));
|
|
|
|
std::string licenseInfo = LicenseInfo();
|
|
/// HTML-format the license message from the core
|
|
QString licenseInfoHTML = QString::fromStdString(licenseInfo);
|
|
|
|
// Make URLs clickable
|
|
QRegExp uri("<(.*)>", Qt::CaseSensitive, QRegExp::RegExp2);
|
|
uri.setMinimal(true); // use non-greedy matching
|
|
licenseInfoHTML.replace(uri, QString("<a style=\"%1\"href=\"\\1\">\\1</a>").arg(GUIUtil::getThemedStyleQString(GUIUtil::ThemedStyle::TS_COMMAND)));
|
|
// Replace newlines with HTML breaks
|
|
licenseInfoHTML.replace("\n", "<br>");
|
|
|
|
ui->aboutMessage->setTextFormat(Qt::RichText);
|
|
ui->scrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
|
|
text = version + "\n" + QString::fromStdString(FormatParagraph(licenseInfo));
|
|
ui->aboutMessage->setText(version + "<br><br>" + licenseInfoHTML);
|
|
ui->aboutMessage->setWordWrap(true);
|
|
ui->helpMessage->setVisible(false);
|
|
} else if (helpMode == cmdline) {
|
|
setWindowTitle(tr("Command-line options"));
|
|
QString header = "Usage: dash-qt [command-line options] \n";
|
|
QTextCursor cursor(ui->helpMessage->document());
|
|
cursor.insertText(version);
|
|
cursor.insertBlock();
|
|
cursor.insertText(header);
|
|
cursor.insertBlock();
|
|
|
|
std::string strUsage = gArgs.GetHelpMessage();
|
|
QString coreOptions = QString::fromStdString(strUsage);
|
|
text = version + "\n\n" + header + "\n" + coreOptions;
|
|
|
|
QTextTableFormat tf;
|
|
tf.setBorderStyle(QTextFrameFormat::BorderStyle_None);
|
|
tf.setCellPadding(2);
|
|
QVector<QTextLength> widths;
|
|
widths << QTextLength(QTextLength::PercentageLength, 35);
|
|
widths << QTextLength(QTextLength::PercentageLength, 65);
|
|
tf.setColumnWidthConstraints(widths);
|
|
|
|
QTextCharFormat bold;
|
|
bold.setFontWeight(QFont::Bold);
|
|
|
|
for (const QString &line : coreOptions.split("\n")) {
|
|
if (line.startsWith(" -"))
|
|
{
|
|
cursor.currentTable()->appendRows(1);
|
|
cursor.movePosition(QTextCursor::PreviousCell);
|
|
cursor.movePosition(QTextCursor::NextRow);
|
|
cursor.insertText(line.trimmed());
|
|
cursor.movePosition(QTextCursor::NextCell);
|
|
} else if (line.startsWith(" ")) {
|
|
cursor.insertText(line.trimmed()+' ');
|
|
} else if (line.size() > 0) {
|
|
//Title of a group
|
|
if (cursor.currentTable())
|
|
cursor.currentTable()->appendRows(1);
|
|
cursor.movePosition(QTextCursor::Down);
|
|
cursor.insertText(line.trimmed(), bold);
|
|
cursor.insertTable(1, 2, tf);
|
|
}
|
|
}
|
|
|
|
ui->helpMessage->moveCursor(QTextCursor::Start);
|
|
ui->scrollArea->setVisible(false);
|
|
} else if (helpMode == pshelp) {
|
|
QString strCoinJoinName = QString::fromStdString(gCoinJoinName);
|
|
setWindowTitle(tr("%1 information").arg(strCoinJoinName));
|
|
|
|
ui->aboutMessage->setTextFormat(Qt::RichText);
|
|
ui->scrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
|
|
ui->aboutMessage->setText(tr("\
|
|
<h3>%1 Basics</h3> \
|
|
%1 gives you true financial privacy by obscuring the origins of your funds. \
|
|
All the Dash in your wallet is comprised of different \"inputs\" which you can think of as separate, discrete coins.<br> \
|
|
%1 uses an innovative process to mix your inputs with the inputs of two or more other people, without having your coins ever leave your wallet. \
|
|
You retain control of your money at all times.<hr> \
|
|
<b>The %1 process works like this:</b>\
|
|
<ol type=\"1\"> \
|
|
<li>%1 begins by breaking your transaction inputs down into standard denominations. \
|
|
These denominations are 0.001 DASH, 0.01 DASH, 0.1 DASH, 1 DASH and 10 DASH -- sort of like the paper money you use every day.</li> \
|
|
<li>Your wallet then sends requests to specially configured software nodes on the network, called \"masternodes.\" \
|
|
These masternodes are informed then that you are interested in mixing a certain denomination. \
|
|
No identifiable information is sent to the masternodes, so they never know \"who\" you are.</li> \
|
|
<li>When two or more other people send similar messages, indicating that they wish to mix the same denomination, a mixing session begins. \
|
|
The masternode mixes up the inputs and instructs all three users' wallets to pay the now-transformed input back to themselves. \
|
|
Your wallet pays that denomination directly to itself, but in a different address (called a change address).</li> \
|
|
<li>In order to fully obscure your funds, your wallet must repeat this process a number of times with each denomination. \
|
|
Each time the process is completed, it's called a \"round.\" Each round of %1 makes it exponentially more difficult to determine where your funds originated.</li> \
|
|
<li>This mixing process happens in the background without any intervention on your part. When you wish to make a transaction, \
|
|
your funds will already be mixed. No additional waiting is required.</li> \
|
|
</ol> <hr>\
|
|
<b>IMPORTANT:</b> Your wallet only contains 1000 of these \"change addresses.\" Every time a mixing event happens, up to 9 of your addresses are used up. \
|
|
This means those 1000 addresses last for about 100 mixing events. When 900 of them are used, your wallet must create more addresses. \
|
|
It can only do this, however, if you have automatic backups enabled.<br> \
|
|
Consequently, users who have backups disabled will also have %1 disabled. <hr>\
|
|
For more information, see the <a style=\"%2\" href=\"%3\">%1 documentation</a>."
|
|
)
|
|
.arg(strCoinJoinName)
|
|
.arg(GUIUtil::getThemedStyleQString(GUIUtil::ThemedStyle::TS_COMMAND))
|
|
.arg("https://docs.dash.org/en/stable/wallets/dashcore/coinjoin-instantsend.html")
|
|
);
|
|
ui->aboutMessage->setWordWrap(true);
|
|
ui->helpMessage->setVisible(false);
|
|
}
|
|
|
|
GUIUtil::handleCloseWindowShortcut(this);
|
|
}
|
|
|
|
HelpMessageDialog::~HelpMessageDialog()
|
|
{
|
|
delete ui;
|
|
}
|
|
|
|
void HelpMessageDialog::printToConsole()
|
|
{
|
|
// On other operating systems, the expected action is to print the message to the console.
|
|
tfm::format(std::cout, "%s\n", qPrintable(text));
|
|
}
|
|
|
|
void HelpMessageDialog::showOrPrint()
|
|
{
|
|
#if defined(WIN32)
|
|
// On Windows, show a message box, as there is no stderr/stdout in windowed applications
|
|
exec();
|
|
#else
|
|
// On other operating systems, print help text to console
|
|
printToConsole();
|
|
#endif
|
|
}
|
|
|
|
void HelpMessageDialog::on_okButton_accepted()
|
|
{
|
|
close();
|
|
}
|
|
|
|
|
|
/** "Shutdown" window */
|
|
ShutdownWindow::ShutdownWindow(QWidget *parent, Qt::WindowFlags f):
|
|
QWidget(parent, f)
|
|
{
|
|
setObjectName("ShutdownWindow");
|
|
|
|
QVBoxLayout *layout = new QVBoxLayout();
|
|
layout->addWidget(new QLabel(
|
|
tr("%1 is shutting down...").arg(PACKAGE_NAME) + "<br /><br />" +
|
|
tr("Do not shut down the computer until this window disappears.")));
|
|
setLayout(layout);
|
|
|
|
GUIUtil::updateFonts();
|
|
|
|
GUIUtil::handleCloseWindowShortcut(this);
|
|
}
|
|
|
|
QWidget* ShutdownWindow::showShutdownWindow(QMainWindow* window)
|
|
{
|
|
assert(window != nullptr);
|
|
|
|
// Show a simple window indicating shutdown status
|
|
QWidget *shutdownWindow = new ShutdownWindow();
|
|
shutdownWindow->setWindowTitle(window->windowTitle());
|
|
|
|
// Center shutdown window at where main window was
|
|
const QPoint global = window->mapToGlobal(window->rect().center());
|
|
shutdownWindow->move(global.x() - shutdownWindow->width() / 2, global.y() - shutdownWindow->height() / 2);
|
|
shutdownWindow->show();
|
|
return shutdownWindow;
|
|
}
|
|
|
|
void ShutdownWindow::closeEvent(QCloseEvent *event)
|
|
{
|
|
event->ignore();
|
|
}
|