Made the transaction date parser a bit more strict
This commit is contained in:
parent
41212cd4c1
commit
38e165a994
1 changed files with 12 additions and 9 deletions
21
src/item.cc
21
src/item.cc
|
|
@ -118,17 +118,20 @@ void item_t::set_tag(const string& tag,
|
||||||
void item_t::parse_tags(const char * p, optional<date_t::year_type> current_year)
|
void item_t::parse_tags(const char * p, optional<date_t::year_type> current_year)
|
||||||
{
|
{
|
||||||
if (const char * b = std::strchr(p, '[')) {
|
if (const char * b = std::strchr(p, '[')) {
|
||||||
if (const char * e = std::strchr(p, ']')) {
|
if (*(b + 1) != '\0' &&
|
||||||
char buf[256];
|
(std::isdigit(*(b + 1)) || *(b + 1) == '=')) {
|
||||||
std::strncpy(buf, b + 1, e - b - 1);
|
if (const char * e = std::strchr(p, ']')) {
|
||||||
buf[e - b - 1] = '\0';
|
char buf[256];
|
||||||
|
std::strncpy(buf, b + 1, e - b - 1);
|
||||||
|
buf[e - b - 1] = '\0';
|
||||||
|
|
||||||
if (char * p = std::strchr(buf, '=')) {
|
if (char * p = std::strchr(buf, '=')) {
|
||||||
*p++ = '\0';
|
*p++ = '\0';
|
||||||
_date_eff = parse_date(p, current_year);
|
_date_eff = parse_date(p, current_year);
|
||||||
|
}
|
||||||
|
if (buf[0])
|
||||||
|
_date = parse_date(buf, current_year);
|
||||||
}
|
}
|
||||||
if (buf[0])
|
|
||||||
_date = parse_date(buf, current_year);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue