diff options
author | Nick Dedekind <nick.dedekind@canonical.com> | 2014-11-11 14:49:40 +0000 |
---|---|---|
committer | Nick Dedekind <nick.dedekind@canonical.com> | 2014-11-11 14:49:40 +0000 |
commit | 0ca199d4f212de9f998b4bc70616f9662134c9ef (patch) | |
tree | 4f64fef1ef9b06812727c84fdc6139f6fff6c562 | |
parent | f3a203bbe1350c5c69d19c1d4d82f984ad23e28d (diff) | |
download | qmenumodel-0ca199d4f212de9f998b4bc70616f9662134c9ef.tar.gz qmenumodel-0ca199d4f212de9f998b4bc70616f9662134c9ef.tar.bz2 qmenumodel-0ca199d4f212de9f998b4bc70616f9662134c9ef.zip |
Allow override of action state parser
-rw-r--r-- | libqmenumodel/src/qdbusactiongroup.cpp | 25 | ||||
-rw-r--r-- | libqmenumodel/src/qdbusactiongroup.h | 8 |
2 files changed, 31 insertions, 2 deletions
diff --git a/libqmenumodel/src/qdbusactiongroup.cpp b/libqmenumodel/src/qdbusactiongroup.cpp index 0ef907a..b29ece0 100644 --- a/libqmenumodel/src/qdbusactiongroup.cpp +++ b/libqmenumodel/src/qdbusactiongroup.cpp @@ -17,6 +17,7 @@ * Renato Araujo Oliveira Filho <renato@canonical.com> */ +#include "actionstateparser.h" #include "qdbusactiongroup.h" #include "qstateaction.h" #include "converter.h" @@ -58,7 +59,8 @@ extern "C" { QDBusActionGroup::QDBusActionGroup(QObject *parent) :QObject(parent), QDBusObject(this), - m_actionGroup(NULL) + m_actionGroup(NULL), + m_actionStateParser(new ActionStateParser(this)) { } @@ -89,7 +91,13 @@ QVariant QDBusActionGroup::actionState(const QString &name) { QVariant result; GVariant *state = g_action_group_get_action_state(m_actionGroup, name.toUtf8().data()); - result = Converter::toQVariant(state); + + if (m_actionStateParser != NULL) { + result = m_actionStateParser->toQVariant(state); + } else { + result = Converter::toQVariant(state); + } + if (state) { g_variant_unref(state); } @@ -190,6 +198,19 @@ void QDBusActionGroup::setActionGroup(GDBusActionGroup *ag) } } +ActionStateParser* QDBusActionGroup::actionStateParser() const +{ + return m_actionStateParser; +} + +void QDBusActionGroup::setActionStateParser(ActionStateParser* actionStateParser) +{ + if (m_actionStateParser != actionStateParser) { + m_actionStateParser = actionStateParser; + Q_EMIT actionStateParserChanged(actionStateParser); + } +} + /*! \internal */ void QDBusActionGroup::clear() { diff --git a/libqmenumodel/src/qdbusactiongroup.h b/libqmenumodel/src/qdbusactiongroup.h index f369a4e..2953e21 100644 --- a/libqmenumodel/src/qdbusactiongroup.h +++ b/libqmenumodel/src/qdbusactiongroup.h @@ -26,6 +26,7 @@ #include <QVariant> class QStateAction; +class ActionStateParser; typedef char gchar; typedef void* gpointer; @@ -40,6 +41,7 @@ class QDBusActionGroup : public QObject, public QDBusObject Q_PROPERTY(QString busName READ busName WRITE setBusName NOTIFY busNameChanged) Q_PROPERTY(QString objectPath READ objectPath WRITE setObjectPath NOTIFY objectPathChanged) Q_PROPERTY(int status READ status NOTIFY statusChanged) + Q_PROPERTY(ActionStateParser* actionStateParser READ actionStateParser WRITE setActionStateParser NOTIFY actionStateParserChanged) public: QDBusActionGroup(QObject *parent=0); @@ -52,6 +54,9 @@ public: Q_INVOKABLE QStateAction *action(const QString &name); Q_INVOKABLE QVariant actionState(const QString &name); + ActionStateParser* actionStateParser() const; + void setActionStateParser(ActionStateParser* actionStateParser); + Q_SIGNALS: void busTypeChanged(DBusEnums::BusType type); void busNameChanged(const QString &busNameChanged); @@ -60,6 +65,7 @@ Q_SIGNALS: void actionAppear(const QString &name); void actionVanish(const QString &name); void actionStateChanged(const QString &name, QVariant state); + void actionStateParserChanged(ActionStateParser* parser); public Q_SLOTS: void start(); @@ -77,6 +83,8 @@ private: int m_signalActionRemovedId; int m_signalStateChangedId; + ActionStateParser* m_actionStateParser; + // workaround to support int as busType void setIntBusType(int busType); |