summaryrefslogtreecommitdiffstats
path: root/src/dbus/qdbusmetatype.h
diff options
context:
space:
mode:
authorLars Knoll <lars.knoll@qt.io>2020-09-09 12:30:11 +0200
committerLars Knoll <lars.knoll@qt.io>2020-09-23 19:30:15 +0200
commitd39bd9e258a5bb45f6209d892ed682809623807d (patch)
treefc75877633b97db8d54930f3826d27ce359c9db7 /src/dbus/qdbusmetatype.h
parentabd1b7f3068e7d4a41adf440d6f6163bfa9f531a (diff)
Cleanup DBus type registration code
Modernize the code base, use QMetaType and avoid reinterpret_casts. Change-Id: I0bad2ee393a0f850cf40b248cb9439b06ed9f663 Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
Diffstat (limited to 'src/dbus/qdbusmetatype.h')
-rw-r--r--src/dbus/qdbusmetatype.h32
1 files changed, 9 insertions, 23 deletions
diff --git a/src/dbus/qdbusmetatype.h b/src/dbus/qdbusmetatype.h
index e241553bb4..2b4d056e85 100644
--- a/src/dbus/qdbusmetatype.h
+++ b/src/dbus/qdbusmetatype.h
@@ -55,37 +55,23 @@ public:
typedef void (*MarshallFunction)(QDBusArgument &, const void *);
typedef void (*DemarshallFunction)(const QDBusArgument &, void *);
- static void registerMarshallOperators(int typeId, MarshallFunction, DemarshallFunction);
- static bool marshall(QDBusArgument &, int id, const void *data);
- static bool demarshall(const QDBusArgument &, int id, void *data);
+ static void registerMarshallOperators(QMetaType typeId, MarshallFunction, DemarshallFunction);
+ static bool marshall(QDBusArgument &, QMetaType id, const void *data);
+ static bool demarshall(const QDBusArgument &, QMetaType id, void *data);
static int signatureToType(const char *signature);
static const char *typeToSignature(int type);
};
template<typename T>
-void qDBusMarshallHelper(QDBusArgument &arg, const T *t)
-{ arg << *t; }
-
-template<typename T>
-void qDBusDemarshallHelper(const QDBusArgument &arg, T *t)
-{ arg >> *t; }
-
-template<typename T>
-int qDBusRegisterMetaType(
-#ifndef Q_QDOC
- T * /* dummy */ = nullptr
-#endif
-)
+QMetaType qDBusRegisterMetaType()
{
- void (*mf)(QDBusArgument &, const T *) = qDBusMarshallHelper<T>;
- void (*df)(const QDBusArgument &, T *) = qDBusDemarshallHelper<T>;
+ auto mf = [](QDBusArgument &arg, const void *t) { arg << *static_cast<const T *>(t); };
+ auto df = [](const QDBusArgument &arg, void *t) { arg >> *static_cast<T *>(t); };
- int id = qMetaTypeId<T>(); // make sure it's registered
- QDBusMetaType::registerMarshallOperators(id,
- reinterpret_cast<QDBusMetaType::MarshallFunction>(mf),
- reinterpret_cast<QDBusMetaType::DemarshallFunction>(df));
- return id;
+ QMetaType metaType = QMetaType::fromType<T>();
+ QDBusMetaType::registerMarshallOperators(metaType, mf, df);
+ return metaType;
}
QT_END_NAMESPACE