diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/event.c | 7 | ||||
-rw-r--r-- | src/recur.c | 7 |
2 files changed, 12 insertions, 2 deletions
diff --git a/src/event.c b/src/event.c index e8694ed..3918ce3 100644 --- a/src/event.c +++ b/src/event.c @@ -124,7 +124,7 @@ struct event *event_scan(FILE * f, struct tm start, int id, char *note, struct item_filter *filter) { char buf[BUFSIZ], *nl; - time_t tstart; + time_t tstart, tend; EXIT_IF(!check_date(start.tm_year, start.tm_mon, start.tm_mday) || !check_time(start.tm_hour, start.tm_min), @@ -147,6 +147,7 @@ struct event *event_scan(FILE * f, struct tm start, int id, char *note, tstart = mktime(&start); EXIT_IF(tstart == -1, _("date error in the event\n")); + tend = tstart + DAYINSEC - 1; /* Filter item. */ if (filter) { @@ -158,6 +159,10 @@ struct event *event_scan(FILE * f, struct tm start, int id, char *note, return NULL; if (filter->start_to >= 0 && tstart > filter->start_to) return NULL; + if (filter->end_from >= 0 && tend < filter->end_from) + return NULL; + if (filter->end_to >= 0 && tend > filter->end_to) + return NULL; } return event_new(buf, note, tstart, id); diff --git a/src/recur.c b/src/recur.c index 667ecdf..2fa2d03 100644 --- a/src/recur.c +++ b/src/recur.c @@ -403,7 +403,7 @@ struct recur_event *recur_event_scan(FILE * f, struct tm start, int id, struct item_filter *filter) { char buf[BUFSIZ], *nl; - time_t tstart, tuntil; + time_t tstart, tend, tuntil; EXIT_IF(!check_date(start.tm_year, start.tm_mon, start.tm_mday) || !check_time(start.tm_hour, start.tm_min) || @@ -434,6 +434,7 @@ struct recur_event *recur_event_scan(FILE * f, struct tm start, int id, } tstart = mktime(&start); EXIT_IF(tstart == -1 || tuntil == -1, _("date error in event")); + tend = tstart + DAYINSEC - 1; /* Filter item. */ if (filter) { @@ -445,6 +446,10 @@ struct recur_event *recur_event_scan(FILE * f, struct tm start, int id, return NULL; if (filter->start_to >= 0 && tstart > filter->start_to) return NULL; + if (filter->end_from >= 0 && tend < filter->end_from) + return NULL; + if (filter->end_to >= 0 && tend > filter->end_to) + return NULL; } return recur_event_new(buf, note, tstart, id, recur_char2def(type), |