Bitcoin Core 28.99.0
P2P Digital Currency
|
A wrapper to reserve an address from a wallet. More...
#include <wallet.h>
Public Member Functions | |
ReserveDestination (CWallet *pwallet, OutputType type) | |
Construct a ReserveDestination object. This does NOT reserve an address yet. More... | |
ReserveDestination (const ReserveDestination &)=delete | |
ReserveDestination & | operator= (const ReserveDestination &)=delete |
~ReserveDestination () | |
Destructor. If a key has been reserved and not KeepKey'ed, it will be returned to the keypool. More... | |
util::Result< CTxDestination > | GetReservedDestination (bool internal) |
Reserve an address. More... | |
void | ReturnDestination () |
Return reserved address. More... | |
void | KeepDestination () |
Keep the address. Do not return its key to the keypool when this object goes out of scope. More... | |
Protected Attributes | |
const CWallet *const | pwallet |
The wallet to reserve from. More... | |
ScriptPubKeyMan * | m_spk_man {nullptr} |
The ScriptPubKeyMan to reserve from. Based on type when GetReservedDestination is called. More... | |
OutputType const | type |
int64_t | nIndex {-1} |
The index of the address's key in the keypool. More... | |
CTxDestination | address |
The destination. More... | |
bool | fInternal {false} |
Whether this is from the internal (change output) keypool. More... | |
A wrapper to reserve an address from a wallet.
ReserveDestination is used to reserve an address. It is currently only used inside of CreateTransaction.
Instantiating a ReserveDestination does not reserve an address. To do so, GetReservedDestination() needs to be called on the object. Once an address has been reserved, call KeepDestination() on the ReserveDestination object to make sure it is not returned. Call ReturnDestination() to return the address so it can be reused (for example, if the address was used in a new transaction and that transaction was not completed and needed to be aborted).
If an address is reserved and KeepDestination() is not called, then the address will be returned when the ReserveDestination goes out of scope.
|
inlineexplicit |
Construct a ReserveDestination object. This does NOT reserve an address yet.
|
delete |
|
inline |
|
delete |
|
protected |
|
protected |
|
protected |
The ScriptPubKeyMan to reserve from. Based on type when GetReservedDestination is called.
|
protected |
|
protected |
|
protected |