From 227da257765a94a8dd0734b0d632005e25b99840 Mon Sep 17 00:00:00 2001 From: Guillaume Desmottes Date: Mon, 28 Mar 2011 09:08:13 +0200 Subject: [PATCH] Move Telepathy utility functions from shell-global to shell-tp-client https://bugzilla.gnome.org/show_bug.cgi?id=645585 --- src/shell-global.c | 128 ----------------------------------------- src/shell-global.h | 27 --------- src/shell-tp-client.c | 130 ++++++++++++++++++++++++++++++++++++++++++ src/shell-tp-client.h | 29 +++++++++- 4 files changed, 158 insertions(+), 156 deletions(-) diff --git a/src/shell-global.c b/src/shell-global.c index b646c6163..a944b06b2 100644 --- a/src/shell-global.c +++ b/src/shell-global.c @@ -2048,66 +2048,6 @@ gboolean _shell_global_check_xdnd_event (ShellGlobal *global, return FALSE; } -/** - * ShellGetTpContactCb: - * @connection: The connection - * @contacts: (element-type TelepathyGLib.Contact): List of contacts - * @failed: Array of failed contacts - */ - -static void -shell_global_get_tp_contacts_cb (TpConnection *self, - guint n_contacts, - TpContact * const *contacts, - guint n_failed, - const TpHandle *failed, - const GError *error, - gpointer user_data, - GObject *weak_object) -{ - int i; - GList *contact_list = NULL; - for (i = 0; i < n_contacts; i++) { - contact_list = g_list_append(contact_list, contacts[i]); - } - - TpHandle *failed_list = g_new0 (TpHandle, n_failed + 1); - memcpy(failed_list, failed, n_failed); - - ((ShellGetTpContactCb)user_data)(self, contact_list, failed_list); -} - - -/** - * shell_get_tp_contacts: - * @self: A connection, which must be ready - * @n_handles: Number of handles in handles - * @handles: (array length=n_handles) (element-type uint): Array of handles - * @n_features: Number of features in features - * @features: (array length=n_features) (allow-none) (element-type uint): - * Array of features - * @callback: (scope async): User callback to run when the contacts are ready - * - * Wrap tp_connection_get_contacts_by_handle so we can transform the array - * into a null-terminated one, which gjs can handle. - * We send the original callback to tp_connection_get_contacts_by_handle as - * user_data, and we have our own function as callback, which does the - * transforming. - */ -void -shell_get_tp_contacts (TpConnection *self, - guint n_handles, - const TpHandle *handles, - guint n_features, - const TpContactFeature *features, - ShellGetTpContactCb callback) -{ - tp_connection_get_contacts_by_handle(self, n_handles, handles, - n_features, features, - shell_global_get_tp_contacts_cb, - callback, NULL, NULL); -} - /** * shell_global_launch_calendar_server: * @global: The #ShellGlobal. @@ -2162,74 +2102,6 @@ shell_global_launch_calendar_server (ShellGlobal *global) g_free (calendar_server_exe); } -static void -shell_global_get_self_contact_features_cb (TpConnection *connection, - guint n_contacts, - TpContact * const *contacts, - const GError *error, - gpointer user_data, - GObject *weak_object) -{ - if (error != NULL) { - g_print ("Failed to upgrade self contact: %s", error->message); - return; - } - ((ShellGetSelfContactFeaturesCb)user_data)(connection, *contacts); -} - -/** - * shell_get_self_contact_features: - * @self: A connection, which must be ready - * @n_features: Number of features in features - * @features: (array length=n_features) (allow-none) (element-type uint): - * Array of features - * @callback: (scope async): User callback to run when the contact is ready - * - * Wrap tp_connection_upgrade_contacts due to the lack of support for - * proper arrays arguments in GJS. - */ -void -shell_get_self_contact_features (TpConnection *self, - guint n_features, - const TpContactFeature *features, - ShellGetSelfContactFeaturesCb callback) -{ - TpContact *self_contact = tp_connection_get_self_contact (self); - - tp_connection_upgrade_contacts (self, 1, &self_contact, - n_features, features, - shell_global_get_self_contact_features_cb, - callback, NULL, NULL); -} - -/** - * shell_get_contact_events: - * @log_manager: A #TplLogManager - * @account: A #TpAccount - * @entity: A #TplEntity - * @num_events: The number of events to retrieve - * @callback: (scope async): User callback to run when the contact is ready - * - * Wrap tpl_log_manager_get_filtered_events_async because gjs cannot support - * multiple callbacks in the same function call. - */ -void -shell_get_contact_events (TplLogManager *log_manager, - TpAccount *account, - TplEntity *entity, - guint num_events, - GAsyncReadyCallback callback) -{ - tpl_log_manager_get_filtered_events_async (log_manager, - account, - entity, - TPL_EVENT_MASK_TEXT, - num_events, - NULL, NULL, - callback, NULL); -} - - /** * shell_get_file_contents_utf8_sync: * @path: UTF-8 encoded filename path diff --git a/src/shell-global.h b/src/shell-global.h index f965e2bd8..fcf853364 100644 --- a/src/shell-global.h +++ b/src/shell-global.h @@ -7,8 +7,6 @@ #include #include #include -#include -#include G_BEGIN_DECLS @@ -158,33 +156,8 @@ void shell_global_notify_error (ShellGlobal *global, void shell_global_init_xdnd (ShellGlobal *global); -typedef void (*ShellGetTpContactCb) (TpConnection *connection, - GList *contacts, - TpHandle *failed); - -void shell_get_tp_contacts (TpConnection *self, - guint n_handles, - const TpHandle *handles, - guint n_features, - const TpContactFeature *features, - ShellGetTpContactCb callback); - void shell_global_launch_calendar_server (ShellGlobal *global); -typedef void (*ShellGetSelfContactFeaturesCb) (TpConnection *connection, - TpContact *contact); - -void shell_get_self_contact_features (TpConnection *self, - guint n_features, - const TpContactFeature *features, - ShellGetSelfContactFeaturesCb callback); - -void shell_get_contact_events (TplLogManager *log_manager, - TpAccount *account, - TplEntity *entity, - guint num_events, - GAsyncReadyCallback callback); - char *shell_get_file_contents_utf8_sync (const char *path, GError **error); diff --git a/src/shell-tp-client.c b/src/shell-tp-client.c index 82700607d..3c28efbb8 100644 --- a/src/shell-tp-client.c +++ b/src/shell-tp-client.c @@ -1,5 +1,7 @@ #include "shell-tp-client.h" +#include + #include G_DEFINE_TYPE(ShellTpClient, shell_tp_client, TP_TYPE_BASE_CLIENT) @@ -123,3 +125,131 @@ shell_tp_client_set_observe_channels_func (ShellTpClient *self, self->priv->user_data_obs = user_data; self->priv->destroy_obs = destroy; } + +/* Telepathy utility functions */ + +/** + * ShellGetTpContactCb: + * @connection: The connection + * @contacts: (element-type TelepathyGLib.Contact): List of contacts + * @failed: Array of failed contacts + */ + +static void +shell_global_get_tp_contacts_cb (TpConnection *self, + guint n_contacts, + TpContact * const *contacts, + guint n_failed, + const TpHandle *failed, + const GError *error, + gpointer user_data, + GObject *weak_object) +{ + int i; + GList *contact_list = NULL; + for (i = 0; i < n_contacts; i++) { + contact_list = g_list_append(contact_list, contacts[i]); + } + + TpHandle *failed_list = g_new0 (TpHandle, n_failed + 1); + memcpy(failed_list, failed, n_failed); + + ((ShellGetTpContactCb)user_data)(self, contact_list, failed_list); +} + +/** + * shell_get_tp_contacts: + * @self: A connection, which must be ready + * @n_handles: Number of handles in handles + * @handles: (array length=n_handles) (element-type uint): Array of handles + * @n_features: Number of features in features + * @features: (array length=n_features) (allow-none) (element-type uint): + * Array of features + * @callback: (scope async): User callback to run when the contacts are ready + * + * Wrap tp_connection_get_contacts_by_handle so we can transform the array + * into a null-terminated one, which gjs can handle. + * We send the original callback to tp_connection_get_contacts_by_handle as + * user_data, and we have our own function as callback, which does the + * transforming. + */ +void +shell_get_tp_contacts (TpConnection *self, + guint n_handles, + const TpHandle *handles, + guint n_features, + const TpContactFeature *features, + ShellGetTpContactCb callback) +{ + tp_connection_get_contacts_by_handle(self, n_handles, handles, + n_features, features, + shell_global_get_tp_contacts_cb, + callback, NULL, NULL); +} + +static void +shell_global_get_self_contact_features_cb (TpConnection *connection, + guint n_contacts, + TpContact * const *contacts, + const GError *error, + gpointer user_data, + GObject *weak_object) +{ + if (error != NULL) { + g_print ("Failed to upgrade self contact: %s", error->message); + return; + } + ((ShellGetSelfContactFeaturesCb)user_data)(connection, *contacts); +} + +/** + * shell_get_self_contact_features: + * @self: A connection, which must be ready + * @n_features: Number of features in features + * @features: (array length=n_features) (allow-none) (element-type uint): + * Array of features + * @callback: (scope async): User callback to run when the contact is ready + * + * Wrap tp_connection_upgrade_contacts due to the lack of support for + * proper arrays arguments in GJS. + */ +void +shell_get_self_contact_features (TpConnection *self, + guint n_features, + const TpContactFeature *features, + ShellGetSelfContactFeaturesCb callback) +{ + TpContact *self_contact = tp_connection_get_self_contact (self); + + tp_connection_upgrade_contacts (self, 1, &self_contact, + n_features, features, + shell_global_get_self_contact_features_cb, + callback, NULL, NULL); +} + +/** + * shell_get_contact_events: + * @log_manager: A #TplLogManager + * @account: A #TpAccount + * @entity: A #TplEntity + * @num_events: The number of events to retrieve + * @callback: (scope async): User callback to run when the contact is ready + * + * Wrap tpl_log_manager_get_filtered_events_async because gjs cannot support + * multiple callbacks in the same function call. + */ +void +shell_get_contact_events (TplLogManager *log_manager, + TpAccount *account, + TplEntity *entity, + guint num_events, + GAsyncReadyCallback callback) +{ + tpl_log_manager_get_filtered_events_async (log_manager, + account, + entity, + TPL_EVENT_MASK_TEXT, + num_events, + NULL, NULL, + callback, NULL); +} diff --git a/src/shell-tp-client.h b/src/shell-tp-client.h index d9f5e1871..cec24ccbc 100644 --- a/src/shell-tp-client.h +++ b/src/shell-tp-client.h @@ -4,7 +4,8 @@ #include #include -#include +#include +#include G_BEGIN_DECLS @@ -57,5 +58,31 @@ void shell_tp_client_set_observe_channels_func (ShellTpClient *self, gpointer user_data, GDestroyNotify destroy); +/* Telepathy utility functions */ +typedef void (*ShellGetTpContactCb) (TpConnection *connection, + GList *contacts, + TpHandle *failed); + +void shell_get_tp_contacts (TpConnection *self, + guint n_handles, + const TpHandle *handles, + guint n_features, + const TpContactFeature *features, + ShellGetTpContactCb callback); + +typedef void (*ShellGetSelfContactFeaturesCb) (TpConnection *connection, + TpContact *contact); + +void shell_get_self_contact_features (TpConnection *self, + guint n_features, + const TpContactFeature *features, + ShellGetSelfContactFeaturesCb callback); + +void shell_get_contact_events (TplLogManager *log_manager, + TpAccount *account, + TplEntity *entity, + guint num_events, + GAsyncReadyCallback callback); + G_END_DECLS #endif /* __SHELL_TP_CLIENT_H__ */