diff options
author | Emanoil Kotsev <deloptes@gmail.com> | 2018-10-08 23:31:34 +0200 |
---|---|---|
committer | Slávek Banko <slavek.banko@axis.cz> | 2018-12-19 01:38:26 +0100 |
commit | f485bfd9858309cefa4e3bb0a088f72bef83d17a (patch) | |
tree | d8034ecabb51440b6c6f37775f80ea6dffc8f7c7 | |
parent | a06151a14fabdd80577e0cb77d90fb6fdee1ca9a (diff) | |
download | dbus-1-tqt-f485bfd9858309cefa4e3bb0a088f72bef83d17a.tar.gz dbus-1-tqt-f485bfd9858309cefa4e3bb0a088f72bef83d17a.zip |
add a function to handle maps of objectpaths
Signed-off-by: Emanoil Kotsev <deloptes@gmail.com>
(cherry picked from commit f126c449160792023e039c19e155242791728389)
-rw-r--r-- | tqdbusmarshall.cpp | 32 |
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(); |