refactor: combine Chain::findFirstBlockWithTime/findFirstBlockWithTimeAndHeight #15670
pull ariard wants to merge 1 commits into bitcoin:master from ariard:2019-03-remove-find-first-block-time-height changing 7 files +44 −54-
ariard commented at 5:04 pm on March 26, 2019: memberAs suggested in #14711, pass height to CChain::FindEarliestAtLeast to simplify Chain interface by combining findFirstBlockWithTime and findFirstBlockWithTimeAndHeight into one
-
DrahtBot commented at 8:27 pm on March 26, 2019: member
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
No conflicts as of last run.
-
fanquake added the label Refactoring on Mar 26, 2019
-
RayHacker96 approved
-
in src/chain.cpp:66 in d43bff5e29 outdated
64 { 65- std::vector<CBlockIndex*>::const_iterator lower = std::lower_bound(vChain.begin(), vChain.end(), nTime, 66- [](CBlockIndex* pBlock, const int64_t& time) -> bool { return pBlock->GetBlockTimeMax() < time; }); 67+ std::pair<int64_t, int> blockparams = std::make_pair(nTime, height); 68+ std::vector<CBlockIndex*>::const_iterator lower = std::lower_bound(vChain.begin(), vChain.end(), blockparams, 69+ [](CBlockIndex* pBlock, const std::pair<int64_t, int>& blockparams) -> bool { return pBlock->GetBlockTimeMax() < blockparams.first && pBlock->nHeight < blockparams.second; });
ryanofsky commented at 8:06 pm on March 27, 2019:It seems like this should say || not &&. If either the time is to low or the height is too small, the block is too early?
ariard commented at 9:33 pm on March 27, 2019:Yes, already corrected locally and tests seem ok, wasn’t sure of std:lower_bound behavior at firstin src/test/skiplist_tests.cpp:163 in d43bff5e29 outdated
174- BOOST_CHECK(!chain.FindEarliestAtLeast(std::numeric_limits<int64_t>::max())); 175- BOOST_CHECK(!chain.FindEarliestAtLeast(std::numeric_limits<unsigned int>::max())); 176- BOOST_CHECK(!chain.FindEarliestAtLeast(int64_t(std::numeric_limits<unsigned int>::max()) + 1)); 177+ BOOST_CHECK_EQUAL(chain.FindEarliestAtLeast(50, 0)->nHeight, 0); 178+ BOOST_CHECK_EQUAL(chain.FindEarliestAtLeast(100, 0)->nHeight, 0); 179+ BOOST_CHECK_EQUAL(chain.FindEarliestAtLeast(150, 3)->nHeight, 3);
ryanofsky commented at 8:08 pm on March 27, 2019:This decreases test coverage for bisecting based on time.
It would be better if this PR just added a few new tests for nonzero heights, and left the existing tests alone (by passing 0 minimum heights).
ariard commented at 10:32 pm on March 27, 2019:Done, also few tests covering both block attributes.MarcoFalke renamed this:
refactor: combine Chain::findFirstBlockWithTime/findFirstBlockWithTim…
refactor: combine Chain::findFirstBlockWithTime/findFirstBlockWithTimeAndHeight
on Mar 27, 2019refactor: combine Chain::findFirstBlockWithTime/findFirstBlockWithTimeAndHeight
As suggested in #14711, pass height to CChain::FindEarliestAtLeast to simplify Chain interface by combining findFirstBlockWithTime and findFirstBlockWithTimeAndHeight into one Extend findearliestatleast_edge_test in consequence
ariard force-pushed on Mar 27, 2019ryanofsky approvedryanofsky commented at 4:27 pm on March 29, 2019: memberutACK 765c0b364d41e9a251c3f88cbe203645854fd790. Looks good, thanks for implementing the suggestion! @jnewbery, you may be interested to review this since you first made the suggestion in #14711 (review)MarcoFalke merged this on Apr 19, 2019MarcoFalke closed this on Apr 19, 2019
MarcoFalke referenced this in commit 56376f3365 on Apr 19, 2019deadalnix referenced this in commit 6f4857cdbc on May 27, 2020DrahtBot locked this on Dec 16, 2021
github-metadata-mirror
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-07 06:12 UTC
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-07 06:12 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me
More mirrored repositories can be found on mirror.b10c.me