diff options
author | Matthias Schiffer <matthias@gamezock.de> | 2009-09-20 16:03:35 +0200 |
---|---|---|
committer | Matthias Schiffer <matthias@gamezock.de> | 2009-09-20 16:03:35 +0200 |
commit | d0cc9153d53dd4bc8dadf8bbcbe4ac72dfbbb61e (patch) | |
tree | 37d55a434528ff8d53e46393eff7ebd5529b52aa /src/Common | |
parent | 78db15a780cc5389fc6e01d500d5c91bdd8bc422 (diff) | |
download | mad-d0cc9153d53dd4bc8dadf8bbcbe4ac72dfbbb61e.tar mad-d0cc9153d53dd4bc8dadf8bbcbe4ac72dfbbb61e.zip |
Extended StorageManager to provide copy and remove methods.
Diffstat (limited to 'src/Common')
-rw-r--r-- | src/Common/StorageBackend.h | 2 | ||||
-rw-r--r-- | src/Common/StorageManager.cpp | 16 | ||||
-rw-r--r-- | src/Common/StorageManager.h | 2 |
3 files changed, 20 insertions, 0 deletions
diff --git a/src/Common/StorageBackend.h b/src/Common/StorageBackend.h index abec185..24bb437 100644 --- a/src/Common/StorageBackend.h +++ b/src/Common/StorageBackend.h @@ -45,6 +45,8 @@ class StorageBackend { virtual void store(const std::string &type, const std::string &name, const XmlData *data) throw (Core::Exception) = 0; virtual boost::shared_ptr<XmlData> load(const std::string &type, const std::string &name) throw (Core::Exception) = 0; + virtual void copy(const std::string &type, const std::string &name, const std::string &newName) throw (Core::Exception) = 0; + virtual void rename(const std::string &type, const std::string &name, const std::string &newName) throw (Core::Exception) = 0; virtual void remove(const std::string &type, const std::string &name) throw (Core::Exception) = 0; public: diff --git a/src/Common/StorageManager.cpp b/src/Common/StorageManager.cpp index 3b14554..5b5fc65 100644 --- a/src/Common/StorageManager.cpp +++ b/src/Common/StorageManager.cpp @@ -76,6 +76,22 @@ boost::shared_ptr<XmlData> StorageManager::load(const std::string &type, const s return backend->load(type, name); } +void StorageManager::copy(const std::string &type, const std::string &name, const std::string &newName) throw (Core::Exception) { + boost::shared_lock<boost::shared_mutex> lock(mutex); + if(!backend) + throw Core::Exception(Core::Exception::NOT_IMPLEMENTED); + + backend->copy(type, name, newName); +} + +void StorageManager::rename(const std::string &type, const std::string &name, const std::string &newName) throw (Core::Exception) { + boost::shared_lock<boost::shared_mutex> lock(mutex); + if(!backend) + throw Core::Exception(Core::Exception::NOT_IMPLEMENTED); + + backend->rename(type, name, newName); +} + void StorageManager::remove(const std::string &type, const std::string &name) throw (Core::Exception) { boost::shared_lock<boost::shared_mutex> lock(mutex); if(!backend) diff --git a/src/Common/StorageManager.h b/src/Common/StorageManager.h index 594c294..d6cb5f5 100644 --- a/src/Common/StorageManager.h +++ b/src/Common/StorageManager.h @@ -59,6 +59,8 @@ class MAD_COMMON_EXPORT StorageManager { void store(const std::string &type, const std::string &name, const XmlData *data) throw (Core::Exception); boost::shared_ptr<XmlData> load(const std::string &type, const std::string &name) throw (Core::Exception); + void copy(const std::string &type, const std::string &name, const std::string &newName) throw (Core::Exception); + void rename(const std::string &type, const std::string &name, const std::string &newName) throw (Core::Exception); void remove(const std::string &type, const std::string &name) throw (Core::Exception); }; |