From 0b233494a69b5e9cd86e91c60016a294e6c9ef50 Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Mon, 1 Feb 2016 13:12:37 +0100 Subject: Fixed modifications --- common/domain/applicationdomaintype.cpp | 9 +++++++-- common/domain/applicationdomaintype.h | 21 +++++++++++++++++---- common/domain/event.cpp | 2 ++ 3 files changed, 26 insertions(+), 6 deletions(-) (limited to 'common/domain') diff --git a/common/domain/applicationdomaintype.cpp b/common/domain/applicationdomaintype.cpp index fccf082..1649cb4 100644 --- a/common/domain/applicationdomaintype.cpp +++ b/common/domain/applicationdomaintype.cpp @@ -76,13 +76,18 @@ QVariant ApplicationDomainType::getProperty(const QByteArray &key) const void ApplicationDomainType::setProperty(const QByteArray &key, const QVariant &value) { Q_ASSERT(mAdaptor); - mChangeSet.insert(key, value); + mChangeSet.insert(key); mAdaptor->setProperty(key, value); } +void ApplicationDomainType::setChangedProperties(const QSet &changeset) +{ + mChangeSet = changeset; +} + QByteArrayList ApplicationDomainType::changedProperties() const { - return mChangeSet.keys(); + return mChangeSet.toList(); } qint64 ApplicationDomainType::revision() const diff --git a/common/domain/applicationdomaintype.h b/common/domain/applicationdomaintype.h index ca1ec1b..ce35af0 100644 --- a/common/domain/applicationdomaintype.h +++ b/common/domain/applicationdomaintype.h @@ -23,6 +23,7 @@ #include #include #include +#include #include "bufferadaptor.h" namespace Sink { @@ -56,16 +57,18 @@ public: virtual ~ApplicationDomainType(); - virtual QVariant getProperty(const QByteArray &key) const; - virtual void setProperty(const QByteArray &key, const QVariant &value); - virtual QByteArrayList changedProperties() const; + QVariant getProperty(const QByteArray &key) const;; + void setProperty(const QByteArray &key, const QVariant &value); + void setChangedProperties(const QSet &changeset); + QByteArrayList changedProperties() const; qint64 revision() const; QByteArray resourceInstanceIdentifier() const; QByteArray identifier() const; private: + friend QDebug operator<<(QDebug, const ApplicationDomainType &); QSharedPointer mAdaptor; - QHash mChangeSet; + QSet mChangeSet; /* * Each domain object needs to store the resource, identifier, revision triple so we can link back to the storage location. */ @@ -83,6 +86,16 @@ inline bool operator==(const ApplicationDomainType& lhs, const ApplicationDomain && lhs.resourceInstanceIdentifier() == rhs.resourceInstanceIdentifier(); } +inline QDebug operator<< (QDebug d, const ApplicationDomainType &type) +{ + d << "ApplicationDomainType(\n"; + for (const auto &property : type.mAdaptor->availableProperties()) { + d << " " << property << "\t" << type.getProperty(property) << "\n"; + } + d << ")"; + return d; +} + struct SINKCOMMON_EXPORT Entity : public ApplicationDomainType { typedef QSharedPointer Ptr; using ApplicationDomainType::ApplicationDomainType; diff --git a/common/domain/event.cpp b/common/domain/event.cpp index 9f81eb8..4210125 100644 --- a/common/domain/event.cpp +++ b/common/domain/event.cpp @@ -69,6 +69,7 @@ QSharedPointer::Buffer> > TypeImple { auto propertyMapper = QSharedPointer >::create(); propertyMapper->addMapping("summary", &Buffer::summary); + propertyMapper->addMapping("description", &Buffer::description); propertyMapper->addMapping("uid", &Buffer::uid); propertyMapper->addMapping("attachment", &Buffer::attachment); return propertyMapper; @@ -78,6 +79,7 @@ QSharedPointer::BufferBuilder> > T { auto propertyMapper = QSharedPointer >::create(); propertyMapper->addMapping("summary", &BufferBuilder::add_summary); + propertyMapper->addMapping("description", &BufferBuilder::add_description); propertyMapper->addMapping("uid", &BufferBuilder::add_uid); propertyMapper->addMapping("attachment", &BufferBuilder::add_attachment); return propertyMapper; -- cgit v1.2.3