aboutsummaryrefslogtreecommitdiffstats
path: root/modules/connman
diff options
context:
space:
mode:
Diffstat (limited to 'modules/connman')
-rw-r--r--modules/connman/evolution-connman.c88
1 files changed, 50 insertions, 38 deletions
diff --git a/modules/connman/evolution-connman.c b/modules/connman/evolution-connman.c
index eacb6913c9..0a320a1f6c 100644
--- a/modules/connman/evolution-connman.c
+++ b/modules/connman/evolution-connman.c
@@ -48,44 +48,46 @@ void e_module_unload (GTypeModule *type_module);
/* Forward Declarations */
GType e_connman_get_type (void);
-static gboolean network_manager_connect (EConnMan *extension);
+static gboolean connman_connect (EConnMan *extension);
G_DEFINE_DYNAMIC_TYPE (EConnMan, e_connman, E_TYPE_EXTENSION)
static void
-extension_set_state (EConnMan *extension, const gchar *state)
+extension_set_state (EConnMan *extension,
+ const gchar *state)
{
EExtensible *extensible;
+ gboolean network_available;
extensible = e_extension_get_extensible (E_EXTENSION (extension));
g_return_if_fail (E_IS_SHELL (extensible));
- e_shell_set_network_available (E_SHELL (extensible), !g_strcmp0 (state, "online"));
+ network_available = (g_strcmp0 (state, "online") == 0);
+ e_shell_set_network_available (E_SHELL (extensible), network_available);
}
static void
-cm_connection_closed_cb (GDBusConnection *pconnection,
- gboolean remote_peer_vanished,
- GError *error,
- gpointer user_data)
+connman_connection_closed_cb (GDBusConnection *pconnection,
+ gboolean remote_peer_vanished,
+ GError *error,
+ gpointer user_data)
{
EConnMan *extension = user_data;
g_object_unref (extension->connection);
extension->connection = NULL;
- g_timeout_add_seconds (
- 3, (GSourceFunc) network_manager_connect, extension);
+ g_timeout_add_seconds (3, (GSourceFunc) connman_connect, extension);
}
static void
conn_manager_signal_cb (GDBusConnection *connection,
- const gchar *sender_name,
- const gchar *object_path,
- const gchar *interface_name,
- const gchar *signal_name,
- GVariant *parameters,
- gpointer user_data)
+ const gchar *sender_name,
+ const gchar *object_path,
+ const gchar *interface_name,
+ const gchar *signal_name,
+ GVariant *parameters,
+ gpointer user_data)
{
EConnMan *extension = user_data;
gchar *state = NULL;
@@ -105,6 +107,8 @@ connman_check_initial_state (EConnMan *extension)
{
GDBusMessage *message = NULL;
GDBusMessage *response = NULL;
+ GVariant *body;
+ gchar *state = NULL;
GError *error = NULL;
message = g_dbus_message_new_method_call (
@@ -115,29 +119,33 @@ connman_check_initial_state (EConnMan *extension)
extension->connection, message,
G_DBUS_SEND_MESSAGE_FLAGS_NONE, 100, NULL, NULL, &error);
- if (response != NULL && !g_dbus_message_to_gerror (response, &error)) {
- gchar *state = NULL;
- GVariant *body = g_dbus_message_get_body (response);
-
- g_variant_get (body, "(s)", &state);
- extension_set_state (extension, state);
- g_free (state);
- } else {
- g_warning ("%s: %s", G_STRFUNC, error ? error->message : "Unknown error");
- if (error)
- g_error_free (error);
- if (response)
+ if (response != NULL) {
+ if (g_dbus_message_to_gerror (response, &error)) {
g_object_unref (response);
- g_object_unref (message);
- return;
+ response = NULL;
+ }
}
g_object_unref (message);
+
+ if (error != NULL) {
+ g_warning ("%s: %s", G_STRFUNC, error->message);
+ g_error_free (error);
+ return;
+ }
+
+ g_return_if_fail (G_IS_DBUS_MESSAGE (response));
+
+ body = g_dbus_message_get_body (response);
+ g_variant_get (body, "(s)", &state);
+ extension_set_state (extension, state);
+ g_free (state);
+
g_object_unref (response);
}
static gboolean
-network_manager_connect (EConnMan *extension)
+connman_connect (EConnMan *extension)
{
GError *error = NULL;
@@ -147,14 +155,18 @@ network_manager_connect (EConnMan *extension)
if (extension->connection != NULL)
return FALSE;
- extension->connection = g_bus_get_sync (G_BUS_TYPE_SYSTEM, NULL, &error);
- if (extension->connection == NULL) {
- g_warning ("%s: %s", G_STRFUNC, error ? error->message : "Unknown error");
- g_error_free (error);
+ extension->connection =
+ g_bus_get_sync (G_BUS_TYPE_SYSTEM, NULL, &error);
+ if (error != NULL) {
+ g_warning ("%s: %s", G_STRFUNC, error->message);
+ g_error_free (error);
return TRUE;
}
+ g_return_val_if_fail (
+ G_IS_DBUS_CONNECTION (extension->connection), FALSE);
+
g_dbus_connection_set_exit_on_close (extension->connection, FALSE);
if (!g_dbus_connection_signal_subscribe (
@@ -174,7 +186,7 @@ network_manager_connect (EConnMan *extension)
g_signal_connect (
extension->connection, "closed",
- G_CALLBACK (cm_connection_closed_cb), extension);
+ G_CALLBACK (connman_connection_closed_cb), extension);
connman_check_initial_state (extension);
@@ -188,9 +200,9 @@ fail:
}
static void
-network_manager_constructed (GObject *object)
+connman_constructed (GObject *object)
{
- network_manager_connect (E_CONNMAN (object));
+ connman_connect (E_CONNMAN (object));
/* Chain up to parent's constructed() method. */
G_OBJECT_CLASS (e_connman_parent_class)->constructed (object);
@@ -203,7 +215,7 @@ e_connman_class_init (EConnManClass *class)
EExtensionClass *extension_class;
object_class = G_OBJECT_CLASS (class);
- object_class->constructed = network_manager_constructed;
+ object_class->constructed = connman_constructed;
extension_class = E_EXTENSION_CLASS (class);
extension_class->extensible_type = E_TYPE_SHELL;