From be6cef93c479056169ab499d03ea212ff22db435 Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Mon, 7 Jun 2010 09:49:17 -0400 Subject: A further simplification of -V and -X With -X COMM, all values are computed in terms of COMM, regardless. With -V, only secondary commodities will ever be computed, never primaries. Further, if a secondary commodities has an associated price, the valuation is done in terms of that price's commodity. --- src/amount.cc | 53 ++++++++++++++++++++++++++++------------------------- src/amount.h | 3 +-- src/balance.cc | 6 ++---- src/balance.h | 5 ++--- src/commodity.cc | 7 +------ src/commodity.h | 4 ++++ src/py_amount.cc | 6 +++--- src/py_balance.cc | 6 +++--- src/py_value.cc | 6 +++--- src/report.cc | 2 +- src/value.cc | 9 ++++----- src/value.h | 3 +-- 12 files changed, 53 insertions(+), 57 deletions(-) (limited to 'src') diff --git a/src/amount.cc b/src/amount.cc index ed8f09d1..105b54ef 100644 --- a/src/amount.cc +++ b/src/amount.cc @@ -724,8 +724,7 @@ void amount_t::in_place_unreduce() } optional -amount_t::value(const bool primary_only, - const optional& moment, +amount_t::value(const optional& moment, const optional& in_terms_of) const { if (quantity) { @@ -740,35 +739,39 @@ amount_t::value(const bool primary_only, "amount_t::value: in_terms_of = " << in_terms_of->symbol()); #endif if (has_commodity() && - (! primary_only || ! commodity().has_flags(COMMODITY_PRIMARY))) { - if (in_terms_of && - commodity().referent() == in_terms_of->referent()) { + (in_terms_of || ! commodity().has_flags(COMMODITY_PRIMARY))) { + optional point; + optional comm(in_terms_of); + + if (comm && commodity().referent() == comm->referent()) { return *this; } - else if (has_annotation() && annotation().price && - annotation().has_flags(ANNOTATION_PRICE_FIXATED)) { - amount_t price(*annotation().price); + else if (has_annotation() && annotation().price) { + if (annotation().has_flags(ANNOTATION_PRICE_FIXATED)) { + point = price_point_t(); + point->price = *annotation().price; + } + else if (! in_terms_of) { + comm = annotation().price->commodity(); + } + } + + if (! point) { + point = commodity().find_price(comm, moment); + // Whether a price was found or not, check whether we should attempt + // to download a price from the Internet. This is done if (a) no + // price was found, or (b) the price is "stale" according to the + // setting of --price-exp. + if (point) + point = commodity().check_for_updated_price(point, moment, comm); + } + + if (point) { + amount_t price(point->price); price.multiply(*this, true); price.in_place_round(); return price; } - else { - optional point = - commodity().find_price(in_terms_of, moment); - - // Whether a price was found or not, check whether we should - // attempt to download a price from the Internet. This is done - // if (a) no price was found, or (b) the price is "stale" - // according to the setting of --price-exp. - point = commodity().check_for_updated_price(point, moment, - in_terms_of); - if (point) { - amount_t price(point->price); - price.multiply(*this, true); - price.in_place_round(); - return price; - } - } } } else { throw_(amount_error, diff --git a/src/amount.h b/src/amount.h index faea8b8e..09c9dc49 100644 --- a/src/amount.h +++ b/src/amount.h @@ -399,8 +399,7 @@ public: $100.00. */ optional - value(const bool primary_only = true, - const optional& moment = none, + value(const optional& moment = none, const optional& in_terms_of = none) const; amount_t price() const; diff --git a/src/balance.cc b/src/balance.cc index bfcd4a35..a8bc649d 100644 --- a/src/balance.cc +++ b/src/balance.cc @@ -185,16 +185,14 @@ balance_t& balance_t::operator/=(const amount_t& amt) } optional -balance_t::value(const bool primary_only, - const optional& moment, +balance_t::value(const optional& moment, const optional& in_terms_of) const { balance_t temp; bool resolved = false; foreach (const amounts_map::value_type& pair, amounts) { - if (optional val = pair.second.value(primary_only, moment, - in_terms_of)) { + if (optional val = pair.second.value(moment, in_terms_of)) { temp += *val; resolved = true; } else { diff --git a/src/balance.h b/src/balance.h index 496b53b7..12d7bc02 100644 --- a/src/balance.h +++ b/src/balance.h @@ -384,9 +384,8 @@ public: } optional - value(const bool primary_only = false, - const optional& moment = none, - const optional& in_terms_of = none) const; + value(const optional& moment = none, + const optional& in_terms_of = none) const; balance_t price() const; diff --git a/src/commodity.cc b/src/commodity.cc index e45332b2..9a757395 100644 --- a/src/commodity.cc +++ b/src/commodity.cc @@ -264,10 +264,6 @@ commodity_t::varied_history_t::find_price(const commodity_t& source, if (comm == source) continue; - // Only value secondary commodities in terms of primary ones - if (! commodity && ! comm.has_flags(COMMODITY_PRIMARY)) - continue; - DEBUG_INDENT("commodity.prices.find", indent + 1); DEBUG("commodity.prices.find", "searching for price via commodity '" << comm << "'"); @@ -370,8 +366,7 @@ commodity_t::find_price(const optional& commodity, #endif ) const { - if (! has_flags(COMMODITY_WALKED) && base->varied_history && - (commodity || ! has_flags(COMMODITY_PRIMARY))) { + if (! has_flags(COMMODITY_WALKED) && base->varied_history) { optional pair; #if defined(VERIFY_ON) optional checkpoint; diff --git a/src/commodity.h b/src/commodity.h index 8fe00a6d..ae7d9d66 100644 --- a/src/commodity.h +++ b/src/commodity.h @@ -59,6 +59,10 @@ struct price_point_t datetime_t when; amount_t price; + price_point_t() {} + price_point_t(datetime_t _when, amount_t _price) + : when(_when), price(_price) {} + bool operator==(const price_point_t& other) const { return when == other.when && price == other.price; } diff --git a/src/py_amount.cc b/src/py_amount.cc index 5afe8c6b..c5962446 100644 --- a/src/py_amount.cc +++ b/src/py_amount.cc @@ -45,16 +45,16 @@ using namespace boost::python; namespace { boost::optional py_value_0(const amount_t& amount) { - return amount.value(false, CURRENT_TIME()); + return amount.value(CURRENT_TIME()); } boost::optional py_value_1(const amount_t& amount, commodity_t& in_terms_of) { - return amount.value(false, CURRENT_TIME(), in_terms_of); + return amount.value(CURRENT_TIME(), in_terms_of); } boost::optional py_value_2(const amount_t& amount, commodity_t& in_terms_of, datetime_t& moment) { - return amount.value(false, moment, in_terms_of); + return amount.value(moment, in_terms_of); } void py_parse_2(amount_t& amount, object in, unsigned char flags) { diff --git a/src/py_balance.cc b/src/py_balance.cc index 7be75444..03a73ff6 100644 --- a/src/py_balance.cc +++ b/src/py_balance.cc @@ -45,16 +45,16 @@ using namespace boost::python; namespace { boost::optional py_value_0(const balance_t& balance) { - return balance.value(false, CURRENT_TIME()); + return balance.value(CURRENT_TIME()); } boost::optional py_value_1(const balance_t& balance, commodity_t& in_terms_of) { - return balance.value(false, CURRENT_TIME(), in_terms_of); + return balance.value(CURRENT_TIME(), in_terms_of); } boost::optional py_value_2(const balance_t& balance, commodity_t& in_terms_of, datetime_t& moment) { - return balance.value(false, moment, in_terms_of); + return balance.value(moment, in_terms_of); } boost::optional diff --git a/src/py_value.cc b/src/py_value.cc index 449320ec..46fa94c3 100644 --- a/src/py_value.cc +++ b/src/py_value.cc @@ -48,16 +48,16 @@ BOOST_PYTHON_MEMBER_FUNCTION_OVERLOADS(set_string_overloads, set_string, 0, 2) namespace { boost::optional py_value_0(const value_t& value) { - return value.value(false, CURRENT_TIME()); + return value.value(CURRENT_TIME()); } boost::optional py_value_1(const value_t& value, commodity_t& in_terms_of) { - return value.value(false, CURRENT_TIME(), in_terms_of); + return value.value(CURRENT_TIME(), in_terms_of); } boost::optional py_value_2(const value_t& value, commodity_t& in_terms_of, datetime_t& moment) { - return value.value(false, moment, in_terms_of); + return value.value(moment, in_terms_of); } PyObject * py_base_type(value_t& value) diff --git a/src/report.cc b/src/report.cc index 2ce0ae73..680205fa 100644 --- a/src/report.cc +++ b/src/report.cc @@ -466,7 +466,7 @@ value_t report_t::fn_market(call_scope_t& scope) /* add_prices= */ false, moment); else - result = args.value_at(0).value(true, moment); + result = args.value_at(0).value(moment); if (! result.is_null()) return result; diff --git a/src/value.cc b/src/value.cc index 7af2fd1e..e5ced56e 100644 --- a/src/value.cc +++ b/src/value.cc @@ -1401,8 +1401,7 @@ bool value_t::is_zero() const return false; } -value_t value_t::value(const bool primary_only, - const optional& moment, +value_t value_t::value(const optional& moment, const optional& in_terms_of) const { switch (type()) { @@ -1411,13 +1410,13 @@ value_t value_t::value(const bool primary_only, case AMOUNT: if (optional val = - as_amount().value(primary_only, moment, in_terms_of)) + as_amount().value(moment, in_terms_of)) return *val; return NULL_VALUE; case BALANCE: if (optional bal = - as_balance().value(primary_only, moment, in_terms_of)) + as_balance().value(moment, in_terms_of)) return *bal; return NULL_VALUE; @@ -1455,7 +1454,7 @@ value_t value_t::exchange_commodities(const std::string& commodities, if (commodity_t * commodity = commodity_pool_t::current_pool->parse_price_expression(p, add_prices, moment)) { - value_t result = value(false, moment, *commodity); + value_t result = value(moment, *commodity); if (! result.is_null()) return result; } diff --git a/src/value.h b/src/value.h index cffd6dee..cb3b024a 100644 --- a/src/value.h +++ b/src/value.h @@ -476,8 +476,7 @@ public: void in_place_unreduce(); // exists for efficiency's sake // Return the "market value" of a given value at a specific time. - value_t value(const bool primary_only = false, - const optional& moment = none, + value_t value(const optional& moment = none, const optional& in_terms_of = none) const; value_t price() const; -- cgit v1.2.3