我有一个看起来像的文件:
#ifndef ENGINE_PLATFORM_AREAEDITOR_H
#define ENGINE_PLATFORM_AREAEDITOR_H
#include <QWidget>
#include "../Widgets/QtSfmlWidget.h"
namespace Engine { namespace World { class Area; } }
//This tell's Qt's qmake to ignore the code between MOC_SKIP_BEGIN and MOC_SKIP_END
// MOC_SKIP_BEGIN
#include "Engine/World/Area.h"
// MOC_SKIP_END
namespace Ui {
class AreaEditor;
}
class AreaEditor : public QWidget
{
Q_OBJECT
public:
Engine::World::Area area;
public:
explicit AreaEditor(QWidget *parent = 0);
~AreaEditor();
//...stuff....
private slots:
void on_markerTextEdit_textChanged();
void onDrawAreaScreen(sf::RenderTarget &renderTarget);
void onDrawAreaResized(const WindowSize &windowSize);
private:
Ui::AreaEditor *ui;
//...stuff....
};
#endif //ENGINE_PLATFORM_AREAEDITOR_H
但是,当 Qt 生成 _moc 文件时,它错误地认为“AreaEditor”在命名空间“Engine”中,从而导致编译失败。
这是 QMake 生成的 moc 文件的示例片段:
______/---------<-< Wrong
V V
void Engine::AreaEditor::qt_static_metacall(QObject *_o, QMetaObject::Call _c, int _id, void **_a)
{
if (_c == QMetaObject::InvokeMetaMethod) {
AreaEditor *_t = static_cast<AreaEditor *>(_o);
switch (_id) {
case 0: _t->on_markerTextEdit_textChanged(); break;
case 1: _t->onDrawAreaScreen((*reinterpret_cast< sf::RenderTarget(*)>(_a[1]))); break;
case 2: _t->onDrawAreaResized((*reinterpret_cast< const WindowSize(*)>(_a[1]))); break;
default: ;
}
}
}
应该是这样的:
void AreaEditor::qt_static_metacall(QObject *_o, QMetaObject::Call _c, int _id, void **_a)
头文件“Engine/World/Area.h”有一个名为“Area”的类,它位于命名空间“Engine”中(实际上,它位于“Engine::World::”,两个嵌套命名空间)。看起来像这样以某种方式使 QMake 感到困惑!
如果我删除#include,将其注释掉,一切都编译得很好(除了我必须预先声明'Area',然后只能将它用作类中的指针或引用)。
所以我尝试将#include 包装在“MOC_SKIP_BEGIN”中,我可以在其中找到看似过时的在线引用,希望 QMake 会跳过该标题。不,仍然无法编译。
有没有一种方法可以编译它,同时仍然能够包含我想要包含的标头?