Skip to content

Conversation

@ryanofsky
Copy link
Contributor

@ryanofsky ryanofsky commented May 20, 2022

With #602, if proxy and pruning settings are disabled in the GUI and the GUI is restarted, proxy and prune values are not stored anywhere. So if these settings are enabled in the future, default values will be shown, not previous values.

This PR stores previous values so they will preserved across restarts. I'm not sure I like this behavior because showing default values seems simpler and safer to me. Previous values may just have been set temporarily and may have never actually worked, and it adds some code complexity to store them.

This PR is one way of resolving #596. Other solutions are possible and could be implemented as alternatives.

@Rspigler
Copy link
Contributor

Concept ACK, since users can reset settings. Will test soon

@DrahtBot
Copy link
Contributor

DrahtBot commented May 21, 2022

The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.

Conflicts

No conflicts as of last run.

@Rspigler
Copy link
Contributor

tACK c2051b3

Works just as described, I think it's really smooth. I think this is a good solution, but open to hearing more opinions obviously.

@Rspigler
Copy link
Contributor

make check error:

FAIL: qt/test/test_bitcoin-qt

test-suite.log:

FAIL: qt/test/test_bitcoin-qt

********* Start testing of AppTests *********
Config: Using QtTest library 5.15.2, Qt 5.15.2 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 10.2.1 20210110), debian 11
PASS : AppTests::initTestCase()
QINFO : AppTests::appTests() Backing up GUI settings to "/tmp/test_common_Bitcoin Core/81926fa71dbc85c864c7dcdacb11a038f304fc445d63880f3579c457bffc9b87/regtest/guisettings.ini.bak"
QDEBUG : AppTests::appTests() requestInitialize : Requesting initialize
QDEBUG : AppTests::appTests() Running initialization in thread
QDEBUG : AppTests::appTests() initializeResult : Initialization result: true
QINFO : AppTests::appTests() Platform customization: "other"
QWARN : AppTests::appTests() This plugin does not support propagateSizeHints()
QWARN : AppTests::appTests() This plugin does not support propagateSizeHints()
QWARN : AppTests::appTests() This plugin does not support raise()
QWARN : AppTests::appTests() This plugin does not support raise()
QWARN : AppTests::appTests() This plugin does not support grabbing the keyboard
QWARN : AppTests::appTests() This plugin does not support propagateSizeHints()
QDEBUG : AppTests::appTests() requestShutdown : Requesting shutdown
QDEBUG : AppTests::appTests() Running Shutdown in thread
QDEBUG : AppTests::appTests() Shutdown finished
PASS : AppTests::appTests()
PASS : AppTests::cleanupTestCase()
Totals: 3 passed, 0 failed, 0 skipped, 0 blacklisted, 554ms
********* Finished testing of AppTests *********
********* Start testing of OptionTests *********
Config: Using QtTest library 5.15.2, Qt 5.15.2 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 10.2.1 20210110), debian 11
PASS : OptionTests::initTestCase()
FAIL! : OptionTests::migrateSettings() Compared strings are not the same
Actual (std::string(std::istreambuf_iterator(file), std::istreambuf_iterator()).c_str()) : {
"dbcache": "600",
"listen": false,
"onion": "onion:234",
"onion-prev": "",
"par": "12",
"proxy": "proxy:123",
"proxy-prev": "",
"prune": "2861",
"prune-prev": "0"
}

Expected ("{\n" " "dbcache": "600",\n" " "listen": false,\n" " "onion": "onion:234",\n" " "par": "12",\n" " "proxy": "proxy:123",\n" " "prune": "2861"\n" "}\n"): {
"dbcache": "600",
"listen": false,
"onion": "onion:234",
"par": "12",
"proxy": "proxy:123",
"prune": "2861"
}

