X-Git-Url: http://git.claws-mail.org/?p=claws.git;a=blobdiff_plain;f=src%2Fprocmsg.h;h=fef815ffd82ef605adcf3add8240a41789bf9297;hp=98cefd569744b44aff2cf08a3f85470117c13fc6;hb=72387ad26c74ac501ec9f5ce925273275379a115;hpb=4530d0cf3f799917a8a497c27446f0fbc76c2e63;ds=sidebyside diff --git a/src/procmsg.h b/src/procmsg.h index 98cefd569..fef815ffd 100644 --- a/src/procmsg.h +++ b/src/procmsg.h @@ -1,6 +1,6 @@ /* * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client - * Copyright (C) 1999-2002 Hiroyuki Yamamoto + * Copyright (C) 1999-2003 Hiroyuki Yamamoto * * 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 @@ -30,34 +30,35 @@ #include #include -typedef struct _MsgInfo MsgInfo; -typedef struct _MsgFlags MsgFlags; -typedef struct _MsgInfoUpdate MsgInfoUpdate; +typedef struct _MsgInfo MsgInfo; +typedef struct _MsgFlags MsgFlags; +typedef struct _MsgInfoUpdate MsgInfoUpdate; +typedef struct _MailFilteringData MailFilteringData; -typedef enum -{ - MSG_NEW = 1 << 0, - MSG_UNREAD = 1 << 1, - MSG_MARKED = 1 << 2, - MSG_DELETED = 1 << 3, - MSG_REPLIED = 1 << 4, - MSG_FORWARDED = 1 << 5, - - MSG_REALLY_DELETED = 1 << 6, /* mbox stuff */ +typedef GSList MsgInfoList; +typedef GSList MsgNumberList; + +#define MSG_NEW (1U << 0) +#define MSG_UNREAD (1U << 1) +#define MSG_MARKED (1U << 2) +#define MSG_DELETED (1U << 3) +#define MSG_REPLIED (1U << 4) +#define MSG_FORWARDED (1U << 5) +#define MSG_REALLY_DELETED (1U << 6) /* mbox stuff */ #define MSG_CLABEL_SBIT (7) /* start bit of color label */ #define MAKE_MSG_CLABEL(h, m, l) (((h) << (MSG_CLABEL_SBIT + 2)) | \ ((m) << (MSG_CLABEL_SBIT + 1)) | \ ((l) << (MSG_CLABEL_SBIT + 0))) - MSG_CLABEL_NONE = MAKE_MSG_CLABEL(0, 0, 0), - MSG_CLABEL_1 = MAKE_MSG_CLABEL(0, 0, 1), - MSG_CLABEL_2 = MAKE_MSG_CLABEL(0, 1, 0), - MSG_CLABEL_3 = MAKE_MSG_CLABEL(0, 1, 1), - MSG_CLABEL_4 = MAKE_MSG_CLABEL(1, 0, 0), - MSG_CLABEL_5 = MAKE_MSG_CLABEL(1, 0, 1), - MSG_CLABEL_6 = MAKE_MSG_CLABEL(1, 1, 0), - MSG_CLABEL_7 = MAKE_MSG_CLABEL(1, 1, 1), +#define MSG_CLABEL_NONE MAKE_MSG_CLABEL(0U, 0U, 0U) +#define MSG_CLABEL_1 MAKE_MSG_CLABEL(0U, 0U, 1U) +#define MSG_CLABEL_2 MAKE_MSG_CLABEL(0U, 1U, 0U) +#define MSG_CLABEL_3 MAKE_MSG_CLABEL(0U, 1U, 1U) +#define MSG_CLABEL_4 MAKE_MSG_CLABEL(1U, 0U, 0U) +#define MSG_CLABEL_5 MAKE_MSG_CLABEL(1U, 0U, 1U) +#define MSG_CLABEL_6 MAKE_MSG_CLABEL(1U, 1U, 0U) +#define MSG_CLABEL_7 MAKE_MSG_CLABEL(1U, 1U, 1U) #define MSG_CLABEL_ORANGE MSG_CLABEL_1 #define MSG_CLABEL_RED MSG_CLABEL_2 @@ -67,33 +68,29 @@ typedef enum #define MSG_CLABEL_GREEN MSG_CLABEL_6 #define MSG_CLABEL_BROWN MSG_CLABEL_7 - MSG_IGNORE_THREAD = 1 << 10, /* ignore threads */ - MSG_LOCKED = 1 << 11, /* msg is locked */ - MSG_RETRCPT_PENDING = 1 << 12, /* return receipt pending */ +#define MSG_IGNORE_THREAD (1U << 10) /* ignore threads */ +#define MSG_LOCKED (1U << 11) /* msg is locked */ +#define MSG_RETRCPT_PENDING (1U << 12) /* return receipt pending */ +/* RESERVED */ +#define MSG_RESERVED_CLAWS (1U << 30) /* for sylpheed-claws */ +#define MSG_RESERVED (1U << 31) - /* RESERVED */ - MSG_RESERVED_CLAWS = 1 << 30, /* for sylpheed-claws */ - MSG_RESERVED_MAIN = 1 << 31 /* for sylpheed-main */ -} MsgPermFlags; +typedef guint32 MsgPermFlags; #define MSG_CLABEL_FLAG_MASK (MSG_CLABEL_7) -typedef enum -{ - MSG_MOVE = 1 << 0, - MSG_COPY = 1 << 1, - - MSG_QUEUED = 1 << 16, - MSG_DRAFT = 1 << 17, - MSG_ENCRYPTED = 1 << 18, - MSG_IMAP = 1 << 19, - MSG_NEWS = 1 << 20, - MSG_SIGNED = 1 << 21, - - MSG_MIME = 1 << 29, +#define MSG_MOVE (1U << 0) +#define MSG_COPY (1U << 1) +#define MSG_QUEUED (1U << 16) +#define MSG_DRAFT (1U << 17) +#define MSG_ENCRYPTED (1U << 18) +#define MSG_IMAP (1U << 19) +#define MSG_NEWS (1U << 20) +#define MSG_SIGNED (1U << 21) +#define MSG_MIME (1U << 29) +#define MSG_CACHED (1U << 31) - MSG_CACHED = 1 << 31 -} MsgTmpFlags; +typedef guint32 MsgTmpFlags; #define MSG_CACHED_FLAG_MASK (MSG_MIME | MSG_ENCRYPTED | MSG_SIGNED) @@ -142,9 +139,11 @@ typedef enum #define MSG_IS_RETRCPT_PENDING(msg) (((msg).perm_flags & MSG_RETRCPT_PENDING) != 0) #define MSGINFO_UPDATE_HOOKLIST "msginfo_update" +#define MAIL_FILTERING_HOOKLIST "mail_filtering_hooklist" #include "folder.h" #include "procmime.h" +#include "prefs_filtering.h" struct _MsgFlags { @@ -152,6 +151,7 @@ struct _MsgFlags MsgTmpFlags tmp_flags; }; + struct _MsgInfo { guint refcnt; @@ -198,6 +198,11 @@ struct _MsgInfoUpdate { MsgInfo *msginfo; }; +struct _MailFilteringData +{ + MsgInfo *msginfo; +}; + GHashTable *procmsg_msg_hash_table_create (GSList *mlist); void procmsg_msg_hash_table_append (GHashTable *msg_table, GSList *mlist); @@ -208,9 +213,9 @@ GSList *procmsg_read_cache (FolderItem *item, gint procmsg_get_last_num_in_msg_list(GSList *mlist); void procmsg_msg_list_free (GSList *mlist); void procmsg_get_mark_sum (const gchar *folder, - gint *new, - gint *unread, - gint *total, + gint *new_msgs, + gint *unread_msgs, + gint *total_msgs, gint *min, gint *max, gint first); @@ -229,6 +234,11 @@ FILE *procmsg_open_message_decrypted (MsgInfo *msginfo, #endif gboolean procmsg_msg_exist (MsgInfo *msginfo); +void procmsg_get_filter_keyword (MsgInfo *msginfo, + gchar **header, + gchar **key, + PrefsFilterType type); + void procmsg_empty_trash (void); gint procmsg_send_queue (FolderItem *queue, gboolean save_msgs); @@ -266,4 +276,6 @@ void procmsg_update_unread_children (MsgInfo *info, gboolean newly_marked); void procmsg_msginfo_set_to_folder (MsgInfo *msginfo, FolderItem *to_folder); +gboolean procmsg_msginfo_filter (MsgInfo *msginfo); + #endif /* __PROCMSG_H__ */