diff options
| author | David Corrales | 2007-05-12 20:00:52 +0000 |
|---|---|---|
| committer | David Corrales | 2007-05-12 20:00:52 +0000 |
| commit | d1f56d93f934150f4b579c2e90564e2bf035f113 (patch) | |
| tree | 09aae1d4077c8e1c933fdca88d34d890a46f8a6a /backends/fs/morphos | |
| parent | 86324f00bc561c03b281170125ef2fde14cae132 (diff) | |
| download | scummvm-rg350-d1f56d93f934150f4b579c2e90564e2bf035f113.tar.gz scummvm-rg350-d1f56d93f934150f4b579c2e90564e2bf035f113.tar.bz2 scummvm-rg350-d1f56d93f934150f4b579c2e90564e2bf035f113.zip | |
Use common/singleton.h in the concrete fs factories.
svn-id: r26814
Diffstat (limited to 'backends/fs/morphos')
| -rw-r--r-- | backends/fs/morphos/abox-fs-factory.cpp | 9 | ||||
| -rw-r--r-- | backends/fs/morphos/abox-fs-factory.h | 11 |
2 files changed, 3 insertions, 17 deletions
diff --git a/backends/fs/morphos/abox-fs-factory.cpp b/backends/fs/morphos/abox-fs-factory.cpp index 4689a6a42f..9de810c361 100644 --- a/backends/fs/morphos/abox-fs-factory.cpp +++ b/backends/fs/morphos/abox-fs-factory.cpp @@ -1,14 +1,7 @@ #include "backends/fs/morphos/abox-fs-factory.h" #include "backends/fs/morphos/abox-fs.cpp" -ABoxFilesystemFactory *ABoxFilesystemFactory::_instance = 0; - -ABoxFilesystemFactory *ABoxFilesystemFactory::instance(){ - if(_instance == 0){ - _instance = new ABoxFilesystemFactory(); - } - return _instance; -} +DECLARE_SINGLETON(ABoxFilesystemFactory); AbstractFilesystemNode *ABoxFilesystemFactory::makeRootFileNode() const { return new ABoxFilesystemNode(); diff --git a/backends/fs/morphos/abox-fs-factory.h b/backends/fs/morphos/abox-fs-factory.h index f6cf7774c5..b0d1dfb340 100644 --- a/backends/fs/morphos/abox-fs-factory.h +++ b/backends/fs/morphos/abox-fs-factory.h @@ -8,16 +8,9 @@ * * Parts of this class are documented in the base interface class, AbstractFilesystemFactory. */ -class ABoxFilesystemFactory : public AbstractFilesystemFactory { +class ABoxFilesystemFactory : public AbstractFilesystemFactory, public Common::Singleton<ABoxFilesystemFactory> { public: typedef Common::String String; - - /** - * Creates an instance of ABoxFilesystemFactory using the Singleton pattern. - * - * @return A unique instance of ABoxFilesytemFactory. - */ - static ABoxFilesystemFactory *instance(); virtual AbstractFilesystemNode *makeRootFileNode() const; virtual AbstractFilesystemNode *makeCurrentDirectoryFileNode() const; @@ -27,7 +20,7 @@ protected: ABoxFilesystemFactory() {}; private: - static ABoxFilesystemFactory *_instance; + friend class Common::Singleton<SingletonBaseType>; }; #endif /*ABOX_FILESYSTEM_FACTORY_H*/ |
