gui: Fix open wallet menu initialization order #16231
pull promag wants to merge 1 commits into bitcoin:master from promag:2019-06-fix-open-menu changing 2 files +7 −5-
promag commented at 1:22 pm on June 18, 2019: memberFixes #16230, the menu must be created before connecting to aboutToShow signal.
-
gui: Fix open wallet menu initialization order
The menu must be created before connecting to aboutToShow signal.
-
fanquake added the label GUI on Jun 18, 2019
-
fanquake added the label Needs backport on Jun 18, 2019
-
fanquake added this to the milestone 0.18.1 on Jun 18, 2019
-
DrahtBot commented at 6:45 pm on June 18, 2019: member
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
Reviewers, this pull request conflicts with the following ones:
- #16106 (gui: Sort wallets in open wallet menu by promag)
If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.
-
ryanofsky approved
-
ryanofsky commented at 8:23 pm on June 18, 2019: memberutACK 5224be5a3354e1a22ea4d7f0e40aadfccdf67064. Looks good, fix is simple and makes perfect sense after seeing explanation in #16118 (comment). Without this change (and since #16118), the menu pointer passed to
connect(m_open_wallet_action->menu(), ...)
is null and connecting has no effect. With this change, the menu is constructed earlier so the connect call can work. -
hebasto commented at 6:37 pm on June 21, 2019: memberACK 5224be5a3354e1a22ea4d7f0e40aadfccdf67064, I have tested the code on Bionic with Qt 5.12.4.
-
fanquake commented at 10:23 am on June 23, 2019: member
@promag Thanks for following up here, and sorry for the slow review..
I’ve tested that this change fixes the
File -> Open Wallet ->
behaviour (https://github.com/bitcoin/bitcoin/issues/16230):I’ve also checked that with this change on top of
master
(2cbcc55ba6aea26d64eae3981b83dac04f70240f), theFile
menu is still disabled during load (#16118):You’ve mentioned in some other PRs that going forward, when we are testing GUI changes we should be using
QT_FATAL_WARNINGS=1
. When I use that env variable with this PR,bitcoin-qt
segfaults when it finishes loading:0lldb Bitcoin-Qt.app 1(lldb) target create "Bitcoin-Qt.app" 2Current executable set to 'Bitcoin-Qt.app' (x86_64). 3(lldb) env QT_FATAL_WARNINGS=1 4(lldb) run 5Process 23386 launched: '/Users/michael/github/bitcoin/Bitcoin-Qt.app/Contents/MacOS/Bitcoin-Qt' (x86_64) 62019-06-23 18:21:14.578614+0800 Bitcoin-Qt[23386:57844] MessageTracer: Falling back to default whitelist 7Process 23386 stopped 8* thread [#1](/bitcoin-bitcoin/1/), name = 'bitcoin-main', queue = 'com.apple.main-thread', stop reason = signal SIGABRT 9 frame [#0](/bitcoin-bitcoin/0/): 0x00007fff7e3be2c6 libsystem_kernel.dylib`__pthread_kill + 10 10libsystem_kernel.dylib`__pthread_kill: 11-> 0x7fff7e3be2c6 <+10>: jae 0x7fff7e3be2d0 ; <+20> 12 0x7fff7e3be2c8 <+12>: movq %rax, %rdi 13 0x7fff7e3be2cb <+15>: jmp 0x7fff7e3b8457 ; cerror_nocancel 14 0x7fff7e3be2d0 <+20>: retq 15Target 0: (Bitcoin-Qt) stopped.
-
hebasto commented at 10:33 am on June 23, 2019: member
You’ve mentioned in some other PRs that going forward, when we are testing GUI changes we should be using QT_FATAL_WARNINGS=1. When I use that env variable with this PR, bitcoin-qt segfaults when it finishes loading…
It seems unrelated to this PR as warnings could be produced by the internal Qt code. To verify you could launch:
0QT_FATAL_WARNINGS=7 bitcoin-qt -debug=qt
and check out warnings in the
debug.log
. -
fanquake commented at 10:36 am on June 23, 2019: member
@hebasto Thanks. I had just about figured that out myself, as the debug.log was always cutting off at:
02019-06-23T10:21:21Z UpdateTip: new best=000000000000000000b6a9e3c4aa5619a48023818df48f757f8fff650b51de85 height=494994 version=0x20000002 log2_work=87.490425 tx=272517027 date='2017-11-18T23:38:38Z' progress=0.642811 cache=4.2MiB(31387txo) 12019-06-23T10:21:21Z UpdateTip: new best=000000000000000000aa16a81a9b3b74f47f07bd6184705a3525e8325dffa54f height=494995 version=0x20000000 log2_work=87.490464 tx=272519017 date='2017-11-19T00:03:10Z' progress=0.642816 cache=5.2MiB(39744txo) 22019-06-23T10:21:21Z UpdateTip: new best=00000000000000000076be6678a2efa7793f98900ac0490863514f291e0f90f8 height=494996 version=0x20000000 log2_work=87.490502 tx=272519980 date='2017-11-19T00:03:48Z' progress=0.642818 cache=6.1MiB(47055txo) 32019-06-23T10:21:21Z GUI: Platform customization: "macosx"
So yes, that seems unrelated to this PR, and the changes in #16263 look good.
-
fanquake approved
-
fanquake commented at 10:39 am on June 23, 2019: memberACK 5224be5a3354e1a22ea4d7f0e40aadfccdf67064 Testing included in a comment above. The segfaulting with QT_FATAL_WARNINGS is unrelated to this change.
-
hebasto commented at 10:43 am on June 23, 2019: member
I had just about figured that out myself, as the debug.log was always cutting off at:
02019-06-23T10:21:21Z UpdateTip: new best=000000000000000000b6a9e3c4aa5619a48023818df48f757f8fff650b51de85 height=494994 version=0x20000002 log2_work=87.490425 tx=272517027 date='2017-11-18T23:38:38Z' progress=0.642811 cache=4.2MiB(31387txo) 12019-06-23T10:21:21Z UpdateTip: new best=000000000000000000aa16a81a9b3b74f47f07bd6184705a3525e8325dffa54f height=494995 version=0x20000000 log2_work=87.490464 tx=272519017 date='2017-11-19T00:03:10Z' progress=0.642816 cache=5.2MiB(39744txo) 22019-06-23T10:21:21Z UpdateTip: new best=00000000000000000076be6678a2efa7793f98900ac0490863514f291e0f90f8 height=494996 version=0x20000000 log2_work=87.490502 tx=272519980 date='2017-11-19T00:03:48Z' progress=0.642818 cache=6.1MiB(47055txo) 32019-06-23T10:21:21Z GUI: Platform customization: "macosx"
This case has been fixed in #16263 ;)
-
fanquake merged this on Jun 23, 2019
-
fanquake closed this on Jun 23, 2019
-
fanquake referenced this in commit c1bab5052a on Jun 23, 2019
-
MarcoFalke referenced this in commit 2800b3d5c1 on Jun 23, 2019
-
MarcoFalke removed the label Needs backport on Jun 23, 2019
-
promag deleted the branch on Jun 24, 2019
-
sidhujag referenced this in commit d0a515884f on Jun 30, 2019
-
HashUnlimited referenced this in commit 83ff000351 on Aug 23, 2019
-
Bushstar referenced this in commit 8ddbd02123 on Aug 24, 2019
-
Bushstar referenced this in commit 70ce4f69c7 on Aug 24, 2019
-
Bushstar referenced this in commit fc0aeaf314 on Aug 24, 2019
-
Bushstar referenced this in commit b6a095d2c4 on Aug 24, 2019
-
deadalnix referenced this in commit 27ebbd764c on May 21, 2020
-
PastaPastaPasta referenced this in commit ce9d941767 on Oct 25, 2021
-
pravblockc referenced this in commit c0de9c96cb on Nov 18, 2021
-
MarcoFalke locked this on Dec 16, 2021
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-21 12:12 UTC
More mirrored repositories can be found on mirror.b10c.me