|  |  |  | Camel Reference Manual |  | 
|---|
| CamelStoreCamelStore — | 
            CamelStore;
            CamelFolderInfo;
#define     CAMEL_FOLDER_NOSELECT
#define     CAMEL_FOLDER_NOINFERIORS
#define     CAMEL_FOLDER_CHILDREN
#define     CAMEL_FOLDER_NOCHILDREN
#define     CAMEL_FOLDER_SUBSCRIBED
#define     CAMEL_FOLDER_VIRTUAL
#define     CAMEL_FOLDER_SYSTEM
#define     CAMEL_FOLDER_VTRASH
#define     CAMEL_FOLDER_SHARED_TO_ME
#define     CAMEL_FOLDER_SHARED_BY_ME
#define     CAMEL_FOLDER_TYPE_MASK
#define     CAMEL_FOLDER_TYPE_BIT
#define     CAMEL_FOLDER_TYPE_NORMAL
#define     CAMEL_FOLDER_TYPE_INBOX
#define     CAMEL_FOLDER_TYPE_OUTBOX
#define     CAMEL_FOLDER_TYPE_TRASH
#define     CAMEL_FOLDER_TYPE_JUNK
            CamelRenameInfo;
#define     CAMEL_STORE_SUBSCRIPTIONS
#define     CAMEL_STORE_VTRASH
#define     CAMEL_STORE_FILTER_INBOX
#define     CAMEL_STORE_VJUNK
#define     CAMEL_STORE_FOLDER_CREATE
#define     CAMEL_STORE_FOLDER_EXCL
#define     CAMEL_STORE_FOLDER_BODY_INDEX
#define     CAMEL_STORE_FOLDER_PRIVATE
#define     CAMEL_STORE_FOLDER_CREATE_EXCL
#define     CAMEL_STORE_FOLDER_INFO_FAST
#define     CAMEL_STORE_FOLDER_INFO_RECURSIVE
#define     CAMEL_STORE_FOLDER_INFO_SUBSCRIBED
#define     CAMEL_STORE_FOLDER_INFO_NO_VIRTUAL
CamelFolder* camel_store_get_folder         (CamelStore *store,
                                             const char *folder_name,
                                             guint32 flags,
                                             CamelException *ex);
CamelFolder* camel_store_get_inbox          (CamelStore *store,
                                             CamelException *ex);
CamelFolder* camel_store_get_trash          (CamelStore *store,
                                             CamelException *ex);
CamelFolder* camel_store_get_junk           (CamelStore *store,
                                             CamelException *ex);
CamelFolderInfo* camel_store_create_folder  (CamelStore *store,
                                             const char *parent_name,
                                             const char *folder_name,
                                             CamelException *ex);
void        camel_store_delete_folder       (CamelStore *store,
                                             const char *folder_name,
                                             CamelException *ex);
void        camel_store_rename_folder       (CamelStore *store,
                                             const char *old_name,
                                             const char *new_name,
                                             CamelException *ex);
void        camel_store_sync                (CamelStore *store,
                                             int expunge,
                                             CamelException *ex);
CamelFolderInfo* camel_store_get_folder_info
                                            (CamelStore *store,
                                             const char *top,
                                             guint32 flags,
                                             CamelException *ex);
void        camel_store_free_folder_info    (CamelStore *store,
                                             CamelFolderInfo *fi);
void        camel_store_free_folder_info_full
                                            (CamelStore *store,
                                             CamelFolderInfo *fi);
void        camel_store_free_folder_info_nop
                                            (CamelStore *store,
                                             CamelFolderInfo *fi);
void        camel_folder_info_free          (CamelFolderInfo *fi);
CamelFolderInfo* camel_folder_info_build    (GPtrArray *folders,
                                             const char *namespace,
                                             char separator,
                                             gboolean short_names);
CamelFolderInfo* camel_folder_info_clone    (CamelFolderInfo *fi);
gboolean    camel_store_supports_subscriptions
                                            (CamelStore *store);
gboolean    camel_store_folder_subscribed   (CamelStore *store,
                                             const char *folder_name);
void        camel_store_subscribe_folder    (CamelStore *store,
                                             const char *folder_name,
                                             CamelException *ex);
void        camel_store_unsubscribe_folder  (CamelStore *store,
                                             const char *folder_name,
                                             CamelException *ex);
void        camel_store_noop                (CamelStore *store,
                                             CamelException *ex);
int         camel_store_folder_uri_equal    (CamelStore *store,
                                             const char *uri0,
                                             const char *uri1);
            CamelISubscribe;
CamelType   camel_isubscribe_get_type       (void);
gboolean    camel_isubscribe_subscribed     (CamelStore *store,
                                             const char *name);
