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 */ | 
