diff options
author | John Wiegley <johnw@newartisans.com> | 2010-06-13 00:42:25 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2010-06-13 00:42:25 -0400 |
commit | 40f553228f5a28034c6635fdcb4c86af28a385ed (patch) | |
tree | 2c40305c9f9841a4c3d453a4a5c49ec69056b4b2 /src/times.cc | |
parent | 556211e623cad88213e5087b5c9c36e754d9aa02 (diff) | |
parent | b1b4e2aadff5983d443d70c09ea86a41b015873f (diff) | |
download | fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.gz fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.bz2 fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.zip |
Merge branch 'next'
Diffstat (limited to 'src/times.cc')
-rw-r--r-- | src/times.cc | 884 |
1 files changed, 442 insertions, 442 deletions
diff --git a/src/times.cc b/src/times.cc index 60e8e7cc..26e1dc21 100644 --- a/src/times.cc +++ b/src/times.cc @@ -60,17 +60,17 @@ namespace { temporal_io_t(const char * _fmt_str, bool _input) : fmt_str(_fmt_str), - traits(icontains(fmt_str, "%y"), - icontains(fmt_str, "%m") || icontains(fmt_str, "%b"), - icontains(fmt_str, "%d")), - input(_input) { + traits(icontains(fmt_str, "%y"), + icontains(fmt_str, "%m") || icontains(fmt_str, "%b"), + icontains(fmt_str, "%d")), + input(_input) { #if defined(USE_BOOST_FACETS) if (input) { - input_facet = new InputFacetType(fmt_str); - input_stream.imbue(std::locale(std::locale::classic(), input_facet)); + input_facet = new InputFacetType(fmt_str); + input_stream.imbue(std::locale(std::locale::classic(), input_facet)); } else { - output_facet = new OutputFacetType(fmt_str); - output_stream.imbue(std::locale(std::locale::classic(), output_facet)); + output_facet = new OutputFacetType(fmt_str); + output_stream.imbue(std::locale(std::locale::classic(), output_facet)); } #endif // USE_BOOST_FACETS } @@ -78,14 +78,14 @@ namespace { void set_format(const char * fmt) { fmt_str = fmt; traits = date_traits_t(icontains(fmt_str, "%y"), - icontains(fmt_str, "%m") || - icontains(fmt_str, "%b"), - icontains(fmt_str, "%d")); + icontains(fmt_str, "%m") || + icontains(fmt_str, "%b"), + icontains(fmt_str, "%d")); #if defined(USE_BOOST_FACETS) if (input) - input_facet->format(fmt_str); + input_facet->format(fmt_str); else - output_facet->format(fmt_str); + output_facet->format(fmt_str); #endif // USE_BOOST_FACETS } @@ -110,7 +110,7 @@ namespace { template <> datetime_t temporal_io_t<datetime_t, posix_time::time_input_facet, - posix_time::time_facet> + posix_time::time_facet> ::parse(const char * str) { #if defined(USE_BOOST_FACETS) @@ -122,15 +122,15 @@ namespace { input_stream >> when; #if defined(DEBUG_ON) if (when.is_not_a_date_time()) - DEBUG("times.parse", "Failed to parse date/time '" << str - << "' using pattern '" << fmt_str << "'"); + DEBUG("times.parse", "Failed to parse date/time '" << str + << "' using pattern '" << fmt_str << "'"); #endif if (! when.is_not_a_date_time() && - input_stream.good() && ! input_stream.eof() && - input_stream.peek() != EOF) { - DEBUG("times.parse", "This string has leftovers: '" << str << "'"); - return datetime_t(); + input_stream.good() && ! input_stream.eof() && + input_stream.peek() != EOF) { + DEBUG("times.parse", "This string has leftovers: '" << str << "'"); + return datetime_t(); } return when; #else // USE_BOOST_FACETS @@ -145,7 +145,7 @@ namespace { template <> date_t temporal_io_t<date_t, gregorian::date_input_facet, - gregorian::date_facet> + gregorian::date_facet> ::parse(const char * str) { #if defined(USE_BOOST_FACETS) @@ -157,21 +157,21 @@ namespace { input_stream >> when; #if defined(DEBUG_ON) if (when.is_not_a_date()) - DEBUG("times.parse", "Failed to parse date '" << str - << "' using pattern '" << fmt_str << "'"); + DEBUG("times.parse", "Failed to parse date '" << str + << "' using pattern '" << fmt_str << "'"); #endif if (! when.is_not_a_date() && - input_stream.good() && ! input_stream.eof() && - input_stream.peek() != EOF) { - DEBUG("times.parse", "This string has leftovers: '" << str << "'"); - return date_t(); + input_stream.good() && ! input_stream.eof() && + input_stream.peek() != EOF) { + DEBUG("times.parse", "This string has leftovers: '" << str << "'"); + return date_t(); } return when; #else // USE_BOOST_FACETS std::tm data; std::memset(&data, 0, sizeof(std::tm)); - data.tm_mday = 1; // some formats have no day + data.tm_mday = 1; // some formats have no day if (strptime(str, fmt_str, &data)) return gregorian::date_from_tm(data); else @@ -180,9 +180,9 @@ namespace { } typedef temporal_io_t<datetime_t, posix_time::time_input_facet, - posix_time::time_facet> datetime_io_t; + posix_time::time_facet> datetime_io_t; typedef temporal_io_t<date_t, gregorian::date_input_facet, - gregorian::date_facet> date_io_t; + gregorian::date_facet> date_io_t; shared_ptr<datetime_io_t> input_datetime_io; shared_ptr<date_io_t> input_date_io; @@ -194,8 +194,8 @@ namespace { std::vector<shared_ptr<date_io_t> > readers; date_t parse_date_mask_routine(const char * date_str, date_io_t& io, - optional_year year, - date_traits_t * traits = NULL) + optional_year year, + date_traits_t * traits = NULL) { VERIFY(std::strlen(date_str) < 127); @@ -204,7 +204,7 @@ namespace { for (char * p = buf; *p; p++) if (*p == '.' || *p == '-') - *p = '/'; + *p = '/'; date_t when = io.parse(buf); @@ -219,41 +219,41 @@ namespace { const char * p = when_str.c_str(); const char * q = buf; for (; *p && *q; p++, q++) { - if (*p != *q && *p == '0') p++; - if (! *p || *p != *q) break; + if (*p != *q && *p == '0') p++; + if (! *p || *p != *q) break; } if (*p != '\0' || *q != '\0') - throw_(date_error, _("Invalid date: %1") << date_str); + throw_(date_error, _("Invalid date: %1") << date_str); if (traits) - *traits = io.traits; + *traits = io.traits; if (! io.traits.has_year) { - when = date_t(year ? *year : CURRENT_DATE().year(), - when.month(), when.day()); + when = date_t(year ? *year : CURRENT_DATE().year(), + when.month(), when.day()); - if (! year && when.month() > CURRENT_DATE().month()) - when -= gregorian::years(1); + if (! year && when.month() > CURRENT_DATE().month()) + when -= gregorian::years(1); } } return when; } date_t parse_date_mask(const char * date_str, optional_year year, - date_traits_t * traits = NULL) + date_traits_t * traits = NULL) { if (input_date_io.get()) { date_t when = parse_date_mask_routine(date_str, *input_date_io.get(), - year, traits); + year, traits); if (! when.is_not_a_date()) - return when; + return when; } foreach (shared_ptr<date_io_t>& reader, readers) { date_t when = parse_date_mask_routine(date_str, *reader.get(), - year, traits); + year, traits); if (! when.is_not_a_date()) - return when; + return when; } throw_(date_error, _("Invalid date: %1") << date_str); @@ -344,8 +344,8 @@ date_t date_specifier_t::begin(const optional_year& current_year) const // wday in that month; if the year is set, then in that year. return gregorian::date(static_cast<date_t::year_type>(the_year), - static_cast<date_t::month_type>(the_month), - static_cast<date_t::day_type>(the_day)); + static_cast<date_t::month_type>(the_month), + static_cast<date_t::day_type>(the_day)); } date_t date_specifier_t::end(const optional_year& current_year) const @@ -363,7 +363,7 @@ date_t date_specifier_t::end(const optional_year& current_year) const } std::ostream& operator<<(std::ostream& out, - const date_duration_t& duration) + const date_duration_t& duration) { if (duration.quantum == date_duration_t::DAYS) out << duration.length << " day(s)"; @@ -395,194 +395,194 @@ class date_parser_t struct token_t { enum kind_t { - UNKNOWN, - - TOK_DATE, - TOK_INT, - TOK_SLASH, - TOK_DASH, - TOK_DOT, - - TOK_A_YEAR, - TOK_A_MONTH, - TOK_A_WDAY, - - TOK_SINCE, - TOK_UNTIL, - TOK_IN, - TOK_THIS, - TOK_NEXT, - TOK_LAST, - TOK_EVERY, - - TOK_TODAY, - TOK_TOMORROW, - TOK_YESTERDAY, - - TOK_YEAR, - TOK_QUARTER, - TOK_MONTH, - TOK_WEEK, - TOK_DAY, - - TOK_YEARLY, - TOK_QUARTERLY, - TOK_BIMONTHLY, - TOK_MONTHLY, - TOK_BIWEEKLY, - TOK_WEEKLY, - TOK_DAILY, - - TOK_YEARS, - TOK_QUARTERS, - TOK_MONTHS, - TOK_WEEKS, - TOK_DAYS, - - END_REACHED + UNKNOWN, + + TOK_DATE, + TOK_INT, + TOK_SLASH, + TOK_DASH, + TOK_DOT, + + TOK_A_YEAR, + TOK_A_MONTH, + TOK_A_WDAY, + + TOK_SINCE, + TOK_UNTIL, + TOK_IN, + TOK_THIS, + TOK_NEXT, + TOK_LAST, + TOK_EVERY, + + TOK_TODAY, + TOK_TOMORROW, + TOK_YESTERDAY, + + TOK_YEAR, + TOK_QUARTER, + TOK_MONTH, + TOK_WEEK, + TOK_DAY, + + TOK_YEARLY, + TOK_QUARTERLY, + TOK_BIMONTHLY, + TOK_MONTHLY, + TOK_BIWEEKLY, + TOK_WEEKLY, + TOK_DAILY, + + TOK_YEARS, + TOK_QUARTERS, + TOK_MONTHS, + TOK_WEEKS, + TOK_DAYS, + + END_REACHED } kind; typedef variant<unsigned short, - string, - date_specifier_t::year_type, - date_time::months_of_year, - date_time::weekdays, - date_specifier_t> content_t; + string, + date_specifier_t::year_type, + date_time::months_of_year, + date_time::weekdays, + date_specifier_t> content_t; optional<content_t> value; explicit token_t(kind_t _kind = UNKNOWN, - const optional<content_t>& _value = - content_t(empty_string)) - : kind(_kind), value(_value) { - TRACE_CTOR(date_parser_t::lexer_t::token_t, ""); + const optional<content_t>& _value = + content_t(empty_string)) + : kind(_kind), value(_value) { + TRACE_CTOR(date_parser_t::lexer_t::token_t, ""); } token_t(const token_t& tok) - : kind(tok.kind), value(tok.value) { - TRACE_CTOR(date_parser_t::lexer_t::token_t, "copy"); + : kind(tok.kind), value(tok.value) { + TRACE_CTOR(date_parser_t::lexer_t::token_t, "copy"); } ~token_t() throw() { - TRACE_DTOR(date_parser_t::lexer_t::token_t); + TRACE_DTOR(date_parser_t::lexer_t::token_t); } token_t& operator=(const token_t& tok) { - if (this != &tok) { - kind = tok.kind; - value = tok.value; - } - return *this; + if (this != &tok) { + kind = tok.kind; + value = tok.value; + } + return *this; } operator bool() const { - return kind != END_REACHED; + return kind != END_REACHED; } string to_string() const { - std::ostringstream out; - - switch (kind) { - case UNKNOWN: - out << boost::get<string>(*value); - break; - case TOK_DATE: - return boost::get<date_specifier_t>(*value).to_string(); - case TOK_INT: - out << boost::get<unsigned short>(*value); - break; - case TOK_SLASH: return "/"; - case TOK_DASH: return "-"; - case TOK_DOT: return "."; - case TOK_A_YEAR: - out << boost::get<date_specifier_t::year_type>(*value); - break; - case TOK_A_MONTH: - out << date_specifier_t::month_type - (boost::get<date_time::months_of_year>(*value)); - break; - case TOK_A_WDAY: - out << date_specifier_t::day_of_week_type - (boost::get<date_time::weekdays>(*value)); - break; - case TOK_SINCE: return "since"; - case TOK_UNTIL: return "until"; - case TOK_IN: return "in"; - case TOK_THIS: return "this"; - case TOK_NEXT: return "next"; - case TOK_LAST: return "last"; - case TOK_EVERY: return "every"; - case TOK_TODAY: return "today"; - case TOK_TOMORROW: return "tomorrow"; - case TOK_YESTERDAY: return "yesterday"; - case TOK_YEAR: return "year"; - case TOK_QUARTER: return "quarter"; - case TOK_MONTH: return "month"; - case TOK_WEEK: return "week"; - case TOK_DAY: return "day"; - case TOK_YEARLY: return "yearly"; - case TOK_QUARTERLY: return "quarterly"; - case TOK_BIMONTHLY: return "bimonthly"; - case TOK_MONTHLY: return "monthly"; - case TOK_BIWEEKLY: return "biweekly"; - case TOK_WEEKLY: return "weekly"; - case TOK_DAILY: return "daily"; - case TOK_YEARS: return "years"; - case TOK_QUARTERS: return "quarters"; - case TOK_MONTHS: return "months"; - case TOK_WEEKS: return "weeks"; - case TOK_DAYS: return "days"; - case END_REACHED: return "<EOF>"; - default: - assert(false); - return empty_string; - } - - return out.str(); + std::ostringstream out; + + switch (kind) { + case UNKNOWN: + out << boost::get<string>(*value); + break; + case TOK_DATE: + return boost::get<date_specifier_t>(*value).to_string(); + case TOK_INT: + out << boost::get<unsigned short>(*value); + break; + case TOK_SLASH: return "/"; + case TOK_DASH: return "-"; + case TOK_DOT: return "."; + case TOK_A_YEAR: + out << boost::get<date_specifier_t::year_type>(*value); + break; + case TOK_A_MONTH: + out << date_specifier_t::month_type + (boost::get<date_time::months_of_year>(*value)); + break; + case TOK_A_WDAY: + out << date_specifier_t::day_of_week_type + (boost::get<date_time::weekdays>(*value)); + break; + case TOK_SINCE: return "since"; + case TOK_UNTIL: return "until"; + case TOK_IN: return "in"; + case TOK_THIS: return "this"; + case TOK_NEXT: return "next"; + case TOK_LAST: return "last"; + case TOK_EVERY: return "every"; + case TOK_TODAY: return "today"; + case TOK_TOMORROW: return "tomorrow"; + case TOK_YESTERDAY: return "yesterday"; + case TOK_YEAR: return "year"; + case TOK_QUARTER: return "quarter"; + case TOK_MONTH: return "month"; + case TOK_WEEK: return "week"; + case TOK_DAY: return "day"; + case TOK_YEARLY: return "yearly"; + case TOK_QUARTERLY: return "quarterly"; + case TOK_BIMONTHLY: return "bimonthly"; + case TOK_MONTHLY: return "monthly"; + case TOK_BIWEEKLY: return "biweekly"; + case TOK_WEEKLY: return "weekly"; + case TOK_DAILY: return "daily"; + case TOK_YEARS: return "years"; + case TOK_QUARTERS: return "quarters"; + case TOK_MONTHS: return "months"; + case TOK_WEEKS: return "weeks"; + case TOK_DAYS: return "days"; + case END_REACHED: return "<EOF>"; + default: + assert(false); + return empty_string; + } + + return out.str(); } void dump(std::ostream& out) const { - switch (kind) { - case UNKNOWN: out << "UNKNOWN"; break; - case TOK_DATE: out << "TOK_DATE"; break; - case TOK_INT: out << "TOK_INT"; break; - case TOK_SLASH: out << "TOK_SLASH"; break; - case TOK_DASH: out << "TOK_DASH"; break; - case TOK_DOT: out << "TOK_DOT"; break; - case TOK_A_YEAR: out << "TOK_A_YEAR"; break; - case TOK_A_MONTH: out << "TOK_A_MONTH"; break; - case TOK_A_WDAY: out << "TOK_A_WDAY"; break; - case TOK_SINCE: out << "TOK_SINCE"; break; - case TOK_UNTIL: out << "TOK_UNTIL"; break; - case TOK_IN: out << "TOK_IN"; break; - case TOK_THIS: out << "TOK_THIS"; break; - case TOK_NEXT: out << "TOK_NEXT"; break; - case TOK_LAST: out << "TOK_LAST"; break; - case TOK_EVERY: out << "TOK_EVERY"; break; - case TOK_TODAY: out << "TOK_TODAY"; break; - case TOK_TOMORROW: out << "TOK_TOMORROW"; break; - case TOK_YESTERDAY: out << "TOK_YESTERDAY"; break; - case TOK_YEAR: out << "TOK_YEAR"; break; - case TOK_QUARTER: out << "TOK_QUARTER"; break; - case TOK_MONTH: out << "TOK_MONTH"; break; - case TOK_WEEK: out << "TOK_WEEK"; break; - case TOK_DAY: out << "TOK_DAY"; break; - case TOK_YEARLY: out << "TOK_YEARLY"; break; - case TOK_QUARTERLY: out << "TOK_QUARTERLY"; break; - case TOK_BIMONTHLY: out << "TOK_BIMONTHLY"; break; - case TOK_MONTHLY: out << "TOK_MONTHLY"; break; - case TOK_BIWEEKLY: out << "TOK_BIWEEKLY"; break; - case TOK_WEEKLY: out << "TOK_WEEKLY"; break; - case TOK_DAILY: out << "TOK_DAILY"; break; - case TOK_YEARS: out << "TOK_YEARS"; break; - case TOK_QUARTERS: out << "TOK_QUARTERS"; break; - case TOK_MONTHS: out << "TOK_MONTHS"; break; - case TOK_WEEKS: out << "TOK_WEEKS"; break; - case TOK_DAYS: out << "TOK_DAYS"; break; - case END_REACHED: out << "END_REACHED"; break; - default: - assert(false); - break; - } + switch (kind) { + case UNKNOWN: out << "UNKNOWN"; break; + case TOK_DATE: out << "TOK_DATE"; break; + case TOK_INT: out << "TOK_INT"; break; + case TOK_SLASH: out << "TOK_SLASH"; break; + case TOK_DASH: out << "TOK_DASH"; break; + case TOK_DOT: out << "TOK_DOT"; break; + case TOK_A_YEAR: out << "TOK_A_YEAR"; break; + case TOK_A_MONTH: out << "TOK_A_MONTH"; break; + case TOK_A_WDAY: out << "TOK_A_WDAY"; break; + case TOK_SINCE: out << "TOK_SINCE"; break; + case TOK_UNTIL: out << "TOK_UNTIL"; break; + case TOK_IN: out << "TOK_IN"; break; + case TOK_THIS: out << "TOK_THIS"; break; + case TOK_NEXT: out << "TOK_NEXT"; break; + case TOK_LAST: out << "TOK_LAST"; break; + case TOK_EVERY: out << "TOK_EVERY"; break; + case TOK_TODAY: out << "TOK_TODAY"; break; + case TOK_TOMORROW: out << "TOK_TOMORROW"; break; + case TOK_YESTERDAY: out << "TOK_YESTERDAY"; break; + case TOK_YEAR: out << "TOK_YEAR"; break; + case TOK_QUARTER: out << "TOK_QUARTER"; break; + case TOK_MONTH: out << "TOK_MONTH"; break; + case TOK_WEEK: out << "TOK_WEEK"; break; + case TOK_DAY: out << "TOK_DAY"; break; + case TOK_YEARLY: out << "TOK_YEARLY"; break; + case TOK_QUARTERLY: out << "TOK_QUARTERLY"; break; + case TOK_BIMONTHLY: out << "TOK_BIMONTHLY"; break; + case TOK_MONTHLY: out << "TOK_MONTHLY"; break; + case TOK_BIWEEKLY: out << "TOK_BIWEEKLY"; break; + case TOK_WEEKLY: out << "TOK_WEEKLY"; break; + case TOK_DAILY: out << "TOK_DAILY"; break; + case TOK_YEARS: out << "TOK_YEARS"; break; + case TOK_QUARTERS: out << "TOK_QUARTERS"; break; + case TOK_MONTHS: out << "TOK_MONTHS"; break; + case TOK_WEEKS: out << "TOK_WEEKS"; break; + case TOK_DAYS: out << "TOK_DAYS"; break; + case END_REACHED: out << "END_REACHED"; break; + default: + assert(false); + break; + } } void unexpected(); @@ -592,14 +592,14 @@ class date_parser_t token_t token_cache; lexer_t(string::const_iterator _begin, - string::const_iterator _end) + string::const_iterator _end) : begin(_begin), end(_end) { TRACE_CTOR(date_parser_t::lexer_t, ""); } lexer_t(const lexer_t& lexer) : begin(lexer.begin), end(lexer.end), - token_cache(lexer.token_cache) + token_cache(lexer.token_cache) { TRACE_CTOR(date_parser_t::lexer_t, "copy"); } @@ -614,7 +614,7 @@ class date_parser_t } token_t peek_token() { if (token_cache.kind == token_t::UNKNOWN) - token_cache = next_token(); + token_cache = next_token(); return token_cache; } }; @@ -642,7 +642,7 @@ private: }; void date_parser_t::determine_when(date_parser_t::lexer_t::token_t& tok, - date_specifier_t& specifier) + date_specifier_t& specifier) { switch (tok.kind) { case lexer_t::token_t::TOK_DATE: @@ -680,8 +680,8 @@ date_interval_t date_parser_t::parse() optional<date_specifier_t> inclusion_specifier; date_interval_t period; - date_t today = CURRENT_DATE(); - bool end_inclusive = false; + date_t today = CURRENT_DATE(); + bool end_inclusive = false; for (lexer_t::token_t tok = lexer.next_token(); tok.kind != lexer_t::token_t::END_REACHED; @@ -697,77 +697,77 @@ date_interval_t date_parser_t::parse() case lexer_t::token_t::TOK_DATE: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_INT: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_A_YEAR: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_A_MONTH: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_A_WDAY: if (! inclusion_specifier) - inclusion_specifier = date_specifier_t(); + inclusion_specifier = date_specifier_t(); determine_when(tok, *inclusion_specifier); break; case lexer_t::token_t::TOK_DASH: if (inclusion_specifier) { - since_specifier = inclusion_specifier; - until_specifier = date_specifier_t(); - inclusion_specifier = none; + since_specifier = inclusion_specifier; + until_specifier = date_specifier_t(); + inclusion_specifier = none; - tok = lexer.next_token(); - determine_when(tok, *until_specifier); + tok = lexer.next_token(); + determine_when(tok, *until_specifier); - // The dash operator is special: it has an _inclusive_ end. - end_inclusive = true; + // The dash operator is special: it has an _inclusive_ end. + end_inclusive = true; } else { - tok.unexpected(); + tok.unexpected(); } break; case lexer_t::token_t::TOK_SINCE: if (since_specifier) { - tok.unexpected(); + tok.unexpected(); } else { - since_specifier = date_specifier_t(); - tok = lexer.next_token(); - determine_when(tok, *since_specifier); + since_specifier = date_specifier_t(); + tok = lexer.next_token(); + determine_when(tok, *since_specifier); } break; case lexer_t::token_t::TOK_UNTIL: if (until_specifier) { - tok.unexpected(); + tok.unexpected(); } else { - until_specifier = date_specifier_t(); - tok = lexer.next_token(); - determine_when(tok, *until_specifier); + until_specifier = date_specifier_t(); + tok = lexer.next_token(); + determine_when(tok, *until_specifier); } break; case lexer_t::token_t::TOK_IN: if (inclusion_specifier) { - tok.unexpected(); + tok.unexpected(); } else { - inclusion_specifier = date_specifier_t(); - tok = lexer.next_token(); - determine_when(tok, *inclusion_specifier); + inclusion_specifier = date_specifier_t(); + tok = lexer.next_token(); + determine_when(tok, *inclusion_specifier); } break; @@ -776,90 +776,90 @@ date_interval_t date_parser_t::parse() case lexer_t::token_t::TOK_LAST: { int8_t adjust = 0; if (tok.kind == lexer_t::token_t::TOK_NEXT) - adjust = 1; + adjust = 1; else if (tok.kind == lexer_t::token_t::TOK_LAST) - adjust = -1; + adjust = -1; tok = lexer.next_token(); switch (tok.kind) { case lexer_t::token_t::TOK_INT: - // jww (2009-11-18): Allow things like "last 5 weeks" - assert(! "Need to allow for expressions like \"last 5 weeks\""); - tok.unexpected(); - break; + // jww (2009-11-18): Allow things like "last 5 weeks" + assert(! "Need to allow for expressions like \"last 5 weeks\""); + tok.unexpected(); + break; case lexer_t::token_t::TOK_A_MONTH: { - inclusion_specifier = date_specifier_t(); - determine_when(tok, *inclusion_specifier); - - date_t temp(today.year(), *inclusion_specifier->month, 1); - temp += gregorian::years(adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), - temp.month()); - break; + inclusion_specifier = date_specifier_t(); + determine_when(tok, *inclusion_specifier); + + date_t temp(today.year(), *inclusion_specifier->month, 1); + temp += gregorian::years(adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), + temp.month()); + break; } case lexer_t::token_t::TOK_A_WDAY: { - inclusion_specifier = date_specifier_t(); - determine_when(tok, *inclusion_specifier); - - date_t temp = - date_duration_t::find_nearest(today, date_duration_t::WEEKS); - while (temp.day_of_week() != inclusion_specifier->wday) - temp += gregorian::days(1); - temp += gregorian::days(7 * adjust); - inclusion_specifier = date_specifier_t(temp); - break; + inclusion_specifier = date_specifier_t(); + determine_when(tok, *inclusion_specifier); + + date_t temp = + date_duration_t::find_nearest(today, date_duration_t::WEEKS); + while (temp.day_of_week() != inclusion_specifier->wday) + temp += gregorian::days(1); + temp += gregorian::days(7 * adjust); + inclusion_specifier = date_specifier_t(temp); + break; } case lexer_t::token_t::TOK_YEAR: { - date_t temp(today); - temp += gregorian::years(adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year())); - break; + date_t temp(today); + temp += gregorian::years(adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year())); + break; } case lexer_t::token_t::TOK_QUARTER: { - date_t temp = - date_duration_t::find_nearest(today, date_duration_t::QUARTERS); - temp += gregorian::months(3 * adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), - temp.month()); + date_t temp = + date_duration_t::find_nearest(today, date_duration_t::QUARTERS); + temp += gregorian::months(3 * adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), + temp.month()); #if 0 - period.duration = date_duration_t(date_duration_t::QUARTERS, 1); + period.duration = date_duration_t(date_duration_t::QUARTERS, 1); #endif - break; + break; } case lexer_t::token_t::TOK_WEEK: { - date_t temp = - date_duration_t::find_nearest(today, date_duration_t::WEEKS); - temp += gregorian::days(7 * adjust); - inclusion_specifier = date_specifier_t(today); + date_t temp = + date_duration_t::find_nearest(today, date_duration_t::WEEKS); + temp += gregorian::days(7 * adjust); + inclusion_specifier = date_specifier_t(today); #if 0 - period.duration = date_duration_t(date_duration_t::WEEKS, 1); + period.duration = date_duration_t(date_duration_t::WEEKS, 1); #endif - break; + break; } case lexer_t::token_t::TOK_DAY: { - date_t temp(today); - temp += gregorian::days(adjust); - inclusion_specifier = date_specifier_t(temp); - break; + date_t temp(today); + temp += gregorian::days(adjust); + inclusion_specifier = date_specifier_t(temp); + break; } default: case lexer_t::token_t::TOK_MONTH: { - date_t temp(today); - temp += gregorian::months(adjust); - inclusion_specifier = - date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), - temp.month()); - break; + date_t temp(today); + temp += gregorian::months(adjust); + inclusion_specifier = + date_specifier_t(static_cast<date_specifier_t::year_type>(temp.year()), + temp.month()); + break; } } } @@ -877,49 +877,49 @@ date_interval_t date_parser_t::parse() case lexer_t::token_t::TOK_EVERY: tok = lexer.next_token(); if (tok == lexer_t::token_t::TOK_INT) { - int quantity = boost::get<unsigned short>(*tok.value); - tok = lexer.next_token(); - switch (tok.kind) { - case lexer_t::token_t::TOK_YEARS: - period.duration = date_duration_t(date_duration_t::YEARS, quantity); - break; - case lexer_t::token_t::TOK_QUARTERS: - period.duration = date_duration_t(date_duration_t::QUARTERS, quantity); - break; - case lexer_t::token_t::TOK_MONTHS: - period.duration = date_duration_t(date_duration_t::MONTHS, quantity); - break; - case lexer_t::token_t::TOK_WEEKS: - period.duration = date_duration_t(date_duration_t::WEEKS, quantity); - break; - case lexer_t::token_t::TOK_DAYS: - period.duration = date_duration_t(date_duration_t::DAYS, quantity); - break; - default: - tok.unexpected(); - break; - } + int quantity = boost::get<unsigned short>(*tok.value); + tok = lexer.next_token(); + switch (tok.kind) { + case lexer_t::token_t::TOK_YEARS: + period.duration = date_duration_t(date_duration_t::YEARS, quantity); + break; + case lexer_t::token_t::TOK_QUARTERS: + period.duration = date_duration_t(date_duration_t::QUARTERS, quantity); + break; + case lexer_t::token_t::TOK_MONTHS: + period.duration = date_duration_t(date_duration_t::MONTHS, quantity); + break; + case lexer_t::token_t::TOK_WEEKS: + period.duration = date_duration_t(date_duration_t::WEEKS, quantity); + break; + case lexer_t::token_t::TOK_DAYS: + period.duration = date_duration_t(date_duration_t::DAYS, quantity); + break; + default: + tok.unexpected(); + break; + } } else { - switch (tok.kind) { - case lexer_t::token_t::TOK_YEAR: - period.duration = date_duration_t(date_duration_t::YEARS, 1); - break; - case lexer_t::token_t::TOK_QUARTER: - period.duration = date_duration_t(date_duration_t::QUARTERS, 1); - break; - case lexer_t::token_t::TOK_MONTH: - period.duration = date_duration_t(date_duration_t::MONTHS, 1); - break; - case lexer_t::token_t::TOK_WEEK: - period.duration = date_duration_t(date_duration_t::WEEKS, 1); - break; - case lexer_t::token_t::TOK_DAY: - period.duration = date_duration_t(date_duration_t::DAYS, 1); - break; - default: - tok.unexpected(); - break; - } + switch (tok.kind) { + case lexer_t::token_t::TOK_YEAR: + period.duration = date_duration_t(date_duration_t::YEARS, 1); + break; + case lexer_t::token_t::TOK_QUARTER: + period.duration = date_duration_t(date_duration_t::QUARTERS, 1); + break; + case lexer_t::token_t::TOK_MONTH: + period.duration = date_duration_t(date_duration_t::MONTHS, 1); + break; + case lexer_t::token_t::TOK_WEEK: + period.duration = date_duration_t(date_duration_t::WEEKS, 1); + break; + case lexer_t::token_t::TOK_DAY: + period.duration = date_duration_t(date_duration_t::DAYS, 1); + break; + default: + tok.unexpected(); + break; + } } break; @@ -983,13 +983,13 @@ void date_interval_t::resolve_end() if (start && ! end_of_duration) { end_of_duration = duration->add(*start); DEBUG("times.interval", - "stabilize: end_of_duration = " << *end_of_duration); + "stabilize: end_of_duration = " << *end_of_duration); } if (finish && *end_of_duration > *finish) { end_of_duration = finish; DEBUG("times.interval", - "stabilize: end_of_duration reset to end: " << *end_of_duration); + "stabilize: end_of_duration reset to end: " << *end_of_duration); } if (start && ! next) { @@ -1009,9 +1009,9 @@ date_t date_duration_t::find_nearest(const date_t& date, skip_quantum_t skip) case date_duration_t::QUARTERS: result = date_t(date.year(), date.month(), 1); while (result.month() != gregorian::Jan && - result.month() != gregorian::Apr && - result.month() != gregorian::Jul && - result.month() != gregorian::Oct) + result.month() != gregorian::Apr && + result.month() != gregorian::Jul && + result.month() != gregorian::Oct) result -= gregorian::months(1); break; case date_duration_t::MONTHS: @@ -1043,7 +1043,7 @@ void date_interval_t::stabilize(const optional<date_t>& date) DEBUG("times.interval", "stabilize: date passed, but not aligned"); if (duration) { DEBUG("times.interval", - "stabilize: aligning with a duration: " << *duration); + "stabilize: aligning with a duration: " << *duration); // The interval object has not been seeded with a start date yet, so // find the nearest period before on on date which fits, if possible. @@ -1057,71 +1057,71 @@ void date_interval_t::stabilize(const optional<date_t>& date) #if defined(DEBUG_ON) if (initial_start) - DEBUG("times.interval", - "stabilize: initial_start = " << *initial_start); + DEBUG("times.interval", + "stabilize: initial_start = " << *initial_start); if (initial_finish) - DEBUG("times.interval", - "stabilize: initial_finish = " << *initial_finish); + DEBUG("times.interval", + "stabilize: initial_finish = " << *initial_finish); #endif date_t when = start ? *start : *date; if (duration->quantum == date_duration_t::MONTHS || - duration->quantum == date_duration_t::QUARTERS || - duration->quantum == date_duration_t::YEARS) { - DEBUG("times.interval", - "stabilize: monthly, quarterly or yearly duration"); - start = date_duration_t::find_nearest(when, duration->quantum); + duration->quantum == date_duration_t::QUARTERS || + duration->quantum == date_duration_t::YEARS) { + DEBUG("times.interval", + "stabilize: monthly, quarterly or yearly duration"); + start = date_duration_t::find_nearest(when, duration->quantum); } else { - DEBUG("times.interval", "stabilize: daily or weekly duration"); - start = date_duration_t::find_nearest(when - gregorian::days(400), - duration->quantum); + DEBUG("times.interval", "stabilize: daily or weekly duration"); + start = date_duration_t::find_nearest(when - gregorian::days(400), + duration->quantum); } DEBUG("times.interval", - "stabilize: beginning start date = " << *start); + "stabilize: beginning start date = " << *start); while (*start < *date) { - date_interval_t next_interval(*this); - ++next_interval; - - if (next_interval.start && *next_interval.start < *date) { - *this = next_interval; - } else { - end_of_duration = none; - next = none; - break; - } + date_interval_t next_interval(*this); + ++next_interval; + + if (next_interval.start && *next_interval.start < *date) { + *this = next_interval; + } else { + end_of_duration = none; + next = none; + break; + } } DEBUG("times.interval", "stabilize: proposed start date = " << *start); if (initial_start && (! start || *start < *initial_start)) { - // Using the discovered start, find the end of the period - resolve_end(); + // Using the discovered start, find the end of the period + resolve_end(); - start = initial_start; - DEBUG("times.interval", "stabilize: start reset to initial start"); + start = initial_start; + DEBUG("times.interval", "stabilize: start reset to initial start"); } if (initial_finish && (! finish || *finish > *initial_finish)) { - finish = initial_finish; - DEBUG("times.interval", "stabilize: finish reset to initial finish"); + finish = initial_finish; + DEBUG("times.interval", "stabilize: finish reset to initial finish"); } #if defined(DEBUG_ON) if (start) - DEBUG("times.interval", "stabilize: final start = " << *start); + DEBUG("times.interval", "stabilize: final start = " << *start); if (finish) - DEBUG("times.interval", "stabilize: final finish = " << *finish); + DEBUG("times.interval", "stabilize: final finish = " << *finish); #endif } else if (range) { if (date) { - start = range->begin(date->year()); - finish = range->end(date->year()); + start = range->begin(date->year()); + finish = range->end(date->year()); } else { - start = range->begin(); - finish = range->end(); + start = range->begin(); + finish = range->end(); } } aligned = true; @@ -1134,7 +1134,7 @@ void date_interval_t::stabilize(const optional<date_t>& date) if (! start && ! finish) throw_(date_error, - _("Invalid date interval: neither start, nor finish, nor duration")); + _("Invalid date interval: neither start, nor finish, nor duration")); } else { resolve_end(); } @@ -1146,7 +1146,7 @@ bool date_interval_t::find_period(const date_t& date) if (finish && date > *finish) { DEBUG("times.interval", - "false: date [" << date << "] > finish [" << *finish << "]"); + "false: date [" << date << "] > finish [" << *finish << "]"); return false; } @@ -1155,15 +1155,15 @@ bool date_interval_t::find_period(const date_t& date) } else if (date < *start) { DEBUG("times.interval", - "false: date [" << date << "] < start [" << *start << "]"); + "false: date [" << date << "] < start [" << *start << "]"); return false; } if (end_of_duration) { if (date < *end_of_duration) { DEBUG("times.interval", - "true: date [" << date << "] < end_of_duration [" - << *end_of_duration << "]"); + "true: date [" << date << "] < end_of_duration [" + << *end_of_duration << "]"); return true; } } else { @@ -1185,17 +1185,17 @@ bool date_interval_t::find_period(const date_t& date) while (date >= scan && (! finish || scan < *finish)) { if (date < end_of_scan) { - start = scan; + start = scan; end_of_duration = end_of_scan; - next = none; + next = none; - DEBUG("times.interval", "true: start = " << *start); + DEBUG("times.interval", "true: start = " << *start); DEBUG("times.interval", "true: end_of_duration = " << *end_of_duration); return true; } - scan = duration->add(scan); + scan = duration->add(scan); end_of_scan = duration->add(scan); } @@ -1211,7 +1211,7 @@ date_interval_t& date_interval_t::operator++() if (! duration) throw_(date_error, - _("Cannot increment a date interval without a duration")); + _("Cannot increment a date interval without a duration")); assert(next); @@ -1319,16 +1319,16 @@ date_parser_t::lexer_t::token_t date_parser_t::lexer_t::next_token() date_traits_t traits; date_t when = parse_date_mask(possible_date.c_str(), none, &traits); if (! when.is_not_a_date()) { - begin = i; - return token_t(token_t::TOK_DATE, - token_t::content_t(date_specifier_t(when, traits))); + begin = i; + return token_t(token_t::TOK_DATE, + token_t::content_t(date_specifier_t(when, traits))); } } catch (date_error&) { if (contains(possible_date, "/") || - contains(possible_date, "-") || - contains(possible_date, ".")) - throw; + contains(possible_date, "-") || + contains(possible_date, ".")) + throw; } } @@ -1337,85 +1337,85 @@ date_parser_t::lexer_t::token_t date_parser_t::lexer_t::next_token() string term; bool alnum = std::isalnum(*begin); for (; (begin != end && ! std::isspace(*begin) && - ((alnum && static_cast<bool>(std::isalnum(*begin))) || - (! alnum && ! static_cast<bool>(std::isalnum(*begin))))); begin++) + ((alnum && static_cast<bool>(std::isalnum(*begin))) || + (! alnum && ! static_cast<bool>(std::isalnum(*begin))))); begin++) term.push_back(*begin); if (! term.empty()) { if (std::isdigit(term[0])) { if (term.length() == 4) - return token_t(token_t::TOK_A_YEAR, - token_t::content_t - (lexical_cast<date_specifier_t::year_type>(term))); + return token_t(token_t::TOK_A_YEAR, + token_t::content_t + (lexical_cast<date_specifier_t::year_type>(term))); else - return token_t(token_t::TOK_INT, - token_t::content_t(lexical_cast<unsigned short>(term))); + return token_t(token_t::TOK_INT, + token_t::content_t(lexical_cast<unsigned short>(term))); } else if (std::isalpha(term[0])) { to_lower(term); if (optional<date_time::months_of_year> month = - string_to_month_of_year(term)) { - return token_t(token_t::TOK_A_MONTH, token_t::content_t(*month)); + string_to_month_of_year(term)) { + return token_t(token_t::TOK_A_MONTH, token_t::content_t(*month)); } else if (optional<date_time::weekdays> wday = - string_to_day_of_week(term)) { - return token_t(token_t::TOK_A_WDAY, token_t::content_t(*wday)); + string_to_day_of_week(term)) { + return token_t(token_t::TOK_A_WDAY, token_t::content_t(*wday)); } else if (term == _("from") || term == _("since")) - return token_t(token_t::TOK_SINCE); + return token_t(token_t::TOK_SINCE); else if (term == _("to") || term == _("until")) - return token_t(token_t::TOK_UNTIL); + return token_t(token_t::TOK_UNTIL); else if (term == _("in")) - return token_t(token_t::TOK_IN); + return token_t(token_t::TOK_IN); else if (term == _("this")) - return token_t(token_t::TOK_THIS); + return token_t(token_t::TOK_THIS); else if (term == _("next")) - return token_t(token_t::TOK_NEXT); + return token_t(token_t::TOK_NEXT); else if (term == _("last")) - return token_t(token_t::TOK_LAST); + return token_t(token_t::TOK_LAST); else if (term == _("every")) - return token_t(token_t::TOK_EVERY); + return token_t(token_t::TOK_EVERY); else if (term == _("today")) - return token_t(token_t::TOK_TODAY); + return token_t(token_t::TOK_TODAY); else if (term == _("tomorrow")) - return token_t(token_t::TOK_TOMORROW); + return token_t(token_t::TOK_TOMORROW); else if (term == _("yesterday")) - return token_t(token_t::TOK_YESTERDAY); + return token_t(token_t::TOK_YESTERDAY); else if (term == _("year")) - return token_t(token_t::TOK_YEAR); + return token_t(token_t::TOK_YEAR); else if (term == _("quarter")) - return token_t(token_t::TOK_QUARTER); + return token_t(token_t::TOK_QUARTER); else if (term == _("month")) - return token_t(token_t::TOK_MONTH); + return token_t(token_t::TOK_MONTH); else if (term == _("week")) - return token_t(token_t::TOK_WEEK); + return token_t(token_t::TOK_WEEK); else if (term == _("day")) - return token_t(token_t::TOK_DAY); + return token_t(token_t::TOK_DAY); else if (term == _("yearly")) - return token_t(token_t::TOK_YEARLY); + return token_t(token_t::TOK_YEARLY); else if (term == _("quarterly")) - return token_t(token_t::TOK_QUARTERLY); + return token_t(token_t::TOK_QUARTERLY); else if (term == _("bimonthly")) - return token_t(token_t::TOK_BIMONTHLY); + return token_t(token_t::TOK_BIMONTHLY); else if (term == _("monthly")) - return token_t(token_t::TOK_MONTHLY); + return token_t(token_t::TOK_MONTHLY); else if (term == _("biweekly")) - return token_t(token_t::TOK_BIWEEKLY); + return token_t(token_t::TOK_BIWEEKLY); else if (term == _("weekly")) - return token_t(token_t::TOK_WEEKLY); + return token_t(token_t::TOK_WEEKLY); else if (term == _("daily")) - return token_t(token_t::TOK_DAILY); + return token_t(token_t::TOK_DAILY); else if (term == _("years")) - return token_t(token_t::TOK_YEARS); + return token_t(token_t::TOK_YEARS); else if (term == _("quarters")) - return token_t(token_t::TOK_QUARTERS); + return token_t(token_t::TOK_QUARTERS); else if (term == _("months")) - return token_t(token_t::TOK_MONTHS); + return token_t(token_t::TOK_MONTHS); else if (term == _("weeks")) - return token_t(token_t::TOK_WEEKS); + return token_t(token_t::TOK_WEEKS); else if (term == _("days")) - return token_t(token_t::TOK_DAYS); + return token_t(token_t::TOK_DAYS); } else { token_t::expected('\0', term[0]); @@ -1462,12 +1462,12 @@ namespace { typedef std::map<std::string, date_io_t *> date_io_map; datetime_io_map temp_datetime_io; - date_io_map temp_date_io; + date_io_map temp_date_io; } -std::string format_datetime(const datetime_t& when, - const format_type_t format_type, - const optional<const char *>& format) +std::string format_datetime(const datetime_t& when, + const format_type_t format_type, + const optional<const char *>& format) { if (format_type == FMT_WRITTEN) { return written_datetime_io->format(when); @@ -1491,9 +1491,9 @@ std::string format_datetime(const datetime_t& when, } } -std::string format_date(const date_t& when, - const format_type_t format_type, - const optional<const char *>& format) +std::string format_date(const date_t& when, + const format_type_t format_type, + const optional<const char *>& format) { if (format_type == FMT_WRITTEN) { return written_date_io->format(when); |