summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/quotes.cc90
-rw-r--r--src/quotes.h33
2 files changed, 45 insertions, 78 deletions
diff --git a/src/quotes.cc b/src/quotes.cc
index 5dbbc962..ef7b769e 100644
--- a/src/quotes.cc
+++ b/src/quotes.cc
@@ -31,46 +31,39 @@
#include <system.hh>
+#include "amount.h"
+#include "commodity.h"
+#include "pool.h"
#include "quotes.h"
namespace ledger {
-#if 0
-void quotes_by_script::operator()(commodity_base_t& commodity,
- const datetime_t& moment,
- const datetime_t& date,
- const datetime_t& last,
- amount_t& price)
+optional<price_point_t>
+commodity_quote_from_script(commodity_t& commodity,
+ const optional<commodity_t&>& exchange_commodity)
{
- DEBUG_CLASS("ledger.quotes.download");
-
- DEBUG_("commodity: " << commodity.symbol);
- DEBUG_TIME_(current_moment);
- DEBUG_TIME_(moment);
- DEBUG_TIME_(date);
- DEBUG_TIME_(last);
- if (commodity.history)
- DEBUG_TIME_(commodity.history->last_lookup);
- DEBUG_("pricing_leeway is " << pricing_leeway);
-
- if ((commodity.history &&
- (current_moment - commodity.history->last_lookup) < pricing_leeway) ||
- (current_moment - last) < pricing_leeway ||
- (price && moment > date && (moment - date) <= pricing_leeway))
- return;
-
- using namespace std;
-
- DEBUG_("downloading quote for symbol " << commodity.symbol);
+ DEBUG("commodity.download", "downloading quote for symbol " << commodity.symbol());
+#if defined(DEBUG_ON)
+ if (exchange_commodity)
+ DEBUG("commodity.download",
+ " in terms of commodity " << exchange_commodity->symbol());
+#endif
char buf[256];
buf[0] = '\0';
- bool success = true;
+ string getquote_cmd("getquote \"");
+ getquote_cmd += commodity.symbol();
+ getquote_cmd += "\" \"";
+ if (exchange_commodity)
+ getquote_cmd += exchange_commodity->symbol();
+ getquote_cmd += "\"";
- if (FILE * fp = popen((string("getquote \"") +
- commodity.symbol + "\"").c_str(), "r")) {
- if (feof(fp) || ! fgets(buf, 255, fp))
+ DEBUG("commodity.download", "invoking command: " << getquote_cmd);
+
+ bool success = true;
+ if (FILE * fp = popen(getquote_cmd.c_str(), "r")) {
+ if (std::feof(fp) || ! std::fgets(buf, 255, fp))
success = false;
if (pclose(fp) != 0)
success = false;
@@ -79,31 +72,34 @@ void quotes_by_script::operator()(commodity_base_t& commodity,
}
if (success && buf[0]) {
- char * p = strchr(buf, '\n');
- if (p) *p = '\0';
-
- DEBUG_("downloaded quote: " << buf);
+ if (char * p = std::strchr(buf, '\n')) *p = '\0';
+ DEBUG("commodity.download", "downloaded quote: " << buf);
- price.parse(buf);
- commodity.add_price(current_moment, price);
-
- commodity.history->last_lookup = current_moment;
-
- if (price && ! price_db.empty()) {
+ if (optional<price_point_t> point =
+ amount_t::current_pool->parse_price_directive(buf)) {
+ if (amount_t::current_pool->price_db) {
#if defined(__GNUG__) && __GNUG__ < 3
- ofstream database(price_db.c_str(), ios::out | ios::app);
+ ofstream database(*amount_t::current_pool->price_db,
+ ios::out | ios::app);
#else
- ofstream database(price_db.c_str(), ios_base::out | ios_base::app);
+ ofstream database(*amount_t::current_pool->price_db,
+ std::ios_base::out | std::ios_base::app);
#endif
- database << "P " << current_moment.to_string("%Y/%m/%d %H:%M:%S")
- << " " << commodity.symbol << " " << price << endl;
+ database << "P "
+ << format_datetime(point->when, string("%Y/%m/%d %H:%M:%S"))
+ << " " << commodity.symbol()
+ << " " << point->price
+ << std::endl;
+ }
+ return point;
}
} else {
throw_(std::runtime_error,
- _("Failed to download price for '%1' (command: \"getquote %1\")")
- << commodity.symbol);
+ _("Failed to download price for '%1' (command: \"getquote %2 %3\")")
+ << commodity.symbol() << commodity.symbol()
+ << (exchange_commodity ? exchange_commodity->symbol() : "''"));
}
+ return none;
}
-#endif
} // namespace ledger
diff --git a/src/quotes.h b/src/quotes.h
index 68c7cade..ea47d4c2 100644
--- a/src/quotes.h
+++ b/src/quotes.h
@@ -46,39 +46,10 @@
#ifndef _QUOTES_H
#define _QUOTES_H
-
namespace ledger {
-#if 0
-/**
- * @brief Brief
- *
- * Long.
- */
-class quotes_by_script : public noncopyable, public commodity_t::base_t::updater_t
-{
- string price_db;
- std::size_t pricing_leeway;
-
- quotes_by_script();
-
-public:
- quotes_by_script(path _price_db,
- std::size_t _pricing_leeway)
- : price_db(_price_db), pricing_leeway(_pricing_leeway) {
- TRACE_CTOR(quotes_by_script, "path, std::size_t, bool&");
- }
- ~quotes_by_script() throw() {
- TRACE_DTOR(quotes_by_script);
- }
-
- virtual void operator()(commodity_base_t& commodity,
- const datetime_t& moment,
- const datetime_t& date,
- const datetime_t& last,
- amount_t& price);
-};
-#endif
+optional<price_point_t>
+commodity_quote_from_script(const optional<commodity_t&>& exchange_commodity);
} // namespace ledger