aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-local.c
diff options
context:
space:
mode:
authorNot Zed <NotZed@Ximian.com>2003-09-18 05:19:04 +0800
committerMichael Zucci <zucchi@src.gnome.org>2003-09-18 05:19:04 +0800
commit81a0ff5bc44a3bd11399e6b3c985735737606c8c (patch)
tree54b5ed4342a6843c1db4c7e75f2e1b1fe9b82dff /mail/mail-local.c
parenta36a1bb70b6ebcb51ac39304370c89bda63e11b9 (diff)
downloadgsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.tar
gsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.tar.gz
gsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.tar.bz2
gsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.tar.lz
gsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.tar.xz
gsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.tar.zst
gsoc2013-evolution-81a0ff5bc44a3bd11399e6b3c985735737606c8c.zip
cvs removed.
2003-09-17 Not Zed <NotZed@Ximian.com> * folder-browser.c, folder-browser.h, folder-browser-ui.c folder-browser-ui.h, mail-callbacks.c, mail-callbacks.h mail-display.c, mail-display.h, mail-display-stream.c mail-display-stream.h, mail-format.c, mail-format.h mail-identify.c, mail-search.c, mail-search.h message-browser.c, message-browser.h, subscribe-dialog.c subscribe-dialog.h, mail-font-prefs.c, mail-font-prefs.h: cvs removed. * Makefile.am: Removed mail-font-prefs.[ch], hasn't been built for ages. * em-*.c: killed a bunch of printfs. * em-format-html-display.c (efhd_html_button_press_event): update for html object api chagnes. ** Merge in mail-refactor-2 branch. svn path=/trunk/; revision=22602
Diffstat (limited to 'mail/mail-local.c')
-rw-r--r--mail/mail-local.c42
1 files changed, 41 insertions, 1 deletions
diff --git a/mail/mail-local.c b/mail/mail-local.c
index 26de1dbc2a..0ec4f5a8e9 100644
--- a/mail/mail-local.c
+++ b/mail/mail-local.c
@@ -558,13 +558,50 @@ mlf_getv(CamelObject *object, CamelException *ex, CamelArgGetV *args)
return 0;
}
+static gboolean
+mlf_meta_set(CamelObject *obj, const char *name, const char *value)
+{
+ MailLocalFolder *mlf = MAIL_LOCAL_FOLDER(obj);
+ CamelFolder *f;
+ gboolean res;
+
+ LOCAL_FOLDER_LOCK(mlf);
+ f = mlf->real_folder;
+ camel_object_ref(f);
+ LOCAL_FOLDER_UNLOCK(mlf);
+
+ /* We must write this ourselves, since MailLocalFolder is not persistent itself */
+ if ((res = camel_object_meta_set(f, name, value)))
+ camel_object_state_write(f);
+ camel_object_unref(f);
+
+ return res;
+}
+
+static char *
+mlf_meta_get(CamelObject *obj, const char *name)
+{
+ MailLocalFolder *mlf = MAIL_LOCAL_FOLDER(obj);
+ CamelFolder *f;
+ char * res;
+
+ LOCAL_FOLDER_LOCK(mlf);
+ f = mlf->real_folder;
+ camel_object_ref(f);
+ LOCAL_FOLDER_UNLOCK(mlf);
+
+ res = camel_object_meta_get(f, name);
+ camel_object_unref(f);
+
+ return res;
+}
+
static void
mlf_class_init (CamelObjectClass *camel_object_class)
{
CamelFolderClass *camel_folder_class = CAMEL_FOLDER_CLASS (camel_object_class);
/* override all the functions subclassed in providers/local/ */
-
camel_folder_class->refresh_info = mlf_refresh_info;
camel_folder_class->sync = mlf_sync;
camel_folder_class->expunge = mlf_expunge;
@@ -581,6 +618,9 @@ mlf_class_init (CamelObjectClass *camel_object_class)
camel_folder_class->rename = mlf_rename;
camel_object_class->getv = mlf_getv;
+
+ camel_object_class->meta_get = mlf_meta_get;
+ camel_object_class->meta_set = mlf_meta_set;
}
static void