diff options
author | Tony Puccinelli | 2010-07-28 02:05:17 +0000 |
---|---|---|
committer | Tony Puccinelli | 2010-07-28 02:05:17 +0000 |
commit | ff78cf6771fbbb6a7fd26d00db36c4c72d7a71db (patch) | |
tree | 00bb0e8fe4ebaac432cc586bc6499b8e11f781ac /backends/plugins | |
parent | 749d47ba2668421806ef65f693f9a6bc97d6f902 (diff) | |
download | scummvm-rg350-ff78cf6771fbbb6a7fd26d00db36c4c72d7a71db.tar.gz scummvm-rg350-ff78cf6771fbbb6a7fd26d00db36c4c72d7a71db.tar.bz2 scummvm-rg350-ff78cf6771fbbb6a7fd26d00db36c4c72d7a71db.zip |
abstracted an ELF plugin provider
svn-id: r51400
Diffstat (limited to 'backends/plugins')
-rw-r--r-- | backends/plugins/elf-provider.cpp (renamed from backends/plugins/ds/ds-provider.cpp) | 18 | ||||
-rw-r--r-- | backends/plugins/elf-provider.h (renamed from backends/plugins/ds/ds-provider.h) | 12 | ||||
-rw-r--r-- | backends/plugins/ps2/ps2-provider.cpp | 108 | ||||
-rw-r--r-- | backends/plugins/ps2/ps2-provider.h | 43 |
4 files changed, 15 insertions, 166 deletions
diff --git a/backends/plugins/ds/ds-provider.cpp b/backends/plugins/elf-provider.cpp index ef3864003b..b623f0d881 100644 --- a/backends/plugins/ds/ds-provider.cpp +++ b/backends/plugins/elf-provider.cpp @@ -23,16 +23,16 @@ * */ -#if defined(DYNAMIC_MODULES) && defined(__DS__) +#if defined(DYNAMIC_MODULES) //TODO: && defined(ELF loader target) -#include "backends/plugins/ds/ds-provider.h" +#include "backends/plugins/elf-provider.h" #include "backends/plugins/dynamic-plugin.h" #include "common/fs.h" #include "backends/plugins/elf-loader.h" -class DSPlugin : public DynamicPlugin { +class ELFPlugin : public DynamicPlugin { protected: void *_dlHandle; Common::String _filename; @@ -53,10 +53,10 @@ protected: } public: - DSPlugin(const Common::String &filename) + ELFPlugin(const Common::String &filename) : _dlHandle(0), _filename(filename) {} - ~DSPlugin() { + ~ELFPlugin() { if (_dlHandle) unloadPlugin(); } @@ -88,11 +88,11 @@ public: }; -Plugin* DSPluginProvider::createPlugin(const Common::FSNode &node) const { - return new DSPlugin(node.getPath()); +Plugin* ELFPluginProvider::createPlugin(const Common::FSNode &node) const { + return new ELFPlugin(node.getPath()); } -bool DSPluginProvider::isPluginFilename(const Common::FSNode &node) const { +bool ELFPluginProvider::isPluginFilename(const Common::FSNode &node) const { // Check the plugin suffix Common::String filename = node.getName(); printf("Testing name %s", filename.c_str()); @@ -105,4 +105,4 @@ bool DSPluginProvider::isPluginFilename(const Common::FSNode &node) const { return true; } -#endif // defined(DYNAMIC_MODULES) && defined(__DS__) +#endif // defined(DYNAMIC_MODULES) diff --git a/backends/plugins/ds/ds-provider.h b/backends/plugins/elf-provider.h index 096c1b87a9..10bd1c077f 100644 --- a/backends/plugins/ds/ds-provider.h +++ b/backends/plugins/elf-provider.h @@ -23,14 +23,14 @@ * */ -#ifndef BACKENDS_PLUGINS_DS_DS_PROVIDER_H -#define BACKENDS_PLUGINS_DS_DS_PROVIDER_H +#ifndef BACKENDS_PLUGINS_ELF_PROVIDER_H +#define BACKENDS_PLUGINS_ELF_PROVIDER_H #include "base/plugins.h" -#if defined(DYNAMIC_MODULES) && defined(__DS__) +#if defined(DYNAMIC_MODULES) // TODO: && defined(ELF-loader target) -class DSPluginProvider : public FilePluginProvider { +class ELFPluginProvider : public FilePluginProvider { protected: Plugin* createPlugin(const Common::FSNode &node) const; @@ -38,6 +38,6 @@ protected: }; -#endif // defined(DYNAMIC_MODULES) && defined(__DS__) +#endif // defined(DYNAMIC_MODULES) -#endif /* BACKENDS_PLUGINS_DS_DS_PROVIDER_H */ +#endif /* BACKENDS_PLUGINS_ELF_PROVIDER_H */ diff --git a/backends/plugins/ps2/ps2-provider.cpp b/backends/plugins/ps2/ps2-provider.cpp deleted file mode 100644 index fa4d576306..0000000000 --- a/backends/plugins/ps2/ps2-provider.cpp +++ /dev/null @@ -1,108 +0,0 @@ -/* 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$ - * - */ - -#if defined(DYNAMIC_MODULES) && defined(__PLAYSTATION2__) - -#include "backends/plugins/ps2/ps2-provider.h" -#include "backends/plugins/dynamic-plugin.h" -#include "common/fs.h" - -#include "backends/plugins/elf-loader.h" - - -class PS2Plugin : public DynamicPlugin { -protected: - void *_dlHandle; - Common::String _filename; - - virtual VoidFunc findSymbol(const char *symbol) { - void *func = dlsym(_dlHandle, symbol); - if (!func) - warning("Failed loading symbol '%s' from plugin '%s' (%s)", symbol, _filename.c_str(), dlerror()); - - // FIXME HACK: This is a HACK to circumvent a clash between the ISO C++ - // standard and POSIX: ISO C++ disallows casting between function pointers - // and data pointers, but dlsym always returns a void pointer. For details, - // see e.g. <http://www.trilithium.com/johan/2004/12/problem-with-dlsym/>. - assert(sizeof(VoidFunc) == sizeof(func)); - VoidFunc tmp; - memcpy(&tmp, &func, sizeof(VoidFunc)); - return tmp; - } - -public: - PS2Plugin(const Common::String &filename) - : _dlHandle(0), _filename(filename) {} - - ~PS2Plugin() { - if (_dlHandle) unloadPlugin(); - } - - bool loadPlugin() { - assert(!_dlHandle); - _dlHandle = dlopen(_filename.c_str(), RTLD_LAZY); - - if (!_dlHandle) { - warning("Failed loading plugin '%s' (%s)", _filename.c_str(), dlerror()); - return false; - } - - bool ret = DynamicPlugin::loadPlugin(); - - if (ret) - dlforgetsyms(_dlHandle); - - return ret; - } - - void unloadPlugin() { - DynamicPlugin::unloadPlugin(); - if (_dlHandle) { - if (dlclose(_dlHandle) != 0) - warning("Failed unloading plugin '%s' (%s)", _filename.c_str(), dlerror()); - _dlHandle = 0; - } - } -}; - - -Plugin* PS2PluginProvider::createPlugin(const Common::FSNode &node) const { - return new PS2Plugin(node.getPath()); -} - -bool PS2PluginProvider::isPluginFilename(const Common::FSNode &node) const { - // Check the plugin suffix - Common::String filename = node.getName(); - fprintf(stderr, "Testing name %s", filename.c_str()); - if (!filename.hasSuffix(".PLG") && !filename.hasSuffix(".plg")) { - fprintf(stderr," fail.\n"); - return false; - } - - fprintf(stderr," success!\n"); - return true; -} - -#endif // defined(DYNAMIC_MODULES) && defined(__PLAYSTATION2__) diff --git a/backends/plugins/ps2/ps2-provider.h b/backends/plugins/ps2/ps2-provider.h deleted file mode 100644 index 6a357db63d..0000000000 --- a/backends/plugins/ps2/ps2-provider.h +++ /dev/null @@ -1,43 +0,0 @@ -/* 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$ - * - */ - -#ifndef BACKENDS_PLUGINS_PS2_PS2_PROVIDER_H -#define BACKENDS_PLUGINS_PS2_PS2_PROVIDER_H - -#include "base/plugins.h" - -#if defined(DYNAMIC_MODULES) && defined(__PLAYSTATION2__) - -class PS2PluginProvider : public FilePluginProvider { -protected: - Plugin* createPlugin(const Common::FSNode &node) const; - - bool isPluginFilename(const Common::FSNode &node) const; - -}; - -#endif // defined(DYNAMIC_MODULES) && defined(__PLAYSTATION2__) - -#endif /* BACKENDS_PLUGINS_PS2_PS2_PROVIDER_H */ |