Merge pull request #634 from laanwj/doxygen

Add doxygen documentation
This commit is contained in:
Gavin Andresen 2011-11-21 11:31:57 -08:00
commit 92979f8288
31 changed files with 1983 additions and 144 deletions

1752
doc/Doxyfile Normal file

File diff suppressed because it is too large Load Diff

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.6 KiB

View File

@ -8,6 +8,7 @@ namespace Ui {
} }
class ClientModel; class ClientModel;
/** "About" dialog box */
class AboutDialog : public QDialog class AboutDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT

View File

@ -14,6 +14,8 @@ class QItemSelection;
class QSortFilterProxyModel; class QSortFilterProxyModel;
QT_END_NAMESPACE QT_END_NAMESPACE
/** Widget that shows a list of sending or receiving addresses.
*/
class AddressBookPage : public QDialog class AddressBookPage : public QDialog
{ {
Q_OBJECT Q_OBJECT
@ -25,8 +27,8 @@ public:
}; };
enum Mode { enum Mode {
ForSending, // Pick address for sending ForSending, /**< Open address book to pick address for sending */
ForEditing // Open address book for editing ForEditing /**< Open address book for editing */
}; };
explicit AddressBookPage(Mode mode, Tabs tab, QWidget *parent = 0); explicit AddressBookPage(Mode mode, Tabs tab, QWidget *parent = 0);

View File

