"Master password" is now called "master passphrase".
[claws.git] / src / mainwindow.h
index 095cc542af337c3485f97b5bd3ce20c60a443440..678ff2226fddfa97df84e98edf73057b5bc7f6d8 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2007 Hiroyuki Yamamoto and the Claws Mail team
+ * Copyright (C) 1999-2013 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
 
 typedef struct _MainWindow  MainWindow;
 
-#include "folderview.h"
-#include "summaryview.h"
-#include "headerview.h"
-#include "messageview.h"
+#include "viewtypes.h"
 #include "logwindow.h"
+#include "procmsg.h"
 #include "toolbar.h"
 
 #define OFFLINE_SWITCH_HOOKLIST "offline_switch"
@@ -38,40 +36,52 @@ typedef struct _MainWindow  MainWindow;
 #define THEME_CHANGED_HOOKLIST "theme_changed"
 typedef enum
 {
-       M_UNLOCKED            = 1 << 0,
-       M_MSG_EXIST           = 1 << 1,
-       M_TARGET_EXIST        = 1 << 2,
-       M_SINGLE_TARGET_EXIST = 1 << 3,
-       M_EXEC                = 1 << 4,
-       M_ALLOW_REEDIT        = 1 << 5,
-       M_HAVE_ACCOUNT        = 1 << 6,
-       M_THREADED            = 1 << 7,
-       M_UNTHREADED          = 1 << 8,
-       M_ALLOW_DELETE        = 1 << 9,
-       M_INC_ACTIVE          = 1 << 10,
-       M_NEWS                = 1 << 11,
-       M_HAVE_NEWS_ACCOUNT   = 1 << 12,
-       M_HIDE_READ_MSG       = 1 << 13,
-       M_DELAY_EXEC          = 1 << 14,
-       M_NOT_NEWS            = 1 << 15,
-       M_CAN_LEARN_SPAM      = 1 << 16,
-       M_ACTIONS_EXIST       = 1 << 17,
-       M_HAVE_QUEUED_MAILS   = 1 << 18,
-       M_WANT_SYNC           = 1 << 19,
-       M_TAGS_EXIST          = 1 << 20,
-       M_HAVE_PROCESSING     = 1 << 21,
-       M_SUMMARY_ISLIST      = 1 << 22,
-       M_IN_MSGLIST          = 1 << 23,
-       M_HAVE_MULTI_ACCOUNT  = 1 << 24,
-       M_FOLDER_SELECTED     = 1 << 25,
-       M_SESSION_PASSWORDS   = 1 << 26
+       M_UNLOCKED,
+       M_MSG_EXIST,
+       M_TARGET_EXIST,
+       M_SINGLE_TARGET_EXIST,
+       M_EXEC,
+       M_ALLOW_REEDIT,
+       M_HAVE_ACCOUNT,
+       M_THREADED,
+       M_UNTHREADED,
+       M_ALLOW_DELETE,
+       M_INC_ACTIVE,
+       M_SEND_ACTIVE,
+       M_NEWS,
+       M_HAVE_NEWS_ACCOUNT,
+       M_HIDE_READ_MSG,
+       M_DELAY_EXEC,
+       M_NOT_NEWS,
+       M_CAN_LEARN_SPAM,
+       M_ACTIONS_EXIST,
+       M_HAVE_QUEUED_MAILS,
+       M_WANT_SYNC,
+       M_TAGS_EXIST,
+       M_HAVE_PROCESSING,
+       M_SUMMARY_ISLIST,
+       M_IN_MSGLIST,
+       M_HAVE_MULTI_ACCOUNT,
+       M_FOLDER_SELECTED,
+       M_SESSION_PASSWORDS,
+       M_MASTER_PASSPHRASE,
+       M_DELETED_EXISTS,
+       M_NOT_TRASH,
+       M_HIDE_READ_THREADS,
+       M_HAVE_RETRIEVABLE_ACCOUNT,
+       M_HAVE_ANY_RETRIEVABLE_ACCOUNT,
+
+/* reserved */
+    M_MAX_RESERVED
 } SensitiveCond;
 
+typedef guint64 SensitiveCondMask;
+
 typedef enum
 {
-       NORMAL_LAYOUT    = 0,
-       VERTICAL_LAYOUT  = 1 << 0,
-       WIDE_LAYOUT = 1 << 1,
+       NORMAL_LAYOUT       = 0,
+       VERTICAL_LAYOUT     = 1 << 0,
+       WIDE_LAYOUT         = 1 << 1,
        WIDE_MSGLIST_LAYOUT = 1 << 2,
        SMALL_LAYOUT
 } LayoutType;
@@ -136,14 +146,13 @@ struct _MainWindow
        GtkWidget       *warning_btn;
        GtkWidget       *tags_menu;
        
-#ifdef HAVE_LIBSM
-       gpointer smc_conn;
-#endif
        gboolean         in_folder;
        GtkActionGroup  *action_group;
        GtkUIManager    *ui_manager;
 
-        gboolean        fullscreen;
+#ifdef HAVE_LIBSM
+       gpointer smc_conn;
+#endif
 };
 
 MainWindow *main_window_create         (void);
@@ -177,6 +186,11 @@ void main_window_get_position              (MainWindow     *mainwin);
 
 void main_window_progress_on           (MainWindow     *mainwin);
 void main_window_progress_off          (MainWindow     *mainwin);
+gboolean main_window_empty_trash       (MainWindow     *mainwin,
+                                        gboolean        confirm,
+                                        gboolean        for_quit);
+
+SensitiveCondMask main_window_get_mask(SensitiveCond cond, ...);
 
 void main_window_set_menu_sensitive    (MainWindow     *mainwin);
 
@@ -185,7 +199,7 @@ void main_window_show                       (MainWindow     *mainwin);
 void main_window_hide                  (MainWindow     *mainwin);
 void main_window_popup                 (MainWindow     *mainwin);
 
-SensitiveCond main_window_get_current_state   (MainWindow *mainwin);
+SensitiveCondMask main_window_get_current_state   (MainWindow *mainwin);
 
 void toolbar_set_compose_button               (Toolbar          *toolbar, 
                                               ComposeButtonType  compose_btn_type);
@@ -207,11 +221,7 @@ void mainwindow_exit_folder                      (MainWindow *mainwin);
 void mainwindow_enter_folder                 (MainWindow *mainwin);
 void mainwindow_reset_paned                  (GtkPaned *paned);
 
-#ifdef MAEMO
-gboolean maemo_mainwindow_is_fullscreen               (GtkWidget *widget);
-void maemo_window_full_screen_if_needed               (GtkWindow *window);
-void maemo_connect_key_press_to_mainwindow    (GtkWindow *window);
-void mainwindow_maemo_led_set(gboolean state);
-#endif
+void mainwin_accel_changed_cb (GtkAccelGroup *accelgroup, guint keyval, GdkModifierType modifier,
+                                 GClosure *closure, GtkMenuItem *item);
 
 #endif /* __MAINWINDOW_H__ */