summaryrefslogtreecommitdiff
path: root/src/commodity.h
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-01-19 17:48:27 -0400
committerJohn Wiegley <johnw@newartisans.com>2009-01-19 17:48:27 -0400
commit009dd3969a5cf965a685702b71aee53bf957b206 (patch)
tree8e469bc3133bb55698ebb7f68d9dabaa71ff2a10 /src/commodity.h
parentdc91fdeff280a85b5157cf0aea56eae0bd1ae209 (diff)
downloadfork-ledger-009dd3969a5cf965a685702b71aee53bf957b206.tar.gz
fork-ledger-009dd3969a5cf965a685702b71aee53bf957b206.tar.bz2
fork-ledger-009dd3969a5cf965a685702b71aee53bf957b206.zip
Added a recursive, date-based commodity price searching capability. This
makes it possible to find all possible prices for a commodity by walking the map of pricing relationships to all other commodities, even if the relation is distant.
Diffstat (limited to 'src/commodity.h')
-rw-r--r--src/commodity.h94
1 files changed, 67 insertions, 27 deletions
diff --git a/src/commodity.h b/src/commodity.h
index 1277b2c2..6c9a7586 100644
--- a/src/commodity.h
+++ b/src/commodity.h
@@ -52,6 +52,12 @@ namespace ledger {
DECLARE_EXCEPTION(commodity_error, std::runtime_error);
+struct price_point_t
+{
+ datetime_t when;
+ amount_t price;
+};
+
class commodity_t
: public delegates_flags<>,
public equality_comparable1<commodity_t, noncopyable>
@@ -71,10 +77,19 @@ public:
history_map prices;
ptime last_lookup;
- void add_price(const datetime_t& date, const amount_t& price);
+ void add_price(const datetime_t& date, const amount_t& price,
+ const bool reflexive = true);
bool remove_price(const datetime_t& date);
- optional<amount_t> find_price(const optional<datetime_t>& moment = none);
+ optional<price_point_t>
+ find_price(const commodity_t& source,
+ const optional<commodity_t&>& commodity,
+ const optional<datetime_t>& moment = none,
+ const optional<datetime_t>& oldest = none
+#if defined(DEBUG_ON)
+ , const int indent = 0
+#endif
+ );
};
typedef std::map<commodity_t *, history_t> history_by_commodity_map;
@@ -83,15 +98,28 @@ public:
{
history_by_commodity_map histories;
- void add_price(const datetime_t& date, const amount_t& price);
+ void add_price(const datetime_t& date, const amount_t& price,
+ const bool reflexive = true);
bool remove_price(const datetime_t& date, commodity_t& commodity);
- optional<amount_t>
- find_price(const optional<commodity_t&>& commodity = none,
- const optional<datetime_t>& moment = none);
- optional<amount_t>
- find_price(const std::vector<commodity_t *>& commodities,
- const optional<datetime_t>& moment = none);
+ optional<price_point_t>
+ find_price(const commodity_t& source,
+ const optional<commodity_t&>& commodity = none,
+ const optional<datetime_t>& moment = none,
+ const optional<datetime_t>& oldest = none
+#if defined(DEBUG_ON)
+ , const int indent = 0
+#endif
+ );
+ optional<price_point_t>
+ find_price(const commodity_t& source,
+ const std::vector<commodity_t *>& commodities,
+ const optional<datetime_t>& moment = none,
+ const optional<datetime_t>& oldest = none
+#if defined(DEBUG_ON)
+ , const int indent = 0
+#endif
+ );
optional<history_t&>
history(const optional<commodity_t&>& commodity = none);
@@ -229,25 +257,19 @@ protected:
return none;
}
- optional<history_t&>
- history(const optional<commodity_t&>& commodity);
- optional<history_t&>
- history(const std::vector<commodity_t *>& commodities);
-
- optional<history_t>
- find_price(commodity_t& commodity,
- const optional<datetime_t>& moment,
- std::vector<bool *>& bools);
+ optional<history_t&> history(const optional<commodity_t&>& commodity);
+ optional<history_t&> history(const std::vector<commodity_t *>& commodities);
public:
// These methods provide a transparent pass-through to the underlying
// base->varied_history object.
- void add_price(const datetime_t& date, const amount_t& price) {
+ void add_price(const datetime_t& date, const amount_t& price,
+ const bool reflexive = true) {
if (! base->varied_history)
base->varied_history = varied_history_t();
- base->varied_history->add_price(date, price);
+ base->varied_history->add_price(date, price, reflexive);
}
bool remove_price(const datetime_t& date, commodity_t& commodity) {
if (base->varied_history)
@@ -255,19 +277,37 @@ public:
return false;
}
- optional<amount_t>
- find_price(const optional<commodity_t&>& commodity = none,
- const optional<datetime_t>& moment = none) {
+ optional<price_point_t>
+ find_price(const optional<commodity_t&>& commodity = none,
+ const optional<datetime_t>& moment = none,
+ const optional<datetime_t>& oldest = none
+#if defined(DEBUG_ON)
+ , const int indent = 0
+#endif
+ ) {
if (base->varied_history)
- return base->varied_history->find_price(commodity, moment);
+ return base->varied_history->find_price(*this, commodity, moment, oldest
+#if defined(DEBUG_ON)
+ , indent
+#endif
+ );
return none;
}
- optional<amount_t>
+ optional<price_point_t>
find_price(const std::vector<commodity_t *>& commodities,
- const optional<datetime_t>& moment = none) {
+ const optional<datetime_t>& moment = none,
+ const optional<datetime_t>& oldest = none
+#if defined(DEBUG_ON)
+ , const int indent = 0
+#endif
+ ) {
if (base->varied_history)
- return base->varied_history->find_price(commodities, moment);
+ return base->varied_history->find_price(*this, commodities, moment, oldest
+#if defined(DEBUG_ON)
+ , indent
+#endif
+ );
return none;
}