summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEmanoil Kotsev <[email protected]>2018-10-08 23:31:34 +0200
committerSlávek Banko <[email protected]>2018-12-19 01:38:26 +0100
commitf485bfd9858309cefa4e3bb0a088f72bef83d17a (patch)
treed8034ecabb51440b6c6f37775f80ea6dffc8f7c7
parenta06151a14fabdd80577e0cb77d90fb6fdee1ca9a (diff)
downloaddbus-1-tqt-f485bfd9858309cefa4e3bb0a088f72bef83d17a.tar.gz
dbus-1-tqt-f485bfd9858309cefa4e3bb0a088f72bef83d17a.zip
add a function to handle maps of objectpaths
Signed-off-by: Emanoil Kotsev <[email protected]> (cherry picked from commit f126c449160792023e039c19e155242791728389)
-rw-r--r--tqdbusmarshall.cpp32
1 files changed, 21 insertions, 11 deletions
diff --git a/tqdbusmarshall.cpp b/tqdbusmarshall.cpp
index 7c21619..7f0781f 100644
--- a/tqdbusmarshall.cpp
+++ b/tqdbusmarshall.cpp
@@ -400,6 +400,19 @@ void qFetchUInt64KeyMapEntry(TQT_DBusDataMap<TQ_UINT64>& map, DBusMessageIter* i
map.insert(key, qFetchParameter(&itemIter));
}
+void qFetchObjectPathKeyMapEntry(TQT_DBusDataMap<TQT_DBusObjectPath>& map, DBusMessageIter* it)
+{
+ DBusMessageIter itemIter;
+ dbus_message_iter_recurse(it, &itemIter);
+ Q_ASSERT(dbus_message_iter_has_next(&itemIter));
+
+ TQT_DBusObjectPath key = qFetchParameter(&itemIter).toObjectPath();
+
+ dbus_message_iter_next(&itemIter);
+
+ map.insert(key, qFetchParameter(&itemIter));
+}
+
void qFetchStringKeyMapEntry(TQT_DBusDataMap<TQString>& map, DBusMessageIter* it)
{
DBusMessageIter itemIter;
@@ -487,8 +500,15 @@ static TQT_DBusData qFetchMap(DBusMessageIter *it, const TQT_DBusData& prototype
return TQT_DBusData::fromUInt64KeyMap(map);
}
+ case DBUS_TYPE_OBJECT_PATH: {
+ TQT_DBusDataMap<TQT_DBusObjectPath> map = prototype.toObjectPathKeyMap();
+ do {
+ qFetchObjectPathKeyMapEntry(map, it);
+ } while (dbus_message_iter_next(it));
+
+ return TQT_DBusData::fromObjectPathKeyMap(map);
+ }
case DBUS_TYPE_STRING: // fall through
- case DBUS_TYPE_OBJECT_PATH: // fall through
case DBUS_TYPE_SIGNATURE: {
TQT_DBusDataMap<TQString> map = prototype.toStringKeyMap();
do {
@@ -545,16 +565,6 @@ static TQT_DBusData qFetchParameter(DBusMessageIter *it)
dbus_message_iter_recurse(it, &sub);
return qFetchMap(&sub, prototypeList[0]);
-
-// } else if (arrayType == DBUS_TYPE_BYTE) {
-// DBusMessageIter sub;
-// dbus_message_iter_recurse(it, &sub);
-// int len = dbus_message_iter_get_array_len(&sub);
-// char* data;
-// dbus_message_iter_get_fixed_array(&sub,&data,&len);
-// return TQCString(data,len);
-// } else {
-
} else {
TQT_DBusDataList list = prototypeList[0].toList();