Merging default into cdb_refactoring.

This commit is contained in:
dfighter1985 2012-04-28 19:55:46 +02:00
parent 007f2ed51d
commit fffd28a220
26 changed files with 260 additions and 69 deletions

View file

@ -76,9 +76,10 @@ ENDMACRO(NL_TARGET_DRIVER)
# Argument: # Argument:
### ###
MACRO(NL_DEFAULT_PROPS name label) MACRO(NL_DEFAULT_PROPS name label)
IF(NOT MSVC10) # Note: This is just a workaround for a CMake bug generating VS10 files with a colon in the project name.
SET_TARGET_PROPERTIES(${name} PROPERTIES PROJECT_LABEL ${label}) # CMake Bug ID: http://www.cmake.org/Bug/view.php?id=11819
ENDIF(NOT MSVC10) STRING(REGEX REPLACE "\\:" " -" proj_label ${label})
SET_TARGET_PROPERTIES(${name} PROPERTIES PROJECT_LABEL ${proj_label})
GET_TARGET_PROPERTY(type ${name} TYPE) GET_TARGET_PROPERTY(type ${name} TYPE)
IF(${type} STREQUAL SHARED_LIBRARY) IF(${type} STREQUAL SHARED_LIBRARY)
# Set versions only if target is a shared library # Set versions only if target is a shared library

View file

