mirror of
https://github.com/dashpay/dash.git
synced 2024-12-28 21:42:47 +01:00
a128bdc9e1
Construct CWalletTx objects in CWallet::CommitTransaction, instead of having callers do it. This ensures CWalletTx objects are constructed in a uniform way and all fields are set. This also makes it possible to avoid confusing and wasteful CWalletTx copies in https://github.com/bitcoin/bitcoin/pull/9381 There is no change in behavior.
47 lines
1.2 KiB
C++
47 lines
1.2 KiB
C++
// Copyright (c) 2011-2017 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#ifndef BITCOIN_QT_WALLETMODELTRANSACTION_H
|
|
#define BITCOIN_QT_WALLETMODELTRANSACTION_H
|
|
|
|
#include <qt/walletmodel.h>
|
|
|
|
#include <QObject>
|
|
|
|
class SendCoinsRecipient;
|
|
|
|
class CReserveKey;
|
|
class CWallet;
|
|
class CWalletTx;
|
|
|
|
/** Data model for a walletmodel transaction. */
|
|
class WalletModelTransaction
|
|
{
|
|
public:
|
|
explicit WalletModelTransaction(const QList<SendCoinsRecipient> &recipients);
|
|
|
|
QList<SendCoinsRecipient> getRecipients() const;
|
|
|
|
CTransactionRef& getTransaction();
|
|
unsigned int getTransactionSize();
|
|
|
|
void setTransactionFee(const CAmount& newFee);
|
|
CAmount getTransactionFee() const;
|
|
|
|
CAmount getTotalTransactionAmount() const;
|
|
|
|
void newPossibleKeyChange(CWallet *wallet);
|
|
CReserveKey *getPossibleKeyChange();
|
|
|
|
void reassignAmounts(int nChangePosRet); // needed for the subtract-fee-from-amount feature
|
|
|
|
private:
|
|
QList<SendCoinsRecipient> recipients;
|
|
CTransactionRef walletTransaction;
|
|
std::unique_ptr<CReserveKey> keyChange;
|
|
CAmount fee;
|
|
};
|
|
|
|
#endif // BITCOIN_QT_WALLETMODELTRANSACTION_H
|