mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-03-04 13:55:23 -05:00
refactor: Manage dumptxoutset RAII classes with std::optional
Also removes unused UniValue error variable.
This commit is contained in:
parent
4b5bf335ad
commit
c2b779da4e
1 changed files with 6 additions and 7 deletions
|
@ -56,6 +56,7 @@
|
|||
#include <condition_variable>
|
||||
#include <memory>
|
||||
#include <mutex>
|
||||
#include <optional>
|
||||
|
||||
using kernel::CCoinsStats;
|
||||
using kernel::CoinStatsHashType;
|
||||
|
@ -2786,8 +2787,8 @@ static RPCHelpMan dumptxoutset()
|
|||
|
||||
CConnman& connman = EnsureConnman(node);
|
||||
const CBlockIndex* invalidate_index{nullptr};
|
||||
std::unique_ptr<NetworkDisable> disable_network;
|
||||
std::unique_ptr<TemporaryRollback> temporary_rollback;
|
||||
std::optional<NetworkDisable> disable_network;
|
||||
std::optional<TemporaryRollback> temporary_rollback;
|
||||
|
||||
// If the user wants to dump the txoutset of the current tip, we don't have
|
||||
// to roll back at all
|
||||
|
@ -2812,18 +2813,16 @@ static RPCHelpMan dumptxoutset()
|
|||
// automatically re-enables the network activity at the end of the
|
||||
// process which may not be what the user wants.
|
||||
if (connman.GetNetworkActive()) {
|
||||
disable_network = std::make_unique<NetworkDisable>(connman);
|
||||
disable_network.emplace(connman);
|
||||
}
|
||||
|
||||
invalidate_index = WITH_LOCK(::cs_main, return node.chainman->ActiveChain().Next(target_index));
|
||||
temporary_rollback = std::make_unique<TemporaryRollback>(*node.chainman, *invalidate_index);
|
||||
temporary_rollback.emplace(*node.chainman, *invalidate_index);
|
||||
}
|
||||
|
||||
Chainstate* chainstate;
|
||||
std::unique_ptr<CCoinsViewCursor> cursor;
|
||||
CCoinsStats stats;
|
||||
UniValue result;
|
||||
UniValue error;
|
||||
{
|
||||
// Lock the chainstate before calling PrepareUtxoSnapshot, to be able
|
||||
// to get a UTXO database cursor while the chain is pointing at the
|
||||
|
@ -2847,7 +2846,7 @@ static RPCHelpMan dumptxoutset()
|
|||
}
|
||||
}
|
||||
|
||||
result = WriteUTXOSnapshot(*chainstate, cursor.get(), &stats, tip, afile, path, temppath, node.rpc_interruption_point);
|
||||
UniValue result = WriteUTXOSnapshot(*chainstate, cursor.get(), &stats, tip, afile, path, temppath, node.rpc_interruption_point);
|
||||
fs::rename(temppath, path);
|
||||
|
||||
result.pushKV("path", path.utf8string());
|
||||
|
|
Loading…
Add table
Reference in a new issue