From b29a17465d1e52bd7dd5c57f08e7af53e915eee6 Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Thu, 23 Jun 2016 17:05:47 +0200 Subject: Share special purpose preprocessor implementation. --- common/specialpurposepreprocessor.cpp | 88 +++++++++++++++++++++++++++++++++++ 1 file changed, 88 insertions(+) create mode 100644 common/specialpurposepreprocessor.cpp (limited to 'common/specialpurposepreprocessor.cpp') diff --git a/common/specialpurposepreprocessor.cpp b/common/specialpurposepreprocessor.cpp new file mode 100644 index 0000000..2892105 --- /dev/null +++ b/common/specialpurposepreprocessor.cpp @@ -0,0 +1,88 @@ +#include "specialpurposepreprocessor.h" +#include "entityreader.h" +#include "query.h" +#include "applicationdomaintype.h" + +using namespace Sink; + +static QHash specialPurposeFolders() +{ + QHash hash; + //FIXME localize + hash.insert("drafts", "Drafts"); + hash.insert("trash", "Trash"); + return hash; +} + +static QHash specialPurposeNames() +{ + QHash hash; + for (const auto &value : specialPurposeFolders().values()) { + hash.insert(value.toLower(), specialPurposeFolders().key(value)); + } + return hash; +} + +//specialpurpose, name +static QHash sSpecialPurposeFolders = specialPurposeFolders(); +//Lowercase-name, specialpurpose +static QHash sSpecialPurposeNames = specialPurposeNames(); + +namespace SpecialPurpose { +bool isSpecialPurposeFolderName(const QString &name) +{ + return sSpecialPurposeNames.contains(name.toLower()); +} + +QByteArray getSpecialPurposeType(const QString &name) +{ + return sSpecialPurposeNames.value(name.toLower()); +} +} + +SpecialPurposeProcessor::SpecialPurposeProcessor(const QByteArray &resourceType, const QByteArray &resourceInstanceIdentifier) : mResourceType(resourceType), mResourceInstanceIdentifier(resourceInstanceIdentifier) {} + +QByteArray SpecialPurposeProcessor::ensureFolder(Sink::Storage::Transaction &transaction, const QByteArray &specialPurpose) +{ + if (!mSpecialPurposeFolders.contains(specialPurpose)) { + //Try to find an existing drafts folder + Sink::EntityReader reader(mResourceType, mResourceInstanceIdentifier, transaction); + reader.query(Sink::Query().filter(Query::Comparator(specialPurpose, Query::Comparator::Contains)), + [this, specialPurpose](const ApplicationDomain::Folder &f) -> bool{ + mSpecialPurposeFolders.insert(specialPurpose, f.identifier()); + return false; + }); + if (!mSpecialPurposeFolders.contains(specialPurpose)) { + Trace() << "Failed to find a drafts folder, creating a new one"; + auto folder = ApplicationDomain::Folder::create(mResourceInstanceIdentifier); + folder.setSpecialPurpose(QByteArrayList() << specialPurpose); + folder.setName(sSpecialPurposeFolders.value(specialPurpose)); + folder.setIcon("folder"); + //This processes the pipeline synchronously + createEntity(folder); + mSpecialPurposeFolders.insert(specialPurpose, folder.identifier()); + } + } + return mSpecialPurposeFolders.value(specialPurpose); +} + +void SpecialPurposeProcessor::moveToFolder(Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) +{ + if (newEntity.getProperty("trash").toBool()) { + newEntity.setProperty("folder", ensureFolder(transaction, "trash")); + return; + } + if (newEntity.getProperty("draft").toBool()) { + newEntity.setProperty("folder", ensureFolder(transaction, "drafts")); + } +} + +void SpecialPurposeProcessor::newEntity(const QByteArray &uid, qint64 revision, Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) +{ + moveToFolder(newEntity, transaction); +} + +void SpecialPurposeProcessor::modifiedEntity(const QByteArray &uid, qint64 revision, const Sink::ApplicationDomain::BufferAdaptor &oldEntity, Sink::ApplicationDomain::BufferAdaptor &newEntity, Sink::Storage::Transaction &transaction) +{ + moveToFolder(newEntity, transaction); +} -- cgit v1.2.3