0
0
Fork 0
mirror of https://github.com/bitcoin/bitcoin.git synced 2025-03-11 15:56:58 -04:00
bitcoin-core/src/qt
Samuel Dobson 99ab3a72c5
Merge #15931: Remove GetDepthInMainChain dependency on locked chain interface
36b68de5b2 Remove getBlockDepth method from Chain::interface (Antoine Riard)
b66c429c56 Remove locked_chain from GetDepthInMainChain and its callers (Antoine Riard)
0ff03871ad Use CWallet::m_last_block_processed_height in GetDepthInMainChain (Antoine Riard)
f77b1de16f Only return early from BlockUntilSyncedToCurrentChain if current tip is exact match (Antoine Riard)
769ff05e48 Refactor some importprunedfunds checks with guard clause (Antoine Riard)
5971d3848e Add block_height field in struct Confirmation (Antoine Riard)
9700fcb47f Replace CWalletTx::SetConf by Confirmation initialization list (Antoine Riard)
5aacc3eff1 Add m_last_block_processed_height field in CWallet (Antoine Riard)
10b4729e33 Pass block height in Chain::BlockConnected/Chain::BlockDisconnected (Antoine Riard)

Pull request description:

  Work starter to remove Chain::Lock interface by adding m_last_block_processed_height in CWallet and m_block_height in CMerkleTx to avoid GetDepthInMainChain having to keep a lock . Once this one done, it should ease work to wipe out more cs_main locks from wallet code.

  I think it's ready for a first round of review before to get further.

  - `BlockUntilSyncedToCurrent` : restrain isPotentialTip to isTip because we want to be sure that wallet see BlockDisconnected callbacks if its height differs from the Chain one. It means during a reorg, an RPC could return before the BlockDisconnected callback had been triggered. This could cause a tx that had been included in the disconnected block to be displayed as confirmed, for example.

  ~~- `AbandonTransaction` : in case of conflicted tx (nIndex = -1), we set its m_block_height to the one of conflicting blocks, but if this height is superior to CWallet::m_last_block_processed_height, that means tx isn't conflicted anymore so we return 0 as tx is again unconfirmed~~ After #16624, we instead rely on Confirmation.

  ~~- `AddToWalletIfInvolvingMe`: in case of block disconnected, transactions are added to mempool again, so we need to replace old txn in `mapWallet` with a height set to zero so we remove check on block_hash.IsNull~~ Already done in #16624

ACKs for top commit:
  jnewbery:
    @jkczyz you've ACKed an intermediate commit (github annoyingly orders commits in date order, not commit order). Did you mean to ACK the final commit in this branch (36b68de5b2).
  jkczyz:
    > @jkczyz you've ACKed an intermediate commit (github annoyingly orders commits in date order, not commit order). Did you mean to ACK the final commit in this branch ([36b68de](36b68de5b2)).
  meshcollider:
    utACK 36b68de5b2
  ryanofsky:
    Code review ACK 36b68de5b2. Changes since last review: new jkczyz refactor importprunedfunds commit, changed BlockUntilSyncedToCurrentChainChanges commit title and description, changed Confirmation struct field order and line-wrapped comment
  jnewbery:
    utACK 36b68de5b2
  promag:
    Code review ACK 36b68de5b2.

