diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-09 17:27:54 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-09 17:27:54 -0400 |
commit | 6ca01af594148e12cd8e1da87302644a0bbae3a0 (patch) | |
tree | bb83af15a352e3125053a3d5c0761f8e395ed2c3 /src/times.h | |
parent | cad86ed87f3548aaf9d35890f2b686c2bf064368 (diff) | |
download | fork-ledger-6ca01af594148e12cd8e1da87302644a0bbae3a0.tar.gz fork-ledger-6ca01af594148e12cd8e1da87302644a0bbae3a0.tar.bz2 fork-ledger-6ca01af594148e12cd8e1da87302644a0bbae3a0.zip |
Fixed the use of --effective and --date-format (-y).
Diffstat (limited to 'src/times.h')
-rw-r--r-- | src/times.h | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/src/times.h b/src/times.h index 4bcdd9e2..190e5c6b 100644 --- a/src/times.h +++ b/src/times.h @@ -70,17 +70,17 @@ inline bool is_valid(const date_t& moment) { #endif #define CURRENT_DATE() boost::gregorian::day_clock::universal_day() -extern optional<string> input_date_format; +extern optional<std::string> input_date_format; datetime_t parse_datetime(const char * str, int current_year = -1); -inline datetime_t parse_datetime(const string& str, int current_year = -1) { +inline datetime_t parse_datetime(const std::string& str, int current_year = -1) { return parse_datetime(str.c_str(), current_year); } date_t parse_date(const char * str, int current_year = -1); -inline date_t parse_date(const string& str, int current_year = -1) { +inline date_t parse_date(const std::string& str, int current_year = -1) { return parse_date(str.c_str(), current_year); } @@ -94,21 +94,27 @@ inline std::time_t to_time_t(const ptime& t) return (t-start).total_seconds(); } -inline string format_datetime(const datetime_t& when, - const string format = "%Y-%m-%d %H:%M:%S") +extern std::string output_datetime_format; + +inline std::string format_datetime(const datetime_t& when, + const optional<std::string>& format = none) { char buf[256]; time_t moment = to_time_t(when); - std::strftime(buf, 255, format.c_str(), std::localtime(&moment)); + std::strftime(buf, 255, format ? format->c_str() : + output_datetime_format.c_str(), std::localtime(&moment)); return buf; } -inline string format_date(const date_t& when, - const string format = "%Y-%m-%d") +extern std::string output_date_format; + +inline std::string format_date(const date_t& when, + const optional<std::string>& format = none) { char buf[256]; std::tm moment = gregorian::to_tm(when); - std::strftime(buf, 255, format.c_str(), &moment); + std::strftime(buf, 255, format ? format->c_str() : + output_date_format.c_str(), &moment); return buf; } |