2021-12-30 19:36:57 +02:00
|
|
|
// Copyright (c) 2011-2021 The Bitcoin Core developers
|
2014-12-13 12:09:33 +08:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
2013-11-04 16:20:43 +01:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
2015-12-09 10:53:12 +00:00
|
|
|
#if defined(HAVE_CONFIG_H)
|
2017-11-10 13:57:53 +13:00
|
|
|
#include <config/bitcoin-config.h>
|
2015-12-09 10:53:12 +00:00
|
|
|
#endif
|
|
|
|
|
2018-08-23 13:42:31 -04:00
|
|
|
#include <chainparams.h>
|
2017-11-10 13:57:53 +13:00
|
|
|
#include <fs.h>
|
|
|
|
#include <qt/intro.h>
|
2017-08-15 17:31:26 +02:00
|
|
|
#include <qt/forms/ui_intro.h>
|
2013-04-13 00:13:08 -05:00
|
|
|
|
2019-01-14 13:40:00 +02:00
|
|
|
#include <qt/guiconstants.h>
|
2017-11-10 13:57:53 +13:00
|
|
|
#include <qt/guiutil.h>
|
2019-11-12 13:23:09 +02:00
|
|
|
#include <qt/optionsmodel.h>
|
2014-03-22 10:22:42 +01:00
|
|
|
|
2018-04-07 03:42:02 -04:00
|
|
|
#include <interfaces/node.h>
|
2018-10-22 15:51:11 -07:00
|
|
|
#include <util/system.h>
|
2020-04-21 21:14:11 +00:00
|
|
|
#include <validation.h>
|
2013-05-19 17:36:01 +02:00
|
|
|
|
|
|
|
#include <QFileDialog>
|
|
|
|
#include <QSettings>
|
|
|
|
#include <QMessageBox>
|
|
|
|
|
2015-12-29 15:38:38 +01:00
|
|
|
#include <cmath>
|
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
/* Check free space asynchronously to prevent hanging the UI thread.
|
|
|
|
|
|
|
|
Up to one request to check a path is in flight to this thread; when the check()
|
|
|
|
function runs, the current path is requested from the associated Intro object.
|
|
|
|
The reply is sent back through a signal.
|
|
|
|
|
|
|
|
This ensures that no queue of checking requests is built up while the user is
|
|
|
|
still entering the path, and that always the most recently entered path is checked as
|
|
|
|
soon as the thread becomes available.
|
|
|
|
*/
|
|
|
|
class FreespaceChecker : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
2013-07-23 12:00:41 +02:00
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
public:
|
2017-08-01 12:22:41 +02:00
|
|
|
explicit FreespaceChecker(Intro *intro);
|
2013-05-19 17:36:01 +02:00
|
|
|
|
|
|
|
enum Status {
|
|
|
|
ST_OK,
|
|
|
|
ST_ERROR
|
|
|
|
};
|
|
|
|
|
2015-07-14 13:59:05 +02:00
|
|
|
public Q_SLOTS:
|
2013-05-19 17:36:01 +02:00
|
|
|
void check();
|
|
|
|
|
2015-07-14 13:59:05 +02:00
|
|
|
Q_SIGNALS:
|
2013-05-19 17:36:01 +02:00
|
|
|
void reply(int status, const QString &message, quint64 available);
|
|
|
|
|
|
|
|
private:
|
|
|
|
Intro *intro;
|
|
|
|
};
|
|
|
|
|
2017-08-15 17:31:26 +02:00
|
|
|
#include <qt/intro.moc>
|
2013-05-19 17:36:01 +02:00
|
|
|
|
2016-09-09 13:43:29 +02:00
|
|
|
FreespaceChecker::FreespaceChecker(Intro *_intro)
|
2013-05-19 17:36:01 +02:00
|
|
|
{
|
2016-09-09 13:43:29 +02:00
|
|
|
this->intro = _intro;
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void FreespaceChecker::check()
|
|
|
|
{
|
|
|
|
QString dataDirStr = intro->getPathToCheck();
|
2022-01-11 18:32:11 +02:00
|
|
|
fs::path dataDir = GUIUtil::QStringToPath(dataDirStr);
|
2013-04-13 00:13:08 -05:00
|
|
|
uint64_t freeBytesAvailable = 0;
|
2013-05-19 17:36:01 +02:00
|
|
|
int replyStatus = ST_OK;
|
|
|
|
QString replyMessage = tr("A new data directory will be created.");
|
|
|
|
|
|
|
|
/* Find first parent that exists, so that fs::space does not fail */
|
|
|
|
fs::path parentDir = dataDir;
|
2013-07-23 12:00:41 +02:00
|
|
|
fs::path parentDirOld = fs::path();
|
2013-05-19 17:36:01 +02:00
|
|
|
while(parentDir.has_parent_path() && !fs::exists(parentDir))
|
|
|
|
{
|
|
|
|
parentDir = parentDir.parent_path();
|
2013-07-23 12:00:41 +02:00
|
|
|
|
|
|
|
/* Check if we make any progress, break if not to prevent an infinite loop here */
|
|
|
|
if (parentDirOld == parentDir)
|
|
|
|
break;
|
|
|
|
|
|
|
|
parentDirOld = parentDir;
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
freeBytesAvailable = fs::space(parentDir).available;
|
|
|
|
if(fs::exists(dataDir))
|
|
|
|
{
|
|
|
|
if(fs::is_directory(dataDir))
|
|
|
|
{
|
2013-07-29 16:09:15 +02:00
|
|
|
QString separator = "<code>" + QDir::toNativeSeparators("/") + tr("name") + "</code>";
|
2013-05-19 17:36:01 +02:00
|
|
|
replyStatus = ST_OK;
|
2013-07-29 16:09:15 +02:00
|
|
|
replyMessage = tr("Directory already exists. Add %1 if you intend to create a new directory here.").arg(separator);
|
2013-05-19 17:36:01 +02:00
|
|
|
} else {
|
|
|
|
replyStatus = ST_ERROR;
|
|
|
|
replyMessage = tr("Path already exists, and is not a directory.");
|
|
|
|
}
|
|
|
|
}
|
2014-12-07 13:29:06 +01:00
|
|
|
} catch (const fs::filesystem_error&)
|
2013-05-19 17:36:01 +02:00
|
|
|
{
|
|
|
|
/* Parent directory does not exist or is not accessible */
|
|
|
|
replyStatus = ST_ERROR;
|
|
|
|
replyMessage = tr("Cannot create data directory here.");
|
|
|
|
}
|
2015-07-14 13:59:05 +02:00
|
|
|
Q_EMIT reply(replyStatus, replyMessage, freeBytesAvailable);
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
|
2019-12-08 23:28:50 +02:00
|
|
|
namespace {
|
|
|
|
//! Return pruning size that will be used if automatic pruning is enabled.
|
|
|
|
int GetPruneTargetGB()
|
|
|
|
{
|
2019-08-22 21:40:41 -04:00
|
|
|
int64_t prune_target_mib = gArgs.GetIntArg("-prune", 0);
|
2019-12-08 23:28:50 +02:00
|
|
|
// >1 means automatic pruning is enabled by config, 1 means manual pruning, 0 means no pruning.
|
|
|
|
return prune_target_mib > 1 ? PruneMiBtoGB(prune_target_mib) : DEFAULT_PRUNE_TARGET_GB;
|
|
|
|
}
|
|
|
|
} // namespace
|
2013-05-19 17:36:01 +02:00
|
|
|
|
2019-11-12 14:25:43 +02:00
|
|
|
Intro::Intro(QWidget *parent, int64_t blockchain_size_gb, int64_t chain_state_size_gb) :
|
2020-09-07 19:09:33 +03:00
|
|
|
QDialog(parent, GUIUtil::dialog_flags),
|
2013-05-19 17:36:01 +02:00
|
|
|
ui(new Ui::Intro),
|
2018-07-30 12:37:09 +02:00
|
|
|
thread(nullptr),
|
2018-10-07 13:11:36 +01:00
|
|
|
signalled(false),
|
2019-11-12 14:25:43 +02:00
|
|
|
m_blockchain_size_gb(blockchain_size_gb),
|
2019-12-08 23:28:50 +02:00
|
|
|
m_chain_state_size_gb(chain_state_size_gb),
|
|
|
|
m_prune_target_gb{GetPruneTargetGB()}
|
2013-05-19 17:36:01 +02:00
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
2019-06-26 10:28:13 -04:00
|
|
|
ui->welcomeLabel->setText(ui->welcomeLabel->text().arg(PACKAGE_NAME));
|
|
|
|
ui->storageLabel->setText(ui->storageLabel->text().arg(PACKAGE_NAME));
|
2017-02-08 04:21:04 +00:00
|
|
|
|
|
|
|
ui->lblExplanation1->setText(ui->lblExplanation1->text()
|
2019-06-26 10:28:13 -04:00
|
|
|
.arg(PACKAGE_NAME)
|
2019-11-12 14:25:43 +02:00
|
|
|
.arg(m_blockchain_size_gb)
|
2017-02-08 04:21:04 +00:00
|
|
|
.arg(2009)
|
|
|
|
.arg(tr("Bitcoin"))
|
|
|
|
);
|
2019-06-26 10:28:13 -04:00
|
|
|
ui->lblExplanation2->setText(ui->lblExplanation2->text().arg(PACKAGE_NAME));
|
2017-02-08 04:21:04 +00:00
|
|
|
|
2020-04-21 21:14:11 +00:00
|
|
|
const int min_prune_target_GB = std::ceil(MIN_DISK_SPACE_FOR_BLOCK_FILES / 1e9);
|
|
|
|
ui->pruneGB->setRange(min_prune_target_GB, std::numeric_limits<int>::max());
|
2019-08-22 21:40:41 -04:00
|
|
|
if (gArgs.GetIntArg("-prune", 0) > 1) { // -prune=1 means enabled, above that it's a size in MiB
|
2019-08-24 19:13:04 +02:00
|
|
|
ui->prune->setChecked(true);
|
|
|
|
ui->prune->setEnabled(false);
|
|
|
|
}
|
2020-04-21 21:14:11 +00:00
|
|
|
ui->pruneGB->setValue(m_prune_target_gb);
|
|
|
|
ui->pruneGB->setToolTip(ui->prune->toolTip());
|
2020-04-21 22:02:25 +00:00
|
|
|
ui->lblPruneSuffix->setToolTip(ui->prune->toolTip());
|
2019-12-08 23:28:50 +02:00
|
|
|
UpdatePruneLabels(ui->prune->isChecked());
|
|
|
|
|
|
|
|
connect(ui->prune, &QCheckBox::toggled, [this](bool prune_checked) {
|
|
|
|
UpdatePruneLabels(prune_checked);
|
|
|
|
UpdateFreeSpaceLabel();
|
|
|
|
});
|
2021-03-24 05:37:56 +02:00
|
|
|
connect(ui->pruneGB, qOverload<int>(&QSpinBox::valueChanged), [this](int prune_GB) {
|
2020-04-21 21:14:11 +00:00
|
|
|
m_prune_target_gb = prune_GB;
|
|
|
|
UpdatePruneLabels(ui->prune->isChecked());
|
|
|
|
UpdateFreeSpaceLabel();
|
|
|
|
});
|
2019-12-08 23:28:50 +02:00
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
startThread();
|
|
|
|
}
|
|
|
|
|
|
|
|
Intro::~Intro()
|
|
|
|
{
|
|
|
|
delete ui;
|
|
|
|
/* Ensure thread is finished before it is deleted */
|
2018-09-18 01:17:22 +03:00
|
|
|
thread->quit();
|
2013-05-19 17:36:01 +02:00
|
|
|
thread->wait();
|
|
|
|
}
|
|
|
|
|
|
|
|
QString Intro::getDataDirectory()
|
|
|
|
{
|
|
|
|
return ui->dataDirectory->text();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::setDataDirectory(const QString &dataDir)
|
|
|
|
{
|
|
|
|
ui->dataDirectory->setText(dataDir);
|
2019-04-23 13:26:06 +02:00
|
|
|
if(dataDir == GUIUtil::getDefaultDataDirectory())
|
2013-05-19 17:36:01 +02:00
|
|
|
{
|
|
|
|
ui->dataDirDefault->setChecked(true);
|
|
|
|
ui->dataDirectory->setEnabled(false);
|
|
|
|
ui->ellipsisButton->setEnabled(false);
|
|
|
|
} else {
|
|
|
|
ui->dataDirCustom->setChecked(true);
|
|
|
|
ui->dataDirectory->setEnabled(true);
|
|
|
|
ui->ellipsisButton->setEnabled(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-11-19 03:19:30 +00:00
|
|
|
int64_t Intro::getPruneMiB() const
|
|
|
|
{
|
|
|
|
switch (ui->prune->checkState()) {
|
|
|
|
case Qt::Checked:
|
|
|
|
return PruneGBtoMiB(m_prune_target_gb);
|
|
|
|
case Qt::Unchecked: default:
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-20 14:42:52 +00:00
|
|
|
bool Intro::showIfNeeded(bool& did_show_intro, int64_t& prune_MiB)
|
2013-05-19 17:36:01 +02:00
|
|
|
{
|
2019-08-24 22:34:59 +02:00
|
|
|
did_show_intro = false;
|
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
QSettings settings;
|
|
|
|
/* If data directory provided on command line, no need to look at settings
|
|
|
|
or show a picking dialog */
|
2017-08-01 21:17:40 +02:00
|
|
|
if(!gArgs.GetArg("-datadir", "").empty())
|
2016-08-18 16:58:04 +02:00
|
|
|
return true;
|
2013-05-19 17:36:01 +02:00
|
|
|
/* 1) Default data directory for operating system */
|
2019-04-23 13:26:06 +02:00
|
|
|
QString dataDir = GUIUtil::getDefaultDataDirectory();
|
2013-05-19 17:36:01 +02:00
|
|
|
/* 2) Allow QSettings to override default dir */
|
|
|
|
dataDir = settings.value("strDataDir", dataDir).toString();
|
|
|
|
|
2022-01-11 18:32:11 +02:00
|
|
|
if(!fs::exists(GUIUtil::QStringToPath(dataDir)) || gArgs.GetBoolArg("-choosedatadir", DEFAULT_CHOOSE_DATADIR) || settings.value("fReset", false).toBool() || gArgs.GetBoolArg("-resetguisettings", false))
|
2013-05-19 17:36:01 +02:00
|
|
|
{
|
2018-10-07 13:11:36 +01:00
|
|
|
/* Use selectParams here to guarantee Params() can be used by node interface */
|
|
|
|
try {
|
2018-08-23 13:42:31 -04:00
|
|
|
SelectParams(gArgs.GetChainName());
|
2018-10-07 13:11:36 +01:00
|
|
|
} catch (const std::exception&) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
/* If current default data directory does not exist, let the user choose one */
|
2018-08-23 13:42:31 -04:00
|
|
|
Intro intro(0, Params().AssumedBlockchainSize(), Params().AssumedChainStateSize());
|
2013-05-19 17:36:01 +02:00
|
|
|
intro.setDataDirectory(dataDir);
|
2015-07-28 15:20:14 +02:00
|
|
|
intro.setWindowIcon(QIcon(":icons/bitcoin"));
|
2019-08-24 22:34:59 +02:00
|
|
|
did_show_intro = true;
|
2013-08-24 15:20:37 +02:00
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
while(true)
|
|
|
|
{
|
|
|
|
if(!intro.exec())
|
|
|
|
{
|
|
|
|
/* Cancel clicked */
|
2016-08-18 16:58:04 +02:00
|
|
|
return false;
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
dataDir = intro.getDataDirectory();
|
|
|
|
try {
|
2022-01-11 18:32:11 +02:00
|
|
|
if (TryCreateDirectories(GUIUtil::QStringToPath(dataDir))) {
|
2017-10-12 22:04:46 +13:00
|
|
|
// If a new data directory has been created, make wallets subdirectory too
|
2022-01-11 18:32:11 +02:00
|
|
|
TryCreateDirectories(GUIUtil::QStringToPath(dataDir) / "wallets");
|
2017-10-12 22:04:46 +13:00
|
|
|
}
|
2013-05-19 17:36:01 +02:00
|
|
|
break;
|
2014-12-07 13:29:06 +01:00
|
|
|
} catch (const fs::filesystem_error&) {
|
2019-06-26 10:28:13 -04:00
|
|
|
QMessageBox::critical(nullptr, PACKAGE_NAME,
|
2014-07-31 16:56:14 +02:00
|
|
|
tr("Error: Specified data directory \"%1\" cannot be created.").arg(dataDir));
|
2013-05-19 17:36:01 +02:00
|
|
|
/* fall through, back to choosing screen */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-24 19:13:04 +02:00
|
|
|
// Additional preferences:
|
2020-11-19 03:19:30 +00:00
|
|
|
prune_MiB = intro.getPruneMiB();
|
2019-08-24 19:13:04 +02:00
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
settings.setValue("strDataDir", dataDir);
|
2016-08-10 15:35:22 -04:00
|
|
|
settings.setValue("fReset", false);
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
2014-03-25 09:26:11 +01:00
|
|
|
/* Only override -datadir if different from the default, to make it possible to
|
|
|
|
* override -datadir in the bitcoin.conf file in the default data directory
|
|
|
|
* (to be consistent with bitcoind behavior)
|
|
|
|
*/
|
2019-04-23 13:26:06 +02:00
|
|
|
if(dataDir != GUIUtil::getDefaultDataDirectory()) {
|
2022-01-11 18:32:11 +02:00
|
|
|
gArgs.SoftSetArg("-datadir", fs::PathToString(GUIUtil::QStringToPath(dataDir))); // use OS locale for path setting
|
2017-04-17 15:44:10 -04:00
|
|
|
}
|
2016-08-18 16:58:04 +02:00
|
|
|
return true;
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::setStatus(int status, const QString &message, quint64 bytesAvailable)
|
|
|
|
{
|
|
|
|
switch(status)
|
|
|
|
{
|
|
|
|
case FreespaceChecker::ST_OK:
|
|
|
|
ui->errorMessage->setText(message);
|
|
|
|
ui->errorMessage->setStyleSheet("");
|
|
|
|
break;
|
|
|
|
case FreespaceChecker::ST_ERROR:
|
|
|
|
ui->errorMessage->setText(tr("Error") + ": " + message);
|
|
|
|
ui->errorMessage->setStyleSheet("QLabel { color: #800000 }");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
/* Indicate number of bytes available */
|
|
|
|
if(status == FreespaceChecker::ST_ERROR)
|
|
|
|
{
|
|
|
|
ui->freeSpace->setText("");
|
|
|
|
} else {
|
2019-12-08 17:18:15 +02:00
|
|
|
m_bytes_available = bytesAvailable;
|
|
|
|
if (ui->prune->isEnabled()) {
|
|
|
|
ui->prune->setChecked(m_bytes_available < (m_blockchain_size_gb + m_chain_state_size_gb + 10) * GB_BYTES);
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
2019-12-08 17:18:15 +02:00
|
|
|
UpdateFreeSpaceLabel();
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
/* Don't allow confirm in ERROR state */
|
|
|
|
ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(status != FreespaceChecker::ST_ERROR);
|
|
|
|
}
|
|
|
|
|
2019-12-08 17:18:15 +02:00
|
|
|
void Intro::UpdateFreeSpaceLabel()
|
|
|
|
{
|
2022-02-17 12:39:04 +01:00
|
|
|
QString freeString = tr("%1 GB of space available").arg(m_bytes_available / GB_BYTES);
|
2019-12-08 17:18:15 +02:00
|
|
|
if (m_bytes_available < m_required_space_gb * GB_BYTES) {
|
2021-04-25 21:41:24 +03:00
|
|
|
freeString += " " + tr("(of %1 GB needed)").arg(m_required_space_gb);
|
2019-12-08 17:18:15 +02:00
|
|
|
ui->freeSpace->setStyleSheet("QLabel { color: #800000 }");
|
|
|
|
} else if (m_bytes_available / GB_BYTES - m_required_space_gb < 10) {
|
2021-04-25 21:41:24 +03:00
|
|
|
freeString += " " + tr("(%1 GB needed for full chain)").arg(m_required_space_gb);
|
2019-12-08 17:18:15 +02:00
|
|
|
ui->freeSpace->setStyleSheet("QLabel { color: #999900 }");
|
|
|
|
} else {
|
|
|
|
ui->freeSpace->setStyleSheet("");
|
|
|
|
}
|
|
|
|
ui->freeSpace->setText(freeString + ".");
|
|
|
|
}
|
|
|
|
|
2013-05-19 17:36:01 +02:00
|
|
|
void Intro::on_dataDirectory_textChanged(const QString &dataDirStr)
|
|
|
|
{
|
|
|
|
/* Disable OK button until check result comes in */
|
|
|
|
ui->buttonBox->button(QDialogButtonBox::Ok)->setEnabled(false);
|
|
|
|
checkPath(dataDirStr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::on_ellipsisButton_clicked()
|
|
|
|
{
|
2018-07-31 14:02:34 -04:00
|
|
|
QString dir = QDir::toNativeSeparators(QFileDialog::getExistingDirectory(nullptr, "Choose data directory", ui->dataDirectory->text()));
|
2013-05-19 17:36:01 +02:00
|
|
|
if(!dir.isEmpty())
|
|
|
|
ui->dataDirectory->setText(dir);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::on_dataDirDefault_clicked()
|
|
|
|
{
|
2019-04-23 13:26:06 +02:00
|
|
|
setDataDirectory(GUIUtil::getDefaultDataDirectory());
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::on_dataDirCustom_clicked()
|
|
|
|
{
|
|
|
|
ui->dataDirectory->setEnabled(true);
|
|
|
|
ui->ellipsisButton->setEnabled(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::startThread()
|
|
|
|
{
|
|
|
|
thread = new QThread(this);
|
|
|
|
FreespaceChecker *executor = new FreespaceChecker(this);
|
|
|
|
executor->moveToThread(thread);
|
|
|
|
|
2018-06-24 16:18:22 +01:00
|
|
|
connect(executor, &FreespaceChecker::reply, this, &Intro::setStatus);
|
|
|
|
connect(this, &Intro::requestCheck, executor, &FreespaceChecker::check);
|
2013-05-19 17:36:01 +02:00
|
|
|
/* make sure executor object is deleted in its own thread */
|
2018-09-18 01:17:22 +03:00
|
|
|
connect(thread, &QThread::finished, executor, &QObject::deleteLater);
|
2013-05-19 17:36:01 +02:00
|
|
|
|
|
|
|
thread->start();
|
|
|
|
}
|
|
|
|
|
|
|
|
void Intro::checkPath(const QString &dataDir)
|
|
|
|
{
|
|
|
|
mutex.lock();
|
|
|
|
pathToCheck = dataDir;
|
|
|
|
if(!signalled)
|
|
|
|
{
|
|
|
|
signalled = true;
|
2015-07-14 13:59:05 +02:00
|
|
|
Q_EMIT requestCheck();
|
2013-05-19 17:36:01 +02:00
|
|
|
}
|
|
|
|
mutex.unlock();
|
|
|
|
}
|
|
|
|
|
|
|
|
QString Intro::getPathToCheck()
|
|
|
|
{
|
|
|
|
QString retval;
|
|
|
|
mutex.lock();
|
|
|
|
retval = pathToCheck;
|
|
|
|
signalled = false; /* new request can be queued now */
|
|
|
|
mutex.unlock();
|
|
|
|
return retval;
|
|
|
|
}
|
2019-11-12 15:21:20 +02:00
|
|
|
|
2019-12-08 23:28:50 +02:00
|
|
|
void Intro::UpdatePruneLabels(bool prune_checked)
|
2019-11-12 15:21:20 +02:00
|
|
|
{
|
|
|
|
m_required_space_gb = m_blockchain_size_gb + m_chain_state_size_gb;
|
|
|
|
QString storageRequiresMsg = tr("At least %1 GB of data will be stored in this directory, and it will grow over time.");
|
2019-12-08 23:28:50 +02:00
|
|
|
if (prune_checked && m_prune_target_gb <= m_blockchain_size_gb) {
|
|
|
|
m_required_space_gb = m_prune_target_gb + m_chain_state_size_gb;
|
2019-11-12 15:21:20 +02:00
|
|
|
storageRequiresMsg = tr("Approximately %1 GB of data will be stored in this directory.");
|
|
|
|
}
|
2019-12-08 23:28:50 +02:00
|
|
|
ui->lblExplanation3->setVisible(prune_checked);
|
2020-04-21 21:14:11 +00:00
|
|
|
ui->pruneGB->setEnabled(prune_checked);
|
2020-04-21 22:02:25 +00:00
|
|
|
static constexpr uint64_t nPowTargetSpacing = 10 * 60; // from chainparams, which we don't have at this stage
|
|
|
|
static constexpr uint32_t expected_block_data_size = 2250000; // includes undo data
|
|
|
|
const uint64_t expected_backup_days = m_prune_target_gb * 1e9 / (uint64_t(expected_block_data_size) * 86400 / nPowTargetSpacing);
|
2021-05-15 16:02:43 +03:00
|
|
|
ui->lblPruneSuffix->setText(
|
|
|
|
//: Explanatory text on the capability of the current prune target.
|
|
|
|
tr("(sufficient to restore backups %n day(s) old)", "", expected_backup_days));
|
2019-11-12 15:21:20 +02:00
|
|
|
ui->sizeWarningLabel->setText(
|
|
|
|
tr("%1 will download and store a copy of the Bitcoin block chain.").arg(PACKAGE_NAME) + " " +
|
|
|
|
storageRequiresMsg.arg(m_required_space_gb) + " " +
|
|
|
|
tr("The wallet will also be stored in this directory.")
|
|
|
|
);
|
|
|
|
this->adjustSize();
|
|
|
|
}
|