summaryrefslogtreecommitdiffstats
path: root/src/Common
diff options
context:
space:
mode:
authorMatthias Schiffer <matthias@gamezock.de>2009-09-20 16:03:35 +0200
committerMatthias Schiffer <matthias@gamezock.de>2009-09-20 16:03:35 +0200
commitd0cc9153d53dd4bc8dadf8bbcbe4ac72dfbbb61e (patch)
tree37d55a434528ff8d53e46393eff7ebd5529b52aa /src/Common
parent78db15a780cc5389fc6e01d500d5c91bdd8bc422 (diff)
downloadmad-d0cc9153d53dd4bc8dadf8bbcbe4ac72dfbbb61e.tar
mad-d0cc9153d53dd4bc8dadf8bbcbe4ac72dfbbb61e.zip
Extended StorageManager to provide copy and remove methods.
Diffstat (limited to 'src/Common')
-rw-r--r--src/Common/StorageBackend.h2
-rw-r--r--src/Common/StorageManager.cpp16
-rw-r--r--src/Common/StorageManager.h2
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);
};