4 * by JH <jheinonen@bigfoot.com>
6 * Copyright (C) Jaakko Heinonen
18 #if defined(HAVE_LOCALE_H) && defined(HAVE_SETLOCALE)
30 static void init_abook();
31 static void set_filenames();
32 static void free_filenames();
33 static void parse_command_line(int argc, char **argv);
34 static void show_usage();
35 static void mutt_query(char *str);
36 static void init_mutt_query();
37 static void quit_mutt_query();
38 static void convert(char *srcformat, char *srcfile,
39 char *dstformat, char *dstfile);
41 char *datafile = NULL;
50 signal(SIGKILL, quit_abook);
51 signal(SIGTERM, quit_abook);
59 * this is very ugly for now
61 /*if( options_get_int("datafile", "autosave") )*/
63 if( load_database(datafile) == 2 ) {
64 char *tmp = strconcat(getenv("HOME"),
67 if( safe_strcmp(tmp, datafile) ) {
69 statusline_msg("Sorry, the specified file does "
70 "not appear to be a valid abook addressbook");
71 statusline_msg("Will open default addressbook...");
74 load_database(datafile);
85 if( options_get_int("autosave") )
87 else if( statusline_ask_boolean("Save database", TRUE) )
99 main(int argc, char **argv)
101 #if defined(HAVE_SETLOCALE) && defined(HAVE_LOCALE_H)
102 setlocale(LC_ALL, "" );
105 parse_command_line(argc, argv);
121 if( (stat(getenv("HOME"), &s)) == -1 || ! S_ISDIR(s.st_mode) ) {
122 fprintf(stderr,"%s is not a valid HOME directory\n", getenv("HOME") );
127 datafile = strconcat(getenv("HOME"), "/" DATAFILE, NULL);
129 rcfile = strconcat(getenv("HOME"), "/" RCFILE, NULL);
131 atexit(free_filenames);
142 parse_command_line(int argc, char **argv)
146 for( i = 1; i < argc; i++ ) {
147 if( !strcmp(argv[i], "--help") ) {
151 if( !strcmp(argv[i], "--mutt-query") )
152 mutt_query(argv[i + 1]);
154 if( !strcmp(argv[i], "--datafile") ) {
156 if (argv[i+1][0] != '/') {
157 char *cwd = my_getcwd();
158 datafile = strconcat(cwd, "/", argv[i+1], NULL);
161 datafile = strdup(argv[i+1]);
169 if( !strcmp(argv[i], "--convert") ) {
170 if( argc < 5 || argc > 6 ) {
171 fprintf(stderr, "incorrect number of argumets to make conversion\n");
172 fprintf(stderr, "try %s --help\n", argv[0]);
176 convert(argv[i+1], argv[i+2],
177 argv[i+3], argv[i+4]);
179 convert(argv[i+1], argv[i+2], argv[i+3], "-");
181 printf("option %s not recognized\n", argv[i]);
182 printf("try %s --help\n", argv[0]);
192 puts (PACKAGE " v " VERSION "\n");
193 puts (" --help show usage");
194 puts (" --datafile <filename> use an alternative addressbook file");
195 puts (" --mutt-query <string> make a query for mutt");
196 puts (" --convert <inputformat> <inputfile> "
197 "<outputformat> <outputfile>");
199 puts ("available formats for --convert option:");
202 puts ("\nWarning: this version compiled with DEBUG flag ON");
206 extern list_item *database;
210 muttq_print_item(int item)
212 char emails[MAX_EMAILS][MAX_EMAIL_LEN];
215 split_emailstr(item, emails);
217 for(i = 0; i < (options_get_int("mutt_return_all_emails") ?
218 MAX_EMAILS : 1) ; i++)
220 printf("%s\t%s\t%s\n", emails[i],
221 database[item][NAME],
222 database[item][NOTES] == NULL ? " " :
223 database[item][NOTES]
228 mutt_query_name(char *str)
233 for(i = 0, j = 0 ; i < items; i++) {
234 tmp = strdup(database[i][NAME]);
235 if( strstr( strupper(tmp), strupper(str) ) != NULL ) {
248 mutt_query_email(char *str)
251 char *tmp, emails[MAX_EMAILS][MAX_EMAIL_LEN];
253 for(i = 0, j = 0; i < items; i++) {
254 split_emailstr(i, emails);
255 for(k = 0; k < MAX_EMAILS; k++) {
257 tmp = strdup( emails[k] );
258 if( strstr( strupper(tmp), strupper(str) ) != NULL ) {
262 if( options_get_int("mutt_return_all_emails") ) {
267 printf("%s\t%s\n", emails[k],
279 mutt_query(char *str)
285 if( str == NULL || !strcasecmp(str, "all") ) {
286 printf("All items\n");
287 for(i = 0; i < items; i++)
290 if( !mutt_query_name(str) && !mutt_query_email(str) ) {
291 printf("Not found\n");
305 if( load_database(datafile) ) {
306 printf("Cannot open database\n");
313 quit_mutt_query(int status)
323 launch_mutt(int item)
326 char email[MAX_EMAIL_LEN];
328 char *tmp = options_get_str("mutt_command");
330 if( !is_valid_item(item) )
333 cmd = strconcat(tmp, " '", NULL );
335 for(i=0; i < items; i++) {
336 if( ! is_selected(i) && i != list_current_item() )
338 get_first_email(email, i);
339 tmp = mkstr("%s \"%s\"", cmd, database[i][NAME]);
341 if( *database[i][EMAIL] ) {
342 cmd = mkstr("%s <%s>", tmp, email);
346 cmd = strconcat(tmp, " ", NULL);
350 tmp = mkstr("%s%c", cmd, '\'');
354 fprintf(stderr, "cmd: %s\n", cmd);
362 launch_wwwbrowser(int item)
366 if( !is_valid_item(item) )
369 if( database[item][URL] )
370 cmd = mkstr("%s '%s'",
371 options_get_str("www_command"),
372 safe_str(database[item][URL]));
383 abook_malloc(size_t size)
387 if ( (ptr = malloc(size)) == NULL ) {
388 if( is_ui_initialized() )
390 perror("malloc() failed");
398 abook_realloc(void *ptr, size_t size)
400 ptr = realloc(ptr, size);
406 if( is_ui_initialized() )
408 perror("realloc() failed");
416 abook_fopen (const char *path, const char *mode)
420 if( ! strchr(mode, 'r') )
421 return fopen(path, mode);
423 if ( (stat(path, &s)) == -1 )
426 return S_ISREG(s.st_mode) ? fopen(path, mode) : NULL;
432 convert(char *srcformat, char *srcfile, char *dstformat, char *dstfile)
436 if( !srcformat || !srcfile || !dstformat || !dstfile ) {
437 fprintf(stderr, "too few argumets to make conversion\n");
438 fprintf(stderr, "try --help\n");
444 if( !strcmp(srcformat, dstformat) ) {
445 printf( "input and output formats are the same\n"
453 switch( import(srcformat, srcfile) ) {
455 printf("input format %s not supported\n", srcformat);
458 printf("cannot read file %s\n", srcfile);
463 switch( export(dstformat, dstfile) ) {
465 printf("output format %s not supported\n",
470 printf("cannot write file %s\n", dstfile);