summaryrefslogtreecommitdiffstats
path: root/common/dbus-helper.c
diff options
context:
space:
mode:
Diffstat (limited to 'common/dbus-helper.c')
-rw-r--r--common/dbus-helper.c28
1 files changed, 17 insertions, 11 deletions
diff --git a/common/dbus-helper.c b/common/dbus-helper.c
index cf68d82f..6fa90ff1 100644
--- a/common/dbus-helper.c
+++ b/common/dbus-helper.c
@@ -420,18 +420,12 @@ static void append_array_item_string(const char *val, DBusMessageIter *iter)
dbus_message_iter_append_basic(iter, DBUS_TYPE_STRING, &val);
}
-void dbus_message_iter_append_dict_entry(DBusMessageIter *dict,
- const char *key, int type, void *val)
+void dbus_message_iter_append_variant(DBusMessageIter *iter, int type, void *val)
{
- DBusMessageIter entry;
DBusMessageIter value;
DBusMessageIter array;
char *sig;
- dbus_message_iter_open_container(dict, DBUS_TYPE_DICT_ENTRY, NULL, &entry);
-
- dbus_message_iter_append_basic(&entry, DBUS_TYPE_STRING, &key);
-
switch (type) {
case DBUS_TYPE_STRING:
sig = DBUS_TYPE_STRING_AS_STRING;
@@ -452,11 +446,11 @@ void dbus_message_iter_append_dict_entry(DBusMessageIter *dict,
sig = DBUS_TYPE_ARRAY_AS_STRING DBUS_TYPE_STRING_AS_STRING;
break;
default:
- sig = DBUS_TYPE_VARIANT_AS_STRING;
- break;
+ error("Could not append variant with type %d", type);
+ return;
}
- dbus_message_iter_open_container(&entry, DBUS_TYPE_VARIANT, sig, &value);
+ dbus_message_iter_open_container(iter, DBUS_TYPE_VARIANT, sig, &value);
if (type == DBUS_TYPE_ARRAY) {
dbus_message_iter_open_container(&value, DBUS_TYPE_ARRAY,
@@ -468,7 +462,19 @@ void dbus_message_iter_append_dict_entry(DBusMessageIter *dict,
} else
dbus_message_iter_append_basic(&value, type, val);
- dbus_message_iter_close_container(&entry, &value);
+ dbus_message_iter_close_container(iter, &value);
+}
+
+void dbus_message_iter_append_dict_entry(DBusMessageIter *dict,
+ const char *key, int type, void *val)
+{
+ DBusMessageIter entry;
+
+ dbus_message_iter_open_container(dict, DBUS_TYPE_DICT_ENTRY, NULL, &entry);
+
+ dbus_message_iter_append_basic(&entry, DBUS_TYPE_STRING, &key);
+
+ dbus_message_iter_append_variant(&entry, type, val);
dbus_message_iter_close_container(dict, &entry);
}