Loc: [qt/test/optiontests.cpp(64)]
PASS : OptionTests::integerGetArgBug()
PASS : OptionTests::parametersInteraction()
PASS : OptionTests::cleanupTestCase()
Totals: 4 passed, 1 failed, 0 skipped, 0 blacklisted, 207ms
********* Finished testing of OptionTests *********
********* Start testing of URITests *********
Config: Using QtTest library 5.15.2, Qt 5.15.2 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 10.2.1 20210110), debian 11
PASS : URITests::initTestCase()
PASS : URITests::uriTests()
PASS : URITests::cleanupTestCase()
Totals: 3 passed, 0 failed, 0 skipped, 0 blacklisted, 0ms
********* Finished testing of URITests *********
********* Start testing of RPCNestedTests *********
Config: Using QtTest library 5.15.2, Qt 5.15.2 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 10.2.1 20210110), debian 11
PASS : RPCNestedTests::initTestCase()
PASS : RPCNestedTests::rpcNestedTests()
PASS : RPCNestedTests::cleanupTestCase()
Totals: 3 passed, 0 failed, 0 skipped, 0 blacklisted, 10ms
********* Finished testing of RPCNestedTests *********
********* Start testing of WalletTests *********
Config: Using QtTest library 5.15.2, Qt 5.15.2 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 10.2.1 20210110), debian 11
PASS : WalletTests::initTestCase()
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: 44c8b7988d51de5198858b0c8cfa504d3a8de71acda23506c45b8dc47e84373e status= 0"
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: ec76e4ab5ae7066ba51a42c5e09a79adaf9708a4a3cdbd02a28d378179f3024e status= 1"
QDEBUG : WalletTests::walletTests() "NotifyAddressBookChanged: mfWxJ45yp2SFn7UciZyNpvDKrzbhyfKrY8 isMine=0 purpose=send status=0"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: 44c8b7988d51de5198858b0c8cfa504d3a8de71acda23506c45b8dc47e84373e 0"
QDEBUG : WalletTests::walletTests() " inModel=0 Index=20-20 showTransaction=1 derivedStatus=0"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: ec76e4ab5ae7066ba51a42c5e09a79adaf9708a4a3cdbd02a28d378179f3024e 1"
QDEBUG : WalletTests::walletTests() " inModel=1 Index=27-28 showTransaction=1 derivedStatus=1"
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: 8f3bc8d976966056ec5597ee811f35df382dd48cb7bae427802e2849bd72bc74 status= 0"
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: 20bb379fd28f090730ac2d207b92c6e95c69dfa48a8118577edb20e068c9a65d status= 1"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: 8f3bc8d976966056ec5597ee811f35df382dd48cb7bae427802e2849bd72bc74 0"
QDEBUG : WalletTests::walletTests() " inModel=0 Index=43-43 showTransaction=1 derivedStatus=0"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: 20bb379fd28f090730ac2d207b92c6e95c69dfa48a8118577edb20e068c9a65d 1"
QDEBUG : WalletTests::walletTests() " inModel=1 Index=34-35 showTransaction=1 derivedStatus=1"
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: c396007f84cb9643a1030708dcc0b9ad2a03bda49a87762f29a1b48d639a153a status= 0"
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: 20bb379fd28f090730ac2d207b92c6e95c69dfa48a8118577edb20e068c9a65d status= 1"
QDEBUG : WalletTests::walletTests() "NotifyTransactionChanged: 8f3bc8d976966056ec5597ee811f35df382dd48cb7bae427802e2849bd72bc74 status= 1"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: 8f3bc8d976966056ec5597ee811f35df382dd48cb7bae427802e2849bd72bc74 1"
QDEBUG : WalletTests::walletTests() " inModel=1 Index=43-44 showTransaction=1 derivedStatus=1"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: c396007f84cb9643a1030708dcc0b9ad2a03bda49a87762f29a1b48d639a153a 0"
QDEBUG : WalletTests::walletTests() " inModel=0 Index=19-19 showTransaction=1 derivedStatus=0"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: 20bb379fd28f090730ac2d207b92c6e95c69dfa48a8118577edb20e068c9a65d 1"
QDEBUG : WalletTests::walletTests() " inModel=1 Index=35-36 showTransaction=1 derivedStatus=1"
QDEBUG : WalletTests::walletTests() "TransactionTablePriv::updateWallet: 8f3bc8d976966056ec5597ee811f35df382dd48cb7bae427802e2849bd72bc74 1"
QDEBUG : WalletTests::walletTests() " inModel=1 Index=44-45 showTransaction=1 derivedStatus=1"
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
QDEBUG : WalletTests::walletTests() "NotifyAddressBookChanged: bcrt1q6r5w50cgdqknd6dpxyxk8legnkxy5scygqem4t TEST_LABEL_1 isMine=1 purpose=receive status=0"
QWARN : WalletTests::walletTests() This plugin does not support propagateSizeHints()
PASS : WalletTests::walletTests()
PASS : WalletTests::cleanupTestCase()
Totals: 3 passed, 0 failed, 0 skipped, 0 blacklisted, 707ms
********* Finished testing of WalletTests *********
********* Start testing of AddressBookTests *********
Config: Using QtTest library 5.15.2, Qt 5.15.2 (x86_64-little_endian-lp64 shared (dynamic) release build; by GCC 10.2.1 20210110), debian 11
PASS : AddressBookTests::initTestCase()
QWARN : AddressBookTests::addressBookTests() This plugin does not support propagateSizeHints()
QWARN : AddressBookTests::addressBookTests() This plugin does not support propagateSizeHints()
QDEBUG : AddressBookTests::addressBookTests() "NotifyAddressBookChanged: bcrt1q6m4jcjapjw9zrfv0a60f5qfkupfv4ayu4l0w2h new isMine=0 purpose=send status=0"
PASS : AddressBookTests::addressBookTests()
PASS : AddressBookTests::cleanupTestCase()
Totals: 3 passed, 0 failed, 0 skipped, 0 blacklisted, 603ms
********* Finished testing of AddressBookTests *********