Tree-SHA512: 08b89a0bcc39f67c82a6cb6aee195e6a11697770c788ba737b90986b4893f44e90d1ab9ef87239ea3766508b7e24ea882b7199df41173ab27a3d000328c14644
2019-11-08 23:23:14 +13:00
..
forms Merge #17360: gui: Improve "Hide" button tool-tip message 2019-11-05 20:42:37 +01:00
locale qt: Periodic translations update 2019-09-30 09:41:11 +02:00
res qt: Remove menu icons 2019-08-15 13:05:10 +02:00
test Merge #15931: Remove GetDepthInMainChain dependency on locked chain interface 2019-11-08 23:23:14 +13:00
addressbookpage.cpp Make reasoning about dependencies easier by not including unused dependencies 2019-06-02 17:15:23 +02:00
addressbookpage.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
addresstablemodel.cpp refactor: replace qLowerBound & qUpperBound with std:: upper_bound & lower_bound 2019-08-22 13:43:47 +08:00
addresstablemodel.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
askpassphrasedialog.cpp gui: fix passphrase labels/tooltip in createwalletdialog/askpassphrasedialog 2019-09-09 10:57:38 +02:00
askpassphrasedialog.h Optionally allow AskPassphraseDialog to output the passphrase 2019-09-05 20:36:57 -04:00
bantablemodel.cpp refactor: Remove addrdb.h dependency from node.h 2019-10-29 11:30:12 +02:00
bantablemodel.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
bitcoin.cpp doc: Fix some misspellings 2019-11-04 04:22:53 -05:00
bitcoin.h [gui] add explicit prune setter 2019-08-24 22:36:11 +02:00
bitcoin.qrc qt: Remove menu icons 2019-08-15 13:05:10 +02:00
bitcoin_locale.qrc qt: Periodic translations update 2019-09-30 09:41:11 +02:00
bitcoinaddressvalidator.cpp Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
bitcoinaddressvalidator.h
bitcoinamountfield.cpp Send amount shows minimum amount placeholder 2019-10-19 13:46:59 +01:00
bitcoinamountfield.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
bitcoingui.cpp gui: remove payment request file handling from OpenURI dialog 2019-10-24 16:01:43 -04:00
bitcoingui.h Add Create Wallet menu action 2019-09-05 20:36:57 -04:00
bitcoinstrings.cpp qt: Run "make translate" in ./src 2019-09-16 09:45:11 -04:00
bitcoinunits.cpp Make reasoning about dependencies easier by not including unused dependencies 2019-06-02 17:15:23 +02:00
bitcoinunits.h Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
clientmodel.cpp gui: Make polling in ClientModel asynchronous 2019-10-25 14:53:37 +01:00
clientmodel.h gui: Make polling in ClientModel asynchronous 2019-10-25 14:53:37 +01:00
coincontroldialog.cpp Remove unused includes 2019-10-15 22:56:43 +00:00
coincontroldialog.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
coincontroltreewidget.cpp Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
coincontroltreewidget.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
createwalletdialog.cpp gui: rename encrypt(), blank(), and askPasshprase() 2019-09-09 10:56:38 +02:00
createwalletdialog.h gui: rename encrypt(), blank(), and askPasshprase() 2019-09-09 10:56:38 +02:00
csvmodelwriter.cpp Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
csvmodelwriter.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
editaddressdialog.cpp Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
editaddressdialog.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
guiconstants.h Expose wallet creation to the GUI via WalletController 2019-09-05 20:36:57 -04:00
guiutil.cpp Testchains: Generic selection with -chain=<str> in addition of -testnet and -regtest 2019-09-06 22:05:33 +02:00
guiutil.h qt: Add TextWidth() wrapper 2019-08-23 21:27:50 +03:00
intro.cpp qt: Change default size of intro frame 2019-09-26 21:50:12 +02:00
intro.h [gui] intro: add prune preference 2019-08-24 22:41:32 +02:00
macdockiconhandler.h Remove obj_c for macOS Dock icon menu 2018-11-04 02:42:18 +02:00
macdockiconhandler.mm qt: Replace objc_msgSend with native syntax 2019-08-31 12:25:34 +03:00
macnotificationhandler.h convert C-style (void) parameter lists to C++ style () 2018-09-13 10:36:41 -07:00
macnotificationhandler.mm Refactoring with QString::toNSString 2018-12-16 20:29:56 +02:00
macos_appnap.h macOS: disable AppNap during sync 2018-11-01 18:22:06 +03:00
macos_appnap.mm macOS: disable AppNap during sync 2018-11-01 18:22:06 +03:00
main.cpp Refactor out translation.h 2019-07-24 16:32:53 +03:00
Makefile
modaloverlay.cpp Merge #15084: gui: don't disable the sync overlay when wallet is disabled 2019-10-18 09:15:20 +02:00
modaloverlay.h Merge #15084: gui: don't disable the sync overlay when wallet is disabled 2019-10-18 09:15:20 +02:00
networkstyle.cpp Testchains: Qt: Simplify network/chain styles 2019-09-06 22:13:49 +02:00
networkstyle.h doc: Remove explicit network name references 2019-11-01 12:06:35 +01:00
notificator.cpp Remove misplaced Q_UNUSED and others enhancements 2018-12-20 01:06:37 +02:00
notificator.h Remove misplaced Q_UNUSED and others enhancements 2018-12-20 01:06:37 +02:00
openuridialog.cpp gui: remove payment request file handling from OpenURI dialog 2019-10-24 16:01:43 -04:00
openuridialog.h gui: remove payment request file handling from OpenURI dialog 2019-10-24 16:01:43 -04:00
optionsdialog.cpp scripted-diff: Avoid passing PACKAGE_NAME for translation 2019-06-26 11:01:57 -04:00
optionsdialog.h Merge #13248: [gui] Make proxy icon from statusbar clickable 2018-08-20 13:40:11 +02:00
optionsmodel.cpp Remove BIP70 Support 2019-10-24 16:01:43 -04:00
optionsmodel.h Remove BIP70 Support 2019-10-24 16:01:43 -04:00
overviewpage.cpp Merge #14879: qt: Add warning messages to the debug window 2019-08-28 16:03:09 -04:00
overviewpage.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
paymentserver.cpp gui: Update BIP70 support message 2019-10-24 16:01:43 -04:00
paymentserver.h Remove BIP70 Support 2019-10-24 16:01:43 -04:00
peertablemodel.cpp Remove unused includes 2019-10-15 22:56:43 +00:00
peertablemodel.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
platformstyle.cpp gui: remove unused PlatformStyle::TextColorIcon 2019-08-22 14:50:29 +08:00
platformstyle.h gui: remove unused PlatformStyle::TextColorIcon 2019-08-22 14:50:29 +08:00
qrimagewidget.cpp gui: disable font antialiasing for QR image address 2019-10-25 13:20:32 -04:00
qrimagewidget.h GUI: Move QRImageWidget to its own file-pair 2019-05-02 12:18:18 +00:00
qvalidatedlineedit.cpp Replace remaining 0 with nullptr in Qt code 2019-01-13 03:25:14 -08:00
qvalidatedlineedit.h Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
qvaluecombobox.cpp qt: Use new Qt5 connect syntax 2018-08-21 09:43:54 +01:00
qvaluecombobox.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
README.md Remove BIP70 Support 2019-10-24 16:01:43 -04:00
receivecoinsdialog.cpp Revert "gui: Generate bech32 addresses by default (take 2, fixup)" 2019-09-26 16:23:32 -04:00
receivecoinsdialog.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
receiverequestdialog.cpp Make reasoning about dependencies easier by not including unused dependencies 2019-06-02 17:15:23 +02:00
receiverequestdialog.h GUI: Move QRImageWidget to its own file-pair 2019-05-02 12:18:18 +00:00
recentrequeststablemodel.cpp refactor: replace qSort with std::sort 2019-08-22 13:42:44 +08:00
recentrequeststablemodel.h qt: Remove obsolete QModelIndex::child() 2019-08-25 08:16:14 +03:00
rpcconsole.cpp gui: Make RPCConsole::TabTypes an enum class 2019-10-15 13:46:34 +01:00
rpcconsole.h gui: Make RPCConsole::TabTypes an enum class 2019-10-15 13:46:34 +01:00
sendcoinsdialog.cpp Remove BIP70 Support 2019-10-24 16:01:43 -04:00
sendcoinsdialog.h Make SendConfirmationDialog fully fledged 2019-04-24 21:56:10 +03:00
sendcoinsentry.cpp Remove BIP70 Support 2019-10-24 16:01:43 -04:00
sendcoinsentry.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
signverifymessagedialog.cpp Remove unused includes 2019-10-15 22:56:43 +00:00
signverifymessagedialog.h
splashscreen.cpp Remove unused includes 2019-10-15 22:56:43 +00:00
splashscreen.h Cleanup SplashScreen class 2018-12-02 01:26:28 +02:00
trafficgraphwidget.cpp Add antialiasing to traffic graph widget 2019-07-02 07:26:40 +02:00
trafficgraphwidget.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
transactiondesc.cpp Remove BIP70 Support 2019-10-24 16:01:43 -04:00
transactiondesc.h Remove unused adjustedTime parameter 2018-10-28 09:04:10 +02:00
transactiondescdialog.cpp Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
transactiondescdialog.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
transactionfilterproxy.cpp Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
transactionfilterproxy.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
transactionrecord.cpp Merge #15098: qt: Show addresses for "SendToSelf" transactions 2019-10-09 14:35:29 -04:00
transactionrecord.h Don't label transactions "Open" while catching up 2019-01-03 00:10:24 +02:00
transactiontablemodel.cpp Merge #15098: qt: Show addresses for "SendToSelf" transactions 2019-10-09 14:35:29 -04:00
transactiontablemodel.h Don't use zero as null pointer constant (-Wzero-as-null-pointer-constant) 2019-01-13 03:25:14 -08:00
transactionview.cpp qt: Remove QSignalMapper from TransactionView 2019-08-25 09:12:38 +03:00
transactionview.h qt: Remove QSignalMapper from TransactionView 2019-08-25 09:12:38 +03:00
utilitydialog.cpp Remove BIP70 Support 2019-10-24 16:01:43 -04:00
utilitydialog.h Replace remaining 0 with nullptr in Qt code 2019-01-13 03:25:14 -08:00
walletcontroller.cpp Merge #17120: gui: Fix start timer from non QThread 2019-10-26 13:00:16 +02:00
walletcontroller.h wallet: Avoid showing GUI popups on RPC errors 2019-10-08 13:02:14 -04:00
walletframe.cpp Remove unused includes 2019-10-15 22:56:43 +00:00
walletframe.h gui: Drop unused return values in WalletFrame 2019-02-22 16:26:09 +00:00
walletmodel.cpp Merge #17120: gui: Fix start timer from non QThread 2019-10-26 13:00:16 +02:00
walletmodel.h wallet: Remove left-over BIP70 comment 2019-10-29 17:53:46 +01:00
walletmodeltransaction.cpp Remove BIP70 Support 2019-10-24 16:01:43 -04:00
walletmodeltransaction.h Remove unused includes 2019-10-15 22:56:43 +00:00
walletview.cpp HTML escape address labels in more dialogs and notifications 2019-09-08 16:40:37 -04:00
walletview.h Update copyright headers to 2018 2018-07-27 07:15:02 -04:00
winshutdownmonitor.cpp gui: remove OpenSSL PRNG seeding (Windows, Qt only) 2019-10-15 09:48:50 -04:00
winshutdownmonitor.h Update copyright headers to 2018 2018-07-27 07:15:02 -04:00

