From 557ab32d30bcca3622e06a6809a541a015e84aa3 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Wed, 30 Jan 2019 11:09:08 -0800 Subject: Expose a new utility function for balances: sorted_amounts --- src/balance.cc | 18 +++++++++--------- src/balance.h | 7 +++++++ 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/src/balance.cc b/src/balance.cc index fa1bc20c..478ceb45 100644 --- a/src/balance.cc +++ b/src/balance.cc @@ -240,6 +240,14 @@ balance_t::strip_annotations(const keep_details_t& what_to_keep) const return temp; } +void balance_t::sorted_amounts(amounts_array& sorted) const +{ + foreach (const amounts_map::value_type& pair, amounts) + sorted.push_back(&pair.second); + std::stable_sort(sorted.begin(), sorted.end(), + commodity_t::compare_by_commodity()); +} + void balance_t::map_sorted_amounts(function fn) const { if (! amounts.empty()) { @@ -249,16 +257,8 @@ void balance_t::map_sorted_amounts(function fn) const fn(amount); } else { - typedef std::vector amounts_array; amounts_array sorted; - - foreach (const amounts_map::value_type& pair, amounts) - if (pair.second) - sorted.push_back(&pair.second); - - std::stable_sort(sorted.begin(), sorted.end(), - commodity_t::compare_by_commodity()); - + sorted_amounts(sorted); foreach (const amount_t * amount, sorted) fn(*amount); } diff --git a/src/balance.h b/src/balance.h index 8e773fc5..b9c9c2c8 100644 --- a/src/balance.h +++ b/src/balance.h @@ -81,6 +81,7 @@ class balance_t { public: typedef std::map amounts_map; + typedef std::vector amounts_array; amounts_map amounts; @@ -528,6 +529,12 @@ public: */ balance_t strip_annotations(const keep_details_t& what_to_keep) const; + /** + * Given a balance, insert a commodity-wise sort of the amounts into the + * given amounts_array. + */ + void sorted_amounts(amounts_array& sorted) const; + /** * Iteration primitives. `map_sorted_amounts' allows one to visit * each amount in balance in the proper order for displaying to the -- cgit v1.2.3