2 * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
3 * Copyright (C) 1999-2001 Hiroyuki Yamamoto
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.
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.
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.
26 #include <sys/types.h>
29 typedef struct _MsgInfo MsgInfo;
30 typedef struct _MsgFlags MsgFlags;
41 MSG_FORWARDED = 1 << 5,
43 MSG_REALLY_DELETED = 1 << 6, /* mbox stuff */
45 #define MSG_CLABEL_SBIT (7) /* start bit of color label */
46 #define MAKE_MSG_CLABEL(h, m, l) (((h) << (MSG_CLABEL_SBIT + 2)) | \
47 ((m) << (MSG_CLABEL_SBIT + 1)) | \
48 ((l) << (MSG_CLABEL_SBIT + 0)))
50 MSG_CLABEL_NONE = MAKE_MSG_CLABEL(0, 0, 0),
51 MSG_CLABEL_1 = MAKE_MSG_CLABEL(0, 0, 1),
52 MSG_CLABEL_2 = MAKE_MSG_CLABEL(0, 1, 0),
53 MSG_CLABEL_3 = MAKE_MSG_CLABEL(0, 1, 1),
54 MSG_CLABEL_4 = MAKE_MSG_CLABEL(1, 0, 0),
55 MSG_CLABEL_5 = MAKE_MSG_CLABEL(1, 0, 1),
56 MSG_CLABEL_6 = MAKE_MSG_CLABEL(1, 1, 0),
57 MSG_CLABEL_7 = MAKE_MSG_CLABEL(1, 1, 1),
59 #define MSG_CLABEL_ORANGE MSG_CLABEL_1
60 #define MSG_CLABEL_RED MSG_CLABEL_2
61 #define MSG_CLABEL_PINK MSG_CLABEL_3
62 #define MSG_CLABEL_SKYBLUE MSG_CLABEL_4
63 #define MSG_CLABEL_BLUE MSG_CLABEL_5
64 #define MSG_CLABEL_GREEN MSG_CLABEL_6
65 #define MSG_CLABEL_BROWN MSG_CLABEL_7
67 MSG_IGNORE_THREAD = 1 << 10, /* ignore threads */
68 MSG_LOCKED = 1 << 11, /* msg is locked */
71 MSG_RESERVED_CLAWS = 1 << 30, /* for sylpheed-claws */
72 MSG_RESERVED_MAIN = 1 << 31 /* for sylpheed-main */
75 #define MSG_CLABEL_FLAG_MASK (MSG_CLABEL_7)
84 MSG_ENCRYPTED = 1 << 18,
88 MSG_FILTERING = 1 << 25, /* claws: re/set by filtering */
95 #define MSG_CACHED_FLAG_MASK (MSG_MIME)
97 #define MSG_SET_FLAGS(msg, flags) { (msg) |= (flags); }
98 #define MSG_UNSET_FLAGS(msg, flags) { (msg) &= ~(flags); }
99 #define MSG_SET_PERM_FLAGS(msg, flags) \
100 MSG_SET_FLAGS((msg).perm_flags, flags)
101 #define MSG_SET_TMP_FLAGS(msg, flags) \
102 MSG_SET_FLAGS((msg).tmp_flags, flags)
103 #define MSG_UNSET_PERM_FLAGS(msg, flags) \
104 MSG_UNSET_FLAGS((msg).perm_flags, flags)
105 #define MSG_UNSET_TMP_FLAGS(msg, flags) \
106 MSG_UNSET_FLAGS((msg).tmp_flags, flags)
108 #define MSG_IS_NEW(msg) (((msg).perm_flags & MSG_NEW) != 0)
109 #define MSG_IS_UNREAD(msg) (((msg).perm_flags & MSG_UNREAD) != 0)
110 #define MSG_IS_MARKED(msg) (((msg).perm_flags & MSG_MARKED) != 0)
111 #define MSG_IS_DELETED(msg) (((msg).perm_flags & MSG_DELETED) != 0)
112 #define MSG_IS_REPLIED(msg) (((msg).perm_flags & MSG_REPLIED) != 0)
113 #define MSG_IS_LOCKED(msg) (((msg).perm_flags & MSG_LOCKED) != 0)
114 #define MSG_IS_FORWARDED(msg) (((msg).perm_flags & MSG_FORWARDED) != 0)
116 #define MSG_GET_COLORLABEL(msg) (((msg).perm_flags & MSG_CLABEL_FLAG_MASK))
117 #define MSG_GET_COLORLABEL_VALUE(msg) (MSG_GET_COLORLABEL(msg) >> MSG_CLABEL_SBIT)
118 #define MSG_SET_COLORLABEL_VALUE(msg, val) \
119 MSG_SET_PERM_FLAGS(msg, ((((guint)(val)) & 7) << MSG_CLABEL_SBIT))
121 #define MSG_IS_MOVE(msg) (((msg).tmp_flags & MSG_MOVE) != 0)
122 #define MSG_IS_COPY(msg) (((msg).tmp_flags & MSG_COPY) != 0)
124 #define MSG_IS_QUEUED(msg) (((msg).tmp_flags & MSG_QUEUED) != 0)
125 #define MSG_IS_DRAFT(msg) (((msg).tmp_flags & MSG_DRAFT) != 0)
126 #define MSG_IS_ENCRYPTED(msg) (((msg).tmp_flags & MSG_ENCRYPTED) != 0)
127 #define MSG_IS_IMAP(msg) (((msg).tmp_flags & MSG_IMAP) != 0)
128 #define MSG_IS_NEWS(msg) (((msg).tmp_flags & MSG_NEWS) != 0)
129 #define MSG_IS_MIME(msg) (((msg).tmp_flags & MSG_MIME) != 0)
130 #define MSG_IS_CACHED(msg) (((msg).tmp_flags & MSG_CACHED) != 0)
132 /* Claws related flags */
133 #define MSG_IS_REALLY_DELETED(msg) (((msg).perm_flags & MSG_REALLY_DELETED) != 0)
134 #define MSG_IS_IGNORE_THREAD(msg) (((msg).perm_flags & MSG_IGNORE_THREAD) != 0)
135 #define MSG_IS_FILTERING(msg) (((msg).tmp_flags & MSG_FILTERING) != 0)
138 #define WRITE_CACHE_DATA_INT(n, fp) \
139 fwrite(&n, sizeof(n), 1, fp)
141 #define WRITE_CACHE_DATA(data, fp) \
145 if (data == NULL || (len = strlen(data)) == 0) { \
147 WRITE_CACHE_DATA_INT(len, fp); \
149 len = strlen(data); \
150 WRITE_CACHE_DATA_INT(len, fp); \
151 fwrite(data, len, 1, fp); \
157 MsgPermFlags perm_flags;
158 MsgTmpFlags tmp_flags;
182 FolderItem *to_folder;
186 gchar *dispositionnotificationto;
187 gchar *returnreceiptto;
195 /* used only for encrypted messages */
196 gchar *plaintext_file;
197 guint decryption_failed : 1;
200 GHashTable *procmsg_msg_hash_table_create (GSList *mlist);
201 void procmsg_msg_hash_table_append (GHashTable *msg_table,
203 GHashTable *procmsg_to_folder_hash_table_create (GSList *mlist);
205 GSList *procmsg_read_cache (FolderItem *item,
207 void procmsg_set_flags (GSList *mlist,
209 gint procmsg_get_last_num_in_cache (GSList *mlist);
210 void procmsg_msg_list_free (GSList *mlist);
211 void procmsg_write_cache (MsgInfo *msginfo,
213 void procmsg_write_flags (MsgInfo *msginfo,
215 void procmsg_get_mark_sum (const gchar *folder,
219 FILE *procmsg_open_mark_file (const gchar *folder,
222 GNode *procmsg_get_thread_tree (GSList *mlist);
224 void procmsg_move_messages (GSList *mlist);
225 void procmsg_copy_messages (GSList *mlist);
227 gchar *procmsg_get_message_file_path (MsgInfo *msginfo);
228 gchar *procmsg_get_message_file (MsgInfo *msginfo);
229 FILE *procmsg_open_message (MsgInfo *msginfo);
230 gboolean procmsg_msg_exist (MsgInfo *msginfo);
232 void procmsg_empty_trash (void);
233 gint procmsg_send_queue (void);
234 void procmsg_print_message (MsgInfo *msginfo,
235 const gchar *cmdline);
237 MsgInfo *procmsg_msginfo_copy (MsgInfo *msginfo);
238 void procmsg_msginfo_free (MsgInfo *msginfo);
240 gint procmsg_cmp_msgnum_for_sort (gconstpointer a,
242 gint procmsg_send_message_queue (const gchar *file);
244 #endif /* __PROCMSG_H__ */