1 /* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
2 /* camelFolder.h : Abstract class for an email folder */
7 * Bertrand Guiheneuf <bertrand@helixcode.com>
9 * Copyright 1999, 2000 HelixCode (http://www.helixcode.com) .
11 * This program is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License as
13 * published by the Free Software Foundation; either version 2 of the
14 * License, or (at your option) any later version.
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
21 * You should have received a copy of the GNU General Public License
22 * along with this program; if not, write to the Free Software
23 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
28 #ifndef CAMEL_FOLDER_H
29 #define CAMEL_FOLDER_H 1
35 #endif /* __cplusplus }*/
39 typedef struct _CamelFolder CamelFolder;
41 #include "camel-store.h"
42 #include "camel-mime-message.h"
43 #include "camel-folder-summary.h"
44 #include "camel-exception.h"
46 #define CAMEL_FOLDER_TYPE (camel_folder_get_type ())
47 #define CAMEL_FOLDER(obj) (GTK_CHECK_CAST((obj), CAMEL_FOLDER_TYPE, CamelFolder))
48 #define CAMEL_FOLDER_CLASS(k) (GTK_CHECK_CLASS_CAST ((k), CAMEL_FOLDER_TYPE, CamelFolderClass))
49 #define CAMEL_IS_FOLDER(o) (GTK_CHECK_TYPE((o), CAMEL_FOLDER_TYPE))
57 FOLDER_OPEN_UNKNOWN = 0, /* folder open mode is unknown */
58 FOLDER_OPEN_READ = 1, /* folder is read only */
59 FOLDER_OPEN_WRITE = 2, /* folder is write only */
60 FOLDER_OPEN_RW = 3 /* folder is read/write */
61 } CamelFolderOpenMode;
63 typedef void (*CamelFolderAsyncCallback) ();
67 GtkObject parent_object;
69 gboolean can_hold_folders;
70 gboolean can_hold_messages;
71 CamelFolderOpenMode open_mode;
72 CamelFolderState open_state;
75 CamelStore *parent_store;
76 CamelFolder *parent_folder;
77 GList *permanent_flags;
79 gboolean has_summary_capability;
80 CamelFolderSummary *summary;
82 gboolean has_uid_capability;
89 GtkObjectClass parent_class;
92 void (*init_with_store) (CamelFolder *folder,
93 CamelStore *parent_store,
96 void (*open) (CamelFolder *folder,
97 CamelFolderOpenMode mode,
100 void (*close) (CamelFolder *folder,
104 void (*open_async) (CamelFolder *folder,
105 CamelFolderOpenMode mode,
106 CamelFolderAsyncCallback callback,
110 void (*close_async) (CamelFolder *folder,
112 CamelFolderAsyncCallback callback,
116 void (*set_name) (CamelFolder *folder,
120 /* void (*set_full_name) (CamelFolder *folder, const gchar *name); */
122 const gchar * (*get_name) (CamelFolder *folder,
125 const gchar * (*get_full_name) (CamelFolder *folder,
128 gboolean (*can_hold_folders) (CamelFolder *folder,
131 gboolean (*can_hold_messages) (CamelFolder *folder,
134 gboolean (*exists) (CamelFolder *folder,
137 gboolean (*is_open) (CamelFolder *folder,
140 CamelFolder * (*get_subfolder) (CamelFolder *folder,
141 const gchar *folder_name,
144 gboolean (*create) (CamelFolder *folder,
147 gboolean (*delete) (CamelFolder *folder,
151 gboolean (*delete_messages) (CamelFolder *folder,
154 CamelFolder * (*get_parent_folder) (CamelFolder *folder,
157 CamelStore * (*get_parent_store) (CamelFolder *folder,
160 CamelFolderOpenMode (*get_mode) (CamelFolder *folder,
163 GList * (*list_subfolders) (CamelFolder *folder,
166 GList * (*expunge) (CamelFolder *folder,
169 gboolean (*has_message_number_capability) (CamelFolder *folder, CamelException *ex);
171 CamelMimeMessage * (*get_message_by_number) (CamelFolder *folder,
175 gint (*get_message_count) (CamelFolder *folder,
178 void (*append_message) (CamelFolder *folder,
179 CamelMimeMessage *message,
182 const GList * (*list_permanent_flags) (CamelFolder *folder,
185 void (*copy_message_to) (CamelFolder *folder,
186 CamelMimeMessage *message,
187 CamelFolder *dest_folder,
190 gboolean (*has_uid_capability) (CamelFolder *folder);
192 const gchar * (*get_message_uid) (CamelFolder *folder,
193 CamelMimeMessage *message,
196 CamelMimeMessage * (*get_message_by_uid) (CamelFolder *folder,
200 GList * (*get_uid_list) (CamelFolder *folder,
207 /* Standard Gtk function */
208 GtkType camel_folder_get_type (void);
215 CamelFolder *camel_folder_get_subfolder (CamelFolder *folder,
219 void camel_folder_open (CamelFolder *folder,
220 CamelFolderOpenMode mode,
224 void camel_folder_close (CamelFolder *folder,
228 gboolean camel_folder_create (CamelFolder *folder, CamelException *ex);
229 CamelFolder *camel_folder_get_parent_folder (CamelFolder *folder, CamelException *ex);
230 CamelStore *camel_folder_get_parent_store (CamelFolder *folder, CamelException *ex);
231 GList *camel_folder_list_subfolders (CamelFolder *folder, CamelException *ex);
234 /* delete operations */
235 gboolean camel_folder_delete (CamelFolder *folder, gboolean recurse, CamelException *ex);
236 gboolean camel_folder_delete_messages (CamelFolder *folder, CamelException *ex);
237 GList *camel_folder_expunge (CamelFolder *folder, CamelException *ex);
240 /* folder name manipulation operations */
241 void camel_folder_set_name (CamelFolder *folder,
244 const gchar *camel_folder_get_name (CamelFolder *folder, CamelException *ex);
245 const gchar *camel_folder_get_full_name (CamelFolder *folder, CamelException *ex);
248 /* various properties accessors */
249 gboolean camel_folder_exists (CamelFolder *folder, CamelException *ex);
250 const GList *camel_folder_list_permanent_flags (CamelFolder *folder, CamelException *ex);
251 CamelFolderOpenMode camel_folder_get_mode (CamelFolder *folder, CamelException *ex);
252 gboolean camel_folder_is_open (CamelFolder *folder, CamelException *ex);
256 /* message manipulation */
257 void camel_folder_append_message (CamelFolder *folder,
258 CamelMimeMessage *message, CamelException *ex);
259 void camel_folder_copy_message_to (CamelFolder *folder,
260 CamelMimeMessage *message,
261 CamelFolder *dest_folder,
265 /* summary related operations */
266 gboolean camel_folder_has_summary_capability (CamelFolder *folder, CamelException *ex);
267 CamelFolderSummary *camel_folder_get_summary (CamelFolder *folder, CamelException *ex);
270 /* number based access operations */
271 gboolean camel_folder_has_message_number_capability (CamelFolder *folder, CamelException *ex);
272 CamelMimeMessage *camel_folder_get_message_by_number (CamelFolder *folder,
273 gint number, CamelException *ex);
274 gint camel_folder_get_message_count (CamelFolder *folder, CamelException *ex);
277 /* uid based access operations */
278 gboolean camel_folder_has_uid_capability (CamelFolder *folder, CamelException *ex);
279 const gchar * camel_folder_get_message_uid (CamelFolder *folder, CamelMimeMessage *message, CamelException *ex);
280 CamelMimeMessage *camel_folder_get_message_by_uid (CamelFolder *folder, const gchar *uid, CamelException *ex);
281 GList *camel_folder_get_uid_list (CamelFolder *folder, CamelException *ex);
290 #endif /* __cplusplus */
292 #endif /* CAMEL_FOLDER_H */