+time_t time_for_past_day(int day) {
+ time_t t;
+ struct tm *tm;
+ int delta_day;
+ t = time(0);
+ tm = localtime(&t);
+ delta_day = (7 + tm->tm_wday - day) % 7;
+ if(delta_day == 0) { delta_day = 7; }
+ return t - (delta_day * 3600 * 24 + tm->tm_sec + 60 * tm->tm_min + 3600 * tm->tm_hour);
+}
+
+void init_condition(struct search_condition *condition, const char *full_string,
+ const char *default_search_field) {
+ char full_search_field[TOKEN_BUFFER_SIZE], *search_field;
+ unsigned int k, m;
+ const char *string;
+
+ string = parse_token(full_search_field, TOKEN_BUFFER_SIZE, ' ', full_string);
+ search_field = full_search_field;
+
+ if(search_field[0] == '!') {
+ search_field++;
+ condition->negation = 1;
+ } else {
+ condition->negation = 0;
+ }
+
+ condition->field_id = -1;
+
+ /* Recently */
+
+ for(k = 0; k < sizeof(time_criteria) / sizeof(struct time_criterion); k++) {
+ if(strcmp(time_criteria[k].label, search_field) == 0) {
+ condition->field_id = ID_INTERVAL;
+ if(time_criteria[k].past_week_day < 0) {
+ condition->interval_start = time(0) - 3600 * time_criteria[k].start_hour;
+ if(time_criteria[k].end_hour >= 0) {
+ condition->interval_stop = time(0) - 3600 * time_criteria[k].end_hour;
+ } else {
+ condition->interval_stop = 0;
+ }
+ } else {
+ condition->interval_start = time_for_past_day(time_criteria[k].past_week_day);
+ condition->interval_stop = condition->interval_start + 3600 * 24;
+ }
+ break;
+ }
+ }
+
+ if(condition->field_id == -1) {
+
+ /* No time condition matched, look for the search fields */
+
+ for(m = 0; (m < MAX_ID) && condition->field_id == -1; m++) {
+ if(strncmp(field_names[m], search_field, strlen(search_field)) == 0) {
+ condition->field_id = m;
+ }
+ }
+
+ /* None match, if there is a default search field, re-run the search with it */
+
+ if(condition->field_id == -1) {
+ if(default_search_field) {
+ for(m = 0; (m < MAX_ID) && condition->field_id == -1; m++) {
+ if(strncmp(field_names[m],
+ default_search_field, strlen(default_search_field)) == 0) {
+ condition->field_id = m;
+ }
+ }
+ string = full_string;
+ }
+ }
+
+ if(condition->field_id == -1) {
+ fprintf(stderr,
+ "mymail: Syntax error in field name \"%s\".\n",
+ search_field);
+ exit(EXIT_FAILURE);
+ }
+
+ if(regcomp(&condition->regexp,
+ string,
+ REG_ICASE)) {
+ fprintf(stderr,
+ "mymail: Syntax error in regexp \"%s\" for field \"%s\".\n",
+ string,
+ field_names[condition->field_id]);
+ exit(EXIT_FAILURE);
+ }
+ }
+}
+
+void free_condition(struct search_condition *condition) {
+ if(condition->field_id != ID_INTERVAL) {
+ regfree(&condition->regexp);
+ }
+}
+
+/*********************************************************************/
+/*********************************************************************/
+/*********************************************************************/
+