blob: 6e5dbd835c57664b6f6af8d5f852d06f7a594bf6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
#ifndef _TIMES_H
#define _TIMES_H
#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/date_time/posix_time/posix_time_duration.hpp>
#include <boost/date_time/posix_time/posix_time_config.hpp>
#include <boost/date_time/local_time_adjustor.hpp>
#include <ctime>
#include <string>
#include <iostream>
#include "error.h"
namespace ledger {
typedef boost::posix_time::ptime ptime;
typedef ptime::time_duration_type time_duration;
typedef boost::gregorian::date date;
typedef boost::gregorian::date_duration date_duration;
typedef boost::posix_time::seconds seconds;
#define SUPPORT_DATE_AND_TIME 1
#ifdef SUPPORT_DATE_AND_TIME
typedef boost::posix_time::ptime moment_t;
typedef moment_t::time_duration_type duration_t;
inline bool is_valid_moment(const moment_t& moment) {
return ! moment.is_not_a_date_time();
}
#else // SUPPORT_DATE_AND_TIME
typedef boost::gregorian::date moment_t;
typedef boost::gregorian::date_duration duration_t;
inline bool is_valid_moment(const moment_t& moment) {
return ! moment.is_not_a_date();
}
#endif // SUPPORT_DATE_AND_TIME
extern moment_t& now;
class datetime_error : public error {
public:
datetime_error(const string& _reason) throw() : error(_reason) {}
virtual ~datetime_error() throw() {}
};
class interval_t
{
public:
interval_t() {}
interval_t(const string&) {}
operator bool() const {
return false;
}
void start(const moment_t&) {}
moment_t next() const { return moment_t(); }
void parse(std::istream&) {}
};
#if 0
inline moment_t ptime_local_to_utc(const moment_t& when) {
struct std::tm tm_gmt = to_tm(when);
return boost::posix_time::from_time_t(std::mktime(&tm_gmt));
}
// jww (2007-04-18): I need to make a general parsing function
// instead, and then make these into private methods.
inline moment_t ptime_from_local_date_string(const string& date_string) {
return ptime_local_to_utc(moment_t(boost::gregorian::from_string(date_string),
time_duration()));
}
inline moment_t ptime_from_local_time_string(const string& time_string) {
return ptime_local_to_utc(boost::posix_time::time_from_string(time_string));
}
#endif
moment_t parse_datetime(std::istream& in);
inline moment_t parse_datetime(const string& str) {
std::istringstream instr(str);
return parse_datetime(instr);
}
extern ptime time_now;
extern date date_now;
extern bool day_before_month;
struct intorchar
{
int ival;
string sval;
intorchar() : ival(-1) {}
intorchar(int val) : ival(val) {}
intorchar(const string& val) : ival(-1), sval(val) {}
intorchar(const intorchar& o) : ival(o.ival), sval(o.sval) {}
};
}
ledger::moment_t parse_abs_datetime(std::istream& input);
#endif /* _TIMES_H */
|