From 8ee8af3bfba440f6c185aa03b82cb7d0d785b3f3 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Thu, 12 Feb 2009 04:57:19 -0400 Subject: Restored the "prices" command. --- src/iterators.cc | 66 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) (limited to 'src/iterators.cc') diff --git a/src/iterators.cc b/src/iterators.cc index 6745f971..ac5b2fc8 100644 --- a/src/iterators.cc +++ b/src/iterators.cc @@ -72,6 +72,72 @@ xact_t * journal_xacts_iterator::operator()() return xact; } +void xacts_commodities_iterator::reset(journal_t& journal) +{ + journal_xacts.reset(journal); + + std::set commodities; + + for (xact_t * xact = journal_xacts(); xact; xact = journal_xacts()) { + commodity_t& comm(xact->amount.commodity()); + if (comm.flags() & COMMODITY_NOMARKET) + continue; + commodities.insert(&comm); + } + + foreach (commodity_t * comm, commodities) { + optional history = comm->varied_history(); + if (! history) + continue; + + entry_temps.push_back(new entry_t); + entry_temps.back()->payee = comm->symbol(); + entry_temps.back()->_date = CURRENT_DATE(); + + foreach (commodity_t::base_t::history_by_commodity_map::value_type pair, + history->histories) { + commodity_t& price_comm(*pair.first); + commodity_t::history_t& price_hist(pair.second); + + acct_temps.push_back(account_t(NULL, price_comm.symbol())); + + foreach (commodity_t::base_t::history_map::value_type hpair, + price_hist.prices) { + xact_temps.push_back(xact_t(&acct_temps.back())); + xact_t& temp = xact_temps.back(); + temp._date = hpair.first.date(); + temp.entry = entry_temps.back(); + temp.amount = hpair.second; + temp.set_flags(ITEM_GENERATED | ITEM_TEMP); + + entry_temps.back()->add_xact(&temp); + } + } + } + + entries.entries_i = entry_temps.begin(); + entries.entries_end = entry_temps.end(); + + entries.entries_uninitialized = false; + + entry_t * entry = entries(); + if (entry != NULL) + xacts.reset(*entry); +} + +xact_t * xacts_commodities_iterator::operator()() +{ + xact_t * xact = xacts(); + if (xact == NULL) { + entry_t * entry = entries(); + if (entry != NULL) { + xacts.reset(*entry); + xact = xacts(); + } + } + return xact; +} + account_t * basic_accounts_iterator::operator()() { while (! accounts_i.empty() && -- cgit v1.2.3