X-Git-Url: https://fleuret.org/cgi-bin/gitweb/gitweb.cgi?a=blobdiff_plain;f=mymail.c;h=80864d28ad90d568d4ad3bc30d884bfd6e4c37d7;hb=d2d42bbbc5910878fd44cea75beff781255162b6;hp=88c01f509a5da89808282ef097696831815c96c9;hpb=00434484dd0b89eb91cb6ea9be03eeaee1f97751;p=mymail.git diff --git a/mymail.c b/mymail.c index 88c01f5..80864d2 100644 --- a/mymail.c +++ b/mymail.c @@ -57,12 +57,19 @@ #define LEADING_FROM_LINE_REGEXP_STRING "^From .*\\(Mon\\|Tue\\|Wed\\|Thu\\|Fri\\|Sat\\|Sun\\) \\(Jan\\|Feb\\|Mar\\|Apr\\|May\\|Jun\\|Jul\\|Aug\\|Sep\\|Oct\\|Nov\\|Dec\\) [ 0123][0-9] [0-9][0-9]:[0-9][0-9]:[0-9][0-9] [0-9][0-9][0-9][0-9]\n$" +/********************************************************************/ + +struct alias_node { + char *alias, *value; + struct alias_node *next; +}; + /* Global variables! */ int global_quiet; int global_use_leading_time; - regex_t global_leading_from_line_regexp; +struct alias_node *global_alias_list; /********************************************************************/ @@ -186,6 +193,18 @@ char *default_value(char *current_value, } } +/********************************************************************/ + +void *safe_malloc(size_t n) { + void *p = malloc(n); + if(!p && n != 0) { + fprintf(stderr, + "selector: cannot allocate memory: %s\n", strerror(errno)); + exit(EXIT_FAILURE); + } + return p; +} + FILE *safe_fopen(const char *path, const char *mode, const char *comment) { FILE *result = fopen(path, mode); if(result) { @@ -396,6 +415,8 @@ void update_time(int db_key, const char *db_value, time_t *t) { const char *c; struct tm tm; + memset(&tm, 0, sizeof(struct tm)); + if(db_key == ID_LEADING_LINE) { c = db_value; while(*c && *c != ' ') c++; while(*c && *c == ' ') c++; @@ -804,6 +825,14 @@ void init_condition(struct search_condition *condition, const char *full_string, char full_search_field[TOKEN_BUFFER_SIZE], *search_field; unsigned int k, m; const char *string; + struct alias_node *a; + + for(a = global_alias_list; a; a = a->next) { + if(strcmp(full_string, a->alias) == 0) { + full_string = a->value; + break; + } + } string = parse_token(full_search_field, TOKEN_BUFFER_SIZE, ' ', full_string); search_field = full_search_field; @@ -888,6 +917,72 @@ void free_condition(struct search_condition *condition) { } } +const char *eat_space(const char *s) { + while(*s == ' ' || *s == '\t') { s++; } + return s; +} + +void read_rc_file(const char *rc_filename) { + char raw_line[BUFFER_SIZE]; + char command[TOKEN_BUFFER_SIZE], tmp_token[TOKEN_BUFFER_SIZE]; + + FILE *rc_file; + int line_number; + const char *s; + char *t; + + rc_file = fopen(rc_filename, "r"); + + if(rc_file) { + line_number = 1; + while(fgets(raw_line, BUFFER_SIZE, rc_file)) { + t = raw_line; + while(*t) { if(*t == '\n') { *t = '\0'; }; t++; } + + s = raw_line; + s = eat_space(s); + + if(*s && *s != '#') { + s = parse_token(command, TOKEN_BUFFER_SIZE, ' ', s); + + if(strcmp(command, "alias") == 0) { + struct alias_node *a = safe_malloc(sizeof(struct alias_node)); + a->next = global_alias_list; + global_alias_list = a; + if(s) { + s = eat_space(s); + s = parse_token(tmp_token, TOKEN_BUFFER_SIZE, '=', s); + a->alias = strdup(tmp_token); + if(s) { + s = eat_space(s); + a->value = strdup(s); + } else { + fprintf(stderr, "%s:%d syntax error, missing alias value.\n", + rc_filename, + line_number); + exit(EXIT_FAILURE); + } + } else { + fprintf(stderr, "%s:%d syntax error, missing alias key.\n", + rc_filename, + line_number); + exit(EXIT_FAILURE); + } + } else { + fprintf(stderr, "%s:%d syntax error, unknown command '%s'.\n", + rc_filename, + line_number, + command); + exit(EXIT_FAILURE); + } + } + + line_number++; + } + fclose(rc_file); + } +} + /*********************************************************************/ /*********************************************************************/ /*********************************************************************/ @@ -900,6 +995,7 @@ int main(int argc, char **argv) { char *mbox_filename_regexp_string = 0; char *default_search_field; char output_filename[PATH_MAX + 1]; + char rc_filename[PATH_MAX + 1]; int action_index = 0; int error = 0, show_help = 0; const unsigned int nb_fields_to_parse = @@ -908,6 +1004,7 @@ int main(int argc, char **argv) { unsigned int f, n; unsigned int nb_search_conditions; struct search_condition search_conditions[MAX_NB_SEARCH_CONDITIONS]; + struct alias_node *a, *b; if(regcomp(&global_leading_from_line_regexp, LEADING_FROM_LINE_REGEXP_STRING, 0)) { fprintf(stderr, @@ -915,11 +1012,34 @@ int main(int argc, char **argv) { exit(EXIT_FAILURE); } + if(getenv("MYMAILRC")) { + sprintf(rc_filename, "%s", getenv("MYMAILRC")); + } else if(getenv("HOME")) { + sprintf(rc_filename, "%s/.mymailrc", getenv("HOME")); + } else { + rc_filename[0] = '\0'; + } + + global_alias_list = 0; global_quiet = 0; global_use_leading_time = 0; default_search_field = 0; strncpy(output_filename, "", PATH_MAX); + if(rc_filename[0]) { + read_rc_file(rc_filename); + } + + /* + { +#warning Test code added on 2013 May 02 11:17:01 + struct alias_node *a; + for(a = global_alias_list; a; a = a->next) { + printf ("ALIAS [%s] [%s]\n", a->alias, a->value); + } + } + */ + setlocale(LC_ALL, ""); nb_search_conditions = 0; @@ -1082,7 +1202,11 @@ int main(int argc, char **argv) { } } - fprintf(db_file, "%s version_%s format_%d raw\n", MYMAIL_DB_MAGIC_TOKEN, MYMAIL_VERSION, MYMAIL_DB_FORMAT_VERSION); + fprintf(db_file, + "%s version_%s format_%d raw\n", + MYMAIL_DB_MAGIC_TOKEN, + MYMAIL_VERSION, + MYMAIL_DB_FORMAT_VERSION); while(optind < argc) { recursive_index_mbox(db_file, @@ -1185,6 +1309,15 @@ int main(int argc, char **argv) { free_condition(&search_conditions[n]); } + a = global_alias_list; + while(a) { + b = a->next; + free(a->alias); + free(a->value); + free(a); + a = b; + } + free(db_filename); free(db_filename_regexp_string); free(db_root_path);