@ -22,7 +22,7 @@
#include <QMouseEvent> #include <QMouseEvent>
#include <QPainter> #include <QPainter>
namespace Plugin namespace GeorgesQt
{ {
ExpandableHeaderView::ExpandableHeaderView(Qt::Orientation orientation, QWidget * parent) ExpandableHeaderView::ExpandableHeaderView(Qt::Orientation orientation, QWidget * parent)

View file

@ -20,7 +20,7 @@
// Qt includes // Qt includes
#include <QHeaderView> #include <QHeaderView>
namespace Plugin namespace GeorgesQt
{ {
class ExpandableHeaderView : public QHeaderView class ExpandableHeaderView : public QHeaderView
{ {

View file

@ -37,7 +37,7 @@
#include "georgesform_proxy_model.h" #include "georgesform_proxy_model.h"
#include "formitem.h" #include "formitem.h"
namespace Plugin namespace GeorgesQt
{ {
FormDelegate::FormDelegate(QObject *parent) FormDelegate::FormDelegate(QObject *parent)
@ -275,4 +275,4 @@ namespace Plugin
QRect r = option.rect; QRect r = option.rect;
editor->setGeometry(r); editor->setGeometry(r);
} }
} /* namespace Plugin */ } /* namespace GeorgesQt */

View file

@ -19,7 +19,7 @@
#include <QStyledItemDelegate> #include <QStyledItemDelegate>
namespace Plugin namespace GeorgesQt
{ {
class FormDelegate : public QStyledItemDelegate class FormDelegate : public QStyledItemDelegate

View file

@ -23,7 +23,7 @@
#include <nel/georges/u_type.h> #include <nel/georges/u_type.h>
#include <nel/georges/form.h> #include <nel/georges/form.h>
namespace Plugin namespace GeorgesQt
{ {
CFormItem::CFormItem(NLGEORGES::UFormElm* elm, const QList<QVariant> &data, CFormItem *parent, CFormItem::CFormItem(NLGEORGES::UFormElm* elm, const QList<QVariant> &data, CFormItem *parent,

View file

@ -24,7 +24,7 @@
#include <QList> #include <QList>
#include <QVariant> #include <QVariant>
namespace Plugin namespace GeorgesQt
{ {
class CFormItem class CFormItem

View file

@ -28,7 +28,7 @@
using namespace NLGEORGES; using namespace NLGEORGES;
namespace Plugin namespace GeorgesQt
{ {
CGeorges::CGeorges(): FormLoader(0) CGeorges::CGeorges(): FormLoader(0)
@ -61,4 +61,4 @@ namespace Plugin
return type; return type;
} }
} /* namespace Plugin */ } /* namespace GeorgesQt */

View file

@ -38,7 +38,7 @@ namespace NLGEORGES
using namespace NLGEORGES; using namespace NLGEORGES;
namespace Plugin namespace GeorgesQt
{ {
/** /**
@ -64,6 +64,6 @@ namespace Plugin
};/* class CGeorges */ };/* class CGeorges */
} /* namespace Plugin */ } /* namespace GeorgesQt */
#endif // GEORGES_H #endif // GEORGES_H

View file

@ -23,7 +23,7 @@
// NeL includes // NeL includes
namespace Plugin namespace GeorgesQt
{ {
CGeorgesDirTreeDialog::CGeorgesDirTreeDialog(QString ldPath, QWidget *parent) CGeorgesDirTreeDialog::CGeorgesDirTreeDialog(QString ldPath, QWidget *parent)
@ -109,4 +109,4 @@ void CGeorgesDirTreeDialog::ldPathChanged(QString path)
} }
} }
} /* namespace NLQT */ } /* namespace GeorgesQt */

View file

@ -28,7 +28,7 @@
#include "ui_georges_dirtree_form.h" #include "ui_georges_dirtree_form.h"
#include "georges_filesystem_model.h" #include "georges_filesystem_model.h"
namespace Plugin namespace GeorgesQt
{ {
class CGeorgesDirTreeDialog: public QDockWidget class CGeorgesDirTreeDialog: public QDockWidget
@ -57,6 +57,6 @@ private Q_SLOTS:
}; /* CGEorgesDirTreeDialog */ }; /* CGEorgesDirTreeDialog */
} /* namespace NLQT */ } /* namespace GeorgesQt */
#endif // GEORGES_DIRTREE_DIALOG_H #endif // GEORGES_DIRTREE_DIALOG_H

View file

@ -44,6 +44,9 @@
<height>0</height> <height>0</height>
</size> </size>
</property> </property>
<property name="alternatingRowColors">
<bool>true</bool>
</property>
</widget> </widget>
</item> </item>
<item row="0" column="1"> <item row="0" column="1">

View file

@ -17,7 +17,7 @@
#ifndef GEORGES_EDITOR_CONSTANTS_H #ifndef GEORGES_EDITOR_CONSTANTS_H
#define GEORGES_EDITOR_CONSTANTS_H #define GEORGES_EDITOR_CONSTANTS_H
namespace Plugin namespace GeorgesQt
{ {
namespace Constants namespace Constants
{ {
@ -26,6 +26,6 @@ const char * const GEORGES_EDITOR_SECTION = "GeorgesEditor";
} // namespace Constants } // namespace Constants
} // namespace Plugin } // namespace GeorgesQt
#endif // GEORGES_EDITOR_CONSTANTS_H #endif // GEORGES_EDITOR_CONSTANTS_H

View file

@ -33,7 +33,7 @@
#include <QToolBar> #include <QToolBar>
#include <QDebug> #include <QDebug>
namespace Plugin namespace GeorgesQt
{ {
GeorgesEditorForm::GeorgesEditorForm(QWidget *parent) GeorgesEditorForm::GeorgesEditorForm(QWidget *parent)
@ -112,24 +112,9 @@ namespace Plugin
void GeorgesEditorForm::open() void GeorgesEditorForm::open()
{ {
/*qDebug() << "GeorgesEditorForm::open()"; QString fileName = QFileDialog::getOpenFileName(this, tr("Open Form"));
if (!m_dockedWidgets.size()) if(!fileName.isNull())
{ loadFile(fileName);
m_dockedWidgets.append(new CGeorgesTreeViewDialog(m_mainDock));
m_mainDock->addDockWidget(Qt::RightDockWidgetArea, m_dockedWidgets.last());
}
else
{
m_dockedWidgets.append(new CGeorgesTreeViewDialog(m_mainDock));
Q_ASSERT(m_dockedWidgets.size() > 1);
m_mainDock->tabifyDockWidget(m_dockedWidgets.at(m_dockedWidgets.size() - 2), m_dockedWidgets.last());
}*/
// TODO: FileDialog & loadFile();
//m_mainDock->addDockWidget(Qt::TopDockWidgetArea, new CGeorgesTreeViewDialog(m_mainDock, true));
//m_mainDock->addDockWidget(Qt::LeftDockWidgetArea, new CGeorgesTreeViewDialog(m_mainDock, true));
//QString fileName = QFileDialog::getOpenFileName();
//loadFile(fileName);
} }
void GeorgesEditorForm::newFile() void GeorgesEditorForm::newFile()
@ -191,6 +176,7 @@ namespace Plugin
if (!m_dockedWidgets.size()) if (!m_dockedWidgets.size())
{ {
CGeorgesTreeViewDialog *dock = new CGeorgesTreeViewDialog(m_mainDock); CGeorgesTreeViewDialog *dock = new CGeorgesTreeViewDialog(m_mainDock);
dock->setUndoStack(m_undoStack);
m_lastActiveDock = dock; m_lastActiveDock = dock;
m_dockedWidgets.append(dock); m_dockedWidgets.append(dock);
@ -212,6 +198,7 @@ namespace Plugin
} }
} }
CGeorgesTreeViewDialog *dock = new CGeorgesTreeViewDialog(m_mainDock); CGeorgesTreeViewDialog *dock = new CGeorgesTreeViewDialog(m_mainDock);
dock->setUndoStack(m_undoStack);
m_dockedWidgets.append(dock); m_dockedWidgets.append(dock);
connect(m_dockedWidgets.last(), SIGNAL(closing()), connect(m_dockedWidgets.last(), SIGNAL(closing()),
@ -284,4 +271,4 @@ namespace Plugin
} }
} }
} }
} /* namespace Plugin */ } /* namespace GeorgesQt */

View file

@ -23,7 +23,7 @@
// Qt includes // Qt includes
#include <QtGui/QUndoStack> #include <QtGui/QUndoStack>
namespace Plugin namespace GeorgesQt
{ {
class CGeorgesDirTreeDialog; class CGeorgesDirTreeDialog;
@ -70,6 +70,6 @@ private:
CGeorgesTreeViewDialog *m_lastActiveDock; CGeorgesTreeViewDialog *m_lastActiveDock;
}; /* class GeorgesEditorForm */ }; /* class GeorgesEditorForm */
} /* namespace Plugin */ } /* namespace GeorgesQt */
#endif // GEORGES_EDITOR_FORM_H #endif // GEORGES_EDITOR_FORM_H

View file

@ -27,7 +27,7 @@
// Qt includes // Qt includes
#include <QtCore/QObject> #include <QtCore/QObject>
namespace Plugin namespace GeorgesQt
{ {
GeorgesEditorPlugin::~GeorgesEditorPlugin() GeorgesEditorPlugin::~GeorgesEditorPlugin()
@ -97,4 +97,4 @@ QWidget *GeorgesEditorContext::widget()
} }
Q_EXPORT_PLUGIN(Plugin::GeorgesEditorPlugin) Q_EXPORT_PLUGIN(GeorgesQt::GeorgesEditorPlugin)

View file

@ -38,7 +38,7 @@ namespace ExtensionSystem
class IPluginSpec; class IPluginSpec;
} }
namespace Plugin namespace GeorgesQt
{ {
class GeorgesEditorForm; class GeorgesEditorForm;
class GeorgesEditorPlugin : public QObject, public ExtensionSystem::IPlugin class GeorgesEditorPlugin : public QObject, public ExtensionSystem::IPlugin
@ -93,6 +93,6 @@ public:
GeorgesEditorForm *m_georgesEditorForm; GeorgesEditorForm *m_georgesEditorForm;
}; };
} // namespace Plugin } // namespace GeorgesQt
#endif // LANDSCAPE_EDITOR_PLUGIN_H #endif // LANDSCAPE_EDITOR_PLUGIN_H

View file

@ -19,7 +19,7 @@
#include <QApplication> #include <QApplication>
#include <QStyle> #include <QStyle>
namespace Plugin namespace GeorgesQt
{ {
CGeorgesFileSystemModel::CGeorgesFileSystemModel(QString ldPath, QObject *parent) CGeorgesFileSystemModel::CGeorgesFileSystemModel(QString ldPath, QObject *parent)
@ -159,6 +159,6 @@ void CGeorgesFileSystemModel::checkLDPath()
// } // }
// return QSortFilterProxyModel::data(index, role); // return QSortFilterProxyModel::data(index, role);
//} //}
} /* namespace NLQT */ } /* namespace GeorgesQt */
/* end of file */ /* end of file */

View file

@ -20,7 +20,7 @@
#include <QtGui/QFileSystemModel> #include <QtGui/QFileSystemModel>
#include <QSortFilterProxyModel> #include <QSortFilterProxyModel>
namespace Plugin namespace GeorgesQt
{ {
class CGeorgesFileSystemModel : public QFileSystemModel class CGeorgesFileSystemModel : public QFileSystemModel
@ -74,6 +74,6 @@ private Q_SLOTS:
// bool filterAcceptsRow(int source_row, const QModelIndex &source_parent) const; // bool filterAcceptsRow(int source_row, const QModelIndex &source_parent) const;
//}; //};
} /* namespace NLQT */ } /* namespace GeorgesQt */
#endif // GEORGES_FILESYSTEM_MODEL_H #endif // GEORGES_FILESYSTEM_MODEL_H

View file

@ -21,12 +21,20 @@
#include <QSettings> #include <QSettings>
#include <QFileDialog> #include <QFileDialog>
#include <QDebug> #include <QDebug>
#include <QMenu>
// NeL includes // NeL includes
#include <nel/misc/path.h> #include <nel/misc/path.h>
#include <nel/misc/file.h> #include <nel/misc/file.h>
#include <nel/misc/o_xml.h> #include <nel/misc/o_xml.h>
#include <nel/georges/u_form_loader.h>
#include <nel/georges/form.h> #include <nel/georges/form.h>
#include <nel/georges/u_form.h>
#include <nel/georges/u_type.h>
// OVQT Includes
#include "../core/icore.h"
#include "../core/core_constants.h"
// Project includes // Project includes
#include "georges.h" #include "georges.h"
@ -39,7 +47,7 @@
using namespace NLMISC; using namespace NLMISC;
using namespace NLGEORGES; using namespace NLGEORGES;
namespace Plugin namespace GeorgesQt
{ {
CGeorgesTreeViewDialog::CGeorgesTreeViewDialog(QWidget *parent /*= 0*/) CGeorgesTreeViewDialog::CGeorgesTreeViewDialog(QWidget *parent /*= 0*/)
@ -50,6 +58,11 @@ namespace Plugin
m_georges = new CGeorges; m_georges = new CGeorges;
loadedForm = ""; loadedForm = "";
// Set the default sheet dir dir to the level design path.
m_lastSheetDir = ".";
QSettings *settings = Core::ICore::instance()->settings();
m_lastSheetDir = settings->value(Core::Constants::LEVELDESIGN_PATH, "l:/leveldesign").toString();
settings->endGroup();
m_ui.setupUi(this); m_ui.setupUi(this);
m_header = new ExpandableHeaderView(Qt::Horizontal, m_ui.treeView); m_header = new ExpandableHeaderView(Qt::Horizontal, m_ui.treeView);
@ -65,6 +78,10 @@ namespace Plugin
FormDelegate *formdelegate = new FormDelegate(this); FormDelegate *formdelegate = new FormDelegate(this);
m_ui.treeView->setItemDelegateForColumn(1, formdelegate); m_ui.treeView->setItemDelegateForColumn(1, formdelegate);
// Set up custom context menu.
setContextMenuPolicy(Qt::CustomContextMenu);
connect(this, SIGNAL(customContextMenuRequested(const QPoint&)), this, SLOT(showContextMenu(const QPoint&)));
connect(m_ui.treeView, SIGNAL(doubleClicked (QModelIndex)), connect(m_ui.treeView, SIGNAL(doubleClicked (QModelIndex)),
this, SLOT(doubleClicked (QModelIndex))); this, SLOT(doubleClicked (QModelIndex)));
connect(m_ui.checkBoxParent, SIGNAL(toggled(bool)), connect(m_ui.checkBoxParent, SIGNAL(toggled(bool)),
@ -203,9 +220,34 @@ namespace Plugin
} }
} }
void CGeorgesTreeViewDialog::addParentForm(CForm *form) void CGeorgesTreeViewDialog::addParentForm(QString parentFormNm)
{ {
//((CForm*)_form)->insertParent(((CForm*)_form)->getParentCount(), form->getFilename().c_str(), form); // Try to load the form
NLGEORGES::UForm *uParentForm = m_georges->loadForm(parentFormNm.toStdString());
NLGEORGES::CForm *parentForm = dynamic_cast<NLGEORGES::CForm*>(uParentForm);
NLGEORGES::CForm *mainForm = static_cast<NLGEORGES::CForm*>(m_form);
CGeorgesFormProxyModel * proxyModel = dynamic_cast<CGeorgesFormProxyModel *>(m_ui.treeView->model());
CGeorgesFormModel *model = dynamic_cast<CGeorgesFormModel *>(proxyModel->sourceModel());
if(parentForm)
{
if (mainForm != parentForm)
{
// Check it is the same dfn
if (parentForm->Elements.FormDfn == mainForm->Elements.FormDfn)
{
// This is the parent form selector
if(!mainForm->insertParent(mainForm->getParentCount(),parentFormNm.toStdString().c_str(), parentForm))
nlwarning("Failed to add parent form: %s", parentFormNm.toStdString().c_str());
else
{
nlinfo("Successfullyadded parent form: %s", parentFormNm.toStdString().c_str());
model->addParentForm(parentFormNm);
}
}
}
}
} }
void CGeorgesTreeViewDialog::modifiedFile( ) void CGeorgesTreeViewDialog::modifiedFile( )
@ -385,4 +427,121 @@ namespace Plugin
} }
} }
} /* namespace NLQT */ void CGeorgesTreeViewDialog::showContextMenu(const QPoint &pos)
{
QMenu contextMenu;
QMenu *structContext = NULL;
QPoint globalPos = this->mapToGlobal(pos);
// Fisrt we're going to see if we've right clicked on a new item and select it.
QModelIndex &index = this->m_ui.treeView->currentIndex();
if(!index.isValid())
return;
CGeorgesFormProxyModel * mp = dynamic_cast<CGeorgesFormProxyModel *>(m_ui.treeView->model());
CGeorgesFormModel *m = dynamic_cast<CGeorgesFormModel *>(mp->sourceModel());
QModelIndex sourceIndex = mp->mapToSource(index);
if (m)
{
CFormItem *item = m->getItem(sourceIndex);
// Right click on the "parents" item
if (item->data(0) == "parents")
contextMenu.addAction("Add parent...");
// Right click on a parent item
else if(item->parent() && item->parent()->data(0) == "parents")
{
contextMenu.addAction("Add parent...");
contextMenu.addAction("Remove parent");
}
else if(item->getFormElm()->isArray())
contextMenu.addAction("Add array entry...");
else if(item->getFormElm()->isStruct())
{
QMenu *structContext = new QMenu("Add struct element...", this);
contextMenu.addMenu(structContext);
NLGEORGES::UFormDfn *defn = item->getFormElm()->getStructDfn();
if(defn)
{
for(uint defnNum=0; defnNum < defn->getNumEntry(); defnNum++)
{
std::string entryName;
std::string dummy;
UFormElm::TWhereIsValue *whereV = new UFormElm::TWhereIsValue;
bool result = defn->getEntryName(defnNum, entryName);
bool result2 = item->getFormElm()->getValueByName(dummy, entryName.c_str(), NLGEORGES::UFormElm::Eval, whereV);
if(result2 && *whereV != UFormElm::ValueForm)
{
structContext->addAction(entryName.c_str());
}
delete whereV;
}
}
}
else if(item->getFormElm()->isAtom() && item->valueFrom() == NLGEORGES::UFormElm::ValueForm)
contextMenu.addAction("Revert to parent/default...");
QAction *selectedItem = contextMenu.exec(globalPos);
if(selectedItem)
{
if(selectedItem->text() == "Add parent...")
{
// Get the file extension of the form so we can build a dialog pattern.
QString file = m_form->getFilename().c_str();
file = file.remove(0,file.indexOf(".")+1);
QString filePattern = "Parent Sheets (*."+file+")";
nlinfo("parent defn name '%s'", file.toStdString().c_str());
QStringList fileNames = QFileDialog::getOpenFileNames(this, tr("Select parent sheets..."), m_lastSheetDir, filePattern);
if(!fileNames.isEmpty())
{
Q_FOREACH(QString fileToParent, fileNames)
{
// Get just the filename. Georges doesn't want the path.
QFileInfo pathInfo( fileToParent );
QString tmpFileName( pathInfo.fileName() );
nlinfo("requesting to add parent form '%s'", tmpFileName.toStdString().c_str());
// Call to add the form and load it into the Georges form.
addParentForm(tmpFileName);
// Save the file lookup path for future dialog boxes.
m_lastSheetDir = pathInfo.absolutePath();
}
}
m_ui.treeView->expandAll();
}
else if(selectedItem->text() == "Remove parent")
{
NLGEORGES::CForm *form = static_cast<NLGEORGES::CForm *>(m_form);
QString parentFileName = item->data(0).toString();
for(uint num = 0; num < form->getParentCount(); num++)
{
QString curParentName = form->getParent(num)->getFilename().c_str();
if(parentFileName == curParentName)
{
form->removeParent(num);
m->removeParentForm(parentFileName);
break;
}
}
m_ui.treeView->expandAll();
}
} // if selected context menu item is valid.
} // if 'm' model valid.
if(structContext)
delete structContext;
}
} /* namespace GeorgesQt */

View file

@ -22,6 +22,9 @@
// Qt includes // Qt includes
#include <QtGui/QDockWidget> #include <QtGui/QDockWidget>
#include <QtGui/QUndoCommand>
#include <QtGui/QUndoStack>
// STL includes // STL includes
@ -37,7 +40,7 @@ namespace NLGEORGES
using namespace NLGEORGES; using namespace NLGEORGES;
namespace Plugin namespace GeorgesQt
{ {
class CGeorges; class CGeorges;
@ -54,12 +57,16 @@ namespace Plugin
void setModified(bool m) {m_modified = m;} void setModified(bool m) {m_modified = m;}
CForm* getFormByName(const QString); CForm* getFormByName(const QString);
void addParentForm(CForm *form); void addParentForm(QString parentFormNm);
void write ( ); void write ( );
QTabWidget* tabWidget() { return m_ui.treeViewTabWidget; } QTabWidget* tabWidget() { return m_ui.treeViewTabWidget; }
void setUndoStack(QUndoStack *stack) {
m_undoStack = stack;
}
QString loadedForm; QString loadedForm;
protected: protected:
@ -75,6 +82,7 @@ namespace Plugin
void loadFormIntoDialog(CForm *form = 0); void loadFormIntoDialog(CForm *form = 0);
void modifiedFile( ); void modifiedFile( );
void checkVisibility(bool); void checkVisibility(bool);
void showContextMenu(const QPoint &pos);
private Q_SLOTS: private Q_SLOTS:
void doubleClicked ( const QModelIndex & index ); void doubleClicked ( const QModelIndex & index );
@ -87,10 +95,15 @@ namespace Plugin
UForm *m_form; UForm *m_form;
CGeorges *m_georges; CGeorges *m_georges;
QUndoStack *m_undoStack;
/// Contains a record of the last directory a sheet file dialog was opened for.
QString m_lastSheetDir;
bool m_modified; bool m_modified;
}; /* CGeorgesTreeViewDialog */ }; /* CGeorgesTreeViewDialog */
} /* namespace NLQT */ } /* namespace GeorgesQt */
#endif // GEORGES_TREEVIEWER_DIALOG_H #endif // GEORGES_TREEVIEWER_DIALOG_H

View file

@ -63,6 +63,9 @@
<height>0</height> <height>0</height>
</size> </size>
</property> </property>
<property name="alternatingRowColors">
<bool>true</bool>
</property>
</widget> </widget>
</item> </item>
<item row="1" column="0"> <item row="1" column="0">

View file

@ -40,16 +40,16 @@
using namespace NLGEORGES; using namespace NLGEORGES;
namespace Plugin namespace GeorgesQt
{ {
CGeorgesFormModel::CGeorgesFormModel(UFormElm *rootElm, QMap< QString, QStringList> deps, CGeorgesFormModel::CGeorgesFormModel(UFormElm *rootElm, QMap< QString, QStringList> deps,
QString comment, QStringList parents, bool *expanded, QObject *parent) : QAbstractItemModel(parent) QString comment, QStringList parents, bool *expanded, QObject *parent) : QAbstractItemModel(parent)
{ {
QList<QVariant> rootData;
rootData << "Value" << "Data" << "Extra";// << "Type"; m_rootData << "Value" << "Data" << "Extra";// << "Type";
m_rootElm = rootElm; m_rootElm = rootElm;
m_rootItem = new CFormItem(m_rootElm, rootData); m_rootItem = new CFormItem(m_rootElm, m_rootData);
m_dependencies = deps; m_dependencies = deps;
m_comments = comment; m_comments = comment;
m_parents = parents; m_parents = parents;
@ -669,6 +669,27 @@ namespace Plugin
Q_EMIT layoutAboutToBeChanged(); Q_EMIT layoutAboutToBeChanged();
Q_EMIT layoutChanged(); Q_EMIT layoutChanged();
} }
} /* namespace Plugin */
void CGeorgesFormModel::addParentForm(QString parentForm)
{
beginResetModel();
m_parents.push_back(parentForm);
delete m_rootItem;
m_rootItem = new CFormItem(m_rootElm, m_rootData);
setupModelData();
endResetModel();
}
void CGeorgesFormModel::removeParentForm(QString parentForm)
{
beginResetModel();
m_parents.removeOne(parentForm);
delete m_rootItem;
m_rootItem = new CFormItem(m_rootElm, m_rootData);
setupModelData();
endResetModel();
}
} /* namespace GeorgesQt */
/* end of file */ /* end of file */