This directory contains the BitcoinQT graphical user interface (GUI). It uses the cross-platform framework Qt.

The current precise version for Qt 5 is specified in qt.mk.

Compile and run

See build instructions (macOS, Windows, Unix, etc).

To run:

./src/qt/bitcoin-qt

Files and directories

forms

Contains Designer UI files. They are created with Qt Creator, but can be edited using any text editor.

locale

Contains translations. They are periodically updated. The process is described here.

res

Resources such as the icon.

test

Tests.

bitcoingui.(h/cpp)

Represents the main window of the Bitcoin UI.

*model.(h/cpp)

The model. When it has a corresponding controller, it generally inherits from QAbstractTableModel. Models that are used by controllers as helpers inherit from other Qt classes like QValidator.

ClientModel is used by the main application bitcoingui and several models like peertablemodel.

*page.(h/cpp)

A controller. :NAMEpage.cpp generally includes :NAMEmodel.h and forms/:NAME.page.ui with a similar :NAME.

*dialog.(h/cpp)

Various dialogs, e.g. to open a URL. Inherit from QDialog.

paymentserver.(h/cpp)

Used to process BIP21 payment URI requests. Also handles URI based application switching (e.g. when following a bitcoin:... link from a browser).

walletview.(h/cpp)

Represents the view to a single wallet.