Failed tests: 1

~InitExecutor : Stopping thread
~InitExecutor : Stopped thread
FAIL qt/test/test_bitcoin-qt (exit status: 1)

Functional and util tests pass.

@ryanofsky
Copy link
Contributor Author

make check error:

Yes this happens on cirrus and locally too because actually enabling proxy/prune/onion settings sets the -prev settings to "" instead of removing them from the file. I could just update optionstest to reflect this, but I think it would be a little nicer to delete the -prev settings when the real settings are active, so will work on this when I update the PR.

@hebasto
Copy link
Member

hebasto commented Jun 12, 2022

This is based on #15936 + #600 + #601 + #602.

Time to undraft and rebase?
:)

Maybe also clean up the PR description a bit?

This provides a way for the GUI settings dialog box to retain previous pruning
and proxy settings when they are disabled, as requested by vasild:

bitcoin/bitcoin#15936 (review)
bitcoin/bitcoin#15936 (comment)
bitcoin/bitcoin#15936 (comment)

Importantly, while this PR changes the settings.json format, it changes it in a
fully backwards compatible way, so previous versious of bitcoind and bitcoin-qt
will correctly interpret prune, proxy, and onion settins written by new
versions of bitcoin-qt.
@ryanofsky ryanofsky marked this pull request as ready for review September 21, 2022 16:18
@ryanofsky
Copy link
Contributor Author

Time to undraft and rebase? :)

Done!

Rebased c2051b3 -> 9d3127b (pr/qtkeep.3 -> pr/qtkeep.4, compare) after base PR #602 merge

@ryanofsky
Copy link
Contributor Author

I think it would be a little nicer to delete the -prev settings when the real settings are active, so will work on this when I update the PR.

This was also implemented in the last push

Copy link
Member

@hebasto hebasto left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK 9d3127b, tested on Ubuntu 22.04.

Although, #596 (comment).

@hebasto
Copy link
Member

hebasto commented Oct 26, 2022

cc @vasild @Sjors @jarolrod

@ryanofsky
Copy link
Contributor Author

re: #596 (comment)

While reviewing #603, I've made an opinion that

Other approaches like storing unused prune and proxy settings in QSettings

looks nicer, as all those settings are GUI-specific.

If others agree, I can probably change the PR pretty easily to do this. Just replace new std::string suffix parameters with bool inactive parameters, pass true instead of "-prev", and false instead of "". When inactive is true, store the setting to QSettings with "-prev" suffix. When inactive is false, store the setting normally to settings.json.

@hebasto hebasto added the UX All about "how to get things done" label Oct 26, 2022
@vasild
Copy link
Contributor

vasild commented Nov 2, 2022

Makes sense to me.

nit: maybe use "active" instead of "inactive" to avoid double negation "inactive=false" aka "is not non-active".

Copy link
Contributor

@vasild vasild left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK 9d3127b

Would be nice to have this in 24.0 to avoid changing user behavior from 23->24 (and to restore it in 24->25).

Would be happy to re-review if changed like discussed in: #603 (comment)

@hebasto
Copy link
Member

hebasto commented Nov 15, 2022

Would be happy to re-review if changed like discussed in: #603 (comment)

