如果给出类型I的声明不包含Q_OBJECT
宏,我有一些有趣的需要显示编译错误。我找到了一种不好的方法。实际上,它重复了Qt开发人员做同样技巧的想法:
template<typename T>
void checkForQObjectMacro()
{
reinterpret_cast<T *>(0)->qt_check_for_QOBJECT_macro(*reinterpret_cast<T *>(0));
}
这很好用但它确实给出了奇怪的错误信息。我想展示一条可读的消息。一种方法是使用static_assert
构造。但我不知道如何实现Q_OBJECT
宏存在的静态验证条件。也许有人可以提出一个漂亮的黑客?也非常感谢任何想法。
答案 0 :(得分:3)
Q_STATIC_ASSERT_X(QtPrivate::HasQ_OBJECT_Macro<typename SignalType::Object>::Value,
"No Q_OBJECT in the class with the signal");
请注意,它使用的是here的私有API:
namespace QtPrivate {
/* Trait that tells is a the Object has a Q_OBJECT macro */
template <typename Object> struct HasQ_OBJECT_Macro {
template <typename T>
static char test(int (T::*)(QMetaObject::Call, int, void **));
static int test(int (Object::*)(QMetaObject::Call, int, void **));
enum { Value = sizeof(test(&Object::qt_metacall)) == sizeof(int) };
};
}
在这里你可以看到Gerrit在5.2中的变化: