Changed: #1206 correct fix is to load the plugins and update ovqt example plugin.

This commit is contained in:
dnk-88 2010-12-03 12:21:12 +02:00
parent 17407f813c
commit e019d92dea
15 changed files with 170 additions and 85 deletions

View file

@ -3,7 +3,7 @@ INCLUDE( ${QT_USE_FILE} )
FILE(GLOB OBJECT_VIEWER_SRC configuration.h entity.h object_viewer.h particle_editor.h modules.h sound_system.h FILE(GLOB OBJECT_VIEWER_SRC configuration.h entity.h object_viewer.h particle_editor.h modules.h sound_system.h
particle_node.h ps_initial_pos.h dup_ps.h vegetable_editor.h vegetable_node.h particle_node.h ps_initial_pos.h dup_ps.h vegetable_editor.h vegetable_node.h
extension_system/plugin_spec.h extension_system/iplugin_spec.h extension_system/plugin_spec.h
extension_system/*.cpp *.cpp) extension_system/*.cpp *.cpp)
SET(OBJECT_VIEWER_HDR main_window.h graphics_viewport.h animation_dialog.h SET(OBJECT_VIEWER_HDR main_window.h graphics_viewport.h animation_dialog.h

View file

@ -20,7 +20,7 @@
#ifndef IPLUGIN_H #ifndef IPLUGIN_H
#define IPLUGIN_H #define IPLUGIN_H
#include <QtPlugin> #include <QtCore/QtPlugin>
#include <QtCore/QString> #include <QtCore/QString>
#include "iplugin_manager.h" #include "iplugin_manager.h"
@ -52,6 +52,6 @@ public:
}; //namespace NLQT }; //namespace NLQT
Q_DECLARE_INTERFACE(NLQT::IPlugin, "com.ryzom.dev.ObjectViewerQt.IPlugin/0.8") Q_DECLARE_INTERFACE(NLQT::IPlugin, "com.ryzom.dev.ObjectViewerQt.IPlugin/0.9")
#endif // IPLUGIN_H #endif // IPLUGIN_H

View file

@ -26,7 +26,7 @@
namespace NLQT namespace NLQT
{ {
class CPluginSpec; class IPluginSpec;
class IPluginManager: public QObject class IPluginManager: public QObject
{ {
@ -44,9 +44,7 @@ public:
virtual void loadPlugins() = 0; virtual void loadPlugins() = 0;
virtual QStringList getPluginPaths() const = 0; virtual QStringList getPluginPaths() const = 0;
virtual void setPluginPaths(const QStringList &paths) = 0; virtual void setPluginPaths(const QStringList &paths) = 0;
virtual QList<NLQT::CPluginSpec *> plugins() const = 0; virtual QList<NLQT::IPluginSpec *> plugins() const = 0;
virtual CPluginSpec *pluginByName(const QString &name) const = 0;
Q_SIGNALS: Q_SIGNALS:
void objectAdded(QObject *obj); void objectAdded(QObject *obj);

View file

@ -0,0 +1,69 @@
/*
Object Viewer Qt
Copyright (C) 2010 Dzmitry Kamiahin <dnk-88@tut.by>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef IPLUGINSPEC_H
#define IPLUGINSPEC_H
#include <QtCore/QString>
namespace NLQT
{
class IPlugin;
class IPluginManager;
struct State
{
enum List
{
Invalid = 1,
Read,
Loaded,
Initialized,
Running,
Stopped,
Deleted
};
};
class IPluginSpec
{
public:
virtual ~IPluginSpec() {}
virtual QString name() const = 0;
virtual QString version() const = 0;
virtual QString vendor() const = 0;
virtual QString description() const = 0;
virtual QString location() const = 0;
virtual QString filePath() const = 0;
virtual QString fileName() const = 0;
virtual IPlugin *plugin() const = 0;
// state
virtual int getState() const = 0;
virtual bool hasError() const = 0;
virtual QString errorString() const = 0;
};
} // namespace NLQT
#endif // IPLUGINSPEC_H

View file

@ -109,15 +109,16 @@ void CPluginManager::setPluginPaths(const QStringList &paths)
readPluginPaths(); readPluginPaths();
} }
QList<CPluginSpec *> CPluginManager::plugins() const QList<IPluginSpec *> CPluginManager::plugins() const
{ {
return _pluginSpecs; return _ipluginSpecs;
} }
void CPluginManager::readPluginPaths() void CPluginManager::readPluginPaths()
{ {
qDeleteAll(_pluginSpecs); qDeleteAll(_pluginSpecs);
_pluginSpecs.clear(); _pluginSpecs.clear();
_ipluginSpecs.clear();
QStringList pluginsList; QStringList pluginsList;
QStringList searchPaths = _pluginPaths; QStringList searchPaths = _pluginPaths;
@ -144,19 +145,12 @@ void CPluginManager::readPluginPaths()
spec->setFileName(pluginFile); spec->setFileName(pluginFile);
spec->_pluginManager = this; spec->_pluginManager = this;
_pluginSpecs.append(spec); _pluginSpecs.append(spec);
_ipluginSpecs.append(spec);
} }
Q_EMIT pluginsChanged(); Q_EMIT pluginsChanged();
} }
CPluginSpec *CPluginManager::pluginByName(const QString &name) const
{
Q_FOREACH (CPluginSpec *spec, _pluginSpecs)
if (spec->name() == name)
return spec;
return 0;
}
void CPluginManager::setPluginState(CPluginSpec *spec, int destState) void CPluginManager::setPluginState(CPluginSpec *spec, int destState)
{ {
if (spec->hasError()) if (spec->hasError())

View file

@ -30,6 +30,7 @@ namespace NLQT
{ {
class IPlugin; class IPlugin;
class CPluginSpec;
class CPluginManager : public IPluginManager class CPluginManager : public IPluginManager
{ {
@ -48,9 +49,7 @@ public:
virtual void loadPlugins(); virtual void loadPlugins();
virtual QStringList getPluginPaths() const; virtual QStringList getPluginPaths() const;
virtual void setPluginPaths(const QStringList &paths); virtual void setPluginPaths(const QStringList &paths);
virtual QList<CPluginSpec *> plugins() const; virtual QList<IPluginSpec *> plugins() const;
virtual CPluginSpec *pluginByName(const QString &name) const;
private: private:
void setPluginState(CPluginSpec *spec, int destState); void setPluginState(CPluginSpec *spec, int destState);
@ -60,6 +59,7 @@ private:
mutable QReadWriteLock _lock; mutable QReadWriteLock _lock;
QList<CPluginSpec *> _pluginSpecs; QList<CPluginSpec *> _pluginSpecs;
QList<IPluginSpec *> _ipluginSpecs;
QStringList _pluginPaths; QStringList _pluginPaths;
QList<QObject *> _allObjects; QList<QObject *> _allObjects;

View file

@ -19,6 +19,7 @@
#include "plugin_spec.h" #include "plugin_spec.h"
#include <QtCore/QList>
#include <QtCore/QFile> #include <QtCore/QFile>
#include <QtCore/QFileInfo> #include <QtCore/QFileInfo>
#include <QtCore/QPluginLoader> #include <QtCore/QPluginLoader>
@ -40,10 +41,6 @@ CPluginSpec::CPluginSpec():
{ {
} }
CPluginSpec::~CPluginSpec()
{
}
QString CPluginSpec::name() const QString CPluginSpec::name() const
{ {
return _name; return _name;

View file

@ -20,48 +20,29 @@
#ifndef PLUGINSPEC_H #ifndef PLUGINSPEC_H
#define PLUGINSPEC_H #define PLUGINSPEC_H
#include <QtCore/QString> #include "iplugin_spec.h"
#include <QtCore/QList>
namespace NLQT namespace NLQT
{ {
class IPlugin;
class IPluginManager;
struct State class CPluginSpec: public IPluginSpec
{
enum List
{
Invalid = 1,
Read,
Loaded,
Initialized,
Running,
Stopped,
Deleted
};
};
class CPluginSpec
{ {
public: public:
~CPluginSpec(); virtual QString name() const;
virtual QString version() const;
virtual QString vendor() const;
virtual QString description() const;
QString name() const; virtual QString location() const;
QString version() const; virtual QString filePath() const;
QString vendor() const; virtual QString fileName() const;
QString description() const;
QString location() const; virtual IPlugin *plugin() const;
QString filePath() const;
QString fileName() const;
IPlugin *plugin() const;
// state // state
int getState() const; virtual int getState() const;
bool hasError() const; virtual bool hasError() const;
QString errorString() const; virtual QString errorString() const;
private: private:
CPluginSpec(); CPluginSpec();

View file

@ -19,12 +19,24 @@
<layout class="QGridLayout" name="gridLayout"> <layout class="QGridLayout" name="gridLayout">
<item row="0" column="0" colspan="4"> <item row="0" column="0" colspan="4">
<widget class="QTreeWidget" name="pluginTreeWidget"> <widget class="QTreeWidget" name="pluginTreeWidget">
<property name="alternatingRowColors">
<bool>true</bool>
</property>
<property name="indentation">
<number>0</number>
</property>
<property name="rootIsDecorated"> <property name="rootIsDecorated">
<bool>false</bool> <bool>false</bool>
</property> </property>
<property name="uniformRowHeights">
<bool>true</bool>
</property>
<property name="itemsExpandable"> <property name="itemsExpandable">
<bool>false</bool> <bool>false</bool>
</property> </property>
<property name="sortingEnabled">
<bool>true</bool>
</property>
<column> <column>
<property name="text"> <property name="text">
<string>State</string> <string>State</string>

View file

@ -28,7 +28,7 @@
#include <QtGui/QTreeWidgetItem> #include <QtGui/QTreeWidgetItem>
// Project includes // Project includes
#include "plugin_spec.h" #include "iplugin_spec.h"
#include "iplugin_manager.h" #include "iplugin_manager.h"
namespace NLQT namespace NLQT
@ -55,7 +55,7 @@ void CPluginView::updateList()
static QIcon errorIcon = QApplication::style()->standardIcon(QStyle::SP_DialogCancelButton); static QIcon errorIcon = QApplication::style()->standardIcon(QStyle::SP_DialogCancelButton);
QList<QTreeWidgetItem *> items; QList<QTreeWidgetItem *> items;
Q_FOREACH (CPluginSpec *spec, _pluginManager->plugins()) Q_FOREACH (IPluginSpec *spec, _pluginManager->plugins())
{ {
QTreeWidgetItem *item = new QTreeWidgetItem(QStringList() QTreeWidgetItem *item = new QTreeWidgetItem(QStringList()
<< "" << ""

View file

@ -13,7 +13,7 @@
#include <nel/misc/file.h> #include <nel/misc/file.h>
#include <nel/misc/path.h> #include <nel/misc/path.h>
#include <nel/misc/command.h> #include <nel/misc/command.h>
#include "extension_system/plugin_spec.h" #include "extension_system/iplugin_spec.h"
// Project includes // Project includes
#include "modules.h" #include "modules.h"
@ -103,7 +103,7 @@ sint main(int argc, char **argv)
Modules::plugMan().loadPlugins(); Modules::plugMan().loadPlugins();
QStringList errors; QStringList errors;
Q_FOREACH (NLQT::CPluginSpec *spec, Modules::plugMan().plugins()) Q_FOREACH (NLQT::IPluginSpec *spec, Modules::plugMan().plugins())
if (spec->hasError()) if (spec->hasError())
errors.append(spec->fileName() + " : " + spec->errorString()); errors.append(spec->fileName() + " : " + spec->errorString());

View file

@ -354,19 +354,23 @@ void CMainWindow::createActions()
void CMainWindow::createMenus() void CMainWindow::createMenus()
{ {
_fileMenu = menuBar()->addMenu(tr("&File")); _fileMenu = menuBar()->addMenu(tr("&File"));
_fileMenu->setObjectName("ovqt.Menu.File");
_fileMenu->addAction(_openAction); _fileMenu->addAction(_openAction);
_fileMenu->addSeparator(); _fileMenu->addSeparator();
_fileMenu->addAction(_exitAction); _fileMenu->addAction(_exitAction);
_viewMenu = menuBar()->addMenu(tr("&View")); _viewMenu = menuBar()->addMenu(tr("&View"));
_viewMenu->setObjectName("ovqt.Menu.View");
_viewMenu->addAction(_setBackColorAction); _viewMenu->addAction(_setBackColorAction);
_viewMenu->addAction(_SetupFog->toggleViewAction()); _viewMenu->addAction(_SetupFog->toggleViewAction());
_sceneMenu = menuBar()->addMenu(tr("&Scene")); _sceneMenu = menuBar()->addMenu(tr("&Scene"));
_sceneMenu->setObjectName("ovqt.Menu.Scene");
_sceneMenu->addAction(_resetSceneAction); _sceneMenu->addAction(_resetSceneAction);
_sceneMenu->addAction(_saveScreenshotAction); _sceneMenu->addAction(_saveScreenshotAction);
_toolsMenu = menuBar()->addMenu(tr("&Tools")); _toolsMenu = menuBar()->addMenu(tr("&Tools"));
_toolsMenu->setObjectName("ovqt.Menu.Tools");
_toolsMenu->addAction(_AnimationDialog->toggleViewAction()); _toolsMenu->addAction(_AnimationDialog->toggleViewAction());
_AnimationDialog->toggleViewAction()->setIcon(QIcon(":/images/anim.png")); _AnimationDialog->toggleViewAction()->setIcon(QIcon(":/images/anim.png"));
@ -411,9 +415,16 @@ void CMainWindow::createMenus()
menuBar()->addSeparator(); menuBar()->addSeparator();
_helpMenu = menuBar()->addMenu(tr("&Help")); _helpMenu = menuBar()->addMenu(tr("&Help"));
_helpMenu->setObjectName("ovqt.Menu.Help");
_helpMenu->addAction(_aboutAction); _helpMenu->addAction(_aboutAction);
_helpMenu->addAction(_aboutQtAction); _helpMenu->addAction(_aboutQtAction);
_helpMenu->addAction(_pluginViewAction); _helpMenu->addAction(_pluginViewAction);
Modules::plugMan().addObject(_fileMenu);
Modules::plugMan().addObject(_viewMenu);
Modules::plugMan().addObject(_sceneMenu);
Modules::plugMan().addObject(_toolsMenu);
Modules::plugMan().addObject(_helpMenu);
} }
void CMainWindow::createToolBars() void CMainWindow::createToolBars()

View file

@ -6,8 +6,7 @@ INCLUDE_DIRECTORIES( ${CMAKE_CURRENT_BINARY_DIR}
FILE(GLOB SRC *.cpp *.h) FILE(GLOB SRC *.cpp *.h)
SET(OVQT_EXT_SYS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/iplugin.h SET(OVQT_EXT_SYS_SRC ${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/iplugin.h
${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/iplugin_manager.h ${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/iplugin_manager.h
${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/plugin_spec.h ${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/iplugin_spec.h)
${CMAKE_CURRENT_SOURCE_DIR}/../../extension_system/plugin_spec.cpp)
SET(OVQT_PLUG_EXAMPLE_HDR plugin1.h) SET(OVQT_PLUG_EXAMPLE_HDR plugin1.h)

View file

@ -3,9 +3,11 @@
#include <QtCore/QObject> #include <QtCore/QObject>
#include <QtGui/QMessageBox> #include <QtGui/QMessageBox>
#include <QtGui/QMainWindow> #include <QtGui/QMainWindow>
#include <QtGui/QMenu>
#include <QtGui/QAction>
#include <QtGui/QMenuBar> #include <QtGui/QMenuBar>
#include "../../extension_system/plugin_spec.h" #include "../../extension_system/iplugin_spec.h"
#include "nel/misc/debug.h" #include "nel/misc/debug.h"
@ -17,36 +19,30 @@ bool MyPlugin::initialize(NLQT::IPluginManager *pluginManager, QString *errorStr
_plugMan = pluginManager; _plugMan = pluginManager;
QString str; QString str;
QList<NLQT::CPluginSpec *> listPlug = pluginManager->plugins(); QList<NLQT::IPluginSpec *> listPlug = pluginManager->plugins();
Q_FOREACH (NLQT::CPluginSpec *plugSpec, listPlug) Q_FOREACH (NLQT::IPluginSpec *plugSpec, listPlug)
str += plugSpec->name(); str += plugSpec->name();
QMessageBox msgBox; nlinfo(str.toStdString().c_str());
msgBox.setText(str);
msgBox.exec();
nlinfo("test message");
return true; return true;
} }
void MyPlugin::extensionsInitialized() void MyPlugin::extensionsInitialized()
{ {
QString str; QMenu *helpMenu = qobject_cast<QMenu *>(objectByName("ovqt.Menu.Help"));
QList<QObject *> listObjects = _plugMan->allObjects(); helpMenu->addSeparator();
QAction *newAction = helpMenu->addAction("MyPlugin");
Q_FOREACH (QObject *qobj, listObjects)
{ connect(newAction, SIGNAL(triggered()), this, SLOT(execMessageBox()));
if (qobj->objectName() == "CMainWindow") }
{
QMainWindow *wnd = qobject_cast< QMainWindow* >(qobj);
str += qobj->objectName() + QString(": width=%1,height=%2").arg(wnd->width()).arg(wnd->height());
}
}
void MyPlugin::execMessageBox()
{
QMainWindow *wnd = qobject_cast<QMainWindow *>(objectByName("CMainWindow"));
QMessageBox msgBox; QMessageBox msgBox;
msgBox.setText(str); msgBox.setText(wnd->objectName() + QString(": width=%1,height=%2").arg(wnd->width()).arg(wnd->height()));
msgBox.exec(); msgBox.exec();
} }
@ -63,17 +59,33 @@ QString MyPlugin::name() const
QString MyPlugin::version() const QString MyPlugin::version() const
{ {
return "0.1"; return "0.2";
} }
QString MyPlugin::vendor() const QString MyPlugin::vendor() const
{ {
return "dnk"; return "dnk-88";
} }
QString MyPlugin::description() const QString MyPlugin::description() const
{ {
return "Example plugin"; return "Example ovqt plugin.";
} }
QObject* MyPlugin::objectByName(const QString &name) const
{
Q_FOREACH (QObject *qobj, _plugMan->allObjects())
if (qobj->objectName() == name)
return qobj;
return 0;
}
NLQT::IPluginSpec *MyPlugin::pluginByName(const QString &name) const
{
Q_FOREACH (NLQT::IPluginSpec *spec, _plugMan->plugins())
if (spec->name() == name)
return spec;
return 0;
}
Q_EXPORT_PLUGIN(MyPlugin) Q_EXPORT_PLUGIN(MyPlugin)

View file

@ -11,6 +11,12 @@ namespace NLMISC
{ {
class CLibraryContext; class CLibraryContext;
} }
namespace NLQT
{
class IPluginSpec;
}
namespace Plugin namespace Plugin
{ {
@ -29,6 +35,12 @@ public:
QString version() const; QString version() const;
QString vendor() const; QString vendor() const;
QString description() const; QString description() const;
QObject *objectByName(const QString &name) const;
NLQT::IPluginSpec *pluginByName(const QString &name) const;
private Q_SLOTS:
void execMessageBox();
protected: protected:
NLMISC::CLibraryContext *_LibContext; NLMISC::CLibraryContext *_LibContext;