So would I :)

@ryanofsky
Copy link
Contributor Author

Would be happy to re-review if changed like discussed in: #603 (comment)

So would I :)

I started working on this, but I think I changed my mind about this alternate approach and now prefer the current approach.

I don't think storing enabled settings in settings.json but storing disabled settings in QSettings is a good idea, because the idea of storing disabled settings is not really inherently GUI specific. Storing disabled settings could be useful for the RPC interface as well. Actually one of the original reasons for introducing settings.json was to allow runtime configuration via RPC, and I still think an interface like:

bitcoin-cli settings set prune 3G
bitcoin-cli settings disable prune
bitcoin-cli settings enable prune
bitcoin-cli settings set proxy 127.0.0.1:9050
bitcoin-cli settings disable proxy
bitcoin-cli settings enable proxy

could be a good idea, and if implemented should use same disabled settings storage that the GUI uses, making settings.json a more appropriate place than QSettings.

In light of this it would probably be better to move disabled settings logic down into the common or util layers instead of being in the GUI layer. But this could happen in a followup.

Would be curious if this makes sense to others. Even if we never add another interface that enables & disables settings, it just seem plausible that there could be other interfaces that use these values, so it makes sense to store them alongside the normal settings, not someplace GUI-specific.

@ryanofsky
Copy link
Contributor Author

Just to summarize discussion above, I think that as long we believe it is useful to store disabled prune and proxy values, then settings.json is a better place to store them than QSettings, so this PR is implementing the right approach, and is ready for review/testing/merge.

If we think it's ok to reset disabled settings to default instead of saving them, then that is the current behavior, and this PR could just be closed. I'm beginning to think more that it is good to store disabled settings, so this PR seems like a good idea, but resetting them also seems reasonable, so I don't have a strong opinion.

Copy link
Contributor

@jarolrod jarolrod left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@hebasto hebasto merged commit e43ff4e into bitcoin-core:master Feb 15, 2023
sidhujag pushed a commit to syscoin/syscoin that referenced this pull request Feb 15, 2023
… onion-prev settings

9d3127b Add settings.json prune-prev, proxy-prev, onion-prev settings (Ryan Ofsky)

Pull request description:

  With bitcoin#602, if proxy and pruning settings are disabled in the GUI and the GUI is restarted, proxy and prune values are not stored anywhere. So if these settings are enabled in the future, default values will be shown, not previous values.

  This PR stores previous values so they will preserved across restarts. I'm not sure I like this behavior because showing default values seems simpler and safer to me. Previous values may just have been set temporarily and may have never actually worked, and it adds some code complexity to store them.

  This PR is one way of resolving bitcoin#596. Other solutions are possible and could be implemented as alternatives.

ACKs for top commit:
  hebasto:
    ACK 9d3127b, tested on Ubuntu 22.04.
  vasild:
    ACK 9d3127b
  jarolrod:
    tACK 9d3127b

