summaryrefslogtreecommitdiffstats
path: root/tqdbusdata.h
diff options
context:
space:
mode:
Diffstat (limited to 'tqdbusdata.h')
-rw-r--r--tqdbusdata.h1223
1 files changed, 0 insertions, 1223 deletions
diff --git a/tqdbusdata.h b/tqdbusdata.h
deleted file mode 100644
index ae64706..0000000
--- a/tqdbusdata.h
+++ /dev/null
@@ -1,1223 +0,0 @@
-/* qdbusdata.h DBUS data 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 TQDBUSDATA_H
-#define TQDBUSDATA_H
-
-#include "tqdbusmacros.h"
-#include <tqglobal.h>
-
-class TQCString;
-class TQT_DBusDataList;
-class TQT_DBusVariant;
-class TQT_DBusObjectPath;
-class TQT_DBusUnixFd;
-class TQString;
-
-template<typename T> class TQValueList;
-template<typename T> class TQT_DBusDataMap;
-
-/**
- * @brief Class for accurately representing D-Bus data types
- *
- * The TQT_DBusData class can be compared to TQt's TQVariant class, but
- * specialized to contain data types used in D-Bus messages.
- *
- * Like TQVariant objects of TQT_DBusData use implicit sharing, i.e. copying
- * a TQT_DBusData object is a cheap operation and does not require that the
- * content itself is copied.
- *
- * Depending on the #Type of the object, the content can be a recursive
- * construct of TQT_DBusData objects, e.g. a #List can contain elements that are
- * containers themselves, e.g. #Map, #Struct, #Variant or even #List again.
- *
- * @see TQT_DBusDataList
- * @see TQT_DBusDataMap
- * @see TQT_DBusDataConverter
- */
-class TQDBUS_EXPORT TQT_DBusData
-{
-public:
- /**
- * @brief Enum for the data types used in D-Bus messages
- *
- * In order to provide correct mapping of C++ and TQt types and the data
- * types used in D-Bus messages, TQT_DBusData uses explicit naming of types
- * where the name is usually the one used in D-Bus, with the exception of
- * #List and #Map since this is closer to the TQt container they are
- * implemented with (TQValueList and TQMap respectively)
- *
- * @see type(), keyType()
- * @see typeName()
- */
- enum Type
- {
- /**
- * Base type for TQT_DBusData objects created by the default constructor.
- *
- * Also used as the type of returned objects when getter type methods
- * fail due to type incompatabilties, i.e. toInt32() called on a #List
- * object.
- *
- * @see isValid()
- */
- Invalid = 0,
-
- /**
- * Type when encapsulating a boolean value.
- *
- * @see fromBool(), toBool()
- */
- Bool,
-
- /**
- * Type when encapsulating a byte (unsigned char) value.
- *
- * @see fromByte(), toByte()
- */
- Byte,
-
- /**
- * Type when encapsulating a signed 16-bit integer value.
- *
- * @see fromInt16(), toInt16()
- */
- Int16,
-
- /**
- * Type when encapsulating an unsigned 16-bit integer value.
- *
- * @see fromUInt16(), toUInt16()
- */
- UInt16,
-
- /**
- * Type when encapsulating a signed 32-bit integer value.
- *
- * @see fromInt32(), toInt32()
- */
- Int32,
-
- /**
- * Type when encapsulating an unsigned 32-bit integer value.
- *
- * @see fromUInt32(), toUInt32()
- */
- UInt32,
-
- /**
- * Type when encapsulating a signed 64-bit integer value.
- *
- * @see fromInt64(), toInt64()
- */
- Int64,
-
- /**
- * Type when encapsulating an unsigned 64-bit integer value.
- *
- * @see fromUInt64(), toUInt64()
- */
- UInt64,
-
- /**
- * Type when encapsulating a double value.
- *
- * @see fromDouble(), toDouble()
- */
- Double,
-
- /**
- * Type when encapsulating a string value.
- *
- * All strings are converted to UTF-8 during transmission
- *
- * @see fromString(), toString()
- */
- String,
-
- /**
- * Type when encapsulating a D-Bus object path.
- *
- * D-Bus defines a special string variation for transporting the
- * paths used to address objects within D-Bus services, see
- * @ref dbusconventions-objectpath for formatting details.
- *
- * @note from the point of view of this bindings an object path is
- * pretty much a normal string with externally checked restrictions.
- * However, method calls or return values can require a signature
- * to include an object path and any remote peer might then reject
- * the normal string signature.
- *
- * @see fromObjectPath(), toObjectPath()
- */
- ObjectPath,
-
- /**
- * Type when encapsulating a D-Bus unix file handle.
- *
- * @see fromUnixFd(), toUnixFd()
- */
- UnixFd,
-
- /**
- * Type when encapsulating a list of values.
- *
- * The D-Bus type this maps to is called @c array but since the TQt
- * container class used to implement this type is TQValueList (or rather
- * TQT_DBusDataList), the TQT_DBusData type is called @c List instead.
- *
- * A list can contain any of the supported types as elements, even
- * container types.
- * However it can only contain elements with the same type per list
- * object.
- *
- * @see fromList(), toList()
- */
- List,
-
- /**
- * Type when encapsulating a struct of values.
- *
- * A struct is basically a list of struct member variables, each
- * member can be any of the supported types, even containers types.
- *
- * The C++/TQt value type used in the converter methods is a TQValueList
- * with type TQT_DBusData.
- * For example a TQRect could be mapped like this:
- * @code
- * TQRect rect(0, 0, 640, 480);
- * TQValueList<TQT_DBusData> memberList;
- *
- * memberList << TQT_DBusData::fromInt32(rect.x());
- * memberList << TQT_DBusData::fromInt32(rect.y());
- * memberList << TQT_DBusData::fromInt32(rect.width());
- * memberList << TQT_DBusData::fromInt32(rect.height());
- *
- * TQT_DBusData data = TQT_DBusData:fromStruct(memberList);
- * @endcode
- *
- * And reconstructed like this:
- * @code
- * memberList = data.toStruct();
- *
- * int x = memberList[0].toInt32();
- * int y = memberList[1].toInt32();
- * int w = memberList[2].toInt32();
- * int h = memberList[3].toInt32();
- *
- * rect = TQRect(x, y, w, h);
- * @endcode
- *
- * @note Empty structs, i.e. an empty member list, are not allowed
- *
- * @see fromStruct(), toStruct()
- * @see TQT_DBusDataConverter
- */
- Struct,
-
- /**
- * Type when encapsulating a special variable container value.
- *
- * See TQT_DBusVariant for details on variant usage.
- *
- * @see fromVariant(), toVariant()
- */
- Variant,
-
- /**
- * Type when encapsulating a map of keys to values.
- *
- * The D-Bus type this maps to is called @c dict but since the TQt
- * container class used to implement this type is TQMap (or rather
- * TQT_DBusDataMap), the TQT_DBusData type is called @c Map instead.
- *
- * A map can contain any of the supported types as values, even
- * container types, but only the following basic types as keys:
- * - #Byte
- * - #Int16
- * - #UInt16
- * - #Int32
- * - #UInt32
- * - #Int64
- * - #UInt64
- * - #String
- * - #ObjectPath
- * - #UnixFd
- *
- * All values need to be of the same type.
- *
- * @see fromByteKeyMap(), toByteKeyMap()
- * @see fromInt16KeyMap(), toInt16KeyMap()
- * @see fromUInt16KeyMap(), toUInt16KeyMap()
- * @see fromInt32KeyMap(), toInt32KeyMap()
- * @see fromUInt32KeyMap(), toUInt32KeyMap()
- * @see fromInt64KeyMap(), toInt64KeyMap()
- * @see fromUInt64KeyMap(), toUInt64KeyMap()
- * @see fromStringKeyMap(), toStringKeyMap()
- * @see fromObjectPathKeyMap(), toObjectPathKeyMap()
- * @see fromUnixFdKeyMap(), toUnixFdKeyMap()
- */
- Map
- };
-
- /**
- * @brief Creates an empty, #Invalid data object
- */
- TQT_DBusData();
-
- /**
- * @brief Copies a given @p other data object
- *
- * Since TQT_DBusData is implicitly shared, both objects will have the
- * same content and the last object to reference it will delete it.
- *
- * @param other the object to copy
- */
- TQT_DBusData(const TQT_DBusData& other);
-
- /**
- * @brief Destroys the data object
- *
- * If this is the last instance to a shared content, it will delete it
- * as well.
- */
- ~TQT_DBusData();
-
- /**
- * @brief Copies a given @p other data object
- *
- * Since TQT_DBusData is implicitly shared, both objects will have the
- * same content and the last object to reference it will delete it.
- *
- * @param other the object to copy
- *
- * @return a reference to this instance
- */
- TQT_DBusData& operator=(const TQT_DBusData& other);
-
- /**
- * @brief Checks if the given @p other data object is equal to this instance
- *
- * Two TQT_DBusData object are considered equal if they reference the same
- * shared content or have the same type and the content's equality operator
- * says the contents are equal.
- *
- * @param other the object to compare with
- *
- * @return @c true if the two data objects are equal, otherwise @c false
- */
- bool operator==(const TQT_DBusData& other) const;
-
- /**
- * @brief Checks if the given @p other data object is different from this instance
- *
- * @param other the object to compare with
- *
- * @return @c false if the two data objects are not equal, otherwise @c false
- *
- * @see operator==()
- */
- bool operator!=(const TQT_DBusData& other) const;
-
- /**
- * @brief Checks whether the data object contains a valid content
- *
- * This is equal to checking type() for not being #Invalid
- *
- * @return @c true if the data object is valid, otherwise @c false
- */
- inline bool isValid() const { return type() != TQT_DBusData::Invalid; }
-
- /**
- * @brief Returns the #Type of the data object
- *
- * @return one of the values of the #Type enum
- *
- * @see keyType()
- * @see typeName()
- */
- Type type() const;
-
- /**
- * @brief Returns the #Type of the key type for maps
- *
- * If the type of the data object is #Map, this method returns the type
- * of the map's key, #String for a TQT_DBusDataMap<TQString>
- *
- * If the type of the data object is not #Map, it will return #Invalid
- *
- * @return one of the values of the #Type enum, #Invalid if the object is
- * not holding a #Map
- *
- * @see type()
- * @see typeName()
- */
- Type keyType() const;
-
- /**
- * @brief Returns the string representation of the object's #Type
- *
- * @return an ASCII C-string for the object's type
- *
- * @see type()
- * @see typeName(Type)
- */
- inline const char* typeName() const { return typeName(type()); }
-
- /**
- * @brief Returns the string representation for the given @p type
- *
- * @param type the #Type to get the string representation for
- *
- * @return an ASCII C-string for the given @p type
- *
- * @see type()
- * @see typeName()
- */
- static const char* typeName(Type type);
-
- /**
- * @brief Creates a data object for the given boolean @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Bool containing the @p value
- *
- * @see toBool()
- */
- static TQT_DBusData fromBool(bool value);
-
- /**
- * @brief Tries to get the encapsulated boolean value
- *
- * If the data object is not of type #Bool this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Bool)
- *
- * @return the encapsulated boolean value or @c false if it fails
- *
- * @see fromBool()
- */
- bool toBool(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given byte (unsigned char) @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Byte containing the @p value
- *
- * @see toByte()
- */
- static TQT_DBusData fromByte(TQ_UINT8 value);
-
- /**
- * @brief Tries to get the encapsulated byte (unsigned char) value
- *
- * If the data object is not of type #Byte this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Byte)
- *
- * @return the encapsulated byte (unsigned char) value or @c 0 if it fails
- *
- * @see fromByte()
- */
- TQ_UINT8 toByte(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given signed 16-bit integer @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Int16 containing the @p value
- *
- * @see toInt16()
- */
- static TQT_DBusData fromInt16(TQ_INT16 value);
-
- /**
- * @brief Tries to get the encapsulated signed 16-bit integer value
- *
- * If the data object is not of type #Int16 this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Int16)
- *
- * @return the encapsulated signed 16-bit integer value or @c 0 if it fails
- *
- * @see fromInt16()
- */
- TQ_INT16 toInt16(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given unsigned 16-bit integer @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #UInt16 containing the @p value
- *
- * @see toUInt16()
- */
- static TQT_DBusData fromUInt16(TQ_UINT16 value);
-
- /**
- * @brief Tries to get the encapsulated unsigned 16-bit integer value
- *
- * If the data object is not of type #UInt16 this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #UInt16)
- *
- * @return the encapsulated unsigned 16-bit integer value or @c 0 if it fails
- *
- * @see fromUInt16()
- */
- TQ_UINT16 toUInt16(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given signed 32-bit integer @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Int32 containing the @p value
- *
- * @see toInt32()
- */
- static TQT_DBusData fromInt32(TQ_INT32 value);
-
- /**
- * @brief Tries to get the encapsulated signed 32-bit integer value
- *
- * If the data object is not of type #Int32 this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Int32)
- *
- * @return the encapsulated signed 32-bit integer value or @c 0 if it fails
- *
- * @see fromInt32()
- */
- TQ_INT32 toInt32(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given unsigned 32-bit integer @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #UInt32 containing the @p value
- *
- * @see toUInt32()
- */
- static TQT_DBusData fromUInt32(TQ_UINT32 value);
-
- /**
- * @brief Tries to get the encapsulated unsigned 32-bit integer value
- *
- * If the data object is not of type #UInt32 this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #UInt32)
- *
- * @return the encapsulated unsigned 32-bit integer value or @c 0 if it fails
- *
- * @see fromUInt32()
- */
- TQ_UINT32 toUInt32(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given signed 64-bit integer @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Int64 containing the @p value
- *
- * @see toInt64()
- */
- static TQT_DBusData fromInt64(TQ_INT64 value);
-
- /**
- * @brief Tries to get the encapsulated signed 64-bit integer value
- *
- * If the data object is not of type #Int64 this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Int64)
- *
- * @return the encapsulated signed 64-bit integer value or @c 0 if it fails
- *
- * @see fromInt64()
- */
- TQ_INT64 toInt64(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given unsigned 64-bit integer @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #UInt64 containing the @p value
- *
- * @see toUInt64()
- */
- static TQT_DBusData fromUInt64(TQ_UINT64 value);
-
- /**
- * @brief Tries to get the encapsulated unsigned 64-bit integer value
- *
- * If the data object is not of type #UInt64 this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #UInt64)
- *
- * @return the encapsulated unsigned 64-bit integer value or @c 0 if it fails
- *
- * @see fromUInt64()
- */
- TQ_UINT64 toUInt64(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given double @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Double containing the @p value
- *
- * @see toDouble()
- */
- static TQT_DBusData fromDouble(double value);
-
- /**
- * @brief Tries to get the encapsulated double value
- *
- * If the data object is not of type #Double this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Double)
- *
- * @return the encapsulated double value or @c 0.0 if it fails
- *
- * @see fromDouble()
- */
- double toDouble(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given string @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #String containing the @p value
- *
- * @see toString()
- */
- static TQT_DBusData fromString(const TQString& value);
-
- /**
- * @brief Tries to get the encapsulated string value
- *
- * If the data object is not of type #String this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #String)
- *
- * @return the encapsulated string value or @c TQString() if it fails
- *
- * @see fromString()
- */
- TQString toString(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given object path @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #ObjectPath containing the @p value
- *
- * @see toObjectPath()
- */
- static TQT_DBusData fromObjectPath(const TQT_DBusObjectPath& value);
-
- /**
- * @brief Tries to get the encapsulated object path value
- *
- * If the data object is not of type #ObjectPath this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #ObjectPath)
- *
- * @return the encapsulated object path value or an empty and invalid object
- * if it fails
- *
- * @see fromObjectPath()
- */
- TQT_DBusObjectPath toObjectPath(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given unix file handle @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #UnixFd containing the @p value
- *
- * @see toUnixFd()
- */
- static TQT_DBusData fromUnixFd(const TQT_DBusUnixFd& value);
-
- /**
- * @brief Tries to get the encapsulated unix file handle value
- *
- * If the data object is not of type #UnixFd this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #UnixFd)
- *
- * @return the encapsulated object path value or an empty and invalid object
- * if it fails
- *
- * @see fromUnixFd()
- */
- TQT_DBusUnixFd toUnixFd(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p list
- *
- * \note The list is allowed to be empty but is required to have a valid type
- *
- * Unless the list the is empty, the convenience method fromTQValueList() will
- * usually be easier to use since it does not require to create a
- * TQT_DBusDataList first. For empty lists this method has to be used to
- * make sure there is sufficient type information on the list's elements
- * available for the binding's marshalling code.
- *
- * @param list the list to encapsulate
- *
- * @return a data object of type #List containing the @p list or
- * an #Invalid object if the list's type is #Invalid
- *
- * @see toList()
- */
- static TQT_DBusData fromList(const TQT_DBusDataList& list);
-
- /**
- * @brief Tries to get the encapsulated list
- *
- * If the data object is not of type #List this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #List)
- *
- * @return the encapsulated list or an empty and #Invalid list if it fails
- *
- * @see fromList()
- */
- TQT_DBusDataList toList(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p list
- *
- * @warning All elements of the list have to be of the same #Type
- *
- * Convenience overload for fromList(), usually more straight forward to use
- * because it doesn't require to create a TQT_DBusDataList object first,
- * however it can only handle lists which contain elements, for empty lists
- * fromList() is the only option.
- *
- * @param list the list to encapsulate
- *
- * @return a data object of type #List containing the @p list or
- * an #Invalid object if the list is empty or if elements have
- * different types.
- *
- * @see toTQValueList()
- */
- static TQT_DBusData fromTQValueList(const TQValueList<TQT_DBusData>& list);
-
- /**
- * @brief Tries to get the encapsulated list
- *
- * Convenience overload for toList().
- *
- * @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 type #List)
- *
- * @return the encapsulated list or an empty and #Invalid list if it fails
- *
- * @see fromTQValueList()
- */
- TQValueList<TQT_DBusData> toTQValueList(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given struct's @p memberList
- *
- * See the documentation of #Struct for an example.
- *
- * @param memberList the list of already encapsulated struct members
- *
- * @return a data object of type #Struct containing the @p memberList
- *
- * @see toStruct()
- */
- static TQT_DBusData fromStruct(const TQValueList<TQT_DBusData>& memberList);
-
- /**
- * @brief Tries to get the encapsulated struct memberList
- *
- * If the data object is not of type #Struct this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * See the documentation of #Struct for an example.
- *
- * @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 type #Struct)
- *
- * @return the encapsulated memberList or an empty list if it fails
- *
- * @see fromStruct()
- */
- TQValueList<TQT_DBusData> toStruct(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given variant @p value
- *
- * @param value the value to encapsulate
- *
- * @return a data object of type #Variant containing the @p value
- *
- * @see toVariant()
- */
- static TQT_DBusData fromVariant(const TQT_DBusVariant& value);
-
- /**
- * @brief Tries to get the encapsulated variant value
- *
- * If the data object is not of type #Variant this will fail, i.e.
- * the parameter @p ok will be set to @c false if present.
- *
- * @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 type #Variant)
- *
- * @return the encapsulated variant value or an empty variant if it fails
- *
- * @see fromVariant()
- */
- TQT_DBusVariant toVariant(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #Byte.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toByteKeyMap()
- */
- static TQT_DBusData fromByteKeyMap(const TQT_DBusDataMap<TQ_UINT8>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #Byte
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #Byte)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromByteKeyMap()
- */
- TQT_DBusDataMap<TQ_UINT8> toByteKeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #Int16.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toInt16KeyMap()
- */
- static TQT_DBusData fromInt16KeyMap(const TQT_DBusDataMap<TQ_INT16>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #Int16
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #Int16)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromInt16KeyMap()
- */
- TQT_DBusDataMap<TQ_INT16> toInt16KeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #UInt16.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toUInt16KeyMap()
- */
- static TQT_DBusData fromUInt16KeyMap(const TQT_DBusDataMap<TQ_UINT16>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #UInt16
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #UInt16)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromUInt16KeyMap()
- */
- TQT_DBusDataMap<TQ_UINT16> toUInt16KeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #Int32.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toInt32KeyMap()
- */
- static TQT_DBusData fromInt32KeyMap(const TQT_DBusDataMap<TQ_INT32>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #Int32
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #Int32)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromInt32KeyMap()
- */
- TQT_DBusDataMap<TQ_INT32> toInt32KeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #UInt32.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toUInt32KeyMap()
- */
- static TQT_DBusData fromUInt32KeyMap(const TQT_DBusDataMap<TQ_UINT32>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #UInt32
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #UInt32)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromUInt32KeyMap()
- */
- TQT_DBusDataMap<TQ_UINT32> toUInt32KeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #Int64.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toInt64KeyMap()
- */
- static TQT_DBusData fromInt64KeyMap(const TQT_DBusDataMap<TQ_INT64>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #Int64
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #Int64)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromInt64KeyMap()
- */
- TQT_DBusDataMap<TQ_INT64> toInt64KeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #UInt64.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toUInt64KeyMap()
- */
- static TQT_DBusData fromUInt64KeyMap(const TQT_DBusDataMap<TQ_UINT64>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #UInt64
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #UInt64)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromUInt64KeyMap()
- */
- TQT_DBusDataMap<TQ_UINT64> toUInt64KeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #String.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toStringKeyMap()
- */
- static TQT_DBusData fromStringKeyMap(const TQT_DBusDataMap<TQString>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not #String
- * this will fail, i.e. the parameter @p ok will be set to @c false if
- * present.
- *
- * @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 type #Map or
- * value type not #String)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromStringKeyMap()
- */
- TQT_DBusDataMap<TQString> toStringKeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #ObjectPath.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toObjectPathKeyMap()
- */
- static TQT_DBusData fromObjectPathKeyMap(const TQT_DBusDataMap<TQT_DBusObjectPath>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not
- * #ObjectPath this will fail, i.e. the parameter @p ok will be set to
- * @c false if present.
- *
- * @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 type #Map or
- * value type not #ObjectPath)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromObjectPathKeyMap()
- */
- TQT_DBusDataMap<TQT_DBusObjectPath> toObjectPathKeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates a data object for the given @p map
- *
- * \note The map is allowed to be empty but is required to have a valid
- * value type
- *
- * The resulting data object will have the keyType() set to #UnixFd.
- *
- * @param map the map to encapsulate
- *
- * @return a data object of type #Map containing the @p map or
- * an #Invalid object if the map's value type is #Invalid
- *
- * @see toUnixFdhKeyMap()
- */
- static TQT_DBusData fromUnixFdKeyMap(const TQT_DBusDataMap<TQT_DBusUnixFd>& map);
-
- /**
- * @brief Tries to get the encapsulated map
- *
- * If the data object is not of type #Map or if its value type is not
- * #UnixFd this will fail, i.e. the parameter @p ok will be set to
- * @c false if present.
- *
- * @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 type #Map or
- * value type not #UnixFd)
- *
- * @return the encapsulated map or an empty and #Invalid map if it fails
- *
- * @see fromUnixFdKeyMap()
- */
- TQT_DBusDataMap<TQT_DBusUnixFd> toUnixFdKeyMap(bool* ok = 0) const;
-
- /**
- * @brief Creates the data objects D-Bus signature
- *
- * Recursivly builds the D-Bus signature of the data object if it holds a
- * container type, i.e. if the object is of type #List, #Map or #Struct
- *
- * This can be used to create a signature for TQT_DBusVariant when creating one
- * for sending over D-Bus.
- *
- * @return a string containing the content's signature, or a null string
- * if the data object is #Invalid
- */
- TQCString buildDBusSignature() const;
-
-private:
- class Private;
- Private* d;
-};
-
-#endif