@ -8,6 +8,9 @@ class AddressTablePriv;
class CWallet; class CWallet;
class WalletModel; class WalletModel;
/**
Qt model of the address book in the core. This allows views to access and modify the address book.
*/
class AddressTableModel : public QAbstractTableModel class AddressTableModel : public QAbstractTableModel
{ {
Q_OBJECT Q_OBJECT
@ -16,27 +19,28 @@ public:
~AddressTableModel(); ~AddressTableModel();
enum ColumnIndex { enum ColumnIndex {
Label = 0, /* User specified label */ Label = 0, /**< User specified label */
Address = 1 /* Bitcoin address */ Address = 1 /**< Bitcoin address */
}; };
enum RoleIndex { enum RoleIndex {
TypeRole = Qt::UserRole TypeRole = Qt::UserRole /**< Type of address (#Send or #Receive) */
}; };
// Return status of last edit/insert operation /** Return status of edit/insert operation */
enum EditStatus { enum EditStatus {
OK, OK,
INVALID_ADDRESS, INVALID_ADDRESS, /**< Unparseable address */
DUPLICATE_ADDRESS, DUPLICATE_ADDRESS, /**< Address already in address book */
WALLET_UNLOCK_FAILURE, WALLET_UNLOCK_FAILURE, /**< Wallet could not be unlocked to create new receiving address */
KEY_GENERATION_FAILURE KEY_GENERATION_FAILURE /**< Generating a new public key for a receiving address failed */
}; };
static const QString Send; /* Send addres */ static const QString Send; /**< Specifies send address */
static const QString Receive; /* Receive address */ static const QString Receive; /**< Specifies receive address */
/* Overridden methods from QAbstractTableModel */ /** @name Methods overridden from QAbstractTableModel
@{*/
int rowCount(const QModelIndex &parent) const; int rowCount(const QModelIndex &parent) const;
int columnCount(const QModelIndex &parent) const; int columnCount(const QModelIndex &parent) const;
QVariant data(const QModelIndex &index, int role) const; QVariant data(const QModelIndex &index, int role) const;
@ -45,6 +49,7 @@ public:
QModelIndex index(int row, int column, const QModelIndex & parent) const; QModelIndex index(int row, int column, const QModelIndex & parent) const;
bool removeRows(int row, int count, const QModelIndex & parent = QModelIndex()); bool removeRows(int row, int count, const QModelIndex & parent = QModelIndex());
Qt::ItemFlags flags(const QModelIndex & index) const; Qt::ItemFlags flags(const QModelIndex & index) const;
/*@}*/
/* Add an address to the model. /* Add an address to the model.
Returns the added address on success, and an empty string otherwise. Returns the added address on success, and an empty string otherwise.

View File

@ -9,16 +9,18 @@ namespace Ui {
class WalletModel; class WalletModel;
/** Multifunctional dialog to ask for passphrases. Used for encryption, unlocking, and changing the passphrase.
*/
class AskPassphraseDialog : public QDialog class AskPassphraseDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT
public: public:
enum Mode { enum Mode {
Encrypt, // Ask passphrase x2 Encrypt, /**< Ask passphrase twice and encrypt */
Unlock, // Ask passphrase Unlock, /**< Ask passphrase and unlock */
ChangePass, // Ask old passphrase + new passphrase x2 ChangePass, /**< Ask old passphrase + new passphrase twice */
Decrypt // Ask passphrase Decrypt /**< Ask passphrase and decrypt wallet */
}; };
explicit AskPassphraseDialog(Mode mode, QWidget *parent = 0); explicit AskPassphraseDialog(Mode mode, QWidget *parent = 0);

View File

@ -3,7 +3,7 @@
#include <QRegExpValidator> #include <QRegExpValidator>
/* Base48 entry widget validator. /** Base48 entry widget validator.
Corrects near-miss characters and refuses characters that are no part of base48. Corrects near-miss characters and refuses characters that are no part of base48.
*/ */
class BitcoinAddressValidator : public QValidator class BitcoinAddressValidator : public QValidator

View File

@ -8,8 +8,8 @@ class QDoubleSpinBox;
class QValueComboBox; class QValueComboBox;
QT_END_NAMESPACE QT_END_NAMESPACE
// Coin amount entry widget with separate parts for whole /** Widget for entering bitcoin amounts.
// coins and decimals. */
class BitcoinAmountField: public QWidget class BitcoinAmountField: public QWidget
{ {
Q_OBJECT Q_OBJECT
@ -20,25 +20,27 @@ public:
qint64 value(bool *valid=0) const; qint64 value(bool *valid=0) const;
void setValue(qint64 value); void setValue(qint64 value);
// Mark current valid as invalid in UI /** Mark current value as invalid in UI. */
void setValid(bool valid); void setValid(bool valid);
/** Perform input validation, mark field as invalid if entered value is not valid. */
bool validate(); bool validate();
// Change current unit /** Change unit used to display amount. */
void setDisplayUnit(int unit); void setDisplayUnit(int unit);
// Make field empty and ready for new input /** Make field empty and ready for new input. */
void clear(); void clear();
// Qt messes up the tab chain by default in some cases (issue http://bugreports.qt.nokia.com/browse/QTBUG-10907) /** Qt messes up the tab chain by default in some cases (issue http://bugreports.qt.nokia.com/browse/QTBUG-10907),
// Hence we have to set it up manually in these cases we have to set it up manually.
*/
QWidget *setupTabChain(QWidget *prev); QWidget *setupTabChain(QWidget *prev);
signals: signals:
void textChanged(); void textChanged();
protected: protected:
// Intercept focus-in event and ',' keypresses /** Intercept focus-in event and ',' keypresses */
bool eventFilter(QObject *object, QEvent *event); bool eventFilter(QObject *object, QEvent *event);
private: private:

View File

@ -24,6 +24,10 @@ class QStackedWidget;
class QUrl; class QUrl;
QT_END_NAMESPACE QT_END_NAMESPACE
/**
Bitcoin GUI main class. This class represents the main window of the Bitcoin UI. It communicates with both the client and
wallet models to give the user an up-to-date view of the current core state.
*/
class BitcoinGUI : public QMainWindow class BitcoinGUI : public QMainWindow
{ {
Q_OBJECT Q_OBJECT
@ -31,17 +35,16 @@ public:
explicit BitcoinGUI(QWidget *parent = 0); explicit BitcoinGUI(QWidget *parent = 0);
~BitcoinGUI(); ~BitcoinGUI();
/** Set the client model.
The client model represents the part of the core that communicates with the P2P network, and is wallet-agnostic.
*/
void setClientModel(ClientModel *clientModel); void setClientModel(ClientModel *clientModel);
/** Set the wallet model.
The wallet model represents a bitcoin wallet, and offers access to the list of transactions, address book and sending
functionality.
*/
void setWalletModel(WalletModel *walletModel); void setWalletModel(WalletModel *walletModel);
/* Transaction table tab indices */
enum {
AllTransactions = 0,
SentReceived = 1,
Sent = 2,
Received = 3
} TabIndex;
protected: protected:
void changeEvent(QEvent *e); void changeEvent(QEvent *e);
void closeEvent(QCloseEvent *event); void closeEvent(QCloseEvent *event);
@ -86,41 +89,68 @@ private:
QMovie *syncIconMovie; QMovie *syncIconMovie;
/** Create the main UI actions. */
void createActions(); void createActions();
/** Create the menu bar and submenus. */
void createMenuBar(); void createMenuBar();
/** Create the toolbars */
void createToolBars(); void createToolBars();
QWidget *createTabs(); /** Create system tray (notification) icon */
void createTrayIcon(); void createTrayIcon();
public slots: public slots:
/** Set number of connections shown in the UI */
void setNumConnections(int count); void setNumConnections(int count);
/** Set number of blocks shown in the UI */
void setNumBlocks(int count); void setNumBlocks(int count);
/** Set the encryption status as shown in the UI.
@param[in] status current encryption status
@see WalletModel::EncryptionStatus
*/
void setEncryptionStatus(int status); void setEncryptionStatus(int status);
/** Notify the user of an error in the network or transaction handling code. */
void error(const QString &title, const QString &message); void error(const QString &title, const QString &message);
/* It is currently not possible to pass a return value to another thread through /** Asks the user whether to pay the transaction fee or to cancel the transaction.
BlockingQueuedConnection, so use an indirected pointer. It is currently not possible to pass a return value to another thread through
BlockingQueuedConnection, so an indirected pointer is used.
http://bugreports.qt.nokia.com/browse/QTBUG-10440 http://bugreports.qt.nokia.com/browse/QTBUG-10440
@param[in] nFeeRequired the required fee
@param[out] payFee true to pay the fee, false to not pay the fee
*/ */
void askFee(qint64 nFeeRequired, bool *payFee); void askFee(qint64 nFeeRequired, bool *payFee);
private slots: private slots:
// UI pages /** Switch to overview (home) page */
void gotoOverviewPage(); void gotoOverviewPage();
/** Switch to history (transactions) page */
void gotoHistoryPage(); void gotoHistoryPage();
/** Switch to address book page */
void gotoAddressBookPage(); void gotoAddressBookPage();
/** Switch to receive coins page */
void gotoReceiveCoinsPage(); void gotoReceiveCoinsPage();
/** Switch to send coins page */
void gotoSendCoinsPage(); void gotoSendCoinsPage();
// Misc actions /** Show configuration dialog */
void optionsClicked(); void optionsClicked();
/** Show about dialog */
void aboutClicked(); void aboutClicked();
#ifndef Q_WS_MAC #ifndef Q_WS_MAC
/** Handle tray icon clicked */
void trayIconActivated(QSystemTrayIcon::ActivationReason reason); void trayIconActivated(QSystemTrayIcon::ActivationReason reason);
#endif #endif
/** Show incoming transaction notification for new transactions.
The new items are those between start and end inclusive, under the given parent item.
*/
void incomingTransaction(const QModelIndex & parent, int start, int end); void incomingTransaction(const QModelIndex & parent, int start, int end);
/** Encrypt the wallet */
void encryptWallet(bool status); void encryptWallet(bool status);
/** Change encrypted wallet passphrase */
void changePassphrase(); void changePassphrase();
/** Ask for pass phrase to unlock wallet temporarily */
void unlockWallet(); void unlockWallet();
}; };

View File

@ -4,51 +4,60 @@
#include <QString> #include <QString>
#include <QAbstractListModel> #include <QAbstractListModel>
// Bitcoin unit definitions, encapsulates parsing and formatting /** Bitcoin unit definitions. Encapsulates parsing and formatting
// and serves as list model for dropdown selection boxes. and serves as list model for dropdown selection boxes.
*/
class BitcoinUnits: public QAbstractListModel class BitcoinUnits: public QAbstractListModel
{ {
public: public:
explicit BitcoinUnits(QObject *parent); explicit BitcoinUnits(QObject *parent);
/** Bitcoin units.
@note Source: https://en.bitcoin.it/wiki/Units . Please add only sensible ones
*/
enum Unit enum Unit
{ {
// Source: https://en.bitcoin.it/wiki/Units
// Please add only sensible ones
BTC, BTC,
mBTC, mBTC,
uBTC uBTC
}; };
/// Static API //! @name Static API
// Get list of units, for dropdown box //! Unit conversion and formatting
static QList<Unit> availableUnits(); ///@{
// Is unit ID valid?
static bool valid(int unit);
// Short name
static QString name(int unit);
// Longer description
static QString description(int unit);
// Number of satoshis / unit
static qint64 factor(int unit);
// Number of amount digits (to represent max number of coins)
static int amountDigits(int unit);
// Number of decimals left
static int decimals(int unit);
// Format as string
static QString format(int unit, qint64 amount, bool plussign=false);
// Format as string (with unit)
static QString formatWithUnit(int unit, qint64 amount, bool plussign=false);
// Parse string to coin amount
static bool parse(int unit, const QString &value, qint64 *val_out);
/// AbstractListModel implementation //! Get list of units, for dropdown box
enum { static QList<Unit> availableUnits();
// Unit identifier //! Is unit ID valid?
static bool valid(int unit);
//! Short name
static QString name(int unit);
//! Longer description
static QString description(int unit);
//! Number of Satoshis (1e-8) per unit
static qint64 factor(int unit);
//! Number of amount digits (to represent max number of coins)
static int amountDigits(int unit);
//! Number of decimals left
static int decimals(int unit);
//! Format as string
static QString format(int unit, qint64 amount, bool plussign=false);
//! Format as string (with unit)
static QString formatWithUnit(int unit, qint64 amount, bool plussign=false);
//! Parse string to coin amount
static bool parse(int unit, const QString &value, qint64 *val_out);
///@}
//! @name AbstractListModel implementation
//! List model for unit dropdown selection box.
///@{
enum RoleIndex {
/** Unit identifier */
UnitRole = Qt::UserRole UnitRole = Qt::UserRole
} RoleIndex; };
int rowCount(const QModelIndex &parent) const; int rowCount(const QModelIndex &parent) const;
QVariant data(const QModelIndex &index, int role) const; QVariant data(const QModelIndex &index, int role) const;
///@}
private: private:
QList<BitcoinUnits::Unit> unitlist; QList<BitcoinUnits::Unit> unitlist;
}; };

View File

@ -12,7 +12,7 @@ QT_BEGIN_NAMESPACE
class QDateTime; class QDateTime;
QT_END_NAMESPACE QT_END_NAMESPACE
// Model for Bitcoin network client /** Model for Bitcoin network client. */
class ClientModel : public QObject class ClientModel : public QObject
{ {
Q_OBJECT Q_OBJECT
@ -27,11 +27,11 @@ public:
QDateTime getLastBlockDate() const; QDateTime getLastBlockDate() const;
// Return true if client connected to testnet //! Return true if client connected to testnet
bool isTestNet() const; bool isTestNet() const;
// Return true if core is doing initial block download //! Return true if core is doing initial block download
bool inInitialBlockDownload() const; bool inInitialBlockDownload() const;
// Return conservative estimate of total number of blocks, or 0 if unknown //! Return conservative estimate of total number of blocks, or 0 if unknown
int getNumBlocksOfPeers() const; int getNumBlocksOfPeers() const;
QString formatFullVersion() const; QString formatFullVersion() const;
@ -48,7 +48,7 @@ signals:
void numConnectionsChanged(int count); void numConnectionsChanged(int count);
void numBlocksChanged(int count); void numBlocksChanged(int count);
// Asynchronous error notification //! Asynchronous error notification
void error(const QString &title, const QString &message); void error(const QString &title, const QString &message);
public slots: public slots:

View File

@ -8,7 +8,9 @@ QT_BEGIN_NAMESPACE
class QAbstractItemModel; class QAbstractItemModel;
QT_END_NAMESPACE QT_END_NAMESPACE
// Export TableModel to CSV file /** Export a Qt table model to a CSV file. This is useful for analyzing or post-processing the data in
a spreadsheet.
*/
class CSVModelWriter : public QObject class CSVModelWriter : public QObject
{ {
Q_OBJECT Q_OBJECT
@ -18,8 +20,9 @@ public:
void setModel(const QAbstractItemModel *model); void setModel(const QAbstractItemModel *model);
void addColumn(const QString &title, int column, int role=Qt::EditRole); void addColumn(const QString &title, int column, int role=Qt::EditRole);
// Perform write operation /** Perform export of the model to CSV.
// Returns true on success, false otherwise @returns true on success, false otherwise
*/
bool write(); bool write();
private: private:

View File

@ -12,6 +12,8 @@ namespace Ui {
} }
class AddressTableModel; class AddressTableModel;
/** Dialog for editing an address and associated information.
*/
class EditAddressDialog : public QDialog class EditAddressDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT

View File

@ -12,6 +12,8 @@ class QUrl;
QT_END_NAMESPACE QT_END_NAMESPACE
class SendCoinsRecipient; class SendCoinsRecipient;
/** Static utility functions used by the Bitcoin Qt UI.
*/
class GUIUtil class GUIUtil
{ {
public: public:

View File

@ -8,6 +8,8 @@ class QIcon;
class QWidget; class QWidget;
class objc_object; class objc_object;
/** Macintosh-specific dock icon handler.
*/
class MacDockIconHandler : public QObject class MacDockIconHandler : public QObject
{ {
Q_OBJECT Q_OBJECT

View File

@ -7,9 +7,8 @@ QT_BEGIN_NAMESPACE
class QWidget; class QWidget;
QT_END_NAMESPACE QT_END_NAMESPACE
/* Data <-> Widget mapper that watches for changes, /** Data to Widget mapper that watches for edits and notifies listeners when a field is edited.
to be able to notify when 'dirty' (for example, to This can be used, for example, to enable a commit/apply button in a configuration dialog.
enable a commit/apply button).
*/ */
class MonitoredDataMapper : public QDataWidgetMapper class MonitoredDataMapper : public QDataWidgetMapper
{ {

View File

@ -11,33 +11,34 @@ class QDBusInterface;
#endif #endif
QT_END_NAMESPACE QT_END_NAMESPACE
// Cross-platform desktop notification client /** Cross-platform desktop notification client. */
class Notificator: public QObject class Notificator: public QObject
{ {
Q_OBJECT Q_OBJECT
public: public:
// Create a new notificator /** Create a new notificator.
// Ownership of trayIcon is not transferred to this object @note Ownership of trayIcon is not transferred to this object.
*/
Notificator(const QString &programName=QString(), QSystemTrayIcon *trayIcon=0, QWidget *parent=0); Notificator(const QString &programName=QString(), QSystemTrayIcon *trayIcon=0, QWidget *parent=0);
~Notificator(); ~Notificator();
// Message class // Message class
enum Class enum Class
{ {
Information, Information, /**< Informational message */
Warning, Warning, /**< Notify user of potential problem */
Critical, Critical /**< An error occured */
}; };
public slots: public slots:
/* Show notification message. /** Show notification message.
* @param[in] cls general message class
* cls: general message class @param[in] title title shown with message
* title: title shown with message @param[in] text message content
* text: message content @param[in] icon optional icon to show with message
* icon: optional icon to show with message @param[in] millisTimeout notification timeout in milliseconds (defaults to 10 seconds)
* millisTimeout: notification timeout in milliseconds (default 10 seconds) @note Platform implementations are free to ignore any of the provided fields except for \a text.
*/ */
void notify(Class cls, const QString &title, const QString &text, void notify(Class cls, const QString &title, const QString &text,
const QIcon &icon = QIcon(), int millisTimeout = 10000); const QIcon &icon = QIcon(), int millisTimeout = 10000);
@ -45,10 +46,10 @@ public slots:
private: private:
QWidget *parent; QWidget *parent;
enum Mode { enum Mode {
None, None, /**< Ignore informational notifications, and show a modal pop-up dialog for Critical notifications. */
Freedesktop, // Use DBus org.freedesktop.Notifications Freedesktop, /**< Use DBus org.freedesktop.Notifications */
QSystemTray, // Use QSystemTray::showMessage QSystemTray, /**< Use QSystemTray::showMessage */
Growl // Use the Growl notification system (Mac only) Growl /**< Use the Growl notification system (Mac only) */
}; };
QString programName; QString programName;
Mode mode; Mode mode;

View File

@ -14,6 +14,7 @@ class MainOptionsPage;
class DisplayOptionsPage; class DisplayOptionsPage;
class MonitoredDataMapper; class MonitoredDataMapper;
/** Preferences dialog. */
class OptionsDialog : public QDialog class OptionsDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT
@ -25,6 +26,7 @@ public:
signals: signals:
public slots: public slots:
/** Change the current page to \a index. */
void changePage(int index); void changePage(int index);
private slots: private slots:
@ -33,6 +35,7 @@ private slots:
void applyClicked(); void applyClicked();
void enableApply(); void enableApply();
void disableApply(); void disableApply();
private: private:
QListWidget *contents_widget; QListWidget *contents_widget;
QStackedWidget *pages_widget; QStackedWidget *pages_widget;

View File

@ -5,7 +5,7 @@
class CWallet; class CWallet;
/* Interface from QT to configuration data structure for bitcoin client. /** Interface from QT to configuration data structure for bitcoin client.
To QT, the options are presented as a list with the different options To QT, the options are presented as a list with the different options
laid out vertically. laid out vertically.
This can be changed to a tree once the settings become sufficiently This can be changed to a tree once the settings become sufficiently

View File

@ -13,6 +13,7 @@ namespace Ui {
class WalletModel; class WalletModel;
class TxViewDelegate; class TxViewDelegate;
/** Overview ("home") page widget */
class OverviewPage : public QWidget class OverviewPage : public QWidget
{ {
Q_OBJECT Q_OBJECT

View File

@ -3,8 +3,9 @@
#include <QLineEdit> #include <QLineEdit>
// Line edit that can be marked as "invalid". When marked as invalid, /** Line edit that can be marked as "invalid" to show input validation feedback. When marked as invalid,
// it will get a red background until it is focused. it will get a red background until it is focused.
*/
class QValidatedLineEdit : public QLineEdit class QValidatedLineEdit : public QLineEdit
{ {
Q_OBJECT Q_OBJECT

View File

@ -3,19 +3,18 @@
#include <QComboBox> #include <QComboBox>
// QComboBox that can be used with QDataWidgetMapper to select /* QComboBox that can be used with QDataWidgetMapper to select ordinal values from a model. */
// ordinal values from a model.
class QValueComboBox : public QComboBox class QValueComboBox : public QComboBox
{ {
Q_OBJECT Q_OBJECT
Q_PROPERTY(int value READ value WRITE setValue NOTIFY valueChanged USER true); Q_PROPERTY(int value READ value WRITE setValue NOTIFY valueChanged USER true)
public: public:
explicit QValueComboBox(QWidget *parent = 0); explicit QValueComboBox(QWidget *parent = 0);
int value() const; int value() const;
void setValue(int value); void setValue(int value);
// Model role to use as value /** Specify model role to use as ordinal value */
void setRole(int role); void setRole(int role);
signals: signals:

View File

@ -14,6 +14,7 @@ QT_BEGIN_NAMESPACE
class QUrl; class QUrl;
QT_END_NAMESPACE QT_END_NAMESPACE
/** Dialog for sending bitcoins */
class SendCoinsDialog : public QDialog class SendCoinsDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT
@ -24,8 +25,8 @@ public:
void setModel(WalletModel *model); void setModel(WalletModel *model);
// Qt messes up the tab chain by default in some cases (issue http://bugreports.qt.nokia.com/browse/QTBUG-10907) /** Set up the tab chain manually, as Qt messes up the tab chain by default in some cases (issue http://bugreports.qt.nokia.com/browse/QTBUG-10907).
// Hence we have to set it up manually */
QWidget *setupTabChain(QWidget *prev); QWidget *setupTabChain(QWidget *prev);
void pasteEntry(const SendCoinsRecipient &rv); void pasteEntry(const SendCoinsRecipient &rv);

View File

@ -9,6 +9,7 @@ namespace Ui {
class WalletModel; class WalletModel;
class SendCoinsRecipient; class SendCoinsRecipient;
/** A single entry in the dialog for sending bitcoins. */
class SendCoinsEntry : public QFrame class SendCoinsEntry : public QFrame
{ {
Q_OBJECT Q_OBJECT
@ -21,13 +22,13 @@ public:
bool validate(); bool validate();
SendCoinsRecipient getValue(); SendCoinsRecipient getValue();
// Return true if the entry is still empty and unedited /** Return whether the entry is still empty and unedited */
bool isClear(); bool isClear();
void setValue(const SendCoinsRecipient &value); void setValue(const SendCoinsRecipient &value);
// Qt messes up the tab chain by default in some cases (issue http://bugreports.qt.nokia.com/browse/QTBUG-10907) /** Set up the tab chain manually, as Qt messes up the tab chain by default in some cases (issue http://bugreports.qt.nokia.com/browse/QTBUG-10907).
// Hence we have to set it up manually */
QWidget *setupTabChain(QWidget *prev); QWidget *setupTabChain(QWidget *prev);
public slots: public slots:

View File

@ -8,11 +8,12 @@
class CWallet; class CWallet;
class CWalletTx; class CWalletTx;
/** Provide a human-readable extended HTML description of a transaction.
*/
class TransactionDesc: public QObject class TransactionDesc: public QObject
{ {
Q_OBJECT Q_OBJECT
public: public:
// Provide human-readable extended HTML description of a transaction
static QString toHTML(CWallet *wallet, CWalletTx &wtx); static QString toHTML(CWallet *wallet, CWalletTx &wtx);
private: private:
TransactionDesc() {} TransactionDesc() {}

View File

@ -10,6 +10,7 @@ QT_BEGIN_NAMESPACE
class QModelIndex; class QModelIndex;
QT_END_NAMESPACE QT_END_NAMESPACE
/** Dialog showing transaction details. */
class TransactionDescDialog : public QDialog class TransactionDescDialog : public QDialog
{ {
Q_OBJECT Q_OBJECT

View File

@ -4,29 +4,31 @@
#include <QSortFilterProxyModel> #include <QSortFilterProxyModel>
#include <QDateTime> #include <QDateTime>
// Filter transaction list according to pre-specified rules /** Filter the transaction list according to pre-specified rules. */
class TransactionFilterProxy : public QSortFilterProxyModel class TransactionFilterProxy : public QSortFilterProxyModel
{ {
Q_OBJECT Q_OBJECT
public: public:
explicit TransactionFilterProxy(QObject *parent = 0); explicit TransactionFilterProxy(QObject *parent = 0);
// Earliest date that can be represented (far in the past) /** Earliest date that can be represented (far in the past) */
static const QDateTime MIN_DATE; static const QDateTime MIN_DATE;
// Last date that can be represented (far in the future) /** Last date that can be represented (far in the future) */
static const QDateTime MAX_DATE; static const QDateTime MAX_DATE;
// Type filter bit field (all types) /** Type filter bit field (all types) */
static const quint32 ALL_TYPES = 0xFFFFFFFF; static const quint32 ALL_TYPES = 0xFFFFFFFF;
static quint32 TYPE(int type) { return 1<<type; } static quint32 TYPE(int type) { return 1<<type; }
void setDateRange(const QDateTime &from, const QDateTime &to); void setDateRange(const QDateTime &from, const QDateTime &to);
void setAddressPrefix(const QString &addrPrefix); void setAddressPrefix(const QString &addrPrefix);
// Type filter takes a bitfield created with TYPE() or ALL_TYPES /**
@note Type filter takes a bitfield created with TYPE() or ALL_TYPES
*/
void setTypeFilter(quint32 modes); void setTypeFilter(quint32 modes);
void setMinAmount(qint64 minimum); void setMinAmount(qint64 minimum);
// Set maximum number of rows returned, -1 if unlimited /** Set maximum number of rows returned, -1 if unlimited. */
void setLimit(int limit); void setLimit(int limit);
int rowCount(const QModelIndex &parent = QModelIndex()) const; int rowCount(const QModelIndex &parent = QModelIndex()) const;

View File

@ -8,6 +8,8 @@
class CWallet; class CWallet;
class CWalletTx; class CWalletTx;
/** UI model for transaction status. The transaction status is the part of a transaction that will change over time.
*/
class TransactionStatus class TransactionStatus
{ {
public: public:
@ -20,7 +22,7 @@ public:
{ {
Immature, Immature,
Mature, Mature,
MaturesWarning, /* Will likely not mature because no nodes have confirmed */ MaturesWarning, /**< Transaction will likely not mature because no nodes have confirmed */
NotAccepted NotAccepted
}; };
@ -35,19 +37,26 @@ public:
bool confirmed; bool confirmed;
std::string sortKey; std::string sortKey;
/* For "Generated" transactions */ /** @name Generated (mined) transactions
@{*/
Maturity maturity; Maturity maturity;
int matures_in; int matures_in;
/**@}*/
/* Reported status */ /** @name Reported status
@{*/
Status status; Status status;
int64 depth; int64 depth;
int64 open_for; /* Timestamp if status==OpenUntilDate, otherwise number of blocks */ int64 open_for; /**< Timestamp if status==OpenUntilDate, otherwise number of blocks */
/**@}*/
/* Current number of blocks (to know whether cached status is still valid. */ /** Current number of blocks (to know whether cached status is still valid) */
int cur_num_blocks; int cur_num_blocks;
}; };
/** UI model for a transaction. A core transaction can be represented by multiple UI transactions if it has
multiple outputs.
*/
class TransactionRecord class TransactionRecord
{ {
public: public:
@ -62,7 +71,7 @@ public:
SendToSelf SendToSelf
}; };
/* Number of confirmation needed for transaction */ /** Number of confirmation needed for transaction */
static const int NumConfirmations = 6; static const int NumConfirmations = 6;
TransactionRecord(): TransactionRecord():
@ -84,33 +93,35 @@ public:
{ {
} }
/* Decompose CWallet transaction to model transaction records. /** Decompose CWallet transaction to model transaction records.
*/ */
static bool showTransaction(const CWalletTx &wtx); static bool showTransaction(const CWalletTx &wtx);
static QList<TransactionRecord> decomposeTransaction(const CWallet *wallet, const CWalletTx &wtx); static QList<TransactionRecord> decomposeTransaction(const CWallet *wallet, const CWalletTx &wtx);
/* Fixed */ /** @name Immutable transaction attributes
@{*/
uint256 hash; uint256 hash;
int64 time; int64 time;
Type type; Type type;
std::string address; std::string address;
int64 debit; int64 debit;
int64 credit; int64 credit;
/**@}*/
/* Subtransaction index, for sort key */ /** Subtransaction index, for sort key */
int idx; int idx;
/* Status: can change with block chain update */ /** Status: can change with block chain update */
TransactionStatus status; TransactionStatus status;
/* Return the unique identifier for this transaction (part) */ /** Return the unique identifier for this transaction (part) */
std::string getTxID(); std::string getTxID();
/* Update status from wallet tx. /** Update status from core wallet tx.
*/ */
void updateStatus(const CWalletTx &wtx); void updateStatus(const CWalletTx &wtx);
/* Is a status update needed? /** Return whether a status update is needed.
*/ */
bool statusUpdateNeeded(); bool statusUpdateNeeded();
}; };

View File

@ -9,6 +9,8 @@ class TransactionTablePriv;
class TransactionRecord; class TransactionRecord;
class WalletModel; class WalletModel;
/** UI model for the transaction table of a wallet.
*/
class TransactionTableModel : public QAbstractTableModel class TransactionTableModel : public QAbstractTableModel
{ {
Q_OBJECT Q_OBJECT
@ -16,36 +18,37 @@ public:
explicit TransactionTableModel(CWallet* wallet, WalletModel *parent = 0); explicit TransactionTableModel(CWallet* wallet, WalletModel *parent = 0);
~TransactionTableModel(); ~TransactionTableModel();
enum { enum ColumnIndex {
Status = 0, Status = 0,
Date = 1, Date = 1,
Type = 2, Type = 2,
ToAddress = 3, ToAddress = 3,
Amount = 4 Amount = 4
} ColumnIndex; };
// Roles to get specific information from a transaction row /** Roles to get specific information from a transaction row.
// These are independent of column These are independent of column.
enum { */
// Type of transaction enum RoleIndex {
/** Type of transaction */
TypeRole = Qt::UserRole, TypeRole = Qt::UserRole,
// Date and time this transaction was created /** Date and time this transaction was created */
DateRole, DateRole,
// Long description (HTML format) /** Long description (HTML format) */
LongDescriptionRole, LongDescriptionRole,
// Address of transaction /** Address of transaction */
AddressRole, AddressRole,
// Label of address related to transaction /** Label of address related to transaction */
LabelRole, LabelRole,
// Net amount of transaction /** Net amount of transaction */
AmountRole, AmountRole,
// Unique identifier /** Unique identifier */
TxIDRole, TxIDRole,
// Is transaction confirmed? /** Is transaction confirmed? */
ConfirmedRole, ConfirmedRole,
// Formatted amount, without brackets when unconfirmed /** Formatted amount, without brackets when unconfirmed */
FormattedAmountRole FormattedAmountRole
} RoleIndex; };
int rowCount(const QModelIndex &parent) const; int rowCount(const QModelIndex &parent) const;
int columnCount(const QModelIndex &parent) const; int columnCount(const QModelIndex &parent) const;

View File

@ -16,6 +16,9 @@ class QFrame;
class QDateTimeEdit; class QDateTimeEdit;
QT_END_NAMESPACE QT_END_NAMESPACE
/** Widget showing the transaction list for a wallet, including a filter row.
Using the filter row, the user can view or export a subset of the transactions.
*/
class TransactionView : public QWidget class TransactionView : public QWidget
{ {
Q_OBJECT Q_OBJECT

View File

@ -16,7 +16,7 @@ struct SendCoinsRecipient
qint64 amount; qint64 amount;
}; };
// Interface to Bitcoin wallet from Qt view code /** Interface to Bitcoin wallet from Qt view code. */
class WalletModel : public QObject class WalletModel : public QObject
{ {
Q_OBJECT Q_OBJECT