2010-05-26 [holger] 3.7.6cvs9
[claws.git] / src / summaryview.h
index 3592eb7a95e586466dcb0d27945e5f9c2d183fcd..405d3980d3ad1de2564a9850199c4244175a61c2 100644 (file)
@@ -1,10 +1,10 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2007 Hiroyuki Yamamoto and the Claws Mail team
+ * Copyright (C) 1999-2009 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
- * the Free Software Foundation; either version 2 of the License, or
+ * the Free Software Foundation; either version 3 of the License, or
  * (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful,
@@ -13,8 +13,8 @@
  * GNU General Public License for more details.
  *
  * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ * 
  */
 
 #ifndef __SUMMARY_H__
 
 #include <glib.h>
 #include <gdk/gdk.h>
-#include <gtk/gtkwidget.h>
-#include <gtk/gtkitemfactory.h>
-#include <gtk/gtkctree.h>
-#include <gtk/gtkdnd.h>
+#include <gtk/gtk.h>
 
 typedef struct _SummaryView            SummaryView;
 typedef struct _SummaryColumnState     SummaryColumnState;
@@ -47,10 +44,11 @@ typedef enum
        S_COL_SIZE,
        S_COL_NUMBER,
        S_COL_SCORE,
-       S_COL_LOCKED
+       S_COL_LOCKED,
+       S_COL_TAGS
 } SummaryColumnType;
 
