aboutsummaryrefslogtreecommitdiff
path: root/backends
diff options
context:
space:
mode:
authorTony Puccinelli2010-08-06 06:03:34 +0000
committerTony Puccinelli2010-08-06 06:03:34 +0000
commitd4a4176123f1a39916d1b407ab531bf3adb04697 (patch)
tree325a70442c5ab63b8cd750d886544647a2bca608 /backends
parent415a5aaa363634d76c3b75bf76a51172166e2306 (diff)
downloadscummvm-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
Diffstat (limited to 'backends')
-rw-r--r--backends/module.mk1
-rw-r--r--backends/platform/ds/arm9/makefile2
-rw-r--r--backends/platform/ds/arm9/source/dsmain.cpp3
-rw-r--r--backends/plugins/ds/ds-provider.cpp59
-rw-r--r--backends/plugins/ds/ds-provider.h35
-rw-r--r--backends/plugins/elf-provider.h7
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;