aboutsummaryrefslogtreecommitdiff
path: root/src/util
diff options
context:
space:
mode:
authorMacroFake <falke.marco@gmail.com>2022-07-14 10:04:34 +0200
committerMacroFake <falke.marco@gmail.com>2022-07-14 10:04:42 +0200
commit062b9db0ccb6af8bfbaa2b29132408cda9991b40 (patch)
tree96b12c4ab0e31b5c1c6b580d1a76a401920a19a0 /src/util
parent8efa73e7ce4ea0c1b7ad5c3947a5ecf9fb6361d3 (diff)
parentfa475e9c7977a952617738f2ee8cf600c07d4df8 (diff)
downloadbitcoin-062b9db0ccb6af8bfbaa2b29132408cda9991b40.tar.xz
Merge bitcoin/bitcoin#25594: refactor: Return BResult from restoreWallet
fa475e9c7977a952617738f2ee8cf600c07d4df8 refactor: Return BResult from restoreWallet (MacroFake) fa8de09edc9ec4e6d171df80f746174a0ec58afb Prepare BResult for non-copyable types (MacroFake) Pull request description: This avoids the `error` in-out param (and if `warnings` is added to `BResult`, it will avoid passing that in-out param as well). Also, as it is needed for this change, prepare `BResult` for non-copyable types. ACKs for top commit: w0xlt: reACK https://github.com/bitcoin/bitcoin/pull/25594/commits/fa475e9c7977a952617738f2ee8cf600c07d4df8 ryanofsky: Code review ACK fa475e9c7977a952617738f2ee8cf600c07d4df8. Changes since last review were replacing auto with explicit type and splitting commits Tree-SHA512: 46350883572f13721ddd198f5dfb88d2fa58ebcbda416f74da3563ea15c920fb1e6ff30558526a4ac91c36c21e6afe27751a4e51b7b8bcbcbe805209f4e9014b
Diffstat (limited to 'src/util')
-rw-r--r--src/util/result.h12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/util/result.h b/src/util/result.h
index dcf5edaa5b..2f586a4c9b 100644
--- a/src/util/result.h
+++ b/src/util/result.h
@@ -6,6 +6,7 @@
#define BITCOIN_UTIL_RESULT_H
#include <util/translation.h>
+
#include <variant>
/*
@@ -18,9 +19,9 @@ private:
std::variant<bilingual_str, T> m_variant;
public:
- BResult() : m_variant(Untranslated("")) {}
- BResult(const T& _obj) : m_variant(_obj) {}
- BResult(const bilingual_str& error) : m_variant(error) {}
+ BResult() : m_variant{Untranslated("")} {}
+ BResult(T obj) : m_variant{std::move(obj)} {}
+ BResult(bilingual_str error) : m_variant{std::move(error)} {}
/* Whether the function succeeded or not */
bool HasRes() const { return std::holds_alternative<T>(m_variant); }
@@ -30,6 +31,11 @@ public:
assert(HasRes());
return std::get<T>(m_variant);
}
+ T ReleaseObj()
+ {
+ assert(HasRes());
+ return std::move(std::get<T>(m_variant));
+ }
/* In case of failure, the error cause */
const bilingual_str& GetError() const {