evolution r36184 - branches/mail-dbus-remoting/mail
- From: abharath svn gnome org
- To: svn-commits-list gnome org
- Subject: evolution r36184 - branches/mail-dbus-remoting/mail
- Date: Fri, 29 Aug 2008 04:41:23 +0000 (UTC)
Author: abharath
Date: Fri Aug 29 04:41:23 2008
New Revision: 36184
URL: http://svn.gnome.org/viewvc/evolution?rev=36184&view=rev
Log:
Some more folder remote funcs
Modified:
branches/mail-dbus-remoting/mail/camel-folder-remote-impl.c
branches/mail-dbus-remoting/mail/camel-folder-remote.c
branches/mail-dbus-remoting/mail/camel-folder-remote.h
Modified: branches/mail-dbus-remoting/mail/camel-folder-remote-impl.c
==============================================================================
--- branches/mail-dbus-remoting/mail/camel-folder-remote-impl.c (original)
+++ branches/mail-dbus-remoting/mail/camel-folder-remote-impl.c Fri Aug 29 04:41:23 2008
@@ -109,6 +109,67 @@
dbus_message_append_args (return_val, DBUS_TYPE_STRING, &store_hash_key, DBUS_TYPE_INVALID);
printf("%s: Success. store_hash_key:%s\n", method, store_hash_key);
+ } else if (strcmp(method, "camel_folder_get_name") == 0) {
+ gboolean ret;
+ const char *name;
+
+ ret = dbus_message_get_args (message, NULL,
+ DBUS_TYPE_STRING, &folder_hash_key,
+ DBUS_TYPE_INVALID);
+ folder = g_hash_table_lookup (folder_hash, folder_hash_key);
+
+ name = camel_folder_get_name (folder);
+ dbus_message_append_args (return_val, DBUS_TYPE_STRING, &name, DBUS_TYPE_INVALID);
+ } else if (strcmp(method, "camel_folder_get_full_name") == 0) {
+ gboolean ret;
+ const char *full_name;
+
+ ret = dbus_message_get_args (message, NULL,
+ DBUS_TYPE_STRING, &folder_hash_key,
+ DBUS_TYPE_INVALID);
+ folder = g_hash_table_lookup (folder_hash, folder_hash_key);
+
+ full_name = camel_folder_get_full_name (folder);
+ dbus_message_append_args (return_val, DBUS_TYPE_STRING, &full_name, DBUS_TYPE_INVALID);
+ } else if (strcmp(method, "camel_folder_sync") == 0) {
+ gboolean ret, expunge;
+ char *err;
+ CamelException *ex;
+
+ ex = camel_exception_new ();
+
+ ret = dbus_message_get_args (message, NULL,
+ DBUS_TYPE_STRING, &folder_hash_key,
+ DBUS_TYPE_INT32, &expunge,
+ DBUS_TYPE_INVALID);
+ folder = g_hash_table_lookup (folder_hash, folder_hash_key);
+
+ camel_folder_sync (folder, expunge, ex);
+
+ if (camel_exception_is_set(ex))
+ err = g_strdup (camel_exception_get_description (ex));
+ else
+ err = g_strdup ("");
+
+ camel_exception_free (ex);
+
+ dbus_message_append_args (return_val, DBUS_TYPE_STRING, &err, DBUS_TYPE_INVALID);
+ } else if (strcmp(method, "camel_folder_set_message_flags") == 0) {
+ gboolean ret, is_set;
+ const char *uid;
+ unsigned int flags, set;
+
+ ret = dbus_message_get_args (message, NULL,
+ DBUS_TYPE_STRING, &folder_hash_key,
+ DBUS_TYPE_STRING, &uid,
+ DBUS_TYPE_INT32, &flags,
+ DBUS_TYPE_INT32, &set,
+ DBUS_TYPE_INVALID);
+ folder = g_hash_table_lookup (folder_hash, folder_hash_key);
+
+ is_set = camel_folder_set_message_flags (folder, uid, flags, set);
+
+ dbus_message_append_args (return_val, DBUS_TYPE_INT32, &is_set, DBUS_TYPE_INVALID);
} else if (strncmp (method, "camel_object", 12) == 0) {
return camel_object_signal_handler (connection, message, user_data, CAMEL_ROT_FOLDER);
} else
Modified: branches/mail-dbus-remoting/mail/camel-folder-remote.c
==============================================================================
--- branches/mail-dbus-remoting/mail/camel-folder-remote.c (original)
+++ branches/mail-dbus-remoting/mail/camel-folder-remote.c Fri Aug 29 04:41:23 2008
@@ -168,12 +168,111 @@
return rstore;
}
-guint32 camel_folder_remote_get_folder_flags (CamelFolderRemote *folder)
+const char *
+camel_folder_remote_get_name (CamelFolderRemote *folder)
{
- return 0;
+ gboolean ret;
+ DBusError error;
+ const char *name;
+
+ dbus_error_init (&error);
+ /* Invoke the appropriate dbind call to MailSessionRemoteImpl */
+ ret = dbind_context_method_call (evolution_dbus_peek_context(),
+ CAMEL_DBUS_NAME,
+ CAMEL_FOLDER_OBJECT_PATH,
+ CAMEL_FOLDER_INTERFACE,
+ "camel_folder_get_name",
+ &error,
+ "s=>s", folder->object_id, &name);
+
+ if (!ret) {
+ g_warning ("Error: Camel folder get name: %s\n", error.message);
+ return NULL;
+ }
+
+ d(printf("Camel folder get name remotely\n"));
+ return name;
+}
+
+const char *
+camel_folder_remote_get_full_name (CamelFolderRemote *folder)
+{
+ gboolean ret;
+ DBusError error;
+ const char *full_name;
+
+ dbus_error_init (&error);
+ /* Invoke the appropriate dbind call to MailSessionRemoteImpl */
+ ret = dbind_context_method_call (evolution_dbus_peek_context(),
+ CAMEL_DBUS_NAME,
+ CAMEL_FOLDER_OBJECT_PATH,
+ CAMEL_FOLDER_INTERFACE,
+ "camel_folder_get_full_name",
+ &error,
+ "s=>s", folder->object_id, &full_name);
+
+ if (!ret) {
+ g_warning ("Error: Camel folder get full name: %s\n", error.message);
+ return NULL;
+ }
+
+ d(printf("Camel folder get full name remotely\n"));
+ return full_name;
}
-const char *camel_folder_remote_get_name (CamelFolderRemote *folder)
+void
+camel_folder_remote_sync (CamelFolderRemote *folder, gboolean expunge, CamelException *ex)
{
- return "";
+ gboolean ret;
+ DBusError error;
+ char *err;
+
+ dbus_error_init (&error);
+ /* Invoke the appropriate dbind call to MailSessionRemoteImpl */
+ ret = dbind_context_method_call (evolution_dbus_peek_context(),
+ CAMEL_DBUS_NAME,
+ CAMEL_FOLDER_OBJECT_PATH,
+ CAMEL_FOLDER_INTERFACE,
+ "camel_folder_sync",
+ &error,
+ "si=>s", folder->object_id, expunge, &err);
+
+ if (!ret) {
+ g_warning ("Error: Camel folder sync: %s\n", error.message);
+ return;
+ }
+
+ d(printf("Camel folder sync remotely\n"));
}
+
+gboolean
+camel_folder_remote_set_message_flags (CamelFolderRemote *folder, const char *uid, guint32 flags, guint32 set)
+{
+ gboolean ret, is_set;
+ DBusError error;
+
+ dbus_error_init (&error);
+ /* Invoke the appropriate dbind call to MailSessionRemoteImpl */
+ ret = dbind_context_method_call (evolution_dbus_peek_context(),
+ CAMEL_DBUS_NAME,
+ CAMEL_FOLDER_OBJECT_PATH,
+ CAMEL_FOLDER_INTERFACE,
+ "camel_folder_set_message_flags",
+ &error,
+ "ssii=>i", folder->object_id, uid, flags, set, &is_set);
+
+ if (!ret) {
+ g_warning ("Error: Camel folder sync: %s\n", error.message);
+ return 0;
+ }
+
+ d(printf("Camel folder sync remotely\n"));
+ return is_set;
+}
+
+
+guint32 camel_folder_remote_get_folder_flags (CamelFolderRemote *folder)
+{
+ return 0;
+}
+
Modified: branches/mail-dbus-remoting/mail/camel-folder-remote.h
==============================================================================
--- branches/mail-dbus-remoting/mail/camel-folder-remote.h (original)
+++ branches/mail-dbus-remoting/mail/camel-folder-remote.h Fri Aug 29 04:41:23 2008
@@ -21,6 +21,12 @@
const char *camel_folder_remote_get_name (CamelFolderRemote *folder);
+const char *camel_folder_remote_get_full_name (CamelFolderRemote *folder);
+
+void camel_folder_remote_sync (CamelFolderRemote *folder, gboolean expunge, CamelException *ex);
+
+gboolean camel_folder_remote_set_message_flags (CamelFolderRemote *folder, const char *uid, guint32 flags, guint32 set);
+
guint32 camel_folder_remote_get_folder_flags (CamelFolderRemote *folder);
#endif
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]