(*last)->next = *next;
else
(*first) = *next;
+ (*next)->prev = *last;
(*last) = (*next);
(*next) = (*next)->next;
}
(*last)->next = *next;
else
(*first) = *next;
+ (*next)->prev = *last;
(*last) = (*next);
(*next) = (*next)->next;
}
ical_cals());
/* Load data */
- cal_load(YEAR, MONTH, DAY, 1);
+ cal_load(SEL.year, SEL.month, SEL.day, 1);
/* Debug */
+#ifdef DEBUG_CALS
for (event_t *e = EVENTS; e; e = e->next)
debug("event: %04d-%02d-%02d %02d:%02d: %s - %s",
e->start.year, e->start.month, e->start.day,
debug("todo: %04d-%02d-%02d %02d:%02d: %s - %s",
e->start.year, e->start.month, e->start.day,
e->start.hour, e->start.min, e->name, e->desc);
+#endif
}
/* Load events and todos */
add_days(&eyear, &emonth, &eday, days);
/* Skip if we already loaded enough info */
- if (!before(&start, year, month, day, 0, 0) &&
- before(&end, eyear, emonth, eday, 24, 0))
+ if (before(&start, year, month, day, 0, 0) &&
+ !before(&end, eyear, emonth, eday, 24, 0))
return;
/* Free uneeded data */
dummy_todos(start, end),
ical_todos(start, end));
+ /* Verify events and todos*/
+#ifdef DEBUG_CALS
+ for (event_t *cur = EVENTS; cur; cur = cur->next) {
+ if (!cur->cal)
+ error("Missing cal in event '%s'", cur->name);
+ if ((cur->next && cur->next->prev != cur) ||
+ (cur->prev && cur->prev->next != cur))
+ error("Broken link in event '%s'", cur->name);
+ }
+ for (todo_t *cur = TODOS; cur; cur = cur->next) {
+ if (!cur->cal)
+ error("Missing cal in todo '%s'", cur->name);
+ if ((cur->next && cur->next->prev != cur) ||
+ (cur->prev && cur->prev->next != cur))
+ error("Broken link in todo '%s'", cur->name);
+ }
+#endif
}
/* Config parser */