diff options
author | Daniel Wagner <daniel.wagner@bmw-carit.de> | 2011-12-19 09:46:59 +0100 |
---|---|---|
committer | Daniel Wagner <daniel.wagner@bmw-carit.de> | 2012-05-22 18:44:46 +0200 |
commit | b7001e09888dddeae7201b3de3e1ca7cd21059f6 (patch) | |
tree | c89b0c6c488a7da55b1fff2d7419fbfdd9447de6 /dundee | |
parent | 5f92489f970b2f4dfd0f5dcc3f5affc732225a47 (diff) | |
download | ofono-b7001e09888dddeae7201b3de3e1ca7cd21059f6.tar.bz2 |
dundee: Manager append devices
Diffstat (limited to 'dundee')
-rw-r--r-- | dundee/manager.c | 22 |
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; |