X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fcoreinfo.h;h=17db3cb129efba52fe896506e46cdcdb470b0358;hp=291f5a1e5b6eef62d524dc09aed52e940e60fec4;hb=3a3e844f9fcfd12235a0086af75ecd503b621ef4;hpb=68878dc8366f2f4a0afe132847aad9a51a80cdbf diff --git a/src/common/coreinfo.h b/src/common/coreinfo.h index 291f5a1e..17db3cb1 100644 --- a/src/common/coreinfo.h +++ b/src/common/coreinfo.h @@ -18,28 +18,44 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef COREINFO_H -#define COREINFO_H +#pragma once + +#include "common-export.h" #include "syncableobject.h" /* - * gather various informations about the core. + * gather various information about the core. */ -class CoreInfo : public SyncableObject +class COMMON_EXPORT CoreInfo : public SyncableObject { Q_OBJECT + SYNCABLE_OBJECT - Q_PROPERTY(QVariantMap coreData READ coreData WRITE setCoreData STORED false) + Q_PROPERTY(QVariantMap coreData READ coreData WRITE setCoreData) -public : - CoreInfo(QObject *parent = 0) : SyncableObject(parent) {} +public: + explicit CoreInfo(QObject *parent = nullptr); + inline QVariant &at(const QString &key) { return _coreData[key]; } -public slots: - virtual inline QVariantMap coreData() const { return QVariantMap(); } - virtual inline void setCoreData(const QVariantMap &) {} -}; + void setConnectedClientData(int, QVariantList); + + /** + * Reset the core info state, clearing anything saved + */ + void reset(); +signals: + /** + * Signals that core information has changed + */ + void coreDataChanged(QVariantMap); -#endif //COREINFO_H +public slots: + QVariantMap coreData() const; + void setCoreData(const QVariantMap &); + +private: + QVariantMap _coreData; +};