Changed: Implemented basic mission compilation without publishing.
This commit is contained in:
parent
3e6d643056
commit
99387de827
4 changed files with 91 additions and 3 deletions
|
@ -7,4 +7,8 @@ ADD_SUBDIRECTORY(disp_sheet_id)
|
||||||
ADD_SUBDIRECTORY(object_viewer)
|
ADD_SUBDIRECTORY(object_viewer)
|
||||||
ADD_SUBDIRECTORY(zone_painter)
|
ADD_SUBDIRECTORY(zone_painter)
|
||||||
ADD_SUBDIRECTORY(georges_editor)
|
ADD_SUBDIRECTORY(georges_editor)
|
||||||
|
|
||||||
|
# Ryzom Specific Plugins
|
||||||
|
IF(WITH_RYZOM AND WITH_RYZOM_TOOLS)
|
||||||
ADD_SUBDIRECTORY(mission_compiler)
|
ADD_SUBDIRECTORY(mission_compiler)
|
||||||
|
ENDIF(WITH_RYZOM AND WITH_RYZOM_TOOLS)
|
|
@ -28,9 +28,15 @@ SOURCE_GROUP(QtGeneratedMocSrc FILES ${OVQT_PLUG_MISSION_COMPILER_MOC_SRC} ${OVQ
|
||||||
SOURCE_GROUP("Mission Compiler Plugin" FILES ${SRC})
|
SOURCE_GROUP("Mission Compiler Plugin" FILES ${SRC})
|
||||||
SOURCE_GROUP("OVQT Extension System" FILES ${OVQT_EXT_SYS_SRC})
|
SOURCE_GROUP("OVQT Extension System" FILES ${OVQT_EXT_SYS_SRC})
|
||||||
|
|
||||||
|
# Mission Compiler Library
|
||||||
|
INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/ryzom/tools/leveldesign/mission_compiler_lib)
|
||||||
|
|
||||||
|
# Game Share Library
|
||||||
|
INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/common/src)
|
||||||
|
|
||||||
ADD_LIBRARY(ovqt_plugin_mission_compiler MODULE ${SRC} ${OVQT_PLUG_MISSION_COMPILER_MOC_SRC} ${OVQT_PLUG_MISSION_COMPILER_RC_SRCS} ${OVQT_EXT_SYS_SRC} ${OVQT_PLUG_MISSION_COMPILER_UI_HDRS})
|
ADD_LIBRARY(ovqt_plugin_mission_compiler MODULE ${SRC} ${OVQT_PLUG_MISSION_COMPILER_MOC_SRC} ${OVQT_PLUG_MISSION_COMPILER_RC_SRCS} ${OVQT_EXT_SYS_SRC} ${OVQT_PLUG_MISSION_COMPILER_UI_HDRS})
|
||||||
|
|
||||||
TARGET_LINK_LIBRARIES(ovqt_plugin_mission_compiler ovqt_plugin_core nelmisc nelligo ${QT_LIBRARIES} ${QT_QTOPENGL_LIBRARY})
|
TARGET_LINK_LIBRARIES(ovqt_plugin_mission_compiler ovqt_plugin_core nelmisc nelligo ryzom_mission_compiler_lib ${QT_LIBRARIES} ${QT_QTOPENGL_LIBRARY})
|
||||||
|
|
||||||
NL_DEFAULT_PROPS(ovqt_plugin_mission_compiler "NeL, Tools, 3D: Object Viewer Qt Plugin: Mission Compiler")
|
NL_DEFAULT_PROPS(ovqt_plugin_mission_compiler "NeL, Tools, 3D: Object Viewer Qt Plugin: Mission Compiler")
|
||||||
NL_ADD_RUNTIME_FLAGS(ovqt_plugin_mission_compiler)
|
NL_ADD_RUNTIME_FLAGS(ovqt_plugin_mission_compiler)
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#include "mission_compiler_main_window.h"
|
#include "mission_compiler_main_window.h"
|
||||||
#include "ui_mission_compiler_main_window.h"
|
#include "ui_mission_compiler_main_window.h"
|
||||||
#include "validation_file.h"
|
#include "validation_file.h"
|
||||||
|
#include "mission_compiler.h"
|
||||||
|
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <QSignalMapper>
|
#include <QSignalMapper>
|
||||||
|
@ -62,6 +63,8 @@ MissionCompilerMainWindow::MissionCompilerMainWindow(QWidget *parent) :
|
||||||
|
|
||||||
connect(ui->filterEdit, SIGNAL(textEdited(const QString&)), this, SLOT(handleFilterChanged(const QString&)));
|
connect(ui->filterEdit, SIGNAL(textEdited(const QString&)), this, SLOT(handleFilterChanged(const QString&)));
|
||||||
connect(ui->actionValidate, SIGNAL(triggered()), this, SLOT(handleValidation()));
|
connect(ui->actionValidate, SIGNAL(triggered()), this, SLOT(handleValidation()));
|
||||||
|
connect(ui->actionCompile, SIGNAL(triggered()), this, SLOT(handleCompile()));
|
||||||
|
connect(ui->actionPublish, SIGNAL(triggered()), this, SLOT(handlePublish()));
|
||||||
|
|
||||||
NLLIGO::Register();
|
NLLIGO::Register();
|
||||||
m_ligoConfig.readPrimitiveClass(NLMISC::CPath::lookup("world_editor_classes.xml").c_str(), false);
|
m_ligoConfig.readPrimitiveClass(NLMISC::CPath::lookup("world_editor_classes.xml").c_str(), false);
|
||||||
|
@ -74,6 +77,79 @@ void MissionCompilerMainWindow::handleFilterChanged(const QString &text)
|
||||||
m_filteredProxyModel->setFilterRegExp(*m_regexpFilter);
|
m_filteredProxyModel->setFilterRegExp(*m_regexpFilter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MissionCompilerMainWindow::handleCompile()
|
||||||
|
{
|
||||||
|
compileMission();
|
||||||
|
}
|
||||||
|
|
||||||
|
void MissionCompilerMainWindow::handlePublish()
|
||||||
|
{
|
||||||
|
compileMission(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MissionCompilerMainWindow::compileMission(bool publish)
|
||||||
|
{
|
||||||
|
uint nbMission = 0;
|
||||||
|
|
||||||
|
// First switch toolbox pages to show the compilation output.
|
||||||
|
ui->toolBox->setCurrentIndex(2);
|
||||||
|
|
||||||
|
m_compileLog.append("Begin mission compilation.\n");
|
||||||
|
updateCompileLog();
|
||||||
|
|
||||||
|
// Go through each file.
|
||||||
|
QStringList list = m_selectedPrimitivesModel->stringList();
|
||||||
|
QStringListIterator itr(list);
|
||||||
|
while(itr.hasNext())
|
||||||
|
{
|
||||||
|
QString filename = itr.next();
|
||||||
|
m_compileLog.append("Compiling '"+filename+"'...\n");
|
||||||
|
updateCompileLog();
|
||||||
|
|
||||||
|
NLLIGO::CPrimitives primDoc;
|
||||||
|
NLLIGO::CPrimitiveContext::instance().CurrentPrimitive = &primDoc;
|
||||||
|
NLLIGO::loadXmlPrimitiveFile(primDoc, NLMISC::CPath::lookup(filename.toAscii().data(), false), m_ligoConfig);
|
||||||
|
NLLIGO::CPrimitiveContext::instance().CurrentPrimitive = NULL;
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
CMissionCompiler mc;
|
||||||
|
mc.compileMissions(primDoc.RootNode, filename.toStdString());
|
||||||
|
m_compileLog.append("Found "+QString::number(mc.getMissionsCount())+" valid missions\n");
|
||||||
|
updateCompileLog();
|
||||||
|
|
||||||
|
mc.installCompiledMission(m_ligoConfig, filename.toStdString());
|
||||||
|
nbMission += mc.getMissionsCount();
|
||||||
|
|
||||||
|
// publish files to selected servers
|
||||||
|
//if (publish)
|
||||||
|
//for (uint i=0 ; i<ServerPathPrim.size() ; i++)
|
||||||
|
//{
|
||||||
|
// if (IsDlgButtonChecked(IDC_CHECK_SRV1 + i) != BST_CHECKED)
|
||||||
|
// continue;
|
||||||
|
|
||||||
|
// compileLog += toString("\r\nPublishing to %s ...\r\n", ServerName[i].c_str());
|
||||||
|
// for (uint j=0 ; j<mc.getFileToPublishCount() ; j++)
|
||||||
|
// compileLog += toString(" %s\r\n", (NLMISC::CFile::getFilename(mc.getFileToPublish(j))).c_str());
|
||||||
|
// mc.publishFiles(ServerPathPrim[i], ServerPathText[i], LocalTextPath);
|
||||||
|
//}
|
||||||
|
}
|
||||||
|
catch(const EParseException &e)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (e.Primitive != NULL)
|
||||||
|
m_compileLog.append("In '"+QString(buildPrimPath(e.Primitive).c_str())+"'\n");
|
||||||
|
|
||||||
|
m_compileLog.append("Error while compiling '"+filename+"' :\n"+QString(e.Why.c_str())+"\n");
|
||||||
|
updateCompileLog();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_compileLog.append("Mission compilation complete.\n");
|
||||||
|
updateCompileLog();
|
||||||
|
}
|
||||||
|
|
||||||
void MissionCompilerMainWindow::handleValidation()
|
void MissionCompilerMainWindow::handleValidation()
|
||||||
{
|
{
|
||||||
// First switch toolbox pages to show the compilation output.
|
// First switch toolbox pages to show the compilation output.
|
||||||
|
@ -92,7 +168,6 @@ void MissionCompilerMainWindow::handleValidation()
|
||||||
while(itr.hasNext())
|
while(itr.hasNext())
|
||||||
{
|
{
|
||||||
QString filename = itr.next();
|
QString filename = itr.next();
|
||||||
//QString filePath = NLMISC::CPath::lookup(filename.toAscii().data(), false).c_str();
|
|
||||||
m_compileLog.append("Parsing '"+filename+"'...\n");
|
m_compileLog.append("Parsing '"+filename+"'...\n");
|
||||||
updateCompileLog();
|
updateCompileLog();
|
||||||
|
|
||||||
|
|
|
@ -36,12 +36,15 @@ public:
|
||||||
public Q_SLOTS:
|
public Q_SLOTS:
|
||||||
void handleFilterChanged(const QString &text);
|
void handleFilterChanged(const QString &text);
|
||||||
void handleValidation();
|
void handleValidation();
|
||||||
|
void handleCompile();
|
||||||
|
void handlePublish();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::MissionCompilerMainWindow *ui;
|
Ui::MissionCompilerMainWindow *ui;
|
||||||
|
|
||||||
void updateCompileLog();
|
void updateCompileLog();
|
||||||
bool parsePrimForMissions(NLLIGO::IPrimitive const *prim, TMissionContainer &missions);
|
bool parsePrimForMissions(NLLIGO::IPrimitive const *prim, TMissionContainer &missions);
|
||||||
|
void compileMission(bool publish=false);
|
||||||
|
|
||||||
QMenu *_toolModeMenu;
|
QMenu *_toolModeMenu;
|
||||||
QUndoStack *m_undoStack;
|
QUndoStack *m_undoStack;
|
||||||
|
|
Loading…
Reference in a new issue