diff options
| author | Alexander Tkachev | 2016-05-11 20:24:53 +0600 | 
|---|---|---|
| committer | Alexander Tkachev | 2016-08-24 16:05:07 +0600 | 
| commit | ca2eeb221455e54505aaef7039cfc0b01b807179 (patch) | |
| tree | 9e73268cc9a8a5a1ad805b4107d06e2e0b08cc29 | |
| parent | 7446ffd73bd184610d550a354a8e252b0b7f334d (diff) | |
| download | scummvm-rg350-ca2eeb221455e54505aaef7039cfc0b01b807179.tar.gz scummvm-rg350-ca2eeb221455e54505aaef7039cfc0b01b807179.tar.bz2 scummvm-rg350-ca2eeb221455e54505aaef7039cfc0b01b807179.zip | |
CLOUD: Add Cloud::Manager and Cloud::Storage
This commit introduces Common::CloudManager, which can be accessed from
OSystem.
The backend for this manager is Cloud::Manager (defined in
backends/cloud/manager.h). It should load all users storages from
configs and provide access to current Storage instance. For now it just
creates a new one.
Cloud::Storage (backends/cloud/storage.h) provides an API to interact
with cloud storage, for example, create new directory or sync files.
Right now it's not ready and has only two dummy methods: listDirectory()
and syncSaves().
There is Cloud::Dropbox::DropboxStorage backend
(backends/cloud/dropbox/dropboxstorage.h) for Cloud::Storage. Right now
it implements both listDirectory() and syncSaves() with starting timer
task and handling it by printing out some JSON examples.
| -rw-r--r-- | backends/cloud/dropbox/dropboxstorage.cpp (renamed from backends/cloud/cloudthread.cpp) | 26 | ||||
| -rw-r--r-- | backends/cloud/dropbox/dropboxstorage.h | 45 | ||||
| -rw-r--r-- | backends/cloud/manager.cpp | 41 | ||||
| -rw-r--r-- | backends/cloud/manager.h (renamed from backends/cloud/cloudthread.h) | 23 | ||||
| -rw-r--r-- | backends/cloud/storage.cpp | 49 | ||||
| -rw-r--r-- | backends/cloud/storage.h | 61 | ||||
| -rw-r--r-- | backends/module.mk | 6 | ||||
| -rw-r--r-- | backends/platform/sdl/sdl.cpp | 4 | ||||
| -rw-r--r-- | base/main.cpp | 4 | ||||
| -rw-r--r-- | common/cloudmanager.h | 53 | ||||
| -rw-r--r-- | common/module.mk | 4 | ||||
| -rw-r--r-- | common/system.h | 14 | 
12 files changed, 288 insertions, 42 deletions
| diff --git a/backends/cloud/cloudthread.cpp b/backends/cloud/dropbox/dropboxstorage.cpp index 813354f43f..b841575bf6 100644 --- a/backends/cloud/cloudthread.cpp +++ b/backends/cloud/dropbox/dropboxstorage.cpp @@ -20,22 +20,17 @@  *  */ -#include "cloudthread.h" +#include "backends/cloud/dropbox/dropboxstorage.h"  #include "common/debug.h"  #include "common/json.h" -#include "common/system.h" -#include "common/timer.h"  void example1();  void example2();  void example3(); -void cloudThread(void *thread) { -	CloudThread *cloudThread = (CloudThread *)thread; -	cloudThread->handler(); -}; +namespace Cloud { namespace Dropbox { -void CloudThread::handler() { +void DropboxStorage::handler() {  	if (_firstTime) {  		_firstTime = false; @@ -45,21 +40,16 @@ void CloudThread::handler() {  	} else { }  } -void CloudThread::setTimeout(int interval) { -	Common::TimerManager *manager = g_system->getTimerManager(); -	if (!manager->installTimerProc(cloudThread, interval, this, "Cloud Thread")) -		warning("Failed to create cloud thread"); -} - -void CloudThread::unsetTimeout() { -	Common::TimerManager *manager = g_system->getTimerManager(); -	manager->removeTimerProc(cloudThread); +void DropboxStorage::listDirectory(Common::String path) { +	setTimeout(1000000); //in one second  } -void CloudThread::start() { +void DropboxStorage::syncSaves() {  	setTimeout(1000000); //in one second  } +} } //end of namespace Cloud::Dropbox +  /// SimpleJSON examples:  using Common::JSON; diff --git a/backends/cloud/dropbox/dropboxstorage.h b/backends/cloud/dropbox/dropboxstorage.h new file mode 100644 index 0000000000..43ed9dcbee --- /dev/null +++ b/backends/cloud/dropbox/dropboxstorage.h @@ -0,0 +1,45 @@ +/* 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. +* +*/ + +#ifndef BACKENDS_CLOUD_DROPBOX_STORAGE_H +#define BACKENDS_CLOUD_DROPBOX_STORAGE_H + +#include "backends/cloud/storage.h" + +namespace Cloud { namespace Dropbox { + +class DropboxStorage: public Cloud::Storage { +	bool _firstTime; + +protected: +	virtual void handler(); + +public: +	DropboxStorage() : _firstTime(true) {}; + +	virtual void listDirectory(Common::String path); +	virtual void syncSaves(); +}; + +} }  //end of namespace Cloud::Dropbox + +#endif diff --git a/backends/cloud/manager.cpp b/backends/cloud/manager.cpp new file mode 100644 index 0000000000..05b23771b0 --- /dev/null +++ b/backends/cloud/manager.cpp @@ -0,0 +1,41 @@ +/* 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. +* +*/ + +#include "backends/cloud/manager.h" +#include "backends/cloud/dropbox/dropboxstorage.h" + +namespace Cloud { + +Manager::Manager(): _currentStorage(new Dropbox::DropboxStorage()) {}; + +Manager::~Manager() { delete _currentStorage; } + +Storage* Manager::getCurrentStorage() { +	return _currentStorage; +} + +void Manager::syncSaves() { +	Storage* storage = getCurrentStorage(); +	if (storage) storage->syncSaves(); +} + +} //end of namespace Cloud
\ No newline at end of file diff --git a/backends/cloud/cloudthread.h b/backends/cloud/manager.h index 334a163dde..11cc595da4 100644 --- a/backends/cloud/cloudthread.h +++ b/backends/cloud/manager.h @@ -20,22 +20,25 @@  *  */ -#ifndef BACKENDS_CLOUD_CLOUDTHREAD_H -#define BACKENDS_CLOUD_CLOUDTHREAD_H +#ifndef BACKENDS_CLOUD_MANAGER_H +#define BACKENDS_CLOUD_MANAGER_H -class CloudThread { -	friend void cloudThread(void*); //calls private handler() +#include "common/cloudmanager.h" +#include "common/str.h" -	bool _firstTime; +namespace Cloud { -	void handler(); -	void setTimeout(int interval); -	void unsetTimeout(); +class Manager: public Common::CloudManager { +	Storage* _currentStorage;  public: -	CloudThread(): _firstTime(true) {}; +	Manager(); +	virtual ~Manager(); -	void start(); +	virtual Storage* getCurrentStorage(); +	virtual void syncSaves();  }; +} //end of namespace Cloud +  #endif diff --git a/backends/cloud/storage.cpp b/backends/cloud/storage.cpp new file mode 100644 index 0000000000..3272ecf760 --- /dev/null +++ b/backends/cloud/storage.cpp @@ -0,0 +1,49 @@ +/* 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. +* +*/ + +#include "backends/cloud/storage.h" +#include "common/system.h" +#include "common/timer.h" + +namespace Cloud { + +void cloudThread(void *thread) { +	Storage *cloudThread = (Storage *)thread; +	cloudThread->handler(); +} + +void Storage::handler() { +	unsetTimeout(); +} + +void Storage::setTimeout(int interval) { +	Common::TimerManager *manager = g_system->getTimerManager(); +	if (!manager->installTimerProc(cloudThread, interval, this, "Cloud Thread")) +		; // warning("Failed to create cloud thread"); +} + +void Storage::unsetTimeout() { +	Common::TimerManager *manager = g_system->getTimerManager(); +	manager->removeTimerProc(cloudThread); +} + +} //end of namespace Cloud diff --git a/backends/cloud/storage.h b/backends/cloud/storage.h new file mode 100644 index 0000000000..4afa36f8d8 --- /dev/null +++ b/backends/cloud/storage.h @@ -0,0 +1,61 @@ +/* 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. +* +*/ + +#ifndef BACKENDS_CLOUD_STORAGE_H +#define BACKENDS_CLOUD_STORAGE_H + +#include "common/str.h" + +namespace Cloud { + +class Storage { +	friend void cloudThread(void*); //calls handler() + +protected: +	virtual void handler(); +	virtual void setTimeout(int interval); +	virtual void unsetTimeout(); + +public: +	Storage() {}; +	virtual ~Storage() {}; + +	/** +	* Lists given directory. +	* +	* @param path		directory to list	 +	*/ + +	//TODO: actually make it list directories and some callback to pass gathered files list + +	virtual void listDirectory(Common::String path) = 0; + +	/** +	* Starts saves syncing process. +	*/ + +	virtual void syncSaves() = 0; +}; + +} //end of namespace Cloud + +#endif diff --git a/backends/module.mk b/backends/module.mk index fc2fb99a9d..a1e9c11a1d 100644 --- a/backends/module.mk +++ b/backends/module.mk @@ -251,8 +251,10 @@ endif  # I don't have any define, so I'd just add my files without any  # ifndef USE_CLOUD ? -MODULE_OBJS += \ -	cloud/cloudthread.o +MODULE_OBJS += \	 +	cloud/manager.o \ +	cloud/storage.o \ +	cloud/dropbox/storage.o  # endif  # Include common rules diff --git a/backends/platform/sdl/sdl.cpp b/backends/platform/sdl/sdl.cpp index 84aa5c8421..e743bdf829 100644 --- a/backends/platform/sdl/sdl.cpp +++ b/backends/platform/sdl/sdl.cpp @@ -33,7 +33,7 @@  #include "gui/EventRecorder.h"  #include "common/taskbar.h"  #include "common/textconsole.h" -#include "backends/cloud/cloudthread.h" +#include "backends/cloud/manager.h"  #include "backends/saves/default/default-saves.h" @@ -162,7 +162,7 @@ void OSystem_SDL::init() {  //TODO: define USE_CLOUD  //#if defined(USE_CLOUD)  	if (_cloudThread == 0) -		_cloudThread = new CloudThread(); +		_cloudThread = new Cloud::Manager();  //#endif  } diff --git a/base/main.cpp b/base/main.cpp index ce69117bc6..001d864355 100644 --- a/base/main.cpp +++ b/base/main.cpp @@ -66,7 +66,7 @@  #endif  #include "backends/keymapper/keymapper.h" -#include "backends/cloud/cloudthread.h" +#include "common/cloudmanager.h"  #if defined(_WIN32_WCE)  #include "backends/platform/wince/CELauncherDialog.h" @@ -479,7 +479,7 @@ extern "C" int scummvm_main(int argc, const char * const argv[]) {  	//TODO: define USE_CLOUD  //#ifdef USE_CLOUD -	system.getCloudThread()->start(); +	system.getCloudManager()->syncSaves();  //#endif  	// Unless a game was specified, show the launcher dialog diff --git a/common/cloudmanager.h b/common/cloudmanager.h new file mode 100644 index 0000000000..6b5768280a --- /dev/null +++ b/common/cloudmanager.h @@ -0,0 +1,53 @@ +/* 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. +* +*/ + +#ifndef COMMON_CLOUDMANAGER_H +#define COMMON_CLOUDMANAGER_H + +#include "backends/cloud/storage.h" + +namespace Common { + +class CloudManager { +public: +	CloudManager() {}; +	virtual ~CloudManager() {}; + +	/** +	* Returns active Storage, which could be used to interact +	*  with cloud storage. +	* +	* @return	active Cloud::Storage or null, if there is no active Storage. +	*/ + +	virtual Cloud::Storage* getCurrentStorage() = 0; + +	/** +	* Starts saves syncing process in currently active storage if there is any. +	*/ + +	virtual void syncSaves() = 0; +}; + +} //end of namespace Common + +#endif diff --git a/common/module.mk b/common/module.mk index 54aa16f557..29def4b8aa 100644 --- a/common/module.mk +++ b/common/module.mk @@ -62,5 +62,9 @@ MODULE_OBJS += \  	updates.o  endif +#TODO define USE_CLOUD +#ifdef USE_CLOUD +#endif +  # Include common rules  include $(srcdir)/rules.mk diff --git a/common/system.h b/common/system.h index 1af45fb1fc..b1c74cbc5b 100644 --- a/common/system.h +++ b/common/system.h @@ -56,13 +56,11 @@ class HardwareInputSet;  class Keymap;  class KeymapperDefaultBindings;  #endif -} -  //TODO: define USE_CLOUD -//TODO: probably move to common and name CloudManager  //#if defined(USE_CLOUD) -class CloudThread; +class CloudManager;  //#endif +}  class AudioCDManager;  class FilesystemFactory; @@ -191,7 +189,7 @@ protected:  	*  	* @note _cloudThread is deleted by the OSystem destructor.  	*/ -	CloudThread *_cloudThread; +	Common::CloudManager *_cloudThread;  //#endif  	/** @@ -1135,12 +1133,12 @@ public:  //TODO: define USE_CLOUD  //#if defined(USE_CLOUD)  	/** -	* Returns the CloudThread, used to sync save games and +	* Returns the CloudManager, used to sync save games and  	* upload/download files from user's cloud storage.  	* -	* @return the CloudThread for the current architecture +	* @return the CloudManager for the current architecture  	*/ -	virtual CloudThread *getCloudThread() { +	virtual Common::CloudManager *getCloudManager() {  		return _cloudThread;  	}  //#endif | 
