b34a8043bba3a213eafba8e70b71ad1175700784
[claws.git] / src / folder.h
1 /*
2  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
3  * Copyright (C) 1999-2003 Hiroyuki Yamamoto
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18  */
19
20 #ifndef __FOLDER_H__
21 #define __FOLDER_H__
22
23 #include <glib.h>
24 #include <time.h>
25
26 typedef struct _Folder          Folder;
27 typedef struct _FolderClass     FolderClass;
28
29 typedef struct _LocalFolder     LocalFolder;
30 typedef struct _RemoteFolder    RemoteFolder;
31 #if 0
32 typedef struct _MaildirFolder   MaildirFolder;
33 #endif
34
35 typedef struct _FolderItem      FolderItem;
36 typedef struct _FolderUpdateData        FolderUpdateData;
37 typedef struct _FolderItemUpdateData    FolderItemUpdateData;
38
39 #define FOLDER(obj)             ((Folder *)obj)
40 #define FOLDER_CLASS(obj)       (FOLDER(obj)->klass)
41 #define FOLDER_TYPE(obj)        (FOLDER(obj)->klass->type)
42
43 #define LOCAL_FOLDER(obj)       ((LocalFolder *)obj)
44 #define REMOTE_FOLDER(obj)      ((RemoteFolder *)obj)
45
46 #define FOLDER_IS_LOCAL(obj)    (FOLDER_TYPE(obj) == F_MH      || \
47                                  FOLDER_TYPE(obj) == F_MBOX    || \
48                                  FOLDER_TYPE(obj) == F_MAILDIR)
49
50 #if 0
51 #define MAILDIR_FOLDER(obj)     ((MaildirFolder *)obj)
52 #endif
53
54 #define FOLDER_ITEM(obj)        ((FolderItem *)obj)
55
56 #define FOLDER_UPDATE_HOOKLIST "folder_update"
57 #define FOLDER_ITEM_UPDATE_HOOKLIST "folder_item_update"
58
59 typedef enum
60 {
61         F_MH,
62         F_MBOX,
63         F_MAILDIR,
64         F_IMAP,
65         F_NEWS,
66         F_UNKNOWN
67 } FolderType;
68
69 typedef enum
70 {
71         F_NORMAL,
72         F_INBOX,
73         F_OUTBOX,
74         F_DRAFT,
75         F_QUEUE,
76         F_TRASH
77 } SpecialFolderItemType;
78
79 typedef enum
80 {
81         SORT_BY_NONE,
82         SORT_BY_NUMBER,
83         SORT_BY_SIZE,
84         SORT_BY_DATE,
85         SORT_BY_FROM,
86         SORT_BY_SUBJECT,
87         SORT_BY_SCORE,
88         SORT_BY_LABEL,
89         SORT_BY_MARK,
90         SORT_BY_STATUS,
91         SORT_BY_MIME,
92         SORT_BY_TO,
93         SORT_BY_LOCKED
94 } FolderSortKey;
95
96 typedef enum
97 {
98         SORT_ASCENDING,
99         SORT_DESCENDING
100 } FolderSortType;
101
102 typedef enum
103 {
104         F_MOVE_OK = 0,
105         F_MOVE_FAILED_DEST_IS_PARENT = -1,
106         F_MOVE_FAILED_DEST_IS_CHILD = -2,
107         F_MOVE_FAILED_DEST_OUTSIDE_MAILBOX = -3,
108         F_MOVE_FAILED = -4,
109 } FolderItemMoveResult;
110
111 typedef enum
112 {
113         FOLDER_TREE_CHANGED = 1 << 0,
114         FOLDER_NEW_FOLDERITEM = 1 << 1,
115         FOLDER_REMOVE_FOLDERITEM = 1 << 2,
116 } FolderUpdateFlags;
117
118 typedef enum
119 {
120         F_ITEM_UPDATE_MSGCNT = 1 << 0,
121         F_ITEM_UPDATE_CONTENT = 1 << 1,
122 } FolderItemUpdateFlags;
123
124 typedef void (*FolderUIFunc)            (Folder         *folder,
125                                          FolderItem     *item,
126                                          gpointer        data);
127 typedef void (*FolderDestroyNotify)     (Folder         *folder,
128                                          FolderItem     *item,
129                                          gpointer        data);
130 typedef void (*FolderItemFunc)          (FolderItem     *item,
131                                          gpointer        data);
132
133 #include "folder_item_prefs.h"
134
135 #include "prefs_account.h"
136 #include "session.h"
137 #include "procmsg.h"
138 #include "msgcache.h"
139
140 struct _Folder
141 {
142         FolderClass *klass;
143
144         gchar *name;
145         PrefsAccount *account;
146
147         FolderItem *inbox;
148         FolderItem *outbox;
149         FolderItem *draft;
150         FolderItem *queue;
151         FolderItem *trash;
152
153         FolderUIFunc ui_func;
154         gpointer     ui_func_data;
155
156         GNode *node;
157
158         gpointer data;
159
160         GHashTable *newsart;
161 };
162
163 struct _FolderClass
164 {
165         FolderType  type;
166         gchar      *idstr;
167         gchar      *uistr;
168
169         /* virtual functions */
170
171         /* Folder funtions */
172         Folder          *(*new_folder)          (const gchar    *name,
173                                                  const gchar    *path);
174         void            (*destroy_folder)       (Folder         *folder);
175         gint            (*scan_tree)            (Folder         *folder);
176
177         gint            (*create_tree)          (Folder         *folder);
178
179         /* FolderItem functions */
180         FolderItem      *(*item_new)            (Folder         *folder);
181         void            (*item_destroy)         (Folder         *folder,
182                                                  FolderItem     *item);
183         gchar           *(*item_get_path)       (Folder         *folder,
184                                                  FolderItem     *item);
185         FolderItem      *(*create_folder)       (Folder         *folder,
186                                                  FolderItem     *parent,
187                                                  const gchar    *name);
188         gint            (*rename_folder)        (Folder         *folder,
189                                                  FolderItem     *item,
190                                                  const gchar    *name);
191         gint            (*remove_folder)        (Folder         *folder,
192                                                  FolderItem     *item);
193         gint            (*close)                (Folder         *folder,
194                                                  FolderItem     *item);
195         gint            (*get_num_list)         (Folder         *folder,
196                                                  FolderItem     *item,
197                                                  GSList        **list,
198                                                  gboolean       *old_uids_valid);
199         void            (*update_mark)          (Folder         *folder,
200                                                  FolderItem     *item);
201         void            (*finished_copy)        (Folder         *folder,
202                                                  FolderItem     *item);
203         void            (*finished_remove)      (Folder         *folder,
204                                                  FolderItem     *item);
205         gboolean        (*scan_required)        (Folder         *folder,
206                                                  FolderItem     *item);
207
208         /* Message functions */
209         MsgInfo         *(*get_msginfo)         (Folder         *folder,
210                                                  FolderItem     *item,
211                                                  gint            num);
212         GSList          *(*get_msginfos)        (Folder         *folder,
213                                                  FolderItem     *item,
214                                                  MsgNumberList  *msgnum_list);
215         gchar           *(*fetch_msg)           (Folder         *folder,
216                                                  FolderItem     *item,
217                                                  gint            num);
218         gint            (*add_msg)              (Folder         *folder,
219                                                  FolderItem     *dest,
220                                                  const gchar    *file,
221                                                  MsgFlags       *flags);
222         gint            (*add_msgs)             (Folder         *folder,
223                                                  FolderItem     *dest,
224                                                  GSList         *file_list,
225                                                  GRelation      *relation);
226         gint            (*copy_msg)             (Folder         *folder,
227                                                  FolderItem     *dest,
228                                                  MsgInfo        *msginfo);
229         gint            (*copy_msgs)            (Folder         *folder,
230                                                  FolderItem     *dest,
231                                                  MsgInfoList    *msglist,
232                                                  GRelation      *relation);
233         gint            (*remove_msg)           (Folder         *folder,
234                                                  FolderItem     *item,
235                                                  gint            num);
236         gint            (*remove_all_msg)       (Folder         *folder,
237                                                  FolderItem     *item);
238         gboolean        (*is_msg_changed)       (Folder         *folder,
239                                                  FolderItem     *item,
240                                                  MsgInfo        *msginfo);
241         void            (*change_flags)         (Folder         *folder,
242                                                  FolderItem     *item,
243                                                  MsgInfo        *msginfo,
244                                                  MsgPermFlags    newflags);
245 };
246
247 struct _LocalFolder
248 {
249         Folder folder;
250
251         gchar *rootpath;
252 };
253
254 struct _RemoteFolder
255 {
256         Folder folder;
257
258         Session *session;
259 };
260
261 #if 0
262 struct _MaildirFolder
263 {
264         LocalFolder lfolder;
265 };
266 #endif
267
268 struct _FolderItem
269 {
270         SpecialFolderItemType stype;
271
272         gchar *name;
273         gchar *path;
274
275         time_t mtime;
276
277         gint new_msgs;
278         gint unread_msgs;
279         gint total_msgs;
280         gint unreadmarked_msgs;
281
282         gint last_num;
283
284         MsgCache *cache;
285
286         /* special flags */
287         guint no_sub         : 1; /* no child allowed?    */
288         guint no_select      : 1; /* not selectable?      */
289         guint collapsed      : 1; /* collapsed item       */
290         guint thread_collapsed      : 1; /* collapsed item       */
291         guint threaded       : 1; /* threaded folder view */
292         guint hide_read_msgs : 1; /* hide read messages   */
293         guint ret_rcpt       : 1; /* return receipt       */
294
295         gint op_count;
296         guint opened         : 1; /* opened by summary view */
297         FolderItemUpdateFlags update_flags; /* folderview for this folder should be updated */
298
299         FolderSortKey sort_key;
300         FolderSortType sort_type;
301
302         GNode *node;
303
304         FolderItem *parent;
305
306         Folder *folder;
307
308         PrefsAccount *account;
309
310         gboolean apply_sub;
311         
312         GSList *mark_queue;
313
314         gpointer data;
315
316         FolderItemPrefs * prefs;
317 };
318
319 typedef struct {
320         FolderSortKey   sort_key;
321         FolderSortType  sort_type;
322         guint           collapsed       : 1;
323         guint           thread_collapsed        : 1;
324         guint           threaded        : 1;
325         guint           hide_read_msgs  : 1; /* CLAWS */
326         guint           ret_rcpt        : 1; /* CLAWS */
327 } PersistPrefs;
328
329 struct _FolderUpdateData
330 {
331         Folder                  *folder;
332         FolderUpdateFlags        update_flags;
333         FolderItem              *item;
334 };
335
336 struct _FolderItemUpdateData
337 {
338         FolderItem              *item;
339         FolderItemUpdateFlags    update_flags;
340 };
341
342 void        folder_system_init          (void);
343 void        folder_register_class       (FolderClass    *klass);
344 Folder     *folder_new                  (FolderClass    *type,
345                                          const gchar    *name,
346                                          const gchar    *path);
347 void        folder_local_folder_init    (Folder         *folder,
348                                          const gchar    *name,
349                                          const gchar    *path);
350 void        folder_remote_folder_init   (Folder         *folder,
351                                          const gchar    *name,
352                                          const gchar    *path);
353
354 void        folder_destroy              (Folder         *folder);
355 void        folder_local_folder_destroy (LocalFolder    *lfolder);
356 void        folder_remote_folder_destroy(RemoteFolder   *rfolder);
357
358 FolderItem *folder_item_new             (Folder         *folder,
359                                          const gchar    *name,
360                                          const gchar    *path);
361 void        folder_item_append          (FolderItem     *parent,
362                                          FolderItem     *item);
363 void        folder_item_remove          (FolderItem     *item);
364 void        folder_item_remove_children (FolderItem     *item);
365 void        folder_item_destroy         (FolderItem     *item);
366
367 void        folder_set_ui_func  (Folder         *folder,
368                                  FolderUIFunc    func,
369                                  gpointer        data);
370 void        folder_set_name     (Folder         *folder,
371                                  const gchar    *name);
372 void        folder_tree_destroy (Folder         *folder);
373
374 void   folder_add               (Folder         *folder);
375
376 GList *folder_get_list          (void);
377 gint   folder_read_list         (void);
378 void   folder_write_list        (void);
379 void   folder_scan_tree         (Folder *folder);
380 FolderItem *folder_create_folder(FolderItem     *parent, const gchar *name);
381 void   folder_update_op_count           (void);
382 void   folder_func_to_all_folders       (FolderItemFunc function,
383                                          gpointer data);
384 void   folder_count_total_msgs  (guint          *new_msgs,
385                                  guint          *unread_msgs,
386                                  guint          *unreadmarked_msgs,
387                                  guint          *total_msgs);
388 gchar *folder_get_status        (GPtrArray      *folders,
389                                  gboolean        full);
390
391 Folder     *folder_find_from_path               (const gchar    *path);
392 Folder     *folder_find_from_name               (const gchar    *name,
393                                                  FolderClass    *klass);
394 FolderItem *folder_find_item_from_path          (const gchar    *path);
395 FolderClass *folder_get_class_from_string       (const gchar    *str);
396 gchar      *folder_get_identifier               (Folder         *folder);
397 gchar      *folder_item_get_identifier          (FolderItem     *item);
398 FolderItem *folder_find_item_from_identifier    (const gchar    *identifier);
399 gchar      *folder_item_get_name                (FolderItem     *item);
400
401 Folder     *folder_get_default_folder   (void);
402 FolderItem *folder_get_default_inbox    (void);
403 FolderItem *folder_get_default_outbox   (void);
404 FolderItem *folder_get_default_draft    (void);
405 FolderItem *folder_get_default_queue    (void);
406 FolderItem *folder_get_default_trash    (void);
407 FolderItem *folder_get_default_processing (void);
408 void folder_set_missing_folders         (void);
409 void folder_unref_account_all           (PrefsAccount   *account);
410
411 gchar *folder_item_get_path             (FolderItem     *item);
412
413 gint   folder_item_open                 (FolderItem     *item);
414 gint   folder_item_close                (FolderItem     *item);
415 gint   folder_item_scan                 (FolderItem     *item);
416 void   folder_item_scan_foreach         (GHashTable     *table);
417 MsgInfo *folder_item_get_msginfo        (FolderItem     *item,
418                                          gint            num);
419 MsgInfo *folder_item_get_msginfo_by_msgid(FolderItem    *item,
420                                          const gchar    *msgid);
421 GSList *folder_item_get_msg_list        (FolderItem     *item);
422 gchar *folder_item_fetch_msg            (FolderItem     *item,
423                                          gint            num);
424 gint   folder_item_add_msg              (FolderItem     *dest,
425                                          const gchar    *file,
426                                          MsgFlags       *flags,
427                                          gboolean        remove_source);
428 gint   folder_item_add_msgs             (FolderItem     *dest,
429                                          GSList         *file_list,
430                                          gboolean        remove_source);
431 gint   folder_item_move_to              (FolderItem     *src,
432                                          FolderItem     *dest,
433                                          FolderItem    **new_item);
434 gint   folder_item_move_msg             (FolderItem     *dest,
435                                          MsgInfo        *msginfo);
436 gint   folder_item_move_msgs            (FolderItem     *dest,
437                                          GSList         *msglist);
438 gint   folder_item_copy_msg             (FolderItem     *dest,
439                                          MsgInfo        *msginfo);
440 gint   folder_item_copy_msgs            (FolderItem     *dest,
441                                          GSList         *msglist);
442 gint   folder_item_remove_msg           (FolderItem     *item,
443                                          gint            num);
444 gint   folder_item_remove_msgs          (FolderItem     *item,
445                                          GSList         *msglist);
446 gint   folder_item_remove_all_msg       (FolderItem     *item);
447 void    folder_item_change_msg_flags    (FolderItem     *item,
448                                          MsgInfo        *msginfo,
449                                          MsgPermFlags    newflags);
450 gboolean folder_item_is_msg_changed     (FolderItem     *item,
451                                          MsgInfo        *msginfo);
452 gchar *folder_item_get_cache_file       (FolderItem     *item);
453 gchar *folder_item_get_mark_file        (FolderItem     *item);
454 gchar * folder_item_get_identifier      (FolderItem * item);
455
456 GHashTable *folder_persist_prefs_new    (Folder *folder);
457 void folder_persist_prefs_free          (GHashTable *pptable);
458 const PersistPrefs *folder_get_persist_prefs
459                                         (GHashTable *pptable, const char *name);
460
461 void folder_item_restore_persist_prefs  (FolderItem *item, GHashTable *pptable);
462 void folder_clean_cache_memory          (void);
463 void folder_item_write_cache            (FolderItem *item);
464 void folder_item_set_default_flags      (FolderItem *dest, MsgFlags *flags);
465
466 void folder_item_apply_processing       (FolderItem *item);
467
468 void folder_item_update                 (FolderItem *item,
469                                          FolderItemUpdateFlags update_flags);
470 void folder_item_update_recursive       (FolderItem *item,
471                                          FolderItemUpdateFlags update_flags);
472 void folder_item_update_freeze          (void);
473 void folder_item_update_thaw            (void);
474
475 #endif /* __FOLDER_H__ */