summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2020-03-27 18:20:44 -0700
committerJohn Wiegley <johnw@newartisans.com>2020-03-27 18:20:44 -0700
commitab4198a50f7fe476d9d1c7d56fb09669e7839bf5 (patch)
tree6953af478577dbc7408583e066b5f0c139ebdff9
parenta6a58af28f30ee81f86604b56740d98af8b75c38 (diff)
downloadfork-ledger-ab4198a50f7fe476d9d1c7d56fb09669e7839bf5.tar.gz
fork-ledger-ab4198a50f7fe476d9d1c7d56fb09669e7839bf5.tar.bz2
fork-ledger-ab4198a50f7fe476d9d1c7d56fb09669e7839bf5.zip
Look up annotated amounts within balances by their displayed name
-rw-r--r--src/balance.cc34
-rw-r--r--src/balance.h3
2 files changed, 35 insertions, 2 deletions
diff --git a/src/balance.cc b/src/balance.cc
index f0065dc5..0a2a3fec 100644
--- a/src/balance.cc
+++ b/src/balance.cc
@@ -76,7 +76,9 @@ balance_t& balance_t::operator+=(const amount_t& amt)
if (amt.is_realzero())
return *this;
- amounts_map::iterator i = amounts.find(&amt.commodity());
+ amounts_map::iterator i =
+ amt.commodity().has_annotation() ?
+ find_by_name(amt.commodity()) : amounts.find(&amt.commodity());
if (i != amounts.end())
i->second += amt;
else
@@ -101,7 +103,9 @@ balance_t& balance_t::operator-=(const amount_t& amt)
if (amt.is_realzero())
return *this;
- amounts_map::iterator i = amounts.find(&amt.commodity());
+ amounts_map::iterator i =
+ amt.commodity().has_annotation() ?
+ find_by_name(amt.commodity()) : amounts.find(&amt.commodity());
if (i != amounts.end()) {
i->second -= amt;
if (i->second.is_realzero())
@@ -202,6 +206,30 @@ balance_t::value(const datetime_t& moment,
return resolved ? temp : optional<balance_t>();
}
+balance_t::amounts_map::iterator
+balance_t::find_by_name(const commodity_t& comm)
+{
+ for (amounts_map::iterator i = amounts.begin();
+ i != amounts.end();
+ i++) {
+ if (*(*i).first == comm)
+ return i;
+ }
+ return amounts.end();
+}
+
+balance_t::amounts_map::const_iterator
+balance_t::find_by_name(const commodity_t& comm) const
+{
+ for (amounts_map::const_iterator i = amounts.begin();
+ i != amounts.end();
+ i++) {
+ if (*(*i).first == comm)
+ return i;
+ }
+ return amounts.end();
+}
+
optional<amount_t>
balance_t::commodity_amount(const optional<const commodity_t&>& commodity) const
{
@@ -222,6 +250,8 @@ balance_t::commodity_amount(const optional<const commodity_t&>& commodity) const
}
else if (amounts.size() > 0) {
amounts_map::const_iterator i =
+ commodity->has_annotation() ?
+ find_by_name(*commodity) :
amounts.find(const_cast<commodity_t *>(&*commodity));
if (i != amounts.end())
return i->second;
diff --git a/src/balance.h b/src/balance.h
index 19b6bd84..6c1475ac 100644
--- a/src/balance.h
+++ b/src/balance.h
@@ -506,6 +506,9 @@ public:
optional<amount_t>
commodity_amount(const optional<const commodity_t&>& commodity = none) const;
+ amounts_map::iterator find_by_name(const commodity_t& comm);
+ amounts_map::const_iterator find_by_name(const commodity_t& comm) const;
+
balance_t number() const {
balance_t temp;
foreach (const amounts_map::value_type& pair, amounts)