summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Hughes <richard@hughsie.com>2008-08-04 15:36:47 +0100
committerRichard Hughes <richard@hughsie.com>2008-08-04 15:36:47 +0100
commit0e617b862c8e427cfbcaaeb5f47b7f19979479b5 (patch)
treecc401e792d2c3bfe47a66a91183cf8d031b300a8
parentdfd11030674b9e52ada85c62a3a0860d14c4ac95 (diff)
downloadupower-0e617b862c8e427cfbcaaeb5f47b7f19979479b5.tar.gz
Add a GetStatistics() method on org.freedesktop.DeviceKit.Power.Source so we can print some funky graphs
-rw-r--r--src/dkp-source.c96
-rw-r--r--src/dkp-source.h20
-rw-r--r--src/org.freedesktop.DeviceKit.Power.Source.xml23
3 files changed, 132 insertions, 7 deletions
diff --git a/src/dkp-source.c b/src/dkp-source.c
index 22d4ace..f755f69 100644
--- a/src/dkp-source.c
+++ b/src/dkp-source.c
@@ -41,6 +41,7 @@
#include "dkp-object.h"
#include "dkp-source.h"
#include "dkp-history.h"
+#include "dkp-history-obj.h"
#include "dkp-marshal.h"
#include "dkp-source-glue.h"
@@ -109,6 +110,44 @@ static void dkp_source_removed (DkpDevice *device);
static gboolean dkp_source_changed (DkpDevice *device, DevkitDevice *d, gboolean synthesized);
/**
+ * dkp_source_error_quark:
+ **/
+GQuark
+dkp_source_error_quark (void)
+{
+ static GQuark ret = 0;
+
+ if (ret == 0) {
+ ret = g_quark_from_static_string ("dkp_source_error");
+ }
+
+ return ret;
+}
+
+#define ENUM_ENTRY(NAME, DESC) { NAME, "" #NAME "", DESC }
+
+/**
+ * dkp_source_error_get_type:
+ **/
+GType
+dkp_source_error_get_type (void)
+{
+ static GType etype = 0;
+
+ if (etype == 0)
+ {
+ static const GEnumValue values[] =
+ {
+ ENUM_ENTRY (DKP_SOURCE_ERROR_GENERAL, "GeneralError"),
+ { 0, 0, 0 }
+ };
+ g_assert (DKP_SOURCE_NUM_ERRORS == G_N_ELEMENTS (values) - 1);
+ etype = g_enum_register_static ("DkpSourceError", values);
+ }
+ return etype;
+}
+
+/**
* dkp_source_get_property:
**/
static void
@@ -299,6 +338,8 @@ dkp_source_class_init (DkpSourceClass *klass)
object_class,
PROP_BATTERY_TECHNOLOGY,
g_param_spec_string ("battery-technology", NULL, NULL, NULL, G_PARAM_READABLE));
+
+ dbus_g_error_domain_register (DKP_SOURCE_ERROR, NULL, DKP_SOURCE_TYPE_ERROR);
}
/**
@@ -376,10 +417,10 @@ dkp_source_compute_object_path (const char *native_path)
}
/**
- * dkp_source_register_power_source:
+ * dkp_source_register_source:
**/
static gboolean
-dkp_source_register_power_source (DkpSource *source)
+dkp_source_register_source (DkpSource *source)
{
DBusConnection *connection;
GError *error = NULL;
@@ -441,7 +482,7 @@ dkp_source_new (DkpDaemon *daemon, DevkitDevice *d)
goto out;
}
- if (!dkp_source_register_power_source (DKP_SOURCE (source))) {
+ if (!dkp_source_register_source (DKP_SOURCE (source))) {
g_object_unref (source);
source = NULL;
goto out;
@@ -836,13 +877,58 @@ dkp_source_update (DkpSource *source)
return ret;
}
+#define DKP_DBUS_STRUCT_UINT_DOUBLE_STRING (dbus_g_type_get_struct ("GValueArray", \
+ G_TYPE_UINT, G_TYPE_DOUBLE, G_TYPE_STRING, G_TYPE_INVALID))
+
+/**
+ * dkp_source_get_statistics:
+ **/
+gboolean
+dkp_source_get_statistics (DkpSource *source, const gchar *type, guint timespan, DBusGMethodInvocation *context)
+{
+ GError *error;
+ GPtrArray *array;
+ GPtrArray *complex;
+ const DkpHistoryObj *obj;
+ GValue *value;
+ guint i;
+
+ /* get the correct data */
+ if (strcmp (type, "rate") == 0)
+ array = dkp_history_get_rate_data (source->priv->history, timespan);
+ else if (strcmp (type, "charge") == 0)
+ array = dkp_history_get_charge_data (source->priv->history, timespan);
+ else {
+ error = g_error_new (DKP_DAEMON_ERROR, DKP_DAEMON_ERROR_GENERAL, "type '%s' not recognised", type);
+ dbus_g_method_return_error (context, error);
+ goto out;
+ }
+
+ /* copy data to dbus struct */
+ complex = g_ptr_array_sized_new (array->len);
+ for (i=0; i<array->len; i++) {
+ obj = (const DkpHistoryObj *) g_ptr_array_index (array, i);
+ value = g_new0 (GValue, 1);
+ g_value_init (value, DKP_DBUS_STRUCT_UINT_DOUBLE_STRING);
+ g_value_take_boxed (value, dbus_g_type_specialized_construct (DKP_DBUS_STRUCT_UINT_DOUBLE_STRING));
+ dbus_g_type_struct_set (value, 0, obj->time, 1, obj->value, 2, dkp_source_state_to_text (obj->state), -1);
+ g_ptr_array_add (complex, g_value_get_boxed (value));
+ g_free (value);
+ }
+
+ g_ptr_array_free (array, TRUE);
+ dbus_g_method_return (context, complex);
+out:
+ return TRUE;
+}
+
/**
* dkp_source_refresh:
**/
gboolean
-dkp_source_refresh (DkpSource *power_source, DBusGMethodInvocation *context)
+dkp_source_refresh (DkpSource *source, DBusGMethodInvocation *context)
{
- dkp_source_update (power_source);
+ dkp_source_update (source);
dbus_g_method_return (context);
return TRUE;
}
diff --git a/src/dkp-source.h b/src/dkp-source.h
index 04c5dca..5af87b9 100644
--- a/src/dkp-source.h
+++ b/src/dkp-source.h
@@ -50,14 +50,30 @@ typedef struct
DkpDeviceClass parent_class;
} DkpSourceClass;
+typedef enum
+{
+ DKP_SOURCE_ERROR_GENERAL,
+ DKP_SOURCE_NUM_ERRORS
+} DkpSourceError;
+
+#define DKP_SOURCE_ERROR dkp_source_error_quark ()
+
+GType dkp_source_error_get_type (void);
+#define DKP_SOURCE_TYPE_ERROR (dkp_source_error_get_type ())
+
+GQuark dkp_source_error_quark (void);
GType dkp_source_get_type (void);
DkpSource *dkp_source_new (DkpDaemon *daemon,
DevkitDevice *d);
/* exported methods */
-gboolean dkp_source_refresh (DkpSource *power_source,
+gboolean dkp_source_refresh (DkpSource *source,
+ DBusGMethodInvocation *context);
+gchar *dkp_source_get_id (DkpSource *source);
+gboolean dkp_source_get_statistics (DkpSource *source,
+ const gchar *type,
+ guint timespan,
DBusGMethodInvocation *context);
-gchar *dkp_source_get_id (DkpSource *power_source);
G_END_DECLS
diff --git a/src/org.freedesktop.DeviceKit.Power.Source.xml b/src/org.freedesktop.DeviceKit.Power.Source.xml
index 649db48..59e9143 100644
--- a/src/org.freedesktop.DeviceKit.Power.Source.xml
+++ b/src/org.freedesktop.DeviceKit.Power.Source.xml
@@ -49,6 +49,29 @@
</signal>
<!-- ************************************************************ -->
+ <method name="GetStatistics">
+ <annotation name="org.freedesktop.DBus.GLib.Async" value=""/>
+ <arg name="type" direction="in" type="s">
+ <doc:doc><doc:summary>The type of statistics.
+ Valid types are <literal>rate</literal> or <literal>charge</literal>.</doc:summary></doc:doc>
+ </arg>
+ <arg name="timespan" direction="in" type="u">
+ <doc:doc><doc:summary>The amount of data to return in seconds, or 0 for all.</doc:summary></doc:doc>
+ </arg>
+ <arg name="data" direction="out" type="a(uds)">
+ <doc:doc><doc:summary>The data for the power device.</doc:summary></doc:doc>
+ </arg>
+ <doc:doc>
+ <doc:description>
+ <doc:para>
+ Gets statistics for the power device that may be interesting
+ to show on a graph in the session.
+ </doc:para>
+ </doc:description>
+ </doc:doc>
+ </method>
+
+ <!-- ************************************************************ -->
<property name="native-path" type="s" access="read">
<doc:doc><doc:description><doc:para>
OS specific native path of the power source. On Linux this