void        camel_isubscribe_subscribe      (CamelStore *store,
                                             const char *folder_name,
                                             CamelException *ex);
void        camel_isubscribe_unsubscribe    (CamelStore *store,
                                             const char *folder_name,
                                             CamelException *ex);
CamelObject +----CamelService +----CamelStore +----CamelOfflineStore +----CamelVeeStore
typedef struct {
	struct _CamelFolderInfo *next;
	struct _CamelFolderInfo *parent;
	struct _CamelFolderInfo *child;
	char *uri;
	char *name;
	char *full_name;
	guint32 flags;
	guint32 unread;
	guint32 total;
} CamelFolderInfo;
#define CAMEL_STORE_FOLDER_PRIVATE (1<<3) /* a private folder, that shouldn't show up in unmatched/folder info's, etc */
#define CAMEL_STORE_FOLDER_CREATE_EXCL (CAMEL_STORE_FOLDER_CREATE | CAMEL_STORE_FOLDER_EXCL)
#define CAMEL_STORE_FOLDER_INFO_NO_VIRTUAL (1 << 3) /* don't include vTrash/vJunk folders */
CamelFolder* camel_store_get_folder (CamelStore *store, const char *folder_name, guint32 flags, CamelException *ex);
Get a specific folder object from the store by name.
| store: | a CamelStore object | 
| folder_name: | name of the folder to get | 
| flags: | folder flags (create, save body index, etc) | 
| ex: | a CamelException | 
| Returns : | the folder corresponding to the path folder_name. | 
CamelFolder* camel_store_get_inbox (CamelStore *store, CamelException *ex);
| store: | a CamelStore object | 
| ex: | a CamelException | 
| Returns : | the folder in the store into which new mail is delivered,
or NULLif no such folder exists. | 
CamelFolder* camel_store_get_trash (CamelStore *store, CamelException *ex);
| store: | a CamelStore object | 
| ex: | a CamelException | 
| Returns : | the folder in the store into which trash is delivered, or NULLif no such folder exists. | 
CamelFolder* camel_store_get_junk (CamelStore *store, CamelException *ex);
| store: | a CamelStore object | 
| ex: | a CamelException | 
| Returns : | the folder in the store into which junk is delivered, or NULLif no such folder exists. | 
CamelFolderInfo* camel_store_create_folder (CamelStore *store, const char *parent_name, const char *folder_name, CamelException *ex);
Creates a new folder as a child of an existing folder.
parent_name can be NULL to create a new top-level folder.
| store: | a CamelStore object | 
| parent_name: | name of the new folder's parent, or NULL | 
| folder_name: | name of the folder to create | 
| ex: | a CamelException | 
| Returns : | info about the created folder, which the caller must free with camel_store_free_folder_info | 
void camel_store_delete_folder (CamelStore *store, const char *folder_name, CamelException *ex);
Deletes the named folder. The folder must be empty.
| store: | a CamelStore object | 
| folder_name: | name of the folder to delete | 
| ex: | a CamelException | 
void camel_store_rename_folder (CamelStore *store, const char *old_name, const char *new_name, CamelException *ex);
Rename a named folder to a new name.
| store: | a CamelStore object | 
| old_name: | |
| new_name: | the new name of the folder | 
| ex: | a CamelException | 
void camel_store_sync (CamelStore *store, int expunge, CamelException *ex);
Syncs any changes that have been made to the store object and its folders with the real store.
| store: | a CamelStore object | 
| expunge: | TRUEif an expunge should be done after sync orFALSEotherwise | 
| ex: | a CamelException | 
CamelFolderInfo* camel_store_get_folder_info (CamelStore *store, const char *top, guint32 flags, CamelException *ex);
This fetches information about the folder structure of store,
starting with top, and returns a tree of CamelFolderInfo
structures. If flags includes CAMEL_STORE_FOLDER_INFO_SUBSCRIBED,
only subscribed folders will be listed.   If the store doesn't support
subscriptions, then it will list all folders.  If flags includes
CAMEL_STORE_FOLDER_INFO_RECURSIVE, the returned tree will include
all levels of hierarchy below top. If not, it will only include
the immediate subfolders of top. If flags includes
CAMEL_STORE_FOLDER_INFO_FAST, the unread_message_count fields of
some or all of the structures may be set to -1, if the store cannot
determine that information quickly.  If flags includes
CAMEL_STORE_FOLDER_INFO_NO_VIRTUAL, don't include special virtual
folders (such as vTrash or vJunk).
The CAMEL_STORE_FOLDER_INFO_FAST flag should be considered
deprecated; most backends will behave the same whether it is
supplied or not.  The only guaranteed way to get updated folder
counts is to both open the folder and invoke refresh_info() it.
| store: | a CamelStore object | 
| top: | the name of the folder to start from | 
| flags: | various CAMEL_STORE_FOLDER_INFO_* flags to control behavior | 
| ex: | a CamelException | 
| Returns : | a CamelFolderInfo tree, which must be freed with camel_store_free_folder_info | 
void camel_store_free_folder_info (CamelStore *store, CamelFolderInfo *fi);
Frees the data returned by camel_store_get_folder_info
| store: | a CamelStore object | 
| fi: | a CamelFolderInfo as gotten via camel_store_get_folder_info | 
void        camel_store_free_folder_info_full
                                            (CamelStore *store,
                                             CamelFolderInfo *fi);