Other .h/cpp files

  • UI elements like BitcoinAmountField, which inherit from QWidget.
  • bitcoinstrings.cpp: automatically generated
  • bitcoinunits.(h/cpp): BTC / mBTC / etc handling
  • callback.h
  • guiconstants.h: UI colors, app name, etc
  • guiutil.h: several helper functions
  • macdockiconhandler.(h/mm): macOS dock icon handler
  • macnotificationhandler.(h/mm): display notifications in macOS

Contribute

See CONTRIBUTING.md for general guidelines. Specifically for Qt:

Using Qt Creator as IDE

You can use Qt Creator as an IDE. This is especially useful if you want to change the UI layout.

Download and install the community edition of Qt Creator. Uncheck everything except Qt Creator during the installation process.

Instructions for macOS:

  1. Make sure you installed everything through Homebrew mentioned in the macOS build instructions
  2. Use ./configure with the --enable-debug flag
  3. In Qt Creator do "New Project" -> Import Project -> Import Existing Project
  4. Enter "bitcoin-qt" as project name, enter src/qt as location
  5. Leave the file selection as it is
  6. Confirm the "summary page"
  7. In the "Projects" tab select "Manage Kits..."
  8. Select the default "Desktop" kit and select "Clang (x86 64bit in /usr/bin)" as compiler
  9. Select LLDB as debugger (you might need to set the path to your installation)
  10. Start debugging with Qt Creator (you might need to the executable to "bitcoin-qt" under "Run", which is where you can also add command line arguments)