View file

@ -29,7 +29,7 @@ namespace NLGEORGES {
class UFormElm; class UFormElm;
} }
namespace Plugin namespace GeorgesQt
{ {
class CFormItem; class CFormItem;
@ -56,6 +56,9 @@ namespace Plugin
bool showDefaults() { return m_showDefaults;} bool showDefaults() { return m_showDefaults;}
void setShowParents( bool show ); void setShowParents( bool show );
void setShowDefaults( bool show ); void setShowDefaults( bool show );
void addParentForm(QString parentForm);
void removeParentForm(QString parentForm);
NLGEORGES::UFormElm *getRootForm() { return m_rootElm; }
private: private:
void setupModelData(); void setupModelData();
@ -64,6 +67,7 @@ namespace Plugin
CFormItem* m_rootItem; CFormItem* m_rootItem;
NLGEORGES::UFormElm* m_rootElm; NLGEORGES::UFormElm* m_rootElm;
QList<QVariant> m_rootData;
QMap< QString, QStringList> m_dependencies; QMap< QString, QStringList> m_dependencies;
QString m_comments; QString m_comments;
QStringList m_parents; QStringList m_parents;
@ -71,10 +75,10 @@ namespace Plugin
bool m_showParents; bool m_showParents;
bool m_showDefaults; bool m_showDefaults;
bool *m_expanded; bool *m_expanded;
};/* class CGeorgesFormModel */ };/* class CGeorgesFormModel */
} /* namespace Plugin */ } /* namespace GeorgesQt */
#endif // GEORGESFORM_MODEL_H #endif // GEORGESFORM_MODEL_H

View file

@ -23,7 +23,7 @@
#include "georgesform_proxy_model.h" #include "georgesform_proxy_model.h"
#include "georgesform_model.h" #include "georgesform_model.h"
namespace Plugin namespace GeorgesQt
{ {
bool CGeorgesFormProxyModel::filterAcceptsRow(int sourceRow, bool CGeorgesFormProxyModel::filterAcceptsRow(int sourceRow,
@ -76,6 +76,6 @@ namespace Plugin
{ {
return QSortFilterProxyModel::filterAcceptsColumn(sourceRow, sourceParent); return QSortFilterProxyModel::filterAcceptsColumn(sourceRow, sourceParent);
} }
} /* namespace Plugin */ } /* namespace GeorgesQt */
/* end of file */ /* end of file */

View file

@ -20,7 +20,7 @@
// Qt includes // Qt includes
#include <QSortFilterProxyModel> #include <QSortFilterProxyModel>
namespace Plugin namespace GeorgesQt
{ {
class CGeorgesFormProxyModel : public QSortFilterProxyModel class CGeorgesFormProxyModel : public QSortFilterProxyModel
@ -40,6 +40,6 @@ namespace Plugin
};/* class CGeorgesFormProxyModel */ };/* class CGeorgesFormProxyModel */
} /* namespace NLQT */ } /* namespace GeorgesQt */
#endif // GEORGESFORM_PROXY_MODEL_H #endif // GEORGESFORM_PROXY_MODEL_H