diff options
author | Tony Puccinelli | 2010-08-06 06:03:34 +0000 |
---|---|---|
committer | Tony Puccinelli | 2010-08-06 06:03:34 +0000 |
commit | d4a4176123f1a39916d1b407ab531bf3adb04697 (patch) | |
tree | 325a70442c5ab63b8cd750d886544647a2bca608 | |
parent | 415a5aaa363634d76c3b75bf76a51172166e2306 (diff) | |
download | scummvm-rg350-d4a4176123f1a39916d1b407ab531bf3adb04697.tar.gz scummvm-rg350-d4a4176123f1a39916d1b407ab531bf3adb04697.tar.bz2 scummvm-rg350-d4a4176123f1a39916d1b407ab531bf3adb04697.zip |
added DSPlugin and DS Plugin Provider (steps towards using subtypes of DLObject)
svn-id: r51777
-rw-r--r-- | backends/module.mk | 1 | ||||
-rw-r--r-- | backends/platform/ds/arm9/makefile | 2 | ||||
-rw-r--r-- | backends/platform/ds/arm9/source/dsmain.cpp | 3 | ||||
-rw-r--r-- | backends/plugins/ds/ds-provider.cpp | 59 | ||||
-rw-r--r-- | backends/plugins/ds/ds-provider.h | 35 | ||||
-rw-r--r-- | backends/plugins/elf-provider.h | 7 |
6 files changed, 103 insertions, 4 deletions
diff --git a/backends/module.mk b/backends/module.mk index 748b786eb4..bcfcb53a3e 100644 --- a/backends/module.mk +++ b/backends/module.mk @@ -32,6 +32,7 @@ MODULE_OBJS := \ midi/windows.o \ plugins/elf-provider.o \ plugins/dc/dc-provider.o \ + plugins/ds/ds-provider.o \ plugins/posix/posix-provider.o \ plugins/sdl/sdl-provider.o \ plugins/win32/win32-provider.o \ diff --git a/backends/platform/ds/arm9/makefile b/backends/platform/ds/arm9/makefile index adcf24f5ff..e68624679f 100644 --- a/backends/platform/ds/arm9/makefile +++ b/backends/platform/ds/arm9/makefile @@ -238,7 +238,7 @@ CXXFLAGS= $(CFLAGS) -Wno-non-virtual-dtor -Wno-unknown-pragmas -Wno-reorder \ ASFLAGS = -mcpu=arm9tdmi -mthumb-interwork -DEFINES += -D__DS__ -DNDS -DARM9 -DNONSTANDARD_PORT -DDISABLE_FANCY_THEMES -DVECTOR_RENDERER_FORMAT=1555 -DDISABLE_DOSBOX_OPL -DDISABLE_DEFAULT_SAVEFILEMANAGER -DELF_LOADER_TARGET -DNEW_PLUGIN_DESIGN_FIRST_REFINEMENT -DARM +DEFINES += -D__DS__ -DNDS -DARM9 -DNONSTANDARD_PORT -DDISABLE_FANCY_THEMES -DVECTOR_RENDERER_FORMAT=1555 -DDISABLE_DOSBOX_OPL -DDISABLE_DEFAULT_SAVEFILEMANAGER -DELF_LOADER_TARGET -DARM#-DNEW_PLUGIN_DESIGN_FIRST_REFINEMENT ifdef USE_MAD DEFINES += -DUSE_MAD endif diff --git a/backends/platform/ds/arm9/source/dsmain.cpp b/backends/platform/ds/arm9/source/dsmain.cpp index 4e44e9f1dd..ee9e4d7622 100644 --- a/backends/platform/ds/arm9/source/dsmain.cpp +++ b/backends/platform/ds/arm9/source/dsmain.cpp @@ -112,6 +112,7 @@ #include "backends/plugins/elf-provider.h" +#include "backends/plugins/ds/ds-provider.h" #include "backends/fs/ds/ds-fs.h" #include "base/version.h" @@ -3304,7 +3305,7 @@ int main(void) { #endif #ifdef DYNAMIC_MODULES - PluginManager::instance().addPluginProvider(new ELFPluginProvider()); + PluginManager::instance().addPluginProvider(new DSPluginProvider()); #endif while (1) { diff --git a/backends/plugins/ds/ds-provider.cpp b/backends/plugins/ds/ds-provider.cpp new file mode 100644 index 0000000000..e4ffb7bd43 --- /dev/null +++ b/backends/plugins/ds/ds-provider.cpp @@ -0,0 +1,59 @@ +/* ScummVM - Graphic Adventure Engine + * + * ScummVM is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * 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 2 + * 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + * $URL$ + * $Id$ + * + */ + +/*#include "base/plugins.h" +#include "backends/plugins/dynamic-plugin.h" +#include "common/fs.h" + +#include "backends/plugins/elf-loader.h"*/ +#include "backends/plugins/elf-provider.h" +#include "backends/plugins/ds/ds-provider.h" + +#if defined(DYNAMIC_MODULES) && defined(__DS__) + +class DSPlugin : public ELFPlugin { +public: + DSPlugin(const Common::String &filename) { + _dlHandle = 0; + _filename = filename; + } + + ~DSPlugin() { + if (_dlHandle) + unloadPlugin(); + } + +}; + +/*bool DSPlugin::loadPlugin() { + +};*/ + +Plugin* DSPluginProvider::createPlugin(const Common::FSNode &node) const { + return new DSPlugin(node.getPath()); +} + +#endif // defined(DYNAMIC_MODULES) && defined(ELF_LOADER_TARGET) + diff --git a/backends/plugins/ds/ds-provider.h b/backends/plugins/ds/ds-provider.h new file mode 100644 index 0000000000..d9b1ee9cf4 --- /dev/null +++ b/backends/plugins/ds/ds-provider.h @@ -0,0 +1,35 @@ +/* ScummVM - Graphic Adventure Engine + * + * ScummVM is the legal property of its developers, whose names + * are too numerous to list here. Please refer to the COPYRIGHT + * file distributed with this source distribution. + * + * 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 2 + * 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, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + * $URL$ + * $Id$ + * + */ + +#include "backends/plugins/elf-provider.h" + +#if defined(DYNAMIC_MODULES) && defined(ELF_LOADER_TARGET) + +class DSPluginProvider : public ELFPluginProvider { + Plugin* createPlugin(const Common::FSNode &node) const; +}; + +#endif // defined(DYNAMIC_MODULES) && defined(ELF_LOADER_TARGET) + diff --git a/backends/plugins/elf-provider.h b/backends/plugins/elf-provider.h index 3ed4816c19..2e659df80c 100644 --- a/backends/plugins/elf-provider.h +++ b/backends/plugins/elf-provider.h @@ -42,6 +42,9 @@ protected: virtual VoidFunc findSymbol(const char *symbol); public: + ELFPlugin() { + } + ELFPlugin(const Common::String &filename) : _dlHandle(0), _filename(filename) {} @@ -51,13 +54,13 @@ public: } bool loadPlugin(); - void unloadPlugin(); + virtual void unloadPlugin(); }; class ELFPluginProvider : public FilePluginProvider { protected: - Plugin* createPlugin(const Common::FSNode &node) const; + virtual Plugin* createPlugin(const Common::FSNode &node) const; bool isPluginFilename(const Common::FSNode &node) const; |