An implementation for CamelStore::free_folder_info. Frees all of the data.
| store: | a CamelStore object | 
| fi: | a CamelFolderInfo as gotten via camel_store_get_folder_info | 
void        camel_store_free_folder_info_nop
                                            (CamelStore *store,
                                             CamelFolderInfo *fi);
An implementation for CamelStore::free_folder_info. Does nothing.
| store: | a CamelStore object | 
| fi: | a CamelFolderInfo as gotten via camel_store_get_folder_info | 
void camel_folder_info_free (CamelFolderInfo *fi);
Frees fi.
| fi: | a CamelFolderInfo | 
CamelFolderInfo* camel_folder_info_build (GPtrArray *folders, const char *namespace, char separator, gboolean short_names);
This takes an array of folders and attaches them together according
to the hierarchy described by their full_names and separator. If
namespace is non-NULL, then it will be ignored as a full_name
prefix, for purposes of comparison. If necessary,
camel_folder_info_build will create additional CamelFolderInfo with
NULL urls to fill in gaps in the tree. The value of short_names
is used in constructing the names of these intermediate folders.
NOTE: This is deprected, do not use this. FIXME: remove this/move it to imap, which is the only user of it now.
| folders: | an array of CamelFolderInfo | 
| namespace: | an ignorable prefix on the folder names | 
| separator: | the hieararchy separator character | 
| short_names: | TRUEif the (short) name of a folder is the part after
the lastseparatorin the full name.FALSEif it is the full name. | 
| Returns : | the top level of the tree of linked folder info. | 
CamelFolderInfo* camel_folder_info_clone (CamelFolderInfo *fi);
Clones fi recursively.
| fi: | a CamelFolderInfo | 
| Returns : | the cloned CamelFolderInfo tree. | 
gboolean camel_store_supports_subscriptions (CamelStore *store);
Get whether or not store supports subscriptions to folders.
| store: | a CamelStore object | 
| Returns : | TRUEif folder subscriptions are supported orFALSEotherwise | 
gboolean camel_store_folder_subscribed (CamelStore *store, const char *folder_name);
Find out if a folder has been subscribed to.
| store: | a CamelStore object | 
| folder_name: | full path of the folder | 
| Returns : | TRUEif the folder has been subscribed to orFALSEotherwise | 
void camel_store_subscribe_folder (CamelStore *store, const char *folder_name, CamelException *ex);
Subscribe to the folder described by folder_name.
| store: | a CamelStore object | 
| folder_name: | full path of the folder | 
| ex: | a CamelException | 
void camel_store_unsubscribe_folder (CamelStore *store, const char *folder_name, CamelException *ex);
Unsubscribe from the folder described by folder_name.
| store: | a CamelStore object | 
| folder_name: | full path of the folder | 
| ex: | a CamelException | 
void camel_store_noop (CamelStore *store, CamelException *ex);
Pings store so that its connection doesn't timeout.
| store: | a CamelStore object | 
| ex: | a CamelException | 
int camel_store_folder_uri_equal (CamelStore *store, const char *uri0, const char *uri1);
Compares 2 folder uris to check that they are equal.
| store: | a CamelStore object | 
| uri0: | a folder uri | 
| uri1: | another folder uri | 
| Returns : | TRUEif they are equal orFALSEotherwise | 
typedef struct {
	CamelInterface iface;
	gboolean (*subscribed)(CamelStore *store, const char *folder_name);
	void (*subscribe)(CamelStore *store, const char *folder_name, CamelException *ex);
	void (*unsubscribe)(CamelStore *store, const char *folder_name, CamelException *ex);
} CamelISubscribe;
gboolean camel_isubscribe_subscribed (CamelStore *store, const char *name);
| store: | |
| name: | |
| Returns : | 
void camel_isubscribe_subscribe (CamelStore *store, const char *folder_name, CamelException *ex);
| store: | |
| folder_name: | |
| ex: | 
void camel_isubscribe_unsubscribe (CamelStore *store, const char *folder_name, CamelException *ex);
| store: | |
| folder_name: | |
| ex: | 
| << CamelService | CamelStoreSummary >> |