Please note that in contrast to #16273 I’m limiting the scope to the trivial cases of pure removals (i.e. no includes added) to make reviewing easier.
I’m seeking “Concept ACK”:s for this obviously non-urgent minor cleanup.
Rationale:
Avoids unnecessary re-compiles in case of header changes.
Makes reasoning about code dependencies easier.
Reduces compile-time memory usage.
Reduces compilation time.
Warm fuzzy feeling of being lean :-)
GChuf
commented at 5:03 pm on August 19, 2019:
contributor
I’m all for lean and mean stuff.
Concept ACK
MarcoFalke added this to the milestone Future
on Aug 19, 2019
jb55
commented at 5:59 pm on August 19, 2019:
member
Concept ACK
DrahtBot added the label
Consensus
on Aug 19, 2019
DrahtBot added the label
GUI
on Aug 19, 2019
DrahtBot added the label
Mempool
on Aug 19, 2019
DrahtBot added the label
Mining
on Aug 19, 2019
DrahtBot added the label
P2P
on Aug 19, 2019
DrahtBot added the label
Refactoring
on Aug 19, 2019
DrahtBot added the label
RPC/REST/ZMQ
on Aug 19, 2019
DrahtBot added the label
Tests
on Aug 19, 2019
DrahtBot added the label
TX fees and policy
on Aug 19, 2019
DrahtBot added the label
Utils/log/libs
on Aug 19, 2019
DrahtBot added the label
UTXO Db and Indexes
on Aug 19, 2019
DrahtBot added the label
Validation
on Aug 19, 2019
DrahtBot added the label
Wallet
on Aug 19, 2019
fanquake removed the label
Consensus
on Aug 19, 2019
fanquake removed the label
GUI
on Aug 19, 2019
fanquake removed the label
Mempool
on Aug 19, 2019
fanquake removed the label
Mining
on Aug 19, 2019
fanquake removed the label
P2P
on Aug 19, 2019
fanquake removed the label
RPC/REST/ZMQ
on Aug 19, 2019
fanquake removed the label
TX fees and policy
on Aug 19, 2019
fanquake removed the label
Tests
on Aug 19, 2019
fanquake removed the label
UTXO Db and Indexes
on Aug 19, 2019
fanquake removed the label
Utils/log/libs
on Aug 19, 2019
fanquake removed the label
Validation
on Aug 19, 2019
fanquake removed the label
Wallet
on Aug 19, 2019
fanquake added the label
Needs Conceptual Review
on Aug 19, 2019
DrahtBot
commented at 6:28 pm on August 19, 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:
#16839 (Replace Connman and BanMan globals with Node local by ryanofsky)
#16528 ([WIP] Native Descriptor Wallets (take 2) by achow101)
#16341 (Introduce ScriptPubKeyMan interface and use it for key and script management (aka wallet boxes) by achow101)
#15934 (Merge settings one place instead of five places by ryanofsky)
#14053 (Add address-based index (attempt 4?) by marcinja)
#13686 (ZMQ: Small cleanups in the ZMQ code by domob1812)
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.
emilengler
commented at 7:27 pm on August 19, 2019:
contributor
Concept ACK
promag
commented at 1:36 am on August 25, 2019:
member
Concept ACK.
l2a5b1
commented at 8:42 am on August 29, 2019:
contributor
Concept ACK
practicalswift
commented at 8:23 am on September 26, 2019:
contributor
@MarcoFalke Could this one get a milestone? I think it should have a concrete milestone if valuable enough to keep open :) I’m trying to trim my set of open PR:s so if no milestone I’d rather close.
promag
commented at 10:41 am on September 26, 2019:
member
Running make on HEAD 150c289b4034fb2101df61998dd71b11f3d7fae1:
01286.75 real 1170.31 user 99.80 sys
1748662784 maximum resident set size
20 average shared memory size
30 average unshared data size
40 average unshared stack size
535466407 page reclaims
6168811 page faults
70 swaps
80 block input operations
90 block output operations
100 messages sent
110 messages received
122512 signals received
1339561 voluntary context switches
14377820 involuntary context switches
And on HEAD^ e00ecb3d7aaee463643e486ca03c318e192b8058:
01440.06 real 1300.06 user 113.79 sys
1747356160 maximum resident set size
20 average shared memory size
30 average unshared data size
40 average unshared stack size
535429838 page reclaims
6212723 page faults
70 swaps
80 block input operations
90 block output operations
100 messages sent
110 messages received
122381 signals received
1355950 voluntary context switches
14932017 involuntary context switches
(make clean && ccache -C before each build).
So I’d ACK if this was already rebased and non draft.
practicalswift
commented at 10:48 am on September 26, 2019:
contributor
@promag Thanks a lot for benchmarking! I’ll update and rebase as soon as I get clarification from @MarcoFalke regarding the milestone :)
practicalswift
commented at 8:53 am on October 10, 2019:
contributor
laanwj
commented at 12:20 pm on October 10, 2019:
member
A PR only removing lines is very good. I also think early in the 0.20 cycle is a good time to do this.
So to be clear: this removes unnecessary includes that would otherwise cause the file to be included unnecessary, not includes that still end up being included indirectly through another route?
practicalswift
commented at 1:49 pm on October 10, 2019:
contributor
So to be clear: this removes unnecessary includes that would otherwise cause the file to be included unnecessary, not includes that still end up being included indirectly through another route?
Yes, exactly!
Would you mind adding the 0.20 tag? I’ll update the PR :)
laanwj removed this from the milestone Future
on Oct 10, 2019
laanwj added this to the milestone 0.20.0
on Oct 10, 2019
MarcoFalke marked this as ready for review
on Oct 11, 2019
DrahtBot added the label
Needs rebase
on Oct 11, 2019
laanwj
commented at 7:15 am on October 12, 2019:
member
Let’s get this merged soon then, to not have to keep rebasing, at least there’s basically zero risk.
practicalswift force-pushed
on Oct 12, 2019
DrahtBot removed the label
Needs rebase
on Oct 12, 2019
practicalswift force-pushed
on Oct 12, 2019
practicalswift force-pushed
on Oct 14, 2019
practicalswift force-pushed
on Oct 14, 2019
practicalswift force-pushed
on Oct 14, 2019
DrahtBot added the label
Needs rebase
on Oct 15, 2019
practicalswift force-pushed
on Oct 15, 2019
Remove unused includes084e17cebd
practicalswift force-pushed
on Oct 15, 2019
DrahtBot removed the label
Needs rebase
on Oct 15, 2019
practicalswift
commented at 5:41 am on October 16, 2019:
contributor
Rebased again :)
I think this one should be ready for final code review!
ryanofsky approved
ryanofsky
commented at 2:30 pm on October 16, 2019:
member
Code review ACK084e17cebd424b8e8ced674bc810eef4e6ee5d3b. PR only removes include lines and it still compiles. In the worst case someone might have to explicitly add an include later for something now included implicitly. But maybe some effort was taken to avoid this, and it wouldn’t be a tragedy anyway.
I would encourage @practicalswift to be more transparent about tools and methodologies used, since it’s unclear how this PR was generated, how the changes should be maintained, and if there were tools used that might deserve credit.
practicalswift
commented at 3:29 pm on October 16, 2019:
contributor
@ryanofsky The only tools used are nm and cxxfilt (python module). The rest is a very much Bitcoin Core specific Python script I’ve written myself :)
2207 LOC might sound crazy but a lot of it is taken up by a.) a mapping between object file names and headers file names and b.) a mapping between standard library headers and standard library functions/symbols. The real line count should be somewhere around 400 LOC.
It is not pretty but it works :)
ryanofsky
commented at 3:55 pm on October 16, 2019:
member
Thanks. I’d be curious to see the script if you want to post it somewhere like a gist.
MarcoFalke referenced this in commit
46d6930f8c
on Oct 16, 2019
MarcoFalke
commented at 9:44 pm on October 16, 2019:
This is actually used
practicalswift
commented at 9:46 pm on October 16, 2019:
Oh, I’ll investigate shortly! Did you find any other examples? Was it found by manual review?
MarcoFalke
commented at 9:44 pm on October 16, 2019:
member
ACK
practicalswift
commented at 11:07 pm on October 16, 2019:
contributor
Thanks for merging!
See below for a script run after this merge.
I believe the remaining cases to be of the “non-trivial” type where the header directly included is not needed in itself but one of more of the transitively included headers are.
Consider the src/bench/rpc_blockchain.cpp example: we are currently including validation.h which transitively gives us PROTOCOL_VERSION, CBlock, CBlockIndex and uint256. But we don’t need anything validation.h provides in itself.
Instead of including validation.h we should include version.h for PROTOCOL_VERSION, primitives/block.h for CBlock, chain.h for CBlockIndex and uint256.h for uint256.
Anyone who wants to address the above cases too? Then we should be as lean as it gets when it comes to redundant includes :)
If you do: let me know if you find any false positives/false negatives given the list above.
One caveat is that I’m currently skipping analysis for core_io.h due to the weird naming mismatch between core_io.h ⇄ core_write.cpp/core_read.cpp :)
laanwj
commented at 8:58 am on October 17, 2019:
member
One caveat is that I’m currently skipping analysis for core_io.h
It suppose that is a trivial header anyway, memory usage wise. It’s a few simple functions. It doesn’t pull in any boost nor non-run-of-the-mill C++ standard library headers.
sidhujag referenced this in commit
288cc1fa9f
on Oct 18, 2019
deadalnix referenced this in commit
2e7115ee28
on May 6, 2020
deadalnix referenced this in commit
a3160568ef
on Jun 15, 2020
fanquake referenced this in commit
e658b0e49b
on Mar 27, 2021
sidhujag referenced this in commit
adcbe1adaf
on Mar 27, 2021
practicalswift deleted the branch
on Apr 10, 2021
PastaPastaPasta referenced this in commit
579ff9f89d
on Jun 27, 2021
PastaPastaPasta referenced this in commit
803786cb8b
on Jun 28, 2021
PastaPastaPasta referenced this in commit
67dd77e43b
on Jun 29, 2021
PastaPastaPasta referenced this in commit
3c5dcb036a
on Dec 13, 2021
str4d referenced this in commit
c4e9e1c134
on Jul 16, 2022
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 06:12 UTC
This site is hosted by @0xB10C More mirrored repositories can be found on mirror.b10c.me