diff options
author | Peter Williams <peterw@src.gnome.org> | 2000-08-30 05:28:46 +0800 |
---|---|---|
committer | Peter Williams <peterw@src.gnome.org> | 2000-08-30 05:28:46 +0800 |
commit | da570c66609a9baea34d4899c4ca7e1f8329d471 (patch) | |
tree | 78f82074f39463fc8db0cfb92728d57fe9c2ac84 /camel/camel-folder.c | |
parent | ba2eaa68b17882b0fec2eac160f674d29598795f (diff) | |
download | gsoc2013-evolution-da570c66609a9baea34d4899c4ca7e1f8329d471.tar.gz gsoc2013-evolution-da570c66609a9baea34d4899c4ca7e1f8329d471.tar.zst gsoc2013-evolution-da570c66609a9baea34d4899c4ca7e1f8329d471.zip |
CamelRemoteStore: a new generic store for stores that connect to servers. Prepare for the ability to cancel operations (much better exception handling). Clean up IMAP like nobody's business
svn path=/trunk/; revision=5103
Diffstat (limited to 'camel/camel-folder.c')
-rw-r--r-- | camel/camel-folder.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/camel/camel-folder.c b/camel/camel-folder.c index 201e2cc778..888845aed8 100644 --- a/camel/camel-folder.c +++ b/camel/camel-folder.c @@ -44,6 +44,7 @@ static void init (CamelFolder *folder, CamelStore *parent_store, static void camel_folder_finalize (CamelObject *object); +static void refresh_info (CamelFolder *folder, CamelException *ex); static void folder_sync (CamelFolder *folder, gboolean expunge, CamelException *ex); @@ -134,6 +135,7 @@ camel_folder_class_init (CamelFolderClass *camel_folder_class) /* virtual method definition */ camel_folder_class->init = init; camel_folder_class->sync = folder_sync; + camel_folder_class->refresh_info = refresh_info; camel_folder_class->get_name = get_name; camel_folder_class->get_full_name = get_full_name; camel_folder_class->can_hold_folders = can_hold_folders; @@ -320,6 +322,29 @@ void camel_folder_sync(CamelFolder * folder, gboolean expunge, CamelException * CF_CLASS(folder)->sync(folder, expunge, ex); } +static void +refresh_info (CamelFolder *folder, CamelException *ex) +{ + g_warning ("CamelFolder::refresh_info not implemented for `%s'", + camel_type_to_name (CAMEL_OBJECT_GET_TYPE (folder))); +} + +/** + * camel_folder_refresh_info: + * @folder: The folder object + * @ex: exception object + * + * Updates a folder's summary to be in sync with its backing store + * (called upon creation and when the store's connection is lost + * and then reestablished). + **/ +void camel_folder_refresh_info (CamelFolder * folder, CamelException * ex) +{ + g_return_if_fail(CAMEL_IS_FOLDER(folder)); + + CF_CLASS(folder)->refresh_info(folder, ex); +} + static const gchar *get_name(CamelFolder * folder) { return folder->name; |