2010-11-20 [wwp] 3.7.7cvs2
[claws.git] / src / main.c
index 3c354882703bb84e6d95ca2e256106ffbc2420e1..3a64ef9c134db21e0767570cb5dfaaf460406643 100644 (file)
 #include "tags.h"
 #include "hooks.h"
 #include "menu.h"
+#include "quicksearch.h"
 
 #ifdef HAVE_LIBETPAN
 #include "imap-thread.h"
@@ -191,6 +192,11 @@ static struct RemoteCmd {
        gboolean compose;
        const gchar *compose_mailto;
        GPtrArray *attach_files;
+       gboolean search;
+       const gchar *search_folder;
+       const gchar *search_type;
+       const gchar *search_request;
+       gboolean search_recursive;
        gboolean status;
        gboolean status_full;
        GPtrArray *status_folders;
@@ -321,7 +327,7 @@ static void startup_notification_complete(gboolean with_window)
                gtk_widget_show(hack);
        }
 
-       xdisplay = GDK_DISPLAY();
+       xdisplay = gdk_display_get_default();
        sn_display = sn_display_new(xdisplay,
                                sn_error_trap_push,
                                sn_error_trap_pop);
@@ -793,8 +799,8 @@ static void win32_log(const gchar *log_domain, GLogLevelFlags log_level, const g
 
 static void win32_open_log(void)
 {
-       gchar *logfile = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S, "claws-win32.log", NULL);
-       gchar *oldlogfile = g_strconcat(get_rc_dir(), G_DIR_SEPARATOR_S, "claws-win32.log.bak", NULL);
+       gchar *logfile = g_strconcat(g_get_tmp_dir(), G_DIR_SEPARATOR_S, "claws-win32.log", NULL);
+       gchar *oldlogfile = g_strconcat(g_get_tmp_dir(), G_DIR_SEPARATOR_S, "claws-win32.log.bak", NULL);
 
        if (is_file_exist(logfile)) {
                if (rename_force(logfile, oldlogfile) < 0)
@@ -904,12 +910,6 @@ static void main_dump_features_list(gboolean show_debug_only)
        else
                g_print(" libetpan %d.%d\n", LIBETPAN_VERSION_MAJOR, LIBETPAN_VERSION_MINOR);
 #endif
-#if USE_GNOMEPRINT
-       if (show_debug_only)
-               debug_print(" gnomeprint\n");
-       else
-               g_print(" gnomeprint\n");
-#endif
 #if HAVE_LIBSM
        if (show_debug_only)
                debug_print(" libsm\n");
@@ -1099,7 +1099,7 @@ int main(int argc, char *argv[])
                return 0;
        }
 
-       if (cmd.status || cmd.status_full) {
+       if (cmd.status || cmd.status_full || cmd.search) {
                puts("0 Claws Mail not running.");
                lock_socket_remove();
                return 0;
@@ -1158,7 +1158,9 @@ int main(int argc, char *argv[])
        hildon_program = HILDON_PROGRAM(hildon_program_get_instance());
        static_osso_context = osso_context;
 #endif 
-       gtk_widget_set_default_colormap(gdk_rgb_get_colormap());
+       gtk_widget_set_default_colormap(
+               gdk_screen_get_system_colormap(
+                       gdk_screen_get_default()));
 
        gui_manager = gtkut_create_ui_manager();
 
@@ -1228,12 +1230,20 @@ int main(int argc, char *argv[])
                /* If migration failed or the user didn't want to do it,
                 * we create a new one (and we'll hit wizard later). 
                 */
-               if (r == FALSE && !is_dir_exist(RC_DIR) && make_dir(RC_DIR) < 0) {
+               if (r == FALSE && !is_dir_exist(RC_DIR)) {
+#ifdef G_OS_UNIX
+                       if (copy_dir(SYSCONFDIR "/skel/.claws-mail", RC_DIR) < 0) {
+#endif
+                               if (!is_dir_exist(RC_DIR) && make_dir(RC_DIR) < 0) {
 #ifdef G_OS_WIN32
-                       win32_close_log();
+                                       win32_close_log();
 #endif
-                       exit(1);
-       }
+                                       exit(1);
+                               }
+#ifdef G_OS_UNIX
+                       }
+#endif
+               }
        }
        
 
@@ -1383,6 +1393,11 @@ int main(int argc, char *argv[])
        prefs_account_init();
        account_read_config_all();
 
+#ifdef HAVE_LIBETPAN
+       imap_main_init(prefs_common.skip_ssl_cert_check);
+       imap_main_set_timeout(prefs_common.io_timeout_secs);
+       nntp_main_init(prefs_common.skip_ssl_cert_check);
+#endif 
        /* If we can't read a folder list or don't have accounts,
         * it means the configuration's not done. Either this is
         * a brand new install, either a failed/refused migration.
@@ -1438,16 +1453,12 @@ int main(int argc, char *argv[])
        if (claws_crashed())
                main_window_popup(mainwin);
 
-#ifdef HAVE_LIBETPAN
-       imap_main_init(prefs_common.skip_ssl_cert_check);
-       imap_main_set_timeout(prefs_common.io_timeout_secs);
-       nntp_main_init(prefs_common.skip_ssl_cert_check);
-#endif 
        account_set_missing_folder();
        folder_set_missing_folders();
        folderview_set(folderview);
 
        prefs_matcher_read_config();
+       quicksearch_set_search_strings(mainwin->summaryview->quicksearch);
 
        /* make one all-folder processing before using claws */
        main_window_cursor_wait(mainwin);
@@ -1694,6 +1705,7 @@ static void save_all_caches(FolderItem *item, gpointer data)
 static void exit_claws(MainWindow *mainwin)
 {
        gchar *filename;
+       gboolean have_connectivity;
 
        sc_exiting = TRUE;
 
@@ -1736,9 +1748,14 @@ static void exit_claws(MainWindow *mainwin)
        close_log_file(LOG_PROTOCOL);
        close_log_file(LOG_DEBUG_FILTERING);
 
+#ifdef HAVE_NETWORKMANAGER_SUPPORT
+       have_connectivity = networkmanager_is_online(NULL); 
+#else
+       have_connectivity = TRUE;
+#endif
 #ifdef HAVE_LIBETPAN
-       imap_main_done();
-       nntp_main_done();
+       imap_main_done(have_connectivity);
+       nntp_main_done(have_connectivity);
 #endif
        /* delete crashfile */
        if (!cmd.crash)
@@ -1874,6 +1891,16 @@ static void parse_cmd_opt(int argc, char *argv[])
                                i++;
                                p = (i+1 < argc)?argv[i+1]:NULL;
                        }
+               } else if (!strncmp(argv[i], "--search", 8)) {
+                       cmd.search_folder    = (i+1 < argc)?argv[i+1]:NULL;
+                       cmd.search_type      = (i+2 < argc)?argv[i+2]:NULL;
+                       cmd.search_request   = (i+3 < argc)?argv[i+3]:NULL;
+                       const char* rec      = (i+4 < argc)?argv[i+4]:NULL;
+                       cmd.search_recursive = TRUE;
+                       if (rec && (tolower(*rec)=='n' || tolower(*rec)=='f' || *rec=='0'))
+                               cmd.search_recursive = FALSE;
+                       if (cmd.search_folder && cmd.search_type && cmd.search_request)
+                               cmd.search = TRUE;
                } else if (!strncmp(argv[i], "--online", 8)) {
                        cmd.online_mode = ONLINE_MODE_ONLINE;
                } else if (!strncmp(argv[i], "--offline", 9)) {
@@ -1890,6 +1917,13 @@ static void parse_cmd_opt(int argc, char *argv[])
                                  "                         attached"));
                        g_print("%s\n", _("  --receive              receive new messages"));
                        g_print("%s\n", _("  --receive-all          receive new messages of all accounts"));
+                       g_print("%s\n", _("  --search folder type request [recursive]"));
+                       g_print("%s\n", _("                         searches mail"));
+                       g_print("%s\n", _("                         folder ex.: \"#mh/Mailbox/inbox\" or \"Mail\""));
+                       g_print("%s\n", _("                         type: s[ubject],f[rom],t[o],e[xtended],m[ixed] or g: tag"));
+                       g_print("%s\n", _("                         request: search string"));
+                       g_print("%s\n", _("                         recursive: false if arg. starts with 0, n, N, f or F"));
+
                        g_print("%s\n", _("  --send                 send all queued messages"));
                        g_print("%s\n", _("  --status [folder]...   show the total number of messages"));
                        g_print("%s\n", _("  --status-full [folder]...\n"
@@ -1971,7 +2005,7 @@ static void initial_processing(FolderItem *item, gpointer data)
        MainWindow *mainwin = (MainWindow *)data;
        gchar *buf;
 
-       g_return_if_fail(item);
+       cm_return_if_fail(item);
        buf = g_strdup_printf(_("Processing (%s)..."), 
                              item->path 
                              ? item->path 
@@ -2243,6 +2277,19 @@ static gint prohibit_duplicate_launch(void)
                gchar *str = g_strdup_printf("select %s\n", cmd.target);
                fd_write_all(uxsock, str, strlen(str));
                g_free(str);
+       } else if (cmd.search) {
+               gchar buf[BUFFSIZE];
+               gchar *str =
+                       g_strdup_printf("search %s\n%s\n%s\n%c\n",
+                                                       cmd.search_folder, cmd.search_type, cmd.search_request,
+                                                       (cmd.search_recursive==TRUE)?'1':'0');
+               fd_write_all(uxsock, str, strlen(str));
+               g_free(str);
+               for (;;) {
+                       fd_gets(uxsock, buf, sizeof(buf));
+                       if (!strncmp(buf, ".\n", 2)) break;
+                       fputs(buf, stdout);
+               }
        } else {
 #ifndef G_OS_WIN32
                gchar buf[BUFSIZ];
@@ -2321,6 +2368,8 @@ static void lock_socket_input_cb(gpointer data,
        MainWindow *mainwin = (MainWindow *)data;
        gint sock;
        gchar buf[BUFFSIZE];
+       /* re-use the same quicksearch (& avoid matcher_list mem.leaks) */
+       static QuickSearch *quicksearch = NULL;
 
        sock = fd_accept(source);
        fd_gets(sock, buf, sizeof(buf));
@@ -2376,11 +2425,80 @@ static void lock_socket_input_cb(gpointer data,
        } else if (!strncmp(buf, "select ", 7)) {
                const gchar *target = buf+7;
                mainwindow_jump_to(target, TRUE);
+       } else if (!strncmp(buf, "search ", 7)) {
+               FolderItem* folderItem = NULL;
+               GSList *messages = NULL;
+               gchar *folder_name, *request;
+               QuickSearchType searchType = QUICK_SEARCH_EXTENDED;
+               gboolean recursive;
+
+               if (quicksearch==NULL)
+                       quicksearch = quicksearch_new_nogui();
+               
+               folder_name = g_strdup(buf+7);
+               strretchomp(folder_name);
+
+               if (fd_gets(sock, buf, sizeof(buf)) <= 0) {
+                       g_free(folder_name);
+                       folder_name=NULL;
+               }
+               searchType = quicksearch_type(buf);
+               if (fd_gets(sock, buf, sizeof(buf)) <= 0) {
+                       g_free(folder_name);
+                       folder_name=NULL;
+               }
+               request = g_strdup(buf);
+               strretchomp(request);
+
+               recursive = TRUE;
+               if (fd_gets(sock, buf, sizeof(buf)) > 0)
+                       if (buf[0]=='0')
+                               recursive = FALSE;
+
+               debug_print("search: %s %i %s %i\n",folder_name,searchType,request,recursive);
+
+               if (folder_name)
+                       folderItem = folder_find_item_from_identifier(folder_name);
+               if (folder_name && folderItem == NULL) {
+                       debug_print("Unknow folder item : '%s', searching folder\n",folder_name);
+                       Folder* folder = folder_find_from_path(folder_name);
+                       if (folder != NULL)
+                               folderItem = FOLDER_ITEM(folder->node->data);
+                       else
+                               debug_print("Unknown folder: '%s'\n",folder_name);
+               } else {
+                       debug_print("%s %s\n",folderItem->name, folderItem->path);
+        }
+               if (folderItem != NULL) {
+                       quicksearch_set(quicksearch, searchType, request);
+                       quicksearch_set_recursive(quicksearch, recursive);
+                       search_msgs_in_folders(&messages, quicksearch, folderItem);
+               } else {
+                       g_print("Folder '%s' not found.\n'", folder_name);
+               }
+
+               GSList *cur;
+               for (cur=messages; cur != NULL; cur = cur->next) {
+                       MsgInfo* msg = (MsgInfo *)cur->data;
+                       gchar *file = procmsg_get_message_file_path(msg);
+                       fd_write_all(sock, file, strlen(file));
+                       fd_write_all(sock, "\n", 1);
+                       g_free(file);
+               }
+               fd_write_all(sock, ".\n", 2);
+
+               if (messages != NULL)
+                       procmsg_msg_list_free(messages);
+               g_free(folder_name);
+               g_free(request);
        } else if (!strncmp(buf, "exit", 4)) {
+               if (prefs_common.clean_on_exit && !prefs_common.ask_on_clean) {
+                       procmsg_empty_all_trash();
+                }
                app_will_exit(NULL, mainwin);
        }
-
        fd_close(sock);
+
 }
 
 static void open_compose_new(const gchar *address, GPtrArray *attach_files)