mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-25 02:33:24 -03:00
Merge bitcoin/bitcoin#30194: refactor: use recommended type hiding on multi_index types
a3cb309e7c
refactor: use recommended type hiding on multi_index types (Cory Fields) Pull request description: Recommended by boost docs: https://www.boost.org/doc/libs/1_85_0/libs/multi_index/doc/compiler_specifics.html#type_hiding This significantly reduces the size of the symbol name lengths that end up in the binaries as well as in compiler warnings/errors. Otherwise there should be no functional change. Example before: > 0000000000000000 W unsigned long boost::multi_index::detail::hashed_index<mempoolentry_txid, SaltedTxidHasher, std::equal_to<uint256>, boost::multi_index::detail::nth_layer<1, CTxMemPoolEntry, boost::multi_index::indexed_by<boost::multi_index::hashed_unique<mempoolentry_txid, SaltedTxidHasher, mpl_::na, mpl_::na>, boost::multi_index::hashed_unique<boost::multi_index::tag<index_by_wtxid, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>, mempoolentry_wtxid, SaltedTxidHasher, mpl_::na>, boost::multi_index::ordered_non_unique<boost::multi_index::tag<descendant_score, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>, boost::multi_index::identity<CTxMemPoolEntry>, CompareTxMemPoolEntryByDescendantScore>, boost::multi_index::ordered_non_unique<boost::multi_index::tag<entry_time, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>, boost::multi_index::identity<CTxMemPoolEntry>, CompareTxMemPoolEntryByEntryTime>, boost::multi_index::ordered_non_unique<boost::multi_index::tag<ancestor_score, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>, boost::multi_index::identity<CTxMemPoolEntry>, CompareTxMemPoolEntryByAncestorFee>, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na, mpl_::na>, std::allocator<CTxMemPoolEntry> >, boost::mpl::vector0<mpl_::na>, boost::multi_index::detail::hashed_unique_tag>::count<uint256, SaltedTxidHasher, std::equal_to<uint256> >(uint256 const&, SaltedTxidHasher const&, std::equal_to<uint256> const&, mpl_::bool_<false>) const After: > 0000000000000000 W unsigned long boost::multi_index::detail::hashed_index<mempoolentry_txid, SaltedTxidHasher, std::equal_to<uint256>, boost::multi_index::detail::nth_layer<1, CTxMemPoolEntry, CTxMemPool::CTxMemPoolEntry_Indicies, std::allocator<CTxMemPoolEntry> >, boost::mpl::vector0<mpl_::na>, boost::multi_index::detail::hashed_unique_tag>::count<uint256, SaltedTxidHasher, std::equal_to<uint256> >(uint256 const&, SaltedTxidHasher const&, std::equal_to<uint256> const&, mpl_::bool_<false>) const ACKs for top commit: glozow: ACKa3cb309e7c
, TIL, makes sense to me TheCharlatan: ACKa3cb309e7c
fanquake: ACKa3cb309e7c
Tree-SHA512: f6bb3d133daec126cf064ed6fe4457f457c0cfdbea28778c8ff426be7b41b271ada2d790c6b4129ca22156182c99aaf287e3aa9fb6b076ee55946da40e06e5d8
This commit is contained in:
commit
0f68a05c08
3 changed files with 30 additions and 21 deletions
|
@ -97,21 +97,25 @@ struct CompareTxIterByAncestorCount {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct CTxMemPoolModifiedEntry_Indices final : boost::multi_index::indexed_by<
|
||||||
|
boost::multi_index::ordered_unique<
|
||||||
|
modifiedentry_iter,
|
||||||
|
CompareCTxMemPoolIter
|
||||||
|
>,
|
||||||
|
// sorted by modified ancestor fee rate
|
||||||
|
boost::multi_index::ordered_non_unique<
|
||||||
|
// Reuse same tag from CTxMemPool's similar index
|
||||||
|
boost::multi_index::tag<ancestor_score>,
|
||||||
|
boost::multi_index::identity<CTxMemPoolModifiedEntry>,
|
||||||
|
CompareTxMemPoolEntryByAncestorFee
|
||||||
|
>
|
||||||
|
>
|
||||||
|
{};
|
||||||
|
|
||||||
typedef boost::multi_index_container<
|
typedef boost::multi_index_container<
|
||||||
CTxMemPoolModifiedEntry,
|
CTxMemPoolModifiedEntry,
|
||||||
boost::multi_index::indexed_by<
|
CTxMemPoolModifiedEntry_Indices
|
||||||
boost::multi_index::ordered_unique<
|
|
||||||
modifiedentry_iter,
|
|
||||||
CompareCTxMemPoolIter
|
|
||||||
>,
|
|
||||||
// sorted by modified ancestor fee rate
|
|
||||||
boost::multi_index::ordered_non_unique<
|
|
||||||
// Reuse same tag from CTxMemPool's similar index
|
|
||||||
boost::multi_index::tag<ancestor_score>,
|
|
||||||
boost::multi_index::identity<CTxMemPoolModifiedEntry>,
|
|
||||||
CompareTxMemPoolEntryByAncestorFee
|
|
||||||
>
|
|
||||||
>
|
|
||||||
> indexed_modified_transaction_set;
|
> indexed_modified_transaction_set;
|
||||||
|
|
||||||
typedef indexed_modified_transaction_set::nth_index<0>::type::iterator modtxiter;
|
typedef indexed_modified_transaction_set::nth_index<0>::type::iterator modtxiter;
|
||||||
|
|
|
@ -329,9 +329,7 @@ public:
|
||||||
|
|
||||||
static const int ROLLING_FEE_HALFLIFE = 60 * 60 * 12; // public only for testing
|
static const int ROLLING_FEE_HALFLIFE = 60 * 60 * 12; // public only for testing
|
||||||
|
|
||||||
typedef boost::multi_index_container<
|
struct CTxMemPoolEntry_Indices final : boost::multi_index::indexed_by<
|
||||||
CTxMemPoolEntry,
|
|
||||||
boost::multi_index::indexed_by<
|
|
||||||
// sorted by txid
|
// sorted by txid
|
||||||
boost::multi_index::hashed_unique<mempoolentry_txid, SaltedTxidHasher>,
|
boost::multi_index::hashed_unique<mempoolentry_txid, SaltedTxidHasher>,
|
||||||
// sorted by wtxid
|
// sorted by wtxid
|
||||||
|
@ -359,6 +357,10 @@ public:
|
||||||
CompareTxMemPoolEntryByAncestorFee
|
CompareTxMemPoolEntryByAncestorFee
|
||||||
>
|
>
|
||||||
>
|
>
|
||||||
|
{};
|
||||||
|
typedef boost::multi_index_container<
|
||||||
|
CTxMemPoolEntry,
|
||||||
|
CTxMemPoolEntry_Indices
|
||||||
> indexed_transaction_set;
|
> indexed_transaction_set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -212,14 +212,17 @@ struct ByTimeViewExtractor
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct Announcement_Indices final : boost::multi_index::indexed_by<
|
||||||
|
boost::multi_index::ordered_unique<boost::multi_index::tag<ByPeer>, ByPeerViewExtractor>,
|
||||||
|
boost::multi_index::ordered_non_unique<boost::multi_index::tag<ByTxHash>, ByTxHashViewExtractor>,
|
||||||
|
boost::multi_index::ordered_non_unique<boost::multi_index::tag<ByTime>, ByTimeViewExtractor>
|
||||||
|
>
|
||||||
|
{};
|
||||||
|
|
||||||
/** Data type for the main data structure (Announcement objects with ByPeer/ByTxHash/ByTime indexes). */
|
/** Data type for the main data structure (Announcement objects with ByPeer/ByTxHash/ByTime indexes). */
|
||||||
using Index = boost::multi_index_container<
|
using Index = boost::multi_index_container<
|
||||||
Announcement,
|
Announcement,
|
||||||
boost::multi_index::indexed_by<
|
Announcement_Indices
|
||||||
boost::multi_index::ordered_unique<boost::multi_index::tag<ByPeer>, ByPeerViewExtractor>,
|
|
||||||
boost::multi_index::ordered_non_unique<boost::multi_index::tag<ByTxHash>, ByTxHashViewExtractor>,
|
|
||||||
boost::multi_index::ordered_non_unique<boost::multi_index::tag<ByTime>, ByTimeViewExtractor>
|
|
||||||
>
|
|
||||||
>;
|
>;
|
||||||
|
|
||||||
/** Helper type to simplify syntax of iterator types. */
|
/** Helper type to simplify syntax of iterator types. */
|
||||||
|
|
Loading…
Add table
Reference in a new issue