summaryrefslogtreecommitdiffstats
path: root/tqdbusdatamap.h
diff options
context:
space:
mode:
Diffstat (limited to 'tqdbusdatamap.h')
-rw-r--r--tqdbusdatamap.h1222
1 files changed, 1222 insertions, 0 deletions
diff --git a/tqdbusdatamap.h b/tqdbusdatamap.h
new file mode 100644
index 0000000..9592701
--- /dev/null
+++ b/tqdbusdatamap.h
@@ -0,0 +1,1222 @@
+/* qdbusdatamap.h DBUS data mapping transport type
+ *
+ * Copyright (C) 2007 Kevin Krammer <[email protected]>
+ *
+ * Licensed under the Academic Free License version 2.1
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+ * USA.
+ *
+ */
+
+#ifndef TQDBUSDATAMAP_H
+#define TQDBUSDATAMAP_H
+
+#include "tqdbusmacros.h"
+#include <tqmap.h>
+
+class TQT_DBusData;
+class TQT_DBusObjectPath;
+class TQT_DBusVariant;
+
+/**
+ * @brief Class to transport maps of D-Bus data types
+ *
+ * \note while the D-Bus data type is actually called @c dict this bindings
+ * use the term @c map since TQT_DBusDataMap is essentially a TQMap
+ *
+ * There are basically two ways to create TQT_DBusDataMap objects:
+ * - non-empty from content
+ * - empty by specifying the desired element type
+ *
+ * Example for creating a filled map from content
+ * @code
+ * TQMap<TQ_INT16, TQString> intToStringMap;
+ * map.insert(2, "two");
+ * map.insert(3, "three");
+ * map.insert(5, "five");
+ * map.insert(7, "seven");
+ *
+ * TQT_DBusDataMap<TQ_INT16> dbusMap(intToStringMap);
+ * TQT_DBusData data = TQT_DBusData::fromInt16KeyMap(dbusMap);
+ *
+ * // or even shorter, using implicit conversion
+ * TQT_DBusData other = TQT_DBusData::fromInt16KeyMap(intList);
+ * @endcode
+ *
+ * Example for creating an empty map
+ * @code
+ * // empty map for a simple type, mapping from TQString to double
+ * TQT_DBusDataMap<TQString> list(TQT_DBusData::Double);
+ *
+ * // empty map for value type string lists
+ * TQT_DBusData valueType = TQT_DBusData::fromList(TQT_DBusDataList(TQT_DBusData::String));
+ * TQT_DBusDataMap<TQString> map(valueType);
+ * @endcode
+ *
+ * @see TQT_DBusDataList
+ */
+template <typename T>
+class TQDBUS_EXPORT TQT_DBusDataMap : private TQMap<T, TQT_DBusData>
+{
+ friend class TQT_DBusData;
+
+public:
+ /**
+ * Constant iterator. A TQMapConstIterator with value type specified
+ * as TQT_DBusData
+ */
+ typedef TQMapConstIterator<T, TQT_DBusData> const_iterator;
+
+ /**
+ * @brief Creates an empty and invalid map
+ *
+ * @see TQT_DBusData::Invalid
+ */
+ TQT_DBusDataMap<T>()
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Invalid) {}
+
+ /**
+ * @brief Creates an empty map with the given simple type for values
+ *
+ * The given type has be one of the non-container types, i.e. any other than
+ * TQT_DBusData::Map, TQT_DBusData::List or TQT_DBusData::Struct
+ *
+ * For creating a map with elements which are containers themselves, use
+ * TQT_DBusDataMap<T>(const TQT_DBusData&);
+ *
+ * @param simpleValueType the type of the values in the new map
+ */
+ explicit TQT_DBusDataMap<T>(TQT_DBusData::Type simpleValueType)
+ : TQMap<T, TQT_DBusData>(), m_valueType(simpleValueType) {}
+
+ /**
+ * @brief Creates an empty map with the given container type for values
+ *
+ * For creating a map with simple values you can also use
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type);
+ *
+ * @param containerValueType the type of the values in the new map
+ *
+ * @see hasContainerValueType()
+ */
+ explicit TQT_DBusDataMap<T>(const TQT_DBusData& containerValueType)
+ : TQMap<T, TQT_DBusData>(), m_valueType(containerValueType.type())
+ {
+ if (hasContainerValueType()) m_containerValueType = containerValueType;
+ }
+
+ /**
+ * @brief Creates a map from the given @p other map
+ *
+ * This behaves basically like copying a TQMap through its copy
+ * constructor, i.e. no value are actually copied at this time.
+ *
+ * @param other the other map object to copy from
+ */
+ TQT_DBusDataMap<T>(const TQT_DBusDataMap<T>& other)
+ : TQMap<T, TQT_DBusData>(other), m_valueType(other.m_valueType),
+ m_containerValueType(other.m_containerValueType) {}
+
+ /**
+ * @brief Creates a map from the given TQMap of TQT_DBusData objects
+ *
+ * If the @p other map is empty, this will behave like TQT_DBusDataMap<T>(),
+ * i.e. create an empty and invalid map object.
+ *
+ * Type information for the map object, i.e. value type and, if applicable,
+ * container value type, will be derived from the @p other map's elements.
+ *
+ * \warning if the values of the @p other map do not all have the same
+ * type, the map object will also be empty and invalid
+ *
+ * @param other the TQMap of TQT_DBusData objects to copy from
+ *
+ * @see toTQMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQT_DBusData>& other)
+ : TQMap<T, TQT_DBusData>(other), m_valueType(TQT_DBusData::Invalid)
+ {
+ const_iterator it = begin();
+ if (it == end()) return;
+
+ m_valueType = (*it).type();
+
+ TQCString containerSignature;
+ if (hasContainerValueType())
+ {
+ m_containerValueType = it.data();
+ containerSignature = m_containerValueType.buildDBusSignature();
+ }
+
+ for (++it; it != end(); ++it)
+ {
+ if ((*it).type() != m_valueType)
+ {
+ m_valueType = TQT_DBusData::Invalid;
+ m_containerValueType = TQT_DBusData();
+
+ clear();
+ return;
+ }
+ else if (hasContainerValueType())
+ {
+ if (it.data().buildDBusSignature() != containerSignature)
+ {
+ m_valueType = TQT_DBusData::Invalid;
+ m_containerValueType = TQT_DBusData();
+
+ clear();
+ return;
+ }
+ }
+ }
+ }
+
+ /**
+ * @brief Creates a list from the given TQMap of boolean values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Bool
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Bool
+ *
+ * @param other the TQMap of boolean values to copy from
+ *
+ * @see toBoolMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, bool>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Bool)
+ {
+ typename TQMap<T, bool>::const_iterator it = other.begin();
+ typename TQMap<T, bool>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromBool(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of byte (unsigned char) values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Byte
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Byte
+ *
+ * @param other the TQMap of byte (unsigned char) values to copy from
+ *
+ * @see toByteMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_UINT8>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Byte)
+ {
+ typename TQMap<T, TQ_UINT8>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_UINT8>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromByte(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of signed 16-bit integer values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Int16
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Int16
+ *
+ * @param other the TQMap of signed 16-bit integer values to copy from
+ *
+ * @see toInt16Map()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_INT16>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Int16)
+ {
+ typename TQMap<T, TQ_INT16>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_INT16>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromInt16(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of unsigned 16-bit integer values
+ *
+ * Type information for the map object will be set to TQT_DBusData::UInt16
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::UInt16
+ *
+ * @param other the TQMap of unsigned 16-bit integer values to copy from
+ *
+ * @see toUInt16Map()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_UINT16>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::UInt16)
+ {
+ typename TQMap<T, TQ_UINT16>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_UINT16>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromUInt16(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of signed 32-bit integer values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Int32
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Int32
+ *
+ * @param other the TQMap of signed 32-bit integer values to copy from
+ *
+ * @see toInt32Map()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_INT32>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Int32)
+ {
+ typename TQMap<T, TQ_INT32>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_INT32>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromInt32(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of unsigned 32-bit integer values
+ *
+ * Type information for the map object will be set to TQT_DBusData::UInt16
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::UInt32
+ *
+ * @param other the TQMap of unsigned 32-bit integer values to copy from
+ *
+ * @see toUInt32Map()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_UINT32>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::UInt32)
+ {
+ typename TQMap<T, TQ_UINT32>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_UINT32>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromUInt32(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of signed 64-bit integer values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Int64
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Int64
+ *
+ * @param other the TQMap of signed 64-bit integer values to copy from
+ *
+ * @see toInt64Map()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_INT64>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Int64)
+ {
+ typename TQMap<T, TQ_INT64>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_INT64>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromInt64(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of unsigned 64-bit integer values
+ *
+ * Type information for the map object will be set to TQT_DBusData::UInt64
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::UInt64
+ *
+ * @param other the TQMap of unsigned 64-bit integer values to copy from
+ *
+ * @see toUInt64Map()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQ_UINT64>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::UInt64)
+ {
+ typename TQMap<T, TQ_UINT64>::const_iterator it = other.begin();
+ typename TQMap<T, TQ_UINT64>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromUInt64(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of double values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Double
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Double
+ *
+ * @param other the TQMap of double values to copy from
+ *
+ * @see toDoubleMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, double>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Double)
+ {
+ typename TQMap<T, double>::const_iterator it = other.begin();
+ typename TQMap<T, double>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromDouble(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of TQString values
+ *
+ * Type information for the map object will be set to TQT_DBusData::String
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::String
+ *
+ * @param other the TQMap of TQString values to copy from
+ *
+ * @see toStringMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQString>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::String)
+ {
+ typename TQMap<T, TQString>::const_iterator it = other.begin();
+ typename TQMap<T, TQString>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromString(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of object path values
+ *
+ * Type information for the map object will be set to TQT_DBusData::ObjectPath
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::ObjectPath
+ *
+ * @param other the TQMap of object path values to copy from
+ *
+ * @see toObjectPathMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQT_DBusObjectPath>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::ObjectPath)
+ {
+ typename TQMap<T, TQT_DBusObjectPath>::const_iterator it = other.begin();
+ typename TQMap<T, TQT_DBusObjectPath>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromObjectPath(it.data()));
+ }
+ }
+
+ /**
+ * @brief Creates a map from the given TQMap of TQT_DBusVariant values
+ *
+ * Type information for the map object will be set to TQT_DBusData::Variant
+ * also when the @p other map is empty, i.e. this allows to create an
+ * empty but valid map object, comparable to using
+ * TQT_DBusDataMap<T>(TQT_DBusData::Type) with TQT_DBusData::Variant
+ *
+ * @param other the TQMap of variant values to copy from
+ *
+ * @see toVariantMap()
+ */
+ TQT_DBusDataMap<T>(const TQMap<T, TQT_DBusVariant>& other)
+ : TQMap<T, TQT_DBusData>(), m_valueType(TQT_DBusData::Variant)
+ {
+ typename TQMap<T, TQT_DBusVariant>::const_iterator it = other.begin();
+ typename TQMap<T, TQT_DBusVariant>::const_iterator endIt = other.end();
+ for (; it != endIt; ++it)
+ {
+ insert(it.key(), TQT_DBusData::fromVariant(it.data()));
+ }
+ }
+
+ /**
+ * @brief Copies from the given @p other map
+ *
+ * This behaves basically like copying a TQMap through its assignment
+ * operator, i.e. no value are actually copied at this time.
+ *
+ * @param other the other map object to copy from
+ *
+ * @return a reference to this map object
+ */
+ TQT_DBusDataMap<T>& operator=(const TQT_DBusDataMap<T>& other)
+ {
+ TQMap<T, TQT_DBusData>::operator=(other);
+
+ m_valueType = other.m_valueType;
+ m_containerValueType = other.m_containerValueType;
+
+ return *this;
+ }
+
+ /**
+ * @brief Copies from the given @p other map
+ *
+ * This behaves basically like copying a TQMap through its assignment
+ * operator, i.e. no value are actually copied at this time.
+ *
+ * \warning the value of the given @p other map have to be of the same
+ * type. If they aren't this maps's content will cleared and the
+ * value type will be set to TQT_DBusData::Invalid
+ *
+ * @param other the other map object to copy from
+ *
+ * @return a reference to this map object
+ */
+ TQT_DBusDataMap<T>& operator=(const TQMap<T, TQT_DBusData>& other)
+ {
+ TQMap<T, TQT_DBusData>::operator=(other);
+
+ m_valueType = TQT_DBusData::Invalid;
+ m_containerValueType = TQT_DBusData();
+
+ const_iterator it = begin();
+ if (it == end()) return *this;
+
+ m_valueType = (*it).type();
+
+ TQCString containerSignature;
+ if (hasContainerValueType())
+ {
+ m_containerValueType = it.data();
+ containerSignature = m_containerValueType.buildDBusSignature();
+ }
+
+ for (++it; it != end(); ++it)
+ {
+ if ((*it).type() != m_valueType)
+ {
+ m_valueType = TQT_DBusData::Invalid;
+ m_containerValueType = TQT_DBusData();
+
+ clear();
+ return *this;
+ }
+ else if (hasContainerValueType())
+ {
+ if (it.data()->buildSignature() != containerSignature)
+ {
+ m_valueType = TQT_DBusData::Invalid;
+ m_containerValueType = TQT_DBusData();
+
+ clear();
+ return *this;
+ }
+ }
+ }
+
+ return *this;
+ }
+
+ /**
+ * @brief Returns the key type of the map object
+ *
+ * @return one of the values of the TQT_DBusData#Type enum suitable for
+ * map keys. See TQT_DBusData::Map for details
+ *
+ * @see valueType()
+ */
+ TQT_DBusData::Type keyType() const { return m_keyType; }
+
+ /**
+ * @brief Returns the value type of the map object
+ *
+ * @return one of the values of the TQT_DBusData#Type enum
+ *
+ * @see hasContainerValueType()
+ * @see containerValueType()
+ * @see keyType()
+ */
+ TQT_DBusData::Type valueType() const { return m_valueType; }
+
+ /**
+ * @brief Checks whether the value type is a data container itself
+ *
+ * If the value of the map are containers as well, this will return
+ * @c true
+ * In this case containerValueType() will return a prototype for such a
+ * container.
+ *
+ * @return @c true if the value type is either TQT_DBusData::Map,
+ * TQT_DBusData::List or TQT_DBusData::Struct, otherwise @c false
+ *
+ * @see TQT_DBusDataMap<T>(const TQT_DBusData&)
+ */
+ bool hasContainerValueType() const
+ {
+ return m_valueType == TQT_DBusData::List || m_valueType == TQT_DBusData::Struct
+ || m_valueType == TQT_DBusData::Map;
+ }
+
+ /**
+ * @brief Returns a container prototype for the map's value type
+ *
+ * Lists which have containers as their elements, i.e. hasContainerValueType()
+ * returns @c true this will actually specify the details for the use
+ * container, i.e. the returned data object can be queried for type and
+ * possible further subtypes.
+ *
+ * @return a data object detailing the value type or an invalid data object
+ * if the map does not have a container as its element type
+ *
+ * @see TQT_DBusDataMap<T>(const TQT_DBusData&);
+ * @see valueType()
+ * @see TQT_DBusData::Invalid
+ */
+ TQT_DBusData containerValueType() const { return m_containerValueType; }
+
+ /**
+ * @brief Checks whether this map object has a valid value type
+ *
+ * This is equal to checking valueType() for not being TQT_DBusData::Invalid
+ *
+ * @return @c true if the map object is valid, otherwise @c false
+ */
+ inline bool isValid() const { return valueType() != TQT_DBusData::Invalid; }
+
+ /**
+ * @brief Checks whether this map object has any key/value pairs
+ *
+ * @return @c true if there are no key/values in this map, otherwise @c false
+ *
+ * @see count()
+ */
+ bool isEmpty() const { return TQMap<T, TQT_DBusData>::empty(); }
+
+ /**
+ * @brief Returns the number of key/value pairs of this map object
+ *
+ * @return the number of key/value pairs
+ *
+ * @see isEmpty()
+ */
+ uint count() const { return TQMap<T, TQT_DBusData>::count(); }
+
+ /**
+ * @brief Checks whether the given @p other map is equal to this one
+ *
+ * Two maps are considered equal when they have the same value type (and same
+ * container value type if the have one) and the key/value pairs are equal
+ * as well.
+ *
+ * @param other the other map object to compare with
+ *
+ * @return @c true if the maps are equal, otherwise @c false
+ *
+ * @see TQT_DBusData::operator==()
+ */
+ bool operator==(const TQT_DBusDataMap<T>& other) const
+ {
+ if (m_valueType != other.m_valueType) return false;
+
+ if (count() != other.count()) return false;
+
+ if (hasContainerValueType() != other.hasContainerValueType()) return false;
+
+ if (hasContainerValueType())
+ {
+ if (m_containerValueType.buildDBusSignature() !=
+ other.m_containerValueType.buildDBusSignature()) return false;
+ }
+
+ const_iterator it = begin();
+ const_iterator otherIt = other.begin();
+ for (; it != end() && otherIt != other.end(); ++it, ++otherIt)
+ {
+ if (it.key() != otherIt.key()) return false;
+
+ if (!(it.data() == otherIt.data())) return false;
+ }
+
+ return true;
+ }
+
+ /**
+ * @brief Clears the map
+ *
+ * Value type and, if applicable, container value type will stay untouched.
+ */
+ void clear() { TQMap<T, TQT_DBusData>::clear(); }
+
+ /**
+ * @brief Returns an iterator to the first item according to the key sort order
+ *
+ * @see TQMap::begin()
+ */
+ const_iterator begin() const
+ {
+ return TQMap<T, TQT_DBusData>::begin();
+ }
+
+ /**
+ * @brief Returns an iterator to an invalid position
+ *
+ * @see TQMap::end()
+ */
+ const_iterator end() const
+ {
+ return TQMap<T, TQT_DBusData>::end();
+ }
+
+ /**
+ * @brief Inserts a given value for a given key
+ *
+ * Basically works like the respective TQMap method, but checks if
+ * type of the new value matches the value type of the list.
+ * Maps that are invalid will accept any new type and will then be
+ * typed accordingly.
+ *
+ * If @p data is invalid itself, it will not be inserted at any time.
+ *
+ * \note the more common use case is to work with a TQMap and then
+ * use the respective constructor to create the TQT_DBusDataMap object
+ *
+ * @param key the key were to insert into the map
+ * @param data the data item to insert into the map
+ *
+ * @return @c true on successfull insert, otherwise @c false
+ */
+ bool insert(const T& key, const TQT_DBusData& data)
+ {
+ if (data.type() == TQT_DBusData::Invalid) return false;
+
+ if (m_valueType == TQT_DBusData::Invalid)
+ {
+ m_valueType = data.type();
+
+ // TODO: create empty copy of container
+ if (hasContainerValueType()) m_containerValueType = data;
+
+ TQMap<T, TQT_DBusData>::insert(key, data);
+ }
+ else if (data.type() != m_valueType)
+ {
+ qWarning("TQT_DBusDataMap: trying to add data of type %s to map of type %s",
+ data.typeName(), TQT_DBusData::typeName(m_valueType));
+ }
+ else if (hasContainerValueType())
+ {
+ TQCString ourSignature = m_containerValueType.buildDBusSignature();
+ TQCString dataSignature = data.buildDBusSignature();
+
+ if (ourSignature != dataSignature)
+ {
+ qWarning("TQT_DBusDataMap: trying to add data with signature %s "
+ "to map with value signature %s",
+ dataSignature.data(), ourSignature.data());
+ }
+ else
+ TQMap<T, TQT_DBusData>::insert(key, data);
+ }
+ else
+ TQMap<T, TQT_DBusData>::insert(key, data);
+
+ return true;
+ }
+
+ /**
+ * @brief Converts the map object into a TQMap with TQT_DBusData elements
+ *
+ * @return the key/value pairs of the map object as a TQMap
+ */
+ TQMap<T, TQT_DBusData> toTQMap() const { return *this; }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of bool
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Bool.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Bool)
+ *
+ * @return a TQMap of bool containing the list object's boolean
+ * values or an empty map when converting fails
+ *
+ * @see TQT_DBusData::toBool()
+ */
+ TQMap<T, bool> toBoolMap(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Bool)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, bool>();
+ }
+
+ TQMap<T, bool> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toBool());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_UINT8
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Byte.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Byte)
+ *
+ * @return a TQMap of TQ_UINT8 containing the list object's byte
+ * values or an empty map when converting fails
+ *
+ * @see TQT_DBusData::toBool()
+ */
+ TQMap<T, TQ_UINT8> toByteMap(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Byte)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_UINT8>();
+ }
+
+ TQMap<T, TQ_UINT8> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toByte());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_INT16
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Int16.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Int16)
+ *
+ * @return a TQMap of TQ_INT16 containing the map object's
+ * signed 16-bit integer values or an empty map when converting
+ * fails
+ *
+ * @see TQT_DBusData::toInt16()
+ */
+ TQMap<T, TQ_INT16> toInt16Map(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Int16)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_INT16>();
+ }
+
+ TQMap<T, TQ_INT16> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toInt16());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_UINT16
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::UInt16.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::UInt16)
+ *
+ * @return a TQMap of TQ_UINT16 containing the map object's
+ * unsigned 16-bit integer values or an empty map when converting
+ * fails
+ *
+ * @see TQT_DBusData::toUInt16()
+ */
+ TQMap<T, TQ_UINT16> toUInt16Map(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::UInt16)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_UINT16>();
+ }
+
+ TQMap<T, TQ_UINT16> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toUInt16());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_INT32
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Int32.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Int32)
+ *
+ * @return a TQMap of TQ_INT32 containing the map object's
+ * signed 32-bit integer values or an empty map when converting
+ * fails
+ *
+ * @see TQT_DBusData::toInt32()
+ */
+ TQMap<T, TQ_INT32> toInt32Map(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Int32)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_INT32>();
+ }
+
+ TQMap<T, TQ_INT32> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toInt32());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_UINT32
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::UInt32.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::UInt32)
+ *
+ * @return a TQMap of TQ_UINT32 containing the map object's
+ * unsigned 32-bit integer values or an empty map when converting
+ * fails
+ *
+ * @see TQT_DBusData::toUInt32()
+ */
+ TQMap<T, TQ_UINT32> toUInt32Map(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::UInt32)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_UINT32>();
+ }
+
+ TQMap<T, TQ_UINT32> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toUInt32());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_INT64
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Int64.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Int64)
+ *
+ * @return a TQMap of TQ_INT64 containing the map object's
+ * signed 64-bit integer values or an empty map when converting
+ * fails
+ *
+ * @see TQT_DBusData::toInt64()
+ */
+ TQMap<T, TQ_INT64> toInt64Map(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Int64)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_INT64>();
+ }
+
+ TQMap<T, TQ_INT64> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toInt64());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQ_UINT64
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::UInt64.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::UInt64)
+ *
+ * @return a TQMap of TQ_UINT64 containing the map object's
+ * unsigned 64-bit integer values or an empty map when converting
+ * fails
+ *
+ * @see TQT_DBusData::toUInt64()
+ */
+ TQMap<T, TQ_UINT64> toUInt64Map(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::UInt64)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQ_UINT64>();
+ }
+
+ TQMap<T, TQ_UINT64> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toUInt64());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of double
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Double.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Double)
+ *
+ * @return a TQMap of double containing the map object's double
+ * values or an empty map when converting fails
+ *
+ * @see TQT_DBusData::toDouble()
+ */
+ TQMap<T, double> toDoubleMap(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Double)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, double>();
+ }
+
+ TQMap<T, double> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toDouble());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQString
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::String, see also toTQStringList().
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::String)
+ *
+ * @return a TQMap of TQString containing the map object's string
+ * values or an empty map when converting fails
+ *
+ * @see TQT_DBusData::toString()
+ */
+ TQMap<T, TQString> toStringMap(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::String)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQString>();
+ }
+
+ TQMap<T, TQString> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toString());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of object paths
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::ObjectPath)
+ *
+ * @return a TQMap of object paths containing the map object's object path
+ * values or an empty map when converting fails
+ *
+ * @see TQT_DBusData::toObjectPath()
+ */
+ TQMap<T, TQT_DBusObjectPath> toObjectPathMap(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::ObjectPath)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQT_DBusObjectPath>();
+ }
+
+ TQMap<T, TQT_DBusObjectPath> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toObjectPath());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+ /**
+ * @brief Tries to get the map object's pairs as a TQMap of TQT_DBusVariant
+ *
+ * This is a convenience overload for the case when the map is of
+ * value type TQT_DBusData::Variant.
+ *
+ * @param ok optional pointer to a bool variable to store the
+ * success information in, i.e. will be set to @c true on success
+ * and to @c false if the conversion failed (not of value type
+ * TQT_DBusData::Variant)
+ *
+ * @return a TQMap of TQT_DBusVariant containing the map object's
+ * TQT_DBusVariant values or an empty map when converting fails
+ *
+ * @see TQT_DBusData::toVariant()
+ */
+ TQMap<T, TQT_DBusVariant> toVariantMap(bool* ok = 0) const
+ {
+ if (m_valueType != TQT_DBusData::Variant)
+ {
+ if (ok != 0) *ok = false;
+ return TQMap<T, TQT_DBusVariant>();
+ }
+
+ TQMap<T, TQT_DBusVariant> result;
+
+ const_iterator it = begin();
+ const_iterator endIt = end();
+ for (; it != endIt; ++it)
+ {
+ result.insert(it.key(), (*it).toVariant());
+ }
+
+ if (ok != 0) *ok = true;
+
+ return result;
+ }
+
+private:
+ TQT_DBusData::Type m_valueType;
+ TQT_DBusData m_containerValueType;
+
+ static const TQT_DBusData::Type m_keyType;
+};
+
+#endif