-#define N_SUMMARY_COLS 11
+#define N_SUMMARY_COLS 12
 
 typedef enum
 {
@@ -63,7 +61,8 @@ typedef enum
 typedef enum
 {
        TARGET_MAIL_URI_LIST,
-       TARGET_DUMMY
+       TARGET_DUMMY,
+       TARGET_MAIL_CM_PATH_LIST,
 } TargetInfo;
 
 #include "mainwindow.h"
@@ -76,7 +75,7 @@ typedef enum
 #include "prefs_filtering.h"
 #include "quicksearch.h"
 
-extern GtkTargetEntry summary_drag_types[2];
+extern GtkTargetEntry summary_drag_types[3];
 
 struct _SummaryColumnState
 {
@@ -87,6 +86,7 @@ struct _SummaryColumnState
 struct _SummaryView
 {
        GtkWidget *vbox;
+       GtkWidget *mainwidget_book;
        GtkWidget *scrolledwin;
        GtkWidget *ctree;
        GtkWidget *hbox;
@@ -101,18 +101,21 @@ struct _SummaryView
        GtkWidget *statlabel_msgs;
        GtkWidget *toggle_eventbox;
        GtkWidget *toggle_arrow;
+#ifdef GENERIC_UMPC
+       GtkWidget *multiple_sel_togbtn;
+       GtkWidget *multiple_sel_image;
+#endif
        GtkWidget *toggle_search;
        GtkWidget *quick_search_pixmap;
        GtkWidget *popupmenu;
        GtkWidget *colorlabel_menu;
-
-       GtkItemFactory *popupfactory;
+       GtkWidget *tags_menu;
 
        GtkWidget *window;
 
-       GtkCTreeNode *selected;
-       GtkCTreeNode *displayed;
-       GtkCTreeNode *last_displayed;
+       GtkCMCTreeNode *selected;
+       GtkCMCTreeNode *displayed;
+       GtkCMCTreeNode *last_displayed;
 
        gboolean display_msg;
 
@@ -146,7 +149,7 @@ struct _SummaryView
 
        /* current message status */
        gint   unreadmarked;
-       off_t  total_size;
+       goffset total_size;
        gint   deleted;
        gint   moved;
        gint   copied;
@@ -168,11 +171,13 @@ private:
 
        GtkTargetList *target_list; /* DnD */
        
-       GtkTooltips *tips;
+#if !GTK_CHECK_VERSION(2,12,0)
+       GtkTooltips *tooltips;
+#endif
 };
 
-SummaryView    *summary_create(void);
-
+SummaryView    *summary_create(MainWindow *mainwin);
+void summaryview_destroy(SummaryView *summaryview);
 void summary_init                (SummaryView          *summaryview);
 gboolean summary_show            (SummaryView          *summaryview,
                                   FolderItem           *fitem);
@@ -203,17 +208,17 @@ void summary_select_last_read     (SummaryView            *summaryview);
 void summary_select_parent        (SummaryView         *summaryview);
 void summary_select_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,
-                                  GtkCTreeNode         *node,
+                                  GtkCMCTreeNode               *node,
                                   gboolean              display_msg,
                                   gboolean              do_refresh);
 
-void summary_thread_build        (SummaryView          *summaryview);
-
 void summary_expand_threads      (SummaryView          *summaryview);
 void summary_collapse_threads    (SummaryView          *summaryview);
 void summary_toggle_ignore_thread (SummaryView         *summaryview);
+void summary_toggle_watch_thread  (SummaryView         *summaryview);
 
 void summary_filter              (SummaryView          *summaryview,
                                   gboolean              selected_only);
@@ -233,6 +238,7 @@ void summary_delete_trash     (SummaryView          *summaryview);
 void summary_cancel               (SummaryView          *summaryview);
 
 gboolean summary_execute         (SummaryView          *summaryview);
+gboolean summary_expunge         (SummaryView          *summaryview);
 
 void summary_attract_by_subject          (SummaryView          *summaryview);
 
@@ -253,7 +259,7 @@ gboolean summary_step                 (SummaryView          *summaryview,
 void summary_toggle_view         (SummaryView          *summaryview);
 void summary_set_marks_selected          (SummaryView          *summaryview);
 guint summary_get_msgnum         (SummaryView          *summaryview,
-                                  GtkCTreeNode         *node);
+                                  GtkCMCTreeNode               *node);
 
 void summary_move_selected_to    (SummaryView          *summaryview,
                                   FolderItem           *to_folder);
@@ -276,6 +282,8 @@ void summary_mark_as_spam     (SummaryView          *summaryview,
                                   GtkWidget            *widget);
 void summary_ignore_thread       (SummaryView          *summaryview);
 void summary_unignore_thread     (SummaryView          *summaryview);
+void summary_watch_thread        (SummaryView          *summaryview);
+void summary_unwatch_thread      (SummaryView          *summaryview);
 
 void summary_add_address         (SummaryView          *summaryview);
 void summary_select_all                  (SummaryView          *summaryview);
@@ -286,20 +294,23 @@ void summary_select_thread          (SummaryView          *summaryview,
 void summary_set_colorlabel      (SummaryView          *summaryview,
                                   guint                 labelcolor,
                                   GtkWidget            *widget);
-void summary_set_colorlabel_color (GtkCTree            *ctree,
-                                  GtkCTreeNode         *node,
-                                  guint                 labelcolor);
+void summary_set_tag             (SummaryView          *summaryview,
+                                  gint                  tag_id,
+                                  GtkWidget            *widget);
 
 void summary_set_column_order    (SummaryView          *summaryview);
 
 void summary_toggle_show_read_messages
                                  (SummaryView *summaryview);
+void summary_toggle_show_del_messages
+                                 (SummaryView *summaryview);
 
 void summary_toggle_view_real    (SummaryView  *summaryview);
 
 void summary_reflect_prefs_pixmap_theme
                                   (SummaryView *summaryview);
 void summary_reflect_prefs_custom_colors(SummaryView *summaryview);
+void summary_reflect_tags_changes(SummaryView *summaryview);
 void summary_harvest_address      (SummaryView *summaryview);
 void summary_set_prefs_from_folderitem
                                   (SummaryView *summaryview, FolderItem *item);
@@ -312,4 +323,6 @@ void summary_reflect_prefs(void);
 void summaryview_activate_quicksearch(SummaryView *summaryview, gboolean show);
 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);
 #endif /* __SUMMARY_H__ */