Tree-SHA512: 1778d1819443490c880cfd5c1711d9c5ac75ea3ee8440e2f0ced81d293247163a78ae8aba6027215110aec6533bd7dc6472aeead6796bfbd51bf2354e28f24a9
hebasto added a commit to bitcoin-core/gui-qml that referenced this pull request Feb 17, 2023
Pull request description:

  Sync with the main repo up to bitcoin/bitcoin@73966f7

  The reason for this sync is to bring in the functionality of bitcoin-core/gui#603

  GUIX hashes:
  ```
  9465f358e218b9aaf0ee0f22da821544d65fe8b500d33c9719221b90ae9c913f  guix-build-976c90d2a30e/output/aarch64-linux-gnu/SHA256SUMS.part
  ed9aa8fa7e16f3949e73b253d35cdba8c7fc7ee338080ab91f5e90af0dce57d7  guix-build-976c90d2a30e/output/aarch64-linux-gnu/bitcoin-976c90d2a30e-aarch64-linux-gnu-debug.tar.gz
  6ce2cba039f1924cd5084ddc07a5d3681b1d4f39733fd6ed10921868ce7f53d1  guix-build-976c90d2a30e/output/aarch64-linux-gnu/bitcoin-976c90d2a30e-aarch64-linux-gnu.tar.gz
  6f82a95a6f7954c12fa0f4b7b5cd2b0047beb8e750881b6d4c1223b6cccbfbc6  guix-build-976c90d2a30e/output/arm-linux-gnueabihf/SHA256SUMS.part
  573785f291f7ce1cd9c442ca6ff48e2904abeb958f07298fec209531bcd5f475  guix-build-976c90d2a30e/output/arm-linux-gnueabihf/bitcoin-976c90d2a30e-arm-linux-gnueabihf-debug.tar.gz
  de7724db4746ad0b98f756bef279ca41a8012db36bcd146277d7073ab8ed2f9b  guix-build-976c90d2a30e/output/arm-linux-gnueabihf/bitcoin-976c90d2a30e-arm-linux-gnueabihf.tar.gz
  49eef5983005d5c92d972217bea655ee93ea33eee61f52cf49b379ed7fd35657  guix-build-976c90d2a30e/output/arm64-apple-darwin/SHA256SUMS.part
  d7a57e99853531f9f2be7585037e427f402ff26c47ccdb42cf46542fbf2a398e  guix-build-976c90d2a30e/output/arm64-apple-darwin/bitcoin-976c90d2a30e-arm64-apple-darwin-unsigned.dmg
  81da57a349eb125ba1cd780abf288345d7f8b964248d3b95554e502f9a47d09f  guix-build-976c90d2a30e/output/arm64-apple-darwin/bitcoin-976c90d2a30e-arm64-apple-darwin-unsigned.tar.gz
  b0a098804b53cd4d0486c6ad4c734b711ec749e351beb3d857f4991eddc5df9b  guix-build-976c90d2a30e/output/arm64-apple-darwin/bitcoin-976c90d2a30e-arm64-apple-darwin.tar.gz
  2c8615626209ed30dd9ba60c4e99c3c4b942a6320d580d6b15aedf5e48f57ed0  guix-build-976c90d2a30e/output/dist-archive/bitcoin-976c90d2a30e.tar.gz
  f194eec851e22ea42b4cc6dcce87e97d8d0cb43b07567be08c20f20e8457a9eb  guix-build-976c90d2a30e/output/powerpc64-linux-gnu/SHA256SUMS.part
  23c59be25fee80147b9c9f4fa4c42407478f0528f4b965014fbc1c713baf1f28  guix-build-976c90d2a30e/output/powerpc64-linux-gnu/bitcoin-976c90d2a30e-powerpc64-linux-gnu-debug.tar.gz
  edd5c26e2d01baa1f09939e4568e6c21d21182496a8e59292d02475c812bcbef  guix-build-976c90d2a30e/output/powerpc64-linux-gnu/bitcoin-976c90d2a30e-powerpc64-linux-gnu.tar.gz
  5b5160d98dbfb2bb0a6b83f03b2f6d7b63994902a1a9be604e6c8f52be1dfe37  guix-build-976c90d2a30e/output/powerpc64le-linux-gnu/SHA256SUMS.part
  fea6e0b10079152d99a4afc2f81b2cb629a710dca125f562312fd86dc0a4c5d2  guix-build-976c90d2a30e/output/powerpc64le-linux-gnu/bitcoin-976c90d2a30e-powerpc64le-linux-gnu-debug.tar.gz
  3f3eb482f23ce7adda9dbdccdbd4e94d1b90fcfd447b5daa3b8455902f444114  guix-build-976c90d2a30e/output/powerpc64le-linux-gnu/bitcoin-976c90d2a30e-powerpc64le-linux-gnu.tar.gz
  d0190698eb3f9d84a49f2b97845167a335fb613220932c53b2ccdadf8df8d3bc  guix-build-976c90d2a30e/output/riscv64-linux-gnu/SHA256SUMS.part
  73e805dfb7d5dbdeea42cef92ea7f0f0788fa08b08925b11c98ac4247277d0d5  guix-build-976c90d2a30e/output/riscv64-linux-gnu/bitcoin-976c90d2a30e-riscv64-linux-gnu-debug.tar.gz
  66ef93b3b2248c5a1fc114cfae2a8f8204848599f658441801c99487dcda9b58  guix-build-976c90d2a30e/output/riscv64-linux-gnu/bitcoin-976c90d2a30e-riscv64-linux-gnu.tar.gz
  8a62135277c3b78523c02e0118b69b68e47544cf75eb7e1f81300a8724faef2f  guix-build-976c90d2a30e/output/x86_64-apple-darwin/SHA256SUMS.part
  163538730911593d3a3cdfc2416384d51d34bf9fbb597b516ea943ddfbe2142b  guix-build-976c90d2a30e/output/x86_64-apple-darwin/bitcoin-976c90d2a30e-x86_64-apple-darwin-unsigned.dmg
  7765a42cf56a80caeb0186509030792f2c0b28aad8926d951f5e1fafe726cda7  guix-build-976c90d2a30e/output/x86_64-apple-darwin/bitcoin-976c90d2a30e-x86_64-apple-darwin-unsigned.tar.gz
  f469b7c4f6c51fea30554444eaa6fc818d31e651dbda60950cc9b900e5cecae7  guix-build-976c90d2a30e/output/x86_64-apple-darwin/bitcoin-976c90d2a30e-x86_64-apple-darwin.tar.gz
  fe591d3d4e04c3537974cad6ee84f057c7e48145c32b8645eba266b0d7cb0b3f  guix-build-976c90d2a30e/output/x86_64-linux-gnu/SHA256SUMS.part
  f66091ae7e6b1ebaa7d1ef95ed9b716d2d87687a15bc9379323e6fb4592257cd  guix-build-976c90d2a30e/output/x86_64-linux-gnu/bitcoin-976c90d2a30e-x86_64-linux-gnu-debug.tar.gz
  aa4982f2e330c90d22dc3143892a36d8fb45f7db572d18c503f5b71cf743cb2a  guix-build-976c90d2a30e/output/x86_64-linux-gnu/bitcoin-976c90d2a30e-x86_64-linux-gnu.tar.gz
  32efeed9488e428ebfa5cb1e145905a43943af7e6a302cb48b85be185d24f2eb  guix-build-976c90d2a30e/output/x86_64-w64-mingw32/SHA256SUMS.part
  1eabfd2372de89411bd9ba72bfa004857b5414eed65c08e8435245b91ae22f8a  guix-build-976c90d2a30e/output/x86_64-w64-mingw32/bitcoin-976c90d2a30e-win64-debug.zip
  5a6c153b9258576e1f01892a4856ea29857a5b176e5762a765432bf721e1430f  guix-build-976c90d2a30e/output/x86_64-w64-mingw32/bitcoin-976c90d2a30e-win64-setup-unsigned.exe
  94de454274fd35e5b7ff99f42092ce43b7050e396eaae18335e80a5fbec58cad  guix-build-976c90d2a30e/output/x86_64-w64-mingw32/bitcoin-976c90d2a30e-win64-unsigned.tar.gz
  1a438e20c241af3ac5ea57e742e4e96d7f80c065734520e1178820fbe19aff1f  guix-build-976c90d2a30e/output/x86_64-w64-mingw32/bitcoin-976c90d2a30e-win64.zip

  ```

  [![Windows](https://img.shields.io/badge/OS-Windows-green)](https://api.cirrus-ci.com/v1/artifact/github/bitcoin-core/gui-qml/win64/insecure_win_gui.zip?branch=pull/266)
  [![Intel macOS](https://img.shields.io/badge/OS-Intel%20macOS-green)](https://api.cirrus-ci.com/v1/artifact/github/bitcoin-core/gui-qml/macos/insecure_mac_gui.zip?branch=pull/266)
  [![Apple Silicon macOS](https://img.shields.io/badge/OS-Apple%20Silicon%20macOS-green)](https://api.cirrus-ci.com/v1/artifact/github/bitcoin-core/gui-qml/macos_arm64/insecure_mac_arm64_gui.zip?branch=pull/266)
  [![ARM64 Android](https://img.shields.io/badge/OS-Android-green)](https://api.cirrus-ci.com/v1/artifact/github/bitcoin-core/gui-qml/android/insecure_android_apk.zip?branch=pull/266)

ACKs for top commit:
  hebasto:
    ACK 976c90d, I've synced locally and got zero diff.

Tree-SHA512: 4c7e95ab8a42ff6cfb2481574b4eb6bee8036ff6ca52c3a0cc1004fcadb1bba06c61c7d27c47dc03dc2fd5715314881edb57421ea2681191e48bbcbc5d8b30db
@bitcoin-core bitcoin-core locked and limited conversation to collaborators Feb 15, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

UX All about "how to get things done"

Projects

None yet

Development

Successfully merging this pull request may close these issues.

6 participants