0.9.3claws64
[claws.git] / src / folder.h
index b426051f450fb422eaecc8ea67017184daeb3e54..6e3aaf33708666416921b8568399199c6ee2bd5c 100644 (file)
@@ -31,6 +31,8 @@ typedef struct _RemoteFolder          RemoteFolder;
 typedef struct _MaildirFolder          MaildirFolder;
 #endif
 typedef struct _FolderItem             FolderItem;
+
+typedef struct _FolderUpdateData       FolderUpdateData;
 typedef struct _FolderItemUpdateData   FolderItemUpdateData;
 
 #define FOLDER(obj)            ((Folder *)obj)
@@ -50,6 +52,7 @@ typedef struct _FolderItemUpdateData  FolderItemUpdateData;
 
 #define FOLDER_ITEM(obj)       ((FolderItem *)obj)
 
+#define FOLDER_UPDATE_HOOKLIST "folder_update"
 #define FOLDER_ITEM_UPDATE_HOOKLIST "folder_item_update"
 
 typedef enum
@@ -104,6 +107,16 @@ typedef enum
        F_MOVE_FAILED = -4,
 } FolderItemMoveResult;
 
+typedef enum
+{
+       FOLDER_TREE_CHANGED = 1 << 0,
+/*
+       maybe enhance with:
+       FOLDER_NEW_FOLDERITEM
+       FOLDER_REMOVE_FOLDERITEM
+*/
+} FolderUpdateFlags;
+
 typedef enum
 {
        F_ITEM_UPDATE_MSGCNT = 1 << 0,
@@ -119,7 +132,7 @@ typedef void (*FolderDestroyNotify) (Folder         *folder,
 typedef void (*FolderItemFunc)         (FolderItem     *item,
                                         gpointer        data);
 
-#include "prefs_folder_item.h"
+#include "folder_item_prefs.h"
 
 #include "prefs_account.h"
 #include "session.h"
@@ -169,6 +182,8 @@ struct _FolderClass
        FolderItem      *(*item_new)            (Folder         *folder);
        void            (*item_destroy)         (Folder         *folder,
                                                 FolderItem     *item);
+       gchar           *(*item_get_path)       (Folder         *folder,
+                                                FolderItem     *item);
        FolderItem      *(*create_folder)       (Folder         *folder,
                                                 FolderItem     *parent,
                                                 const gchar    *name);
@@ -177,6 +192,8 @@ struct _FolderClass
                                                 const gchar    *name);
        gint            (*remove_folder)        (Folder         *folder,
                                                 FolderItem     *item);
+       gint            (*close)                (Folder         *folder,
+                                                FolderItem     *item);
        gint            (*get_num_list)         (Folder         *folder,
                                                 FolderItem     *item,
                                                 GSList        **list);
@@ -202,10 +219,18 @@ struct _FolderClass
        gint            (*add_msg)              (Folder         *folder,
                                                 FolderItem     *dest,
                                                 const gchar    *file,
-                                               gboolean         remove_source);
+                                                MsgFlags       *flags);
+       gint            (*add_msgs)             (Folder         *folder,
+                                                FolderItem     *dest,
+                                                GSList         *file_list,
+                                                GRelation      *relation);
        gint            (*copy_msg)             (Folder         *folder,
                                                 FolderItem     *dest,
                                                 MsgInfo        *msginfo);
+       gint            (*copy_msgs)            (Folder         *folder,
+                                                FolderItem     *dest,
+                                                MsgInfoList    *msglist,
+                                                GRelation      *relation);
        gint            (*remove_msg)           (Folder         *folder,
                                                 FolderItem     *item,
                                                 gint            num);
@@ -287,7 +312,7 @@ struct _FolderItem
 
        gpointer data;
 
-       PrefsFolderItem * prefs;
+       FolderItemPrefs * prefs;
 };
 
 typedef struct {
@@ -300,13 +325,22 @@ typedef struct {
        guint           ret_rcpt        : 1; /* CLAWS */
 } PersistPrefs;
 
+struct _FolderUpdateData
+{
+       Folder                  *folder;
+       FolderUpdateFlags        update_flags;
+/*
+       FolderItem              *item
+*/
+};
+
 struct _FolderItemUpdateData
 {
        FolderItem              *item;
        FolderItemUpdateFlags    update_flags;
 };
 
-void       folder_system_init          ();
+void       folder_system_init          (void);
 void       folder_register_class       (FolderClass    *klass);
 Folder     *folder_new                 (FolderClass    *type,
                                         const gchar    *name,
@@ -351,6 +385,8 @@ void   folder_count_total_msgs      (guint          *new_msgs,
                                 guint          *unread_msgs,
                                 guint          *unreadmarked_msgs,
                                 guint          *total_msgs);
+gchar *folder_get_status       (GPtrArray      *folders,
+                                gboolean        full);
 
 Folder     *folder_find_from_path              (const gchar    *path);
 Folder     *folder_find_from_name              (const gchar    *name,
@@ -372,11 +408,10 @@ FolderItem *folder_get_default_processing (void);
 void folder_set_missing_folders                (void);
 void folder_unref_account_all          (PrefsAccount   *account);
 
-gchar *folder_get_path                 (Folder         *folder);
 gchar *folder_item_get_path            (FolderItem     *item);
 
 gint   folder_item_open                        (FolderItem     *item);
-void   folder_item_close               (FolderItem     *item);
+gint   folder_item_close               (FolderItem     *item);
 gint   folder_item_scan                        (FolderItem     *item);
 void   folder_item_scan_foreach                (GHashTable     *table);
 MsgInfo *folder_item_get_msginfo       (FolderItem     *item,
@@ -388,7 +423,11 @@ gchar *folder_item_fetch_msg               (FolderItem     *item,
                                         gint            num);
 gint   folder_item_add_msg             (FolderItem     *dest,
                                         const gchar    *file,
+                                        MsgFlags       *flags,
                                         gboolean        remove_source);
+gint   folder_item_add_msgs             (FolderItem     *dest,
+                                         GSList         *file_list,
+                                         gboolean        remove_source);
 gint   folder_item_move_to             (FolderItem     *src,
                                         FolderItem     *dest,
                                         FolderItem    **new_item);
@@ -412,7 +451,7 @@ gboolean folder_item_is_msg_changed (FolderItem     *item,
                                         MsgInfo        *msginfo);
 gchar *folder_item_get_cache_file      (FolderItem     *item);
 gchar *folder_item_get_mark_file       (FolderItem     *item);
-gchar * folder_item_get_identifier(FolderItem * item);
+gchar * folder_item_get_identifier     (FolderItem * item);
 
 GHashTable *folder_persist_prefs_new   (Folder *folder);
 void folder_persist_prefs_free         (GHashTable *pptable);
@@ -420,7 +459,7 @@ const PersistPrefs *folder_get_persist_prefs
                                        (GHashTable *pptable, const char *name);
 
 void folder_item_restore_persist_prefs (FolderItem *item, GHashTable *pptable);
-void folder_clean_cache_memory         ();
+void folder_clean_cache_memory         (void);
 void folder_item_write_cache           (FolderItem *item);
 void folder_item_set_default_flags     (FolderItem *dest, MsgFlags *flags);
 
@@ -430,7 +469,7 @@ void folder_item_update                     (FolderItem *item,
                                         FolderItemUpdateFlags update_flags);
 void folder_item_update_recursive      (FolderItem *item,
                                         FolderItemUpdateFlags update_flags);
-void folder_item_update_freeze         ();
-void folder_item_update_thaw           ();
+void folder_item_update_freeze         (void);
+void folder_item_update_thaw           (void);
 
 #endif /* __FOLDER_H__ */