2 * Copyright (C) 2003-2007 Imendio AB
3 * Copyright (C) 2007-2011 Collabora Ltd.
5 * This program is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU General Public License as
7 * published by the Free Software Foundation; either version 2 of the
8 * License, or (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
15 * You should have received a copy of the GNU General Public
16 * License along with this program; if not, write to the
17 * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
18 * Boston, MA 02110-1301 USA
20 * Authors: Richard Hult <richard@imendio.com>
21 * Martyn Russell <martyn@imendio.com>
22 * Xavier Claessens <xclaesse@gmail.com>
25 #ifndef __EMPATHY_UTILS_H__
26 #define __EMPATHY_UTILS_H__
29 #include <glib-object.h>
30 #include <gnutls/x509.h>
31 #include <libxml/tree.h>
32 #include <folks/folks.h>
33 #include <folks/folks-telepathy.h>
34 #include <telepathy-glib/telepathy-glib.h>
36 #include "empathy-contact.h"
38 #define EMPATHY_GET_PRIV(obj,type) ((type##Priv *) ((type *) obj)->priv)
39 #define EMP_STR_EMPTY(x) ((x) == NULL || (x)[0] == '\0')
43 void empathy_init (void);
46 gboolean empathy_xml_validate_from_resource (xmlDoc *doc,
47 const gchar *dtd_resourcename);
48 xmlNodePtr empathy_xml_node_get_child (xmlNodePtr node,
49 const gchar *child_name);
50 xmlChar * empathy_xml_node_get_child_content (xmlNodePtr node,
51 const gchar *child_name);
52 xmlNodePtr empathy_xml_node_find_child_prop_value (xmlNodePtr node,
53 const gchar *prop_name,
54 const gchar *prop_value);
57 const gchar * empathy_presence_get_default_message (
58 TpConnectionPresenceType presence);
59 const gchar * empathy_presence_to_str (TpConnectionPresenceType presence);
60 TpConnectionPresenceType empathy_presence_from_str (const gchar *str);
61 gchar * empathy_file_lookup (const gchar *filename,
63 gint empathy_uint_compare (gconstpointer a,
66 const gchar * empathy_account_get_error_message (TpAccount *account,
67 gboolean *user_requested);
69 gchar *empathy_protocol_icon_name (const gchar *protocol);
70 const gchar *empathy_protocol_name_to_display_name (const gchar *proto_name);
71 const gchar *empathy_service_name_to_display_name (const gchar *proto_name);
73 #define EMPATHY_ARRAY_TYPE_OBJECT (empathy_type_dbus_ao ())
74 GType empathy_type_dbus_ao (void);
76 gboolean empathy_account_manager_get_accounts_connected (gboolean *connecting);
78 void empathy_connect_new_account (TpAccount *account,
79 TpAccountManager *account_manager);
81 TpConnectionPresenceType empathy_folks_presence_type_to_tp (
82 FolksPresenceType type);
83 gboolean empathy_folks_individual_contains_contact (
84 FolksIndividual *individual);
85 EmpathyContact * empathy_contact_dup_from_folks_individual (
86 FolksIndividual *individual);
87 TpChannelGroupChangeReason tp_channel_group_change_reason_from_folks_groups_change_reason (
88 FolksGroupDetailsChangeReason reason);
89 TpfPersonaStore * empathy_dup_persona_store_for_connection (
90 TpConnection *connection);
91 gboolean empathy_connection_can_add_personas (TpConnection *connection);
92 gboolean empathy_connection_can_alias_personas (TpConnection *connection,
93 FolksIndividual *individual);
94 gboolean empathy_connection_can_group_personas (TpConnection *connection,
95 FolksIndividual *individual);
96 gboolean empathy_folks_persona_is_interesting (FolksPersona *persona);
98 gchar * empathy_get_x509_certificate_hostname (gnutls_x509_crt_t cert);
100 gchar *empathy_format_currency (gint amount,
102 const gchar *currency);
104 gboolean empathy_account_has_uri_scheme_tel (TpAccount *account);
106 TpContact * empathy_get_tp_contact_for_individual (FolksIndividual *individual,
109 void empathy_individual_can_audio_video_call (FolksIndividual *individual,
110 gboolean *can_audio_call,
111 gboolean *can_video_call,
112 EmpathyContact **out_contact);
114 gboolean empathy_client_types_contains_mobile_device (
117 FolksIndividual * empathy_create_individual_from_tp_contact (
120 FolksIndividual * empathy_ensure_individual_from_tp_contact (
123 const gchar * const * empathy_individual_get_client_types (
124 FolksIndividual *individual);
126 GVariant * empathy_asv_to_vardict (const GHashTable *asv);
128 GVariant * empathy_boxed_to_variant (GType gtype,
129 const gchar *variant_type,
132 /* Copied from wocky/wocky-utils.h */
134 #define empathy_implement_finish_void(source, tag) \
135 if (g_simple_async_result_propagate_error (\
136 G_SIMPLE_ASYNC_RESULT (result), error)) \
138 g_return_val_if_fail (g_simple_async_result_is_valid (result, \
139 G_OBJECT(source), tag), \
143 #define empathy_implement_finish_copy_pointer(source, tag, copy_func, \
145 GSimpleAsyncResult *_simple; \
146 _simple = (GSimpleAsyncResult *) result; \
147 if (g_simple_async_result_propagate_error (_simple, error)) \
149 g_return_val_if_fail (g_simple_async_result_is_valid (result, \
150 G_OBJECT (source), tag), \
152 if (out_param != NULL) \
153 *out_param = copy_func ( \
154 g_simple_async_result_get_op_res_gpointer (_simple)); \
157 #define empathy_implement_finish_return_copy_pointer(source, tag, copy_func) \
158 GSimpleAsyncResult *_simple; \
159 _simple = (GSimpleAsyncResult *) result; \
160 if (g_simple_async_result_propagate_error (_simple, error)) \
162 g_return_val_if_fail (g_simple_async_result_is_valid (result, \
163 G_OBJECT (source), tag), \
165 return copy_func (g_simple_async_result_get_op_res_gpointer (_simple));
167 #define empathy_implement_finish_return_pointer(source, tag) \
168 GSimpleAsyncResult *_simple; \
169 _simple = (GSimpleAsyncResult *) result; \
170 if (g_simple_async_result_propagate_error (_simple, error)) \
172 g_return_val_if_fail (g_simple_async_result_is_valid (result, \
173 G_OBJECT (source), tag), \
175 return g_simple_async_result_get_op_res_gpointer (_simple);
179 #endif /* __EMPATHY_UTILS_H__ */