claws-mail/src/folder.h

820 lines
28 KiB
C
Raw Normal View History

2004-05-10 12:22:28 +02:00
/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
2001-04-19 14:21:46 +02:00
/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
2003-08-25 16:14:47 +02:00
* Copyright (C) 1999-2003 Hiroyuki Yamamoto
2001-04-19 14:21:46 +02:00
*
* 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
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
2005-09-21 [paul] 1.9.14cvs47 * README * README.jp * configure.ac * config/config.rpath * doc/manual/en/sylpheed-20.html * doc/manual/es/sylpheed-20.html * po/bg.po * po/ca.po * po/de.po * po/es.po * po/fr.po * po/it.po * po/pt_BR.po * po/sk.po * po/zh_TW.po * src/account.c * src/account.h * src/action.c * src/action.h * src/adbookbase.h * src/addr_compl.c * src/addr_compl.h * src/addrbook.c * src/addrbook.h * src/addrcache.c * src/addrcache.h * src/addrcindex.c * src/addrcindex.h * src/addrclip.c * src/addrclip.h * src/addrdefs.h * src/addressadd.c * src/addressadd.h * src/addressbook.c * src/addressbook.h * src/addressitem.h * src/addrgather.c * src/addrgather.h * src/addrharvest.c * src/addrharvest.h * src/addrindex.c * src/addrindex.h * src/addritem.c * src/addritem.h * src/addrquery.c * src/addrquery.h * src/addrselect.c * src/addrselect.h * src/alertpanel.c * src/alertpanel.h * src/browseldap.c * src/browseldap.h * src/codeconv.c * src/codeconv.h * src/compose.c * src/compose.h * src/crash.c * src/crash.h * src/customheader.c * src/customheader.h * src/displayheader.c * src/displayheader.h * src/editaddress.c * src/editaddress.h * src/editbook.c * src/editbook.h * src/editgroup.c * src/editgroup.h * src/editjpilot.c * src/editjpilot.h * src/editldap.c * src/editldap.h * src/editldap_basedn.c * src/editldap_basedn.h * src/editvcard.c * src/editvcard.h * src/enriched.c * src/enriched.h * src/exphtmldlg.c * src/exphtmldlg.h * src/expldifdlg.c * src/expldifdlg.h * src/export.c * src/export.h * src/exporthtml.c * src/exporthtml.h * src/exportldif.c * src/exportldif.h * src/filtering.c * src/filtering.h * src/folder.c * src/folder.h * src/folder_item_prefs.c * src/folder_item_prefs.h * src/foldersel.c * src/foldersel.h * src/folderutils.c * src/folderutils.h * src/folderview.c * src/folderview.h * src/grouplistdialog.c * src/grouplistdialog.h * src/headerview.c * src/headerview.h * src/html.c * src/html.h * src/image_viewer.c * src/image_viewer.h * src/imap.c * src/imap.h * src/imap_gtk.c * src/imap_gtk.h * src/import.c * src/import.h * src/importldif.c * src/importldif.h * src/importmutt.c * src/importmutt.h * src/importpine.c * src/importpine.h * src/inc.c * src/inc.h * src/jpilot.c * src/jpilot.h * src/ldapctrl.c * src/ldapctrl.h * src/ldaplocate.c * src/ldaplocate.h * src/ldapquery.c * src/ldapquery.h * src/ldapserver.c * src/ldapserver.h * src/ldaputil.c * src/ldaputil.h * src/ldif.c * src/ldif.h * src/localfolder.c * src/localfolder.h * src/main.c * src/main.h * src/mainwindow.c * src/mainwindow.h * src/manual.c * src/manual.h * src/matcher.c * src/matcher.h * src/matcher_parser.h * src/matcher_parser_lex.l * src/matcher_parser_parse.y * src/mbox.c * src/mbox.h * src/message_search.c * src/message_search.h * src/messageview.c * src/messageview.h * src/mh.c * src/mh.h * src/mh_gtk.c * src/mh_gtk.h * src/mimeview.c * src/mimeview.h * src/msgcache.c * src/msgcache.h * src/mutt.c * src/mutt.h * src/news.c * src/news.h * src/news_gtk.c * src/news_gtk.h * src/noticeview.c * src/noticeview.h * src/partial_download.c * src/partial_download.h * src/pine.c * src/pine.h * src/pop.c * src/pop.h * src/prefs_account.c * src/prefs_account.h * src/prefs_actions.c * src/prefs_actions.h * src/prefs_common.c * src/prefs_common.h * src/prefs_compose_writing.c * src/prefs_compose_writing.h * src/prefs_customheader.c * src/prefs_customheader.h * src/prefs_display_header.c * src/prefs_display_header.h * src/prefs_ext_prog.c * src/prefs_ext_prog.h * src/prefs_filtering.c * src/prefs_filtering.h * src/prefs_filtering_action.c * src/prefs_filtering_action.h * src/prefs_folder_column.c * src/prefs_folder_column.h * src/prefs_folder_item.c * src/prefs_folder_item.h * src/prefs_fonts.c * src/prefs_fonts.h * src/prefs_gtk.c * src/prefs_gtk.h * src/prefs_image_viewer.c * src/prefs_image_viewer.h * src/prefs_matcher.c * src/prefs_matcher.h * src/prefs_message.c * src/prefs_message.h * src/prefs_msg_colors.c * src/prefs_msg_colors.h * src/prefs_other.c * src/prefs_other.h * src/prefs_quote.c * src/prefs_quote.h * src/prefs_receive.c * src/prefs_receive.h * src/prefs_send.c * src/prefs_send.h * src/prefs_spelling.c * src/prefs_spelling.h * src/prefs_summaries.c * src/prefs_summaries.h * src/prefs_summary_column.c * src/prefs_summary_column.h * src/prefs_template.c * src/prefs_template.h * src/prefs_themes.c * src/prefs_themes.h * src/prefs_toolbar.c * src/prefs_toolbar.h * src/prefs_wrapping.c * src/prefs_wrapping.h * src/privacy.c * src/privacy.h * src/procheader.c * src/procheader.h * src/procmime.c * src/procmime.h * src/procmsg.c * src/procmsg.h * src/quote_fmt.c * src/quote_fmt_parse.y * src/recv.c * src/recv.h * src/remotefolder.c * src/remotefolder.h * src/send_message.c * src/send_message.h * src/setup.c * src/setup.h * src/simple-gettext.c * src/sourcewindow.c * src/sourcewindow.h * src/ssl_manager.c * src/ssl_manager.h * src/statusbar.c * src/statusbar.h * src/stock_pixmap.c * src/stock_pixmap.h * src/summary_search.c * src/summary_search.h * src/summaryview.c * src/summaryview.h * src/syldap.c * src/syldap.h * src/textview.c * src/textview.h * src/toolbar.c * src/toolbar.h * src/undo.c * src/undo.h * src/unmime.c * src/unmime.h * src/vcard.c * src/vcard.h * src/wizard.c * src/wizard.h * src/common/base64.c * src/common/base64.h * src/common/defs.h * src/common/hooks.c * src/common/hooks.h * src/common/log.c * src/common/log.h * src/common/md5.c * src/common/md5.h * src/common/mgutils.c * src/common/mgutils.h * src/common/nntp.c * src/common/nntp.h * src/common/passcrypt.c * src/common/passcrypt.h.in * src/common/plugin.c * src/common/plugin.h * src/common/prefs.c * src/common/prefs.h * src/common/progressindicator.c * src/common/progressindicator.h * src/common/quoted-printable.c * src/common/quoted-printable.h * src/common/session.c * src/common/session.h * src/common/smtp.c * src/common/smtp.h * src/common/socket.c * src/common/socket.h * src/common/ssl.c * src/common/ssl.h * src/common/ssl_certificate.c * src/common/ssl_certificate.h * src/common/string_match.c * src/common/string_match.h * src/common/stringtable.c * src/common/sylpheed.c * src/common/sylpheed.h * src/common/template.c * src/common/template.h * src/common/timing.h * src/common/utils.c * src/common/utils.h * src/common/uuencode.c * src/common/uuencode.h * src/common/version.h.in * src/common/xml.c * src/common/xml.h * src/common/xmlprops.c * src/common/xmlprops.h * src/gtk/about.c * src/gtk/about.h * src/gtk/colorlabel.c * src/gtk/colorlabel.h * src/gtk/colorsel.c * src/gtk/colorsel.h * src/gtk/description_window.c * src/gtk/description_window.h * src/gtk/filesel.c * src/gtk/filesel.h * src/gtk/foldersort.c * src/gtk/foldersort.h * src/gtk/gtkutils.c * src/gtk/gtkutils.h * src/gtk/inputdialog.c * src/gtk/inputdialog.h * src/gtk/logwindow.c * src/gtk/logwindow.h * src/gtk/manage_window.c * src/gtk/manage_window.h * src/gtk/menu.c * src/gtk/menu.h * src/gtk/pluginwindow.c * src/gtk/pluginwindow.h * src/gtk/prefswindow.c * src/gtk/prefswindow.h * src/gtk/progressdialog.c * src/gtk/progressdialog.h * src/gtk/quicksearch.c * src/gtk/quicksearch.h * src/gtk/sslcertwindow.c * src/gtk/sslcertwindow.h * src/plugins/clamav/clamav_plugin.c * src/plugins/clamav/clamav_plugin.h * src/plugins/clamav/clamav_plugin_gtk.c * src/plugins/demo/demo.c * src/plugins/dillo_viewer/dillo_prefs.c * src/plugins/dillo_viewer/dillo_prefs.h * src/plugins/dillo_viewer/dillo_viewer.c * src/plugins/mathml_viewer/mathml_viewer.c * src/plugins/pgpcore/passphrase.c * src/plugins/pgpcore/passphrase.h * src/plugins/pgpcore/plugin.c * src/plugins/pgpcore/prefs_gpg.c * src/plugins/pgpcore/prefs_gpg.h * src/plugins/pgpcore/select-keys.c * src/plugins/pgpcore/select-keys.h * src/plugins/pgpcore/sgpgme.c * src/plugins/pgpcore/sgpgme.h * src/plugins/pgpinline/pgpinline.c * src/plugins/pgpinline/pgpinline.h * src/plugins/pgpinline/plugin.c * src/plugins/pgpmime/pgpmime.c * src/plugins/pgpmime/pgpmime.h * src/plugins/pgpmime/plugin.c * src/plugins/spamassassin/spamassassin.c * src/plugins/spamassassin/spamassassin.h * src/plugins/spamassassin/spamassassin_gtk.c * src/plugins/trayicon/trayicon.c * tools/OOo2sylpheed.pl * tools/acroread2sylpheed.pl * tools/asus_mailled.sh * tools/filter_conv.pl * tools/freshmeat_search.pl * tools/google_search.pl * tools/kmail2sylpheed.pl * tools/kmail2sylpheed_v2.pl * tools/maildir2sylpheed.pl * tools/multiwebsearch.pl * tools/newscache_clean.pl * tools/outlook2sylpheed.pl * tools/sylpheed-switcher * tools/update-po * tools/vcard2xml.py * tools/kdeservicemenu/sylpheed-kdeservicemenu.pl update FSF address
2005-09-21 20:22:51 +02:00
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
2001-04-19 14:21:46 +02:00
*/
#ifndef __FOLDER_H__
#define __FOLDER_H__
#include <glib.h>
#include <time.h>
2004-01-12 22:28:31 +01:00
typedef struct _Folder Folder;
typedef struct _FolderClass FolderClass;
2004-01-12 22:28:31 +01:00
typedef struct _FolderItem FolderItem;
typedef struct _FolderUpdateData FolderUpdateData;
typedef struct _FolderItemUpdateData FolderItemUpdateData;
2004-01-12 22:28:31 +01:00
typedef struct _PersistPrefs PersistPrefs;
2001-04-19 14:21:46 +02:00
#define FOLDER(obj) ((Folder *)obj)
#define FOLDER_CLASS(obj) (FOLDER(obj)->klass)
2004-01-12 22:28:31 +01:00
#define FOLDER_TYPE(obj) (FOLDER(obj)->klass->type)
2001-04-19 14:21:46 +02:00
2001-08-16 13:28:10 +02:00
#define FOLDER_IS_LOCAL(obj) (FOLDER_TYPE(obj) == F_MH || \
FOLDER_TYPE(obj) == F_MBOX || \
FOLDER_TYPE(obj) == F_MAILDIR)
2001-04-19 14:21:46 +02:00
#define FOLDER_ITEM(obj) ((FolderItem *)obj)
#define FOLDER_UPDATE_HOOKLIST "folder_update"
#define FOLDER_ITEM_UPDATE_HOOKLIST "folder_item_update"
2001-04-19 14:21:46 +02:00
typedef enum
{
F_MH,
F_MBOX,
F_MAILDIR,
F_IMAP,
F_NEWS,
F_UNKNOWN
} FolderType;
typedef enum
{
F_NORMAL,
F_INBOX,
F_OUTBOX,
F_DRAFT,
F_QUEUE,
F_TRASH
} SpecialFolderItemType;
2002-06-03 08:03:31 +02:00
typedef enum
{
SORT_BY_NONE,
SORT_BY_NUMBER,
SORT_BY_SIZE,
SORT_BY_DATE,
SORT_BY_FROM,
SORT_BY_SUBJECT,
SORT_BY_SCORE,
SORT_BY_LABEL,
SORT_BY_MARK,
2003-01-26 13:56:56 +01:00
SORT_BY_STATUS,
2002-06-03 08:03:31 +02:00
SORT_BY_MIME,
2002-12-26 01:40:41 +01:00
SORT_BY_TO,
2002-06-03 08:03:31 +02:00
SORT_BY_LOCKED
} FolderSortKey;
typedef enum
{
SORT_ASCENDING,
SORT_DESCENDING
} FolderSortType;
typedef enum
{
F_MOVE_OK = 0,
F_MOVE_FAILED_DEST_IS_PARENT = -1,
F_MOVE_FAILED_DEST_IS_CHILD = -2,
F_MOVE_FAILED_DEST_OUTSIDE_MAILBOX = -3,
F_MOVE_FAILED = -4
} FolderItemMoveResult;
typedef enum
{
2004-05-10 12:22:28 +02:00
FOLDER_ADD_FOLDER = 1 << 0,
FOLDER_REMOVE_FOLDER = 1 << 1,
2004-02-21 12:01:01 +01:00
FOLDER_TREE_CHANGED = 1 << 2,
2004-05-10 12:22:28 +02:00
FOLDER_ADD_FOLDERITEM = 1 << 3,
FOLDER_REMOVE_FOLDERITEM = 1 << 4
} FolderUpdateFlags;
typedef enum
{
F_ITEM_UPDATE_MSGCNT = 1 << 0,
F_ITEM_UPDATE_CONTENT = 1 << 1,
2004-06-25 10:05:09 +02:00
F_ITEM_UPDATE_ADDMSG = 1 << 2,
F_ITEM_UPDATE_REMOVEMSG = 1 << 3,
F_ITEM_UPDATE_NAME = 1 << 4
} FolderItemUpdateFlags;
2001-04-19 14:21:46 +02:00
typedef void (*FolderUIFunc) (Folder *folder,
FolderItem *item,
gpointer data);
typedef void (*FolderDestroyNotify) (Folder *folder,
FolderItem *item,
gpointer data);
2004-05-10 12:22:28 +02:00
typedef void (*FolderItemFunc) (FolderItem *item,
2002-06-30 01:33:42 +02:00
gpointer data);
2001-04-19 14:21:46 +02:00
2004-01-12 22:28:31 +01:00
#include "folder_item_prefs.h"
#include "procmsg.h"
#include "msgcache.h"
2004-01-12 22:28:31 +01:00
#include "xml.h"
#include "prefs_account.h"
2001-04-19 14:21:46 +02:00
struct _Folder
{
FolderClass *klass;
2001-04-19 14:21:46 +02:00
gchar *name;
PrefsAccount *account;
2004-05-10 12:22:28 +02:00
guint sort;
2001-04-19 14:21:46 +02:00
FolderItem *inbox;
FolderItem *outbox;
FolderItem *draft;
FolderItem *queue;
FolderItem *trash;
FolderUIFunc ui_func;
gpointer ui_func_data;
GNode *node;
gpointer data;
2002-03-17 10:50:46 +01:00
GHashTable *newsart;
};
struct _FolderClass
{
2004-05-10 12:22:28 +02:00
/**
* A numeric identifier for the FolderClass. Will be removed in the future
*/
FolderType type;
2004-05-10 12:22:28 +02:00
/**
* A string identifier for the FolderClass. Currently used in folderlist.xml.
* Should be lowercase.
*/
gchar *idstr;
2004-05-10 12:22:28 +02:00
/**
* A string for the User Interface that identifies the FolderClass to the
* user. Can be upper and lowercase unlike the idstr.
*/
gchar *uistr;
2004-05-10 12:22:28 +02:00
2001-04-19 14:21:46 +02:00
/* virtual functions */
/* Folder funtions */
2004-05-10 12:22:28 +02:00
/**
* Create a new \c Folder of this \c FolderClass.
*
* \param name The name of the new Folder
* \param path The path of the new Folder
* \return The new \c Folder, or \c NULL when creating the \c Folder
* failed
*/
Folder *(*new_folder) (const gchar *name,
const gchar *path);
2004-05-10 12:22:28 +02:00
/**
* Destroy a \c Folder of this \c FolderClass, frees all resources
* allocated by the Folder
*
* \param folder The \c Folder that should be destroyed.
*/
void (*destroy_folder) (Folder *folder);
2004-05-10 12:22:28 +02:00
/**
* Set the Folder's internal attributes from an \c XMLTag. Also sets the
* parameters of the root-FolderItem of the \c Folder. If \c NULL
* the default function of the basic \¢ FolderClass is used, so it
* must not be \c NULL if one of the parent \c FolderClasses has a \c set_xml
* function. In that case the parent \c FolderClass' \c set_xml function
* can be used or it has to be called with the \c folder and \c tag by
* the implementation.
*
* \param folder The \c Folder which's attributes should be updated
* \param tag The \c XMLTag containing the \c XMLAttrs for the attributes
*/
2004-01-12 22:28:31 +01:00
void (*set_xml) (Folder *folder,
XMLTag *tag);
2004-05-10 12:22:28 +02:00
/**
* Get an \c XMLTag for the attributes of the \c Folder and the root-FolderItem
* of the \c Folder. If \c NULL the default implementation for the basic
* FolderClass will be used, so it must not be \c NULL if one of the
* parent \c FolderClasses has it's own implementation for \c get_xml.
* In that case the parent FolderClass' \c get_xml function can be
* used or the \c XMLTag has to be fetched from the parent's \c get_xml
* function and then the \c FolderClass specific attributes can be
* added to it.
*
* \param Folder The \c Folder which's attributes should be set in the
* \c XMLTag's \c XMLAttrs
* \return XMLTag An \c XMLTag with \c XMLAttrs containing the \c Folder's
* attributes.
*/
2004-01-12 22:28:31 +01:00
XMLTag *(*get_xml) (Folder *folder);
2004-05-10 12:22:28 +02:00
/**
* Rebuild the folder tree from the folder's data
* \todo New implementations of MH and IMAP are actually syncronizing
* the tree with the folder by reusing the old \c FolderItems.
* Claws still destroys the old tree before calling this function.
*
* \param folder The folder which's tree should be rebuild
* \return 0 on success, a negative number otherwise
*/
2004-01-12 22:28:31 +01:00
gint (*scan_tree) (Folder *folder);
gint (*create_tree) (Folder *folder);
/* FolderItem functions */
2004-05-10 12:22:28 +02:00
/**
* Create a new \c FolderItem structure for the \c FolderClass.
* \c FolderClasses can have their own \c FolderItem structure with
* extra attributes.
*
* \param folder The \c Folder for that a \c FolderItem should be
* created
* \return The new \c FolderItem or NULL in case of an error
*/
FolderItem *(*item_new) (Folder *folder);
2004-05-10 12:22:28 +02:00
/**
* Destroy a \c FolderItem from this \c FolderClass. The \c FolderClass
* has to free all private resources used by the \c FolderItem.
*
* \param folder The \c Folder of the \c FolderItem
* \param item The \c FolderItem that should be destroyed
*/
2004-01-12 22:28:31 +01:00
void (*item_destroy) (Folder *folder,
FolderItem *item);
2004-05-10 12:22:28 +02:00
/**
* Set the \c FolderItem's internal attributes from an \c XMLTag. If
* \c NULL the default function of the basic \c FolderClass is used, so it
* must not be \c NULL if one of the parent \c FolderClasses has a \c item_set_xml
* function. In that case the parent \c FolderClass' \c item_set_xml function
* can be used or it has to be called with the \c folder, \c item and \c tag by
* the implementation.
*
* \param folder The \c Folder of the \c FolderItem
* \param item The \c FolderItems which's attributes should be set
* \param tag The \c XMLTag with \c XMLAttrs for the \c FolderItem's
* attributes
*/
2004-01-12 22:28:31 +01:00
void (*item_set_xml) (Folder *folder,
FolderItem *item,
XMLTag *tag);
2004-05-10 12:22:28 +02:00
/**
* Get an \c XMLTag for the attributes of the \c FolderItem If \c NULL
* the default implementation for the basic \c FolderClass will be used,
* so it must not be \c NULL if one of the parent \c FolderClasses has
* it's own implementation for \c item_get_xml. In that case the parent
* FolderClass' \c item_get_xml function can be used or the \c XMLTag
* has to be fetched from the parent's \c item_get_xml function and
* then the \c FolderClass specific attributes can be added to it.
*
* \param folder The \c Folder of the \c FolderItem
* \parem item The \c FolderItem which's attributes should be set in
* the \c XMLTag's \c XMLAttrs
* \return An \c XMLTag with \c XMLAttrs containing the \c FolderItem's
* attributes.
*/
2004-01-12 22:28:31 +01:00
XMLTag *(*item_get_xml) (Folder *folder,
FolderItem *item);
2004-05-10 12:22:28 +02:00
/**
* Get a local path for the \c FolderItem where Sylpheed can save
* it's cache data. For local directory based folders this can be the
* real path. For other folders it can be the local cache directory.
*
* \param folder The \c Folder of the \c FolderItem
* \param item The \c FolderItem for that a path should be returned
* \return A path for the \c FolderItem
*/
gchar *(*item_get_path) (Folder *folder,
FolderItem *item);
2004-05-10 12:22:28 +02:00
/**
* Create a new \c FolderItem. The function must use folder_item_append
* to add the new \c FolderItem to the folder tree
*
* \param folder The \c Folder in which a new \c FolderItem should be
* created
* \param parent \c The parent \c FolderItem for the new \c FolderItem
* \parem name The name for the new \c FolderItem
* \return The new \c FolderItem
*/
FolderItem *(*create_folder) (Folder *folder,
FolderItem *parent,
const gchar *name);
2004-05-10 12:22:28 +02:00
/**
* Rename a \c FolderItem
*
* \param folder The \c Folder of the \c FolderItem that should be
* renamed
* \param item The \c FolderItem that should be renamed
* \param name The new name of the \c FolderItem
* \return 0 on success, a negative number otherwise
*/
2004-01-12 22:28:31 +01:00
gint (*rename_folder) (Folder *folder,
FolderItem *item,
const gchar *name);
2004-05-10 12:22:28 +02:00
/**
* Remove a \c FolderItem from the \c Folder
*
* \param folder The \c Folder that contains the \c FolderItem
* \param item The \c FolderItem that should be removed
* \return 0 on sucess, a negative number otherwise
*/
2004-01-12 22:28:31 +01:00
gint (*remove_folder) (Folder *folder,
FolderItem *item);
2004-05-10 12:22:28 +02:00
/**
* Close a \c FolderItem. Called when the user deselects a
* \c FolderItem.
*
* \attention In Sylpheed-Main operations can only be done on the
* \c FolderItem that is opened in the SummaryView. This
* \c FolderItem will be closed when you select a new
* \c FolderItem in the FolderView. In Claws operations can
* be done any time on any folder and you should not expect
* that all \c FolderItems get closed after operations
*
* \param folder The \c Folder that contains the \c FolderItem
* \param item The \c FolderItem that should be closed
* \return 0 on success, a negative number otherwise
*/
2004-01-12 22:28:31 +01:00
gint (*close) (Folder *folder,
FolderItem *item);
2004-05-10 12:22:28 +02:00
/**
* Get the list of message numbers for the messages in the \c FolderItem
*
* \param folder The \c Folder that contains the \c FolderItem
* \param item The \c FolderItem for which the message numbers should
* be fetched
* \param list Pointer to a GSList where message numbers have to be
* added. Because of the implementation of the GSList that
* changes the pointer of the GSList itself when the first
* item is added this is a pointer to a pointer to a
* GSList structure. Use *item = g_slist_...(*item, ...)
* operations to modify the list.
* \param old_uids_valid In some \c Folders the old UIDs can be invalid.
* Set this pointer to a gboolean to TRUE if the
* old UIDs are still valid, otherwise set it to
* FALSE and the folder system will discard it's
* cache data of the previously know UIDs
* \return The number of message numbers add to the list on success,
* a negative number otherwise.
*/
2004-01-12 22:28:31 +01:00
gint (*get_num_list) (Folder *folder,
FolderItem *item,
GSList **list,
gboolean *old_uids_valid);
2004-05-10 12:22:28 +02:00
/**
* Tell the folder system if a \c FolderItem should be scanned
* (cache data syncronized with the folder content) when it is required
* because the \c FolderItem's content changed. If NULL the folder
* system will not do automatic scanning of \c FolderItems
*
* \param folder The \c Folder that contains the \c FolderItem
* \param item The \c FolderItem which's content should be checked
* \return TRUE if the \c FolderItem should be scanned, FALSE otherwise
*/
gboolean (*scan_required) (Folder *folder,
FolderItem *item);
/* Message functions */
2004-05-10 12:22:28 +02:00
/**
* Get a MsgInfo for a message in a \c FolderItem
*
* \param folder The \c Folder containing the message
* \param item The \c FolderItem containing the message
* \param num The message number of the message
* \return A pointer to a \c MsgInfo decribing the message or \c
* NULL in case of an error
*/
MsgInfo *(*get_msginfo) (Folder *folder,
FolderItem *item,
gint num);
2004-05-10 12:22:28 +02:00
/**
* Get \c MsgInfos for a list of message numbers
*
* \param folder The \c Folder containing the message
* \param item The \c FolderItem containing the message
* \param msgnum_list A list of message numbers for which the
* \c MsgInfos should be fetched
* \return A list of \c MsgInfos for the messages in the \c msgnum_list
* that really exist. Messages that are not found can simply
* be left out.
*/
MsgInfoList *(*get_msginfos) (Folder *folder,
FolderItem *item,
MsgNumberList *msgnum_list);
2004-05-10 12:22:28 +02:00
/**
* Get the filename for a message. This can either be the real message
* file for local folders or a temporary file for remote folders.
*
* \param folder The \c Folder containing the message
* \param item The \c FolderItem containing the message
* \param num The message number of the message
* \return A string with the filename of the message file. The returned
* string has to be freed with \c g_free(). If message is not
* available return NULL.
*/
gchar *(*fetch_msg) (Folder *folder,
FolderItem *item,
gint num);
gchar *(*fetch_msg_full) (Folder *folder,
FolderItem *item,
gint num,
gboolean headers,
gboolean body);
2004-05-10 12:22:28 +02:00
/**
* Add a single message file to a folder with the given flags (if
* flag handling is supported by the folder)
*
* \param folder The target \c Folder for the message
* \param dest the target \c FolderItem for the message
* \param file The file that contains the message
* \param flags The flags the new message should have in the folder
* \return 0 on success, a negative number otherwise
*/
gint (*add_msg) (Folder *folder,
FolderItem *dest,
const gchar *file,
MsgFlags *flags);
2004-05-10 12:22:28 +02:00
/**
* Add multiple messages to a \c FolderItem. If NULL the folder
* system will add messages with \c add_msg one by one
*
* \param folder The target \c Folder for the messages
* \param dest the target \c FolderItem for the messages
* \param file_list A list of \c MsgFileInfos which contain the
* filenames and flags for the new messages
* \param relation Insert tuples of (MsgFileInfo, new message number) to
* provide feedback for the folder system which new
* message number a \c MsgFileInfo got in dest. Insert
* 0 if the new message number is unknown.
*/
gint (*add_msgs) (Folder *folder,
FolderItem *dest,
GSList *file_list,
GRelation *relation);
2004-05-10 12:22:28 +02:00
/**
* Copy a message to a FolderItem
*
* \param folder The \c Folder of the destination FolderItem
* \param dest The destination \c FolderItem for the message
* \param msginfo The message that should be copied
* \return The message number the copied message got, 0 if it is
* unknown because message numbers are assigned by an external
* system and not available after copying or a negative number
* if an error occuried
*/
gint (*copy_msg) (Folder *folder,
FolderItem *dest,
MsgInfo *msginfo);
2004-05-10 12:22:28 +02:00
/**
* Copy multiple messages to a \c FolderItem. If \c NULL the folder
* system will use \c copy_msg to copy messages one by one.
*
* \param folder The \c Folder of the destination FolderItem
* \param dest The destination \c FolderItem for the message
* \param msglist A list of \c MsgInfos which should be copied to dest
* \param relation Insert tuples of (MsgInfo, new message number) to
* provide feedback for the folder system which new
* message number a \c MsgInfo got in dest. Insert
* 0 if the new message number is unknown.
* \return 0 on success, a negative number otherwise
*/
gint (*copy_msgs) (Folder *folder,
FolderItem *dest,
MsgInfoList *msglist,
GRelation *relation);
2004-05-10 12:22:28 +02:00
/**
* Remove a message from a \c FolderItem.
*
* \param folder The \c Folder of the message
* \param item The \c FolderItem containing the message
* \param num The message number of the message
* \return 0 on success, a negative number otherwise
*/
gint (*remove_msg) (Folder *folder,
FolderItem *item,
gint num);
gint (*remove_msgs) (Folder *folder,
FolderItem *item,
MsgInfoList *msglist,
GRelation *relation);
2004-05-10 12:22:28 +02:00
/**
* Remove all messages in a \ c FolderItem
*
* \param folder The \c Folder of the \c FolderItem
* \param item The \FolderItem which's messages should be deleted
* \return 0 on succes, a negative number otherwise
*/
gint (*remove_all_msg) (Folder *folder,
FolderItem *item);
2004-05-10 12:22:28 +02:00
/**
* Check if a message has been modified by someone else
*
* \param folder The \c Folder of the message
* \param item The \c FolderItem containing the message
* \param msginfo The \c MsgInfo for the message that should be checked
* \return \c TRUE if the message was modified, \c FALSE otherwise
*/
gboolean (*is_msg_changed) (Folder *folder,
FolderItem *item,
MsgInfo *msginfo);
2004-05-10 12:22:28 +02:00
/**
* Update a message's flags in the folder data. If NULL only the
* internal flag management will be used. The function has to set
* \c msginfo->flags.perm_flags. It does not have to set the flags
* that it got as \c newflags. If a flag can not be set in this
* \c FolderClass the function can refuse to set it. Flags that are not
* supported by the \c FolderClass should not be refused. They will be
* managed by the internal cache in this case.
*
* \param folder The \c Folder of the message
* \param item The \c FolderItem of the message
* \param msginfo The \c MsgInfo for the message which's flags should be
* updated
* \param newflags The flags the message should get
*/
void (*change_flags) (Folder *folder,
FolderItem *item,
MsgInfo *msginfo,
MsgPermFlags newflags);
2004-05-10 12:22:28 +02:00
/**
* Get the flags for a list of messages. Flags that are not supported
* by the folder should be preserved. They can be copied from
* \c msginfo->flags.perm_flags
*
* \param folder The \c Folder of the messages
* \param item The \c FolderItem of the messages
* \param msglist The list of \c MsgInfos for which the flags should
* be returned
* \param msgflags A \c GRelation for tuples of (MsgInfo, new permanent
* flags for MsgInfo). Add tuples for the messages in msglist
* \return 0 on success, a negative number otherwise
*/
gint (*get_flags) (Folder *folder,
FolderItem *item,
MsgInfoList *msglist,
GRelation *msgflags);
void (*set_batch) (Folder *folder,
FolderItem *item,
gboolean batch);
void (*synchronise) (FolderItem *item);
2001-04-19 14:21:46 +02:00
};
struct _FolderItem
{
SpecialFolderItemType stype;
2003-10-05 12:10:30 +02:00
gchar *name; /* UTF-8 */
gchar *path; /* UTF-8 */
2001-04-19 14:21:46 +02:00
time_t mtime;
gint new_msgs;
gint unread_msgs;
gint total_msgs;
gint unreadmarked_msgs;
gint marked_msgs;
2001-04-19 14:21:46 +02:00
gint last_num;
2002-06-30 01:33:42 +02:00
MsgCache *cache;
/* special flags */
2001-12-11 16:06:46 +01:00
guint no_sub : 1; /* no child allowed? */
guint no_select : 1; /* not selectable? */
guint collapsed : 1; /* collapsed item */
guint thread_collapsed : 1; /* collapsed item */
2001-12-11 16:06:46 +01:00
guint threaded : 1; /* threaded folder view */
guint hide_read_msgs : 1; /* hide read messages */
guint ret_rcpt : 1; /* return receipt */
guint search_match : 1;
2001-06-28 10:44:31 +02:00
2001-07-31 08:17:48 +02:00
gint op_count;
guint opened : 1; /* opened by summary view */
FolderItemUpdateFlags update_flags; /* folderview for this folder should be updated */
2001-07-31 08:17:48 +02:00
2002-06-03 08:03:31 +02:00
FolderSortKey sort_key;
FolderSortType sort_type;
2003-08-25 16:14:47 +02:00
GNode *node;
2001-04-19 14:21:46 +02:00
Folder *folder;
PrefsAccount *account;
gboolean apply_sub;
2002-04-03 10:58:44 +02:00
GSList *mark_queue;
2001-04-19 14:21:46 +02:00
gpointer data;
2001-05-06 06:27:28 +02:00
FolderItemPrefs * prefs;
/* for faster search of special parents */
SpecialFolderItemType parent_stype;
gboolean processing_pending;
2001-04-19 14:21:46 +02:00
};
2004-01-12 22:28:31 +01:00
struct _PersistPrefs
{
FolderSortKey sort_key;
FolderSortType sort_type;
guint collapsed : 1;
guint thread_collapsed : 1;
guint threaded : 1;
guint hide_read_msgs : 1; /* CLAWS */
guint ret_rcpt : 1; /* CLAWS */
2004-01-12 22:28:31 +01:00
};
struct _FolderUpdateData
{
Folder *folder;
FolderUpdateFlags update_flags;
FolderItem *item;
};
struct _FolderItemUpdateData
{
FolderItem *item;
FolderItemUpdateFlags update_flags;
2004-06-25 10:05:09 +02:00
MsgInfo *msg;
};
void folder_system_init (void);
void folder_register_class (FolderClass *klass);
2004-02-21 12:01:01 +01:00
void folder_unregister_class (FolderClass *klass);
Folder *folder_new (FolderClass *type,
2002-01-16 12:48:36 +01:00
const gchar *name,
const gchar *path);
2004-01-12 22:28:31 +01:00
void folder_init (Folder *folder,
const gchar *name);
2002-01-16 12:48:36 +01:00
void folder_destroy (Folder *folder);
2004-01-12 22:28:31 +01:00
void folder_set_xml (Folder *folder,
XMLTag *tag);
XMLTag *folder_get_xml (Folder *folder);
2003-08-26 09:13:40 +02:00
FolderItem *folder_item_new (Folder *folder,
const gchar *name,
const gchar *path);
void folder_item_append (FolderItem *parent,
FolderItem *item);
void folder_item_remove (FolderItem *item);
void folder_item_remove_children (FolderItem *item);
void folder_item_destroy (FolderItem *item);
2004-02-21 12:01:01 +01:00
FolderItem *folder_item_parent (FolderItem *item);
2002-01-16 12:48:36 +01:00
2004-01-12 22:28:31 +01:00
void folder_item_set_xml (Folder *folder,
FolderItem *item,
XMLTag *tag);
XMLTag *folder_item_get_xml (Folder *folder,
FolderItem *item);
2001-04-19 14:21:46 +02:00
void folder_set_ui_func (Folder *folder,
FolderUIFunc func,
gpointer data);
void folder_set_name (Folder *folder,
const gchar *name);
2004-05-10 12:22:28 +02:00
void folder_set_sort (Folder *folder,
guint sort);
2001-04-19 14:21:46 +02:00
void folder_tree_destroy (Folder *folder);
void folder_add (Folder *folder);
2004-05-10 12:22:28 +02:00
void folder_remove (Folder *folder);
2001-04-19 14:21:46 +02:00
2001-11-26 08:53:20 +01:00
GList *folder_get_list (void);
gint folder_read_list (void);
void folder_write_list (void);
void folder_scan_tree (Folder *folder, gboolean rebuild);
FolderItem *folder_create_folder(FolderItem *parent, const gchar *name);
2004-05-10 12:22:28 +02:00
gint folder_item_rename (FolderItem *item, gchar *newname);
void folder_update_op_count (void);
2002-06-30 01:33:42 +02:00
void folder_func_to_all_folders (FolderItemFunc function,
gpointer data);
void folder_count_total_msgs(guint *new_msgs, guint *unread_msgs,
guint *unreadmarked_msgs, guint *marked_msgs,
guint *total_msgs);
gchar *folder_get_status (GPtrArray *folders,
gboolean full);
2001-04-19 14:21:46 +02:00
2002-04-05 10:20:10 +02:00
Folder *folder_find_from_path (const gchar *path);
Folder *folder_find_from_name (const gchar *name,
FolderClass *klass);
2002-04-05 10:20:10 +02:00
FolderItem *folder_find_item_from_path (const gchar *path);
FolderClass *folder_get_class_from_string (const gchar *str);
2004-05-10 12:22:28 +02:00
FolderItem *folder_find_child_item_by_name (FolderItem *item,
const gchar *name);
2002-04-05 10:20:10 +02:00
gchar *folder_get_identifier (Folder *folder);
gchar *folder_item_get_identifier (FolderItem *item);
FolderItem *folder_find_item_from_identifier (const gchar *identifier);
gchar *folder_item_get_name (FolderItem *item);
2002-04-05 10:20:10 +02:00
2001-04-19 14:21:46 +02:00
Folder *folder_get_default_folder (void);
FolderItem *folder_get_default_inbox (void);
FolderItem *folder_get_default_outbox (void);
FolderItem *folder_get_default_draft (void);
FolderItem *folder_get_default_queue (void);
FolderItem *folder_get_default_trash (void);
2001-12-05 23:09:25 +01:00
FolderItem *folder_get_default_processing (void);
2002-03-19 09:37:53 +01:00
void folder_set_missing_folders (void);
2002-10-13 17:43:22 +02:00
void folder_unref_account_all (PrefsAccount *account);
2001-04-19 14:21:46 +02:00
2003-10-05 12:10:30 +02:00
/* return value is locale encoded file name */
2001-04-19 14:21:46 +02:00
gchar *folder_item_get_path (FolderItem *item);
2002-08-28 13:54:45 +02:00
gint folder_item_open (FolderItem *item);
gint folder_item_close (FolderItem *item);
gint folder_item_scan (FolderItem *item);
2004-06-25 10:05:09 +02:00
gint folder_item_syncronize_flags (FolderItem *item);
2001-04-19 14:21:46 +02:00
void folder_item_scan_foreach (GHashTable *table);
MsgInfo *folder_item_get_msginfo (FolderItem *item,
2002-06-30 01:33:42 +02:00
gint num);
MsgInfo *folder_item_get_msginfo_by_msgid(FolderItem *item,
const gchar *msgid);
2002-06-30 01:33:42 +02:00
GSList *folder_item_get_msg_list (FolderItem *item);
2003-10-05 12:10:30 +02:00
/* return value is locale charset */
2001-04-19 14:21:46 +02:00
gchar *folder_item_fetch_msg (FolderItem *item,
gint num);
gchar *folder_item_fetch_msg_full (FolderItem *item,
gint num,
gboolean get_headers,
gboolean get_body);
2004-02-21 12:01:01 +01:00
gint folder_item_fetch_all_msg (FolderItem *item);
2001-04-19 14:21:46 +02:00
gint folder_item_add_msg (FolderItem *dest,
2001-05-17 15:25:31 +02:00
const gchar *file,
MsgFlags *flags,
2001-05-17 15:25:31 +02:00
gboolean remove_source);
gint folder_item_add_msgs (FolderItem *dest,
GSList *file_list,
gboolean remove_source);
gint folder_item_move_to (FolderItem *src,
2002-11-15 16:36:30 +01:00
FolderItem *dest,
FolderItem **new_item);
2001-04-19 14:21:46 +02:00
gint folder_item_move_msg (FolderItem *dest,
MsgInfo *msginfo);
2003-08-05 11:01:01 +02:00
gint folder_item_move_msgs (FolderItem *dest,
2001-04-19 14:21:46 +02:00
GSList *msglist);
gint folder_item_copy_msg (FolderItem *dest,
MsgInfo *msginfo);
2003-08-05 11:01:01 +02:00
gint folder_item_copy_msgs (FolderItem *dest,
2001-04-19 14:21:46 +02:00
GSList *msglist);
gint folder_item_remove_msg (FolderItem *item,
gint num);
2001-10-07 11:15:06 +02:00
gint folder_item_remove_msgs (FolderItem *item,
GSList *msglist);
2001-04-19 14:21:46 +02:00
gint folder_item_remove_all_msg (FolderItem *item);
void folder_item_change_msg_flags (FolderItem *item,
MsgInfo *msginfo,
MsgPermFlags newflags);
2001-04-19 14:21:46 +02:00
gboolean folder_item_is_msg_changed (FolderItem *item,
MsgInfo *msginfo);
2003-10-05 12:10:30 +02:00
/* return value is locale chaset */
2001-04-19 14:21:46 +02:00
gchar *folder_item_get_cache_file (FolderItem *item);
gchar *folder_item_get_mark_file (FolderItem *item);
gchar * folder_item_get_identifier (FolderItem * item);
2001-04-19 14:21:46 +02:00
GHashTable *folder_persist_prefs_new (Folder *folder);
void folder_persist_prefs_free (GHashTable *pptable);
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);
void folder_clean_cache_memory_force (void);
void folder_item_write_cache (FolderItem *item);
void folder_item_set_default_flags (FolderItem *dest, MsgFlags *flags);
void folder_item_apply_processing (FolderItem *item);
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);
void folder_item_update_thaw (void);
void folder_item_set_batch (FolderItem *item, gboolean batch);
gboolean folder_has_parent_of_type (FolderItem *item, SpecialFolderItemType type);
void folder_synchronise (Folder *folder);
gboolean folder_want_synchronise (Folder *folder);
void folder_item_process_open (FolderItem *item,
void (*before_proc_func)(gpointer data),
void (*after_proc_func)(gpointer data),
gpointer data);
2001-04-19 14:21:46 +02:00
#endif /* __FOLDER_H__ */