diff options
author | Javier Jardón <javier.jardon@codethink.co.uk> | 2011-06-27 16:45:26 +0100 |
---|---|---|
committer | Javier Jardón <javier.jardon@codethink.co.uk> | 2011-06-27 16:45:26 +0100 |
commit | 65ab8e5387aa25f86c868c243a90b4b5174b6532 (patch) | |
tree | c9c26afacde01419acac529a1fcb2cf4bcfb0b3f /src/power-service-dbus.c | |
parent | e9f91cffa10b6d00743674faf516dff8e3e13311 (diff) | |
download | ayatana-indicator-power-65ab8e5387aa25f86c868c243a90b4b5174b6532.tar.gz ayatana-indicator-power-65ab8e5387aa25f86c868c243a90b4b5174b6532.tar.bz2 ayatana-indicator-power-65ab8e5387aa25f86c868c243a90b4b5174b6532.zip |
Implement power dbus service interface
Diffstat (limited to 'src/power-service-dbus.c')
-rw-r--r-- | src/power-service-dbus.c | 188 |
1 files changed, 188 insertions, 0 deletions
diff --git a/src/power-service-dbus.c b/src/power-service-dbus.c new file mode 100644 index 0000000..7a42740 --- /dev/null +++ b/src/power-service-dbus.c @@ -0,0 +1,188 @@ +/* +An indicator to power related information in the menubar. + +Copyright 2011 Codethink Ltd. + +Authors: + Javier Jardon <javier.jardon@codethink.co.uk> + +This program is free software: you can redistribute it and/or modify it +under the terms of the GNU General Public License version 3, as published +by the Free Software Foundation. + +This program is distributed in the hope that it will be useful, but +WITHOUT ANY WARRANTY; without even the implied warranties of +MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR +PURPOSE. See the GNU General Public License for more details. + +You should have received a copy of the GNU General Public License along +with this program. If not, see <http://www.gnu.org/licenses/>. +*/ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include "power-service-dbus.h" + +#include <gio/gio.h> + +#include "dbus-shared-names.h" +#include "gen-power-service.xml.h" + +struct _PowerServiceDbusPrivate +{ + GDBusConnection *bus; + GCancellable *bus_cancel; + guint dbus_registration; +}; + +/* GDBus Stuff */ +static GDBusNodeInfo *node_info = NULL; +static GDBusInterfaceInfo *interface_info = NULL; + +static void power_service_dbus_class_init (PowerServiceDbusClass *klass); +static void power_service_dbus_init (PowerServiceDbus *self); +static void power_service_dbus_dispose (GObject *object); +static void power_service_dbus_finalize (GObject *object); +static void bus_get_cb (GObject *object, + GAsyncResult *res, + gpointer user_data); + + +G_DEFINE_TYPE (PowerServiceDbus, power_service_dbus, G_TYPE_OBJECT); + +static void +bus_get_cb (GObject *object, + GAsyncResult *res, + gpointer user_data) +{ + PowerServiceDbus *self = POWER_SERVICE_DBUS (user_data); + PowerServiceDbusPrivate *priv = self->priv; + GError *error = NULL; + GDBusConnection *connection = g_bus_get_finish (res, &error); + + if (error != NULL) + { + g_error("OMG! Unable to get a connection to DBus: %s", error->message); + g_error_free(error); + + return; + } + + priv->bus = connection; + + if (priv->bus_cancel != NULL) + { + g_object_unref (priv->bus_cancel); + priv->bus_cancel = NULL; + } + + /* Now register our object on our new connection */ + priv->dbus_registration = g_dbus_connection_register_object (priv->bus, + INDICATOR_POWER_SERVICE_DBUS_OBJECT, + interface_info, + NULL, + user_data, + NULL, + &error); + if (error != NULL) + { + g_error ("Unable to register the object to DBus: %s", error->message); + g_error_free(error); + + return; + } +} + +static void +power_service_dbus_class_init (PowerServiceDbusClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); + + object_class->dispose = power_service_dbus_dispose; + object_class->finalize = power_service_dbus_finalize; + + /* Setting up the DBus interfaces */ + if (node_info == NULL) + { + GError * error = NULL; + + node_info = g_dbus_node_info_new_for_xml (_power_service, &error); + if (error != NULL) + { + g_error ("Unable to parse Power Service Dbus description: %s", error->message); + g_error_free (error); + } + } + + if (interface_info == NULL) + { + interface_info = g_dbus_node_info_lookup_interface (node_info, INDICATOR_POWER_SERVICE_DBUS_INTERFACE); + + if (interface_info == NULL) + { + g_error ("Unable to find interface '" INDICATOR_POWER_SERVICE_DBUS_INTERFACE "'"); + } + } + + g_type_class_add_private (klass, sizeof (PowerServiceDbusPrivate)); +} + +static void +power_service_dbus_init (PowerServiceDbus *self) +{ + PowerServiceDbusPrivate *priv; + + self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, + POWER_SERVICE_DBUS_TYPE, + PowerServiceDbusPrivate); + priv = self->priv; + + priv->bus = NULL; + priv->bus_cancel = NULL; + priv->dbus_registration = 0; + + self->priv->bus_cancel = g_cancellable_new (); + g_bus_get (G_BUS_TYPE_SESSION, + priv->bus_cancel, + bus_get_cb, + self); +} + +static void +power_service_dbus_dispose (GObject *object) +{ + PowerServiceDbus *self = POWER_SERVICE_DBUS (object); + PowerServiceDbusPrivate *priv = self->priv; + + if (priv->dbus_registration != 0) + { + g_dbus_connection_unregister_object (priv->bus, + priv->dbus_registration); + /* Don't care if it fails, there's nothing we can do */ + priv->dbus_registration = 0; + } + + if (priv->bus != NULL) + { + g_object_unref (priv->bus); + priv->bus = NULL; + } + + if (priv->bus_cancel != NULL) + { + g_cancellable_cancel (priv->bus_cancel); + g_object_unref (priv->bus_cancel); + priv->bus_cancel = NULL; + } + + G_OBJECT_CLASS (power_service_dbus_parent_class)->dispose (object); +} + +static void +power_service_dbus_finalize (GObject *object) +{ + G_OBJECT_CLASS (power_service_dbus_parent_class)->finalize (object); +} + |