diff options
Diffstat (limited to 'interfaces')
-rw-r--r-- | interfaces/include/appframework.hpp | 44 | ||||
-rw-r--r-- | interfaces/src/appframework.cpp | 153 |
2 files changed, 155 insertions, 42 deletions
diff --git a/interfaces/include/appframework.hpp b/interfaces/include/appframework.hpp index d4abefb..29c9b2b 100644 --- a/interfaces/include/appframework.hpp +++ b/interfaces/include/appframework.hpp @@ -17,31 +17,49 @@ #ifndef APPFRAMEWORK_HPP #define APPFRAMEWORK_HPP -#include <QtDBus> +#include <QtCore/QSharedDataPointer> +#include <QtDBus/QDBusArgument> class AppInfo { + Q_GADGET + Q_PROPERTY(QString id READ id) + Q_PROPERTY(QString version READ version) + Q_PROPERTY(int width READ width) + Q_PROPERTY(int height READ height) + Q_PROPERTY(QString name READ name) + Q_PROPERTY(QString description READ description) + Q_PROPERTY(QString shortname READ shortname) + Q_PROPERTY(QString author READ author) + Q_PROPERTY(QString iconPath READ iconPath) public: AppInfo(); + AppInfo(const AppInfo &other); virtual ~AppInfo(); + AppInfo &operator =(const AppInfo &other); + void swap(AppInfo &other) { qSwap(d, other.d); } - QString id; - QString version; - int width; - int height; - QString name; - QString description; - QString shortname; - QString author; - QString iconPath; + QString id() const; + QString version() const; + int width() const; + int height() const; + QString name() const; + QString description() const; + QString shortname() const; + QString author() const; + QString iconPath() const; void read(const QJsonObject &json); - friend QDBusArgument &operator <<(QDBusArgument &argument, const AppInfo &mAppInfo); - friend const QDBusArgument &operator >>(const QDBusArgument &argument, AppInfo &mAppInfo); -}; + friend QDBusArgument &operator <<(QDBusArgument &argument, const AppInfo &appInfo); + friend const QDBusArgument &operator >>(const QDBusArgument &argument, AppInfo &appInfo); +private: + class Private; + QSharedDataPointer<Private> d; +}; +Q_DECLARE_SHARED(AppInfo) Q_DECLARE_METATYPE(AppInfo) Q_DECLARE_METATYPE(QList<AppInfo>) diff --git a/interfaces/src/appframework.cpp b/interfaces/src/appframework.cpp index 15c57c0..ced809e 100644 --- a/interfaces/src/appframework.cpp +++ b/interfaces/src/appframework.cpp @@ -16,8 +16,52 @@ #include "include/appframework.hpp" +#include <QtCore/QJsonObject> + +class AppInfo::Private : public QSharedData +{ +public: + Private(); + Private(const Private &other); + + QString id; + QString version; + int width; + int height; + QString name; + QString description; + QString shortname; + QString author; + QString iconPath; +}; + +AppInfo::Private::Private() + : width(-1) + , height(-1) +{ +} + +AppInfo::Private::Private(const Private &other) + : QSharedData(other) + , id(other.id) + , version(other.version) + , width(other.width) + , height(other.height) + , name(other.name) + , description(other.description) + , shortname(other.shortname) + , author(other.author) + , iconPath(other.iconPath) +{ +} AppInfo::AppInfo() + : d(new Private) +{ +} + +AppInfo::AppInfo(const AppInfo &other) + : d(other.d) { } @@ -25,48 +69,99 @@ AppInfo::~AppInfo() { } +AppInfo &AppInfo::operator =(const AppInfo &other) +{ + d = other.d; + return *this; +} + +QString AppInfo::id() const +{ + return d->id; +} + +QString AppInfo::version() const +{ + return d->version; +} + +int AppInfo::width() const +{ + return d->width; +} + +int AppInfo::height() const +{ + return d->height; +} + +QString AppInfo::name() const +{ + return d->name; +} + +QString AppInfo::description() const +{ + return d->description; +} + +QString AppInfo::shortname() const +{ + return d->shortname; +} + +QString AppInfo::author() const +{ + return d->author; +} + +QString AppInfo::iconPath() const +{ + return d->iconPath; +} + void AppInfo::read(const QJsonObject &json) { - id = json["id"].toString(); - version = json["version"].toString(); - width = json["width"].toInt(); - height = json["height"].toInt(); - name = json["name"].toString(); - description = json["description"].toString(); - shortname = json["shortname"].toString(); - author = json["author"].toString(); - iconPath = json["iconPath"].toString(); + d->id = json["id"].toString(); + d->version = json["version"].toString(); + d->width = json["width"].toInt(); + d->height = json["height"].toInt(); + d->name = json["name"].toString(); + d->description = json["description"].toString(); + d->shortname = json["shortname"].toString(); + d->author = json["author"].toString(); + d->iconPath = json["iconPath"].toString(); } -QDBusArgument &operator <<(QDBusArgument &argument, const AppInfo &mAppInfo) +QDBusArgument &operator <<(QDBusArgument &argument, const AppInfo &appInfo) { argument.beginStructure(); - argument << mAppInfo.id; - argument << mAppInfo.version; - argument << mAppInfo.width; - argument << mAppInfo.height; - argument << mAppInfo.name; - argument << mAppInfo.description; - argument << mAppInfo.shortname; - argument << mAppInfo.author; - argument << mAppInfo.iconPath; + argument << appInfo.d->id; + argument << appInfo.d->version; + argument << appInfo.d->width; + argument << appInfo.d->height; + argument << appInfo.d->name; + argument << appInfo.d->description; + argument << appInfo.d->shortname; + argument << appInfo.d->author; + argument << appInfo.d->iconPath; argument.endStructure(); return argument; } -const QDBusArgument &operator >>(const QDBusArgument &argument, AppInfo &mAppInfo) +const QDBusArgument &operator >>(const QDBusArgument &argument, AppInfo &appInfo) { argument.beginStructure(); - argument >> mAppInfo.id; - argument >> mAppInfo.version; - argument >> mAppInfo.width; - argument >> mAppInfo.height; - argument >> mAppInfo.name; - argument >> mAppInfo.description; - argument >> mAppInfo.shortname; - argument >> mAppInfo.author; - argument >> mAppInfo.iconPath; + argument >> appInfo.d->id; + argument >> appInfo.d->version; + argument >> appInfo.d->width; + argument >> appInfo.d->height; + argument >> appInfo.d->name; + argument >> appInfo.d->description; + argument >> appInfo.d->shortname; + argument >> appInfo.d->author; + argument >> appInfo.d->iconPath; argument.endStructure(); return argument; } |