summaryrefslogtreecommitdiffstats
path: root/dundee
diff options
context:
space:
mode:
authorDaniel Wagner <daniel.wagner@bmw-carit.de>2011-12-19 09:46:59 +0100
committerDaniel Wagner <daniel.wagner@bmw-carit.de>2012-05-22 18:44:46 +0200
commitb7001e09888dddeae7201b3de3e1ca7cd21059f6 (patch)
treec89b0c6c488a7da55b1fff2d7419fbfdd9447de6 /dundee
parent5f92489f970b2f4dfd0f5dcc3f5affc732225a47 (diff)
downloadofono-b7001e09888dddeae7201b3de3e1ca7cd21059f6.tar.bz2
dundee: Manager append devices
Diffstat (limited to 'dundee')
-rw-r--r--dundee/manager.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/dundee/manager.c b/dundee/manager.c
index 61fa25e0..d7374d6a 100644
--- a/dundee/manager.c
+++ b/dundee/manager.c
@@ -30,6 +30,26 @@
#include "dundee.h"
+static void append_device(struct dundee_device *device, void *userdata)
+{
+ DBusMessageIter *array = userdata;
+ const char *path = __dundee_device_get_path(device);
+ DBusMessageIter entry, dict;
+
+ dbus_message_iter_open_container(array, DBUS_TYPE_STRUCT,
+ NULL, &entry);
+ dbus_message_iter_append_basic(&entry, DBUS_TYPE_OBJECT_PATH,
+ &path);
+ dbus_message_iter_open_container(&entry, DBUS_TYPE_ARRAY,
+ OFONO_PROPERTIES_ARRAY_SIGNATURE,
+ &dict);
+
+ __dundee_device_append_properties(device, &dict);
+
+ dbus_message_iter_close_container(&entry, &dict);
+ dbus_message_iter_close_container(array, &entry);
+}
+
static DBusMessage *manager_get_devices(DBusConnection *conn,
DBusMessage *msg, void *data)
{
@@ -56,6 +76,8 @@ static DBusMessage *manager_get_devices(DBusConnection *conn,
DBUS_STRUCT_END_CHAR_AS_STRING,
&array);
+ __dundee_device_foreach(append_device, &array);
+
dbus_message_iter_close_container(&iter, &array);
return reply;