Fix marking all as (un)read recursively when the confirmation
[claws.git] / src / summaryview.h
index f84f93db0ff17892559584f4b37272a6e62be457..2d192e5734a46ab94afd7717d405b80129a035fc 100644 (file)
@@ -1,6 +1,6 @@
 /*
- * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2009 Hiroyuki Yamamoto and the Claws Mail team
+ * Claws Mail -- a GTK+ based, lightweight, and fast e-mail client
+ * Copyright (C) 1999-2015 Hiroyuki Yamamoto and the Claws Mail team
  *
  * This program is free software; you can redistribute it and/or modify
  * it under the terms of the GNU General Public License as published by
@@ -14,7 +14,6 @@
  *
  * You should have received a copy of the GNU General Public License
  * along with this program. If not, see <http://www.gnu.org/licenses/>.
- * 
  */
 
 #ifndef __SUMMARY_H__
@@ -27,7 +26,7 @@
 #include <gdk/gdk.h>
 #include <gtk/gtk.h>
 
-typedef struct _SummaryView            SummaryView;
+#include "viewtypes.h"
 typedef struct _SummaryColumnState     SummaryColumnState;
 
 #define MAIL_MANUAL_FILTERING_HOOKLIST "mail_manual_filtering_hooklist"
@@ -66,9 +65,6 @@ typedef enum
 } TargetInfo;
 
 #include "mainwindow.h"
-#include "folderview.h"
-#include "headerview.h"
-#include "messageview.h"
 #include "compose.h"
 #include "folder.h"
 #include "gtksctree.h"
@@ -115,7 +111,6 @@ struct _SummaryView
 
        GtkCMCTreeNode *selected;
        GtkCMCTreeNode *displayed;
-       GtkCMCTreeNode *last_displayed;
 
        gboolean display_msg;
 
@@ -170,10 +165,12 @@ private:
        gint folder_update_callback_id;
 
        GtkTargetList *target_list; /* DnD */
-       
-#if !GTK_CHECK_VERSION(2,12,0)
-       GtkTooltips *tooltips;
-#endif
+
+       // folders with matches for recursive quicksearch queries
+       GSList *recursive_matched_folders;
+       FolderItem *search_root_folder;
+
+       guint mark_as_read_timeout_tag;
 };
 
 SummaryView    *summary_create(MainWindow *mainwin);
@@ -188,6 +185,7 @@ void summary_lock             (SummaryView          *summaryview);
 void summary_unlock              (SummaryView          *summaryview);
 void summary_freeze              (SummaryView          *summaryview);
 void summary_thaw                (SummaryView          *summaryview);
+void summary_thaw_with_status    (SummaryView          *summaryview);
 void summary_grab_focus                  (SummaryView          *summaryview);
 GtkWidget *summary_get_main_widget(SummaryView                 *summaryview);
 gboolean summary_is_locked       (SummaryView          *summaryview);
@@ -196,6 +194,8 @@ SummarySelection summary_get_selection_type (SummaryView    *summaryview);
 MsgInfo *summary_get_selected_msg              (SummaryView *summaryview);
 GSList *summary_get_selected_msg_list          (SummaryView    *summaryview);
 
+void summary_select_prev         (SummaryView          *summaryview);
+void summary_select_next         (SummaryView          *summaryview);
 void summary_select_prev_unread          (SummaryView          *summaryview);
 void summary_select_next_unread          (SummaryView          *summaryview);
 void summary_select_prev_new     (SummaryView          *summaryview);
@@ -204,15 +204,16 @@ void summary_select_prev_marked     (SummaryView          *summaryview);
 void summary_select_next_marked          (SummaryView          *summaryview);
 void summary_select_prev_labeled  (SummaryView         *summaryview);
 void summary_select_next_labeled  (SummaryView         *summaryview);
-void summary_select_last_read     (SummaryView         *summaryview);
 void summary_select_parent        (SummaryView         *summaryview);
 void summary_select_by_msgnum    (SummaryView          *summaryview,
                                   guint                 msgnum);
+void summary_display_by_msgnum   (SummaryView          *summaryview,
+                                  guint                 msgnum);
+void summary_select_by_msg_list   (SummaryView         *summaryview, GSList *msginfos);
 guint summary_get_current_msgnum  (SummaryView         *summaryview);
 void summary_select_node         (SummaryView          *summaryview,
-                                  GtkCMCTreeNode               *node,
-                                  gboolean              display_msg,
-                                  gboolean              do_refresh);
+                                  GtkCMCTreeNode       *node,
+                                  gint                  force_display);
 
 void summary_expand_threads      (SummaryView          *summaryview);
 void summary_collapse_threads    (SummaryView          *summaryview);
@@ -271,11 +272,12 @@ void summary_save_as                (SummaryView          *summaryview);
 void summary_print               (SummaryView          *summaryview);
 void summary_mark                (SummaryView          *summaryview);
 void summary_unmark              (SummaryView          *summaryview);
-void summary_mark_as_unread      (SummaryView          *summaryview);
 void summary_mark_as_read        (SummaryView          *summaryview);
+void summary_mark_as_unread      (SummaryView          *summaryview);
 void summary_msgs_lock           (SummaryView          *summaryview);
 void summary_msgs_unlock         (SummaryView          *summaryview);
-void summary_mark_all_read       (SummaryView          *summaryview);
+void summary_mark_all_read       (SummaryView          *summaryview, gboolean ask_if_needed);
+void summary_mark_all_unread     (SummaryView          *summaryview, gboolean ask_if_needed);
 void summary_mark_as_spam        (SummaryView          *summaryview, 
                                   guint                 action, 
                                   GtkWidget            *widget);
@@ -288,7 +290,8 @@ void summary_add_address      (SummaryView          *summaryview);
 void summary_select_all                  (SummaryView          *summaryview);
 void summary_unselect_all        (SummaryView          *summaryview);
 void summary_select_thread       (SummaryView          *summaryview,
-                                  gboolean              delete_thread);
+                                  gboolean              delete_thread,
+                                  gboolean              trash_thread);
 
 void summary_set_colorlabel      (SummaryView          *summaryview,
                                   guint                 labelcolor,
@@ -301,6 +304,8 @@ void summary_set_column_order         (SummaryView          *summaryview);
 
 void summary_toggle_show_read_messages
                                  (SummaryView *summaryview);
+void summary_toggle_show_read_threads
+                                 (SummaryView *summaryview);
 void summary_toggle_show_del_messages
                                  (SummaryView *summaryview);
 
@@ -324,4 +329,5 @@ void summary_set_menu_sensitive     (SummaryView            *summaryview);
 void summary_relayout(SummaryView *summaryview);
 void summary_update_unread(SummaryView *summaryview, FolderItem *removed_item);
 gboolean summary_is_list(SummaryView *summaryview);
+gboolean summaryview_search_root_progress(gpointer data, guint at, guint matched, guint total);
 #endif /* __SUMMARY_H__ */