kdeconnect-kde/plasmoid/declarativeplugin/objectfactory.h
Jean Vincent 72535ecf48 Make member variable names, & placement and * placement more coherent
Summary:
Change all member variables to the form m_fooBar because it is the preferred form in Qt (it was half and half between this and mFooBar, and a minority didn't have anything).
Place all references and pointers on the side of the type since it is the majority.

Basically:
 - mFoo -> m_foo
 - foo -> m_foo (if it is a member variable)
 - Type &ref -> Type& ref
 - Type *ptr -> Type* ptr

Reviewers: #kde_connect, nicolasfella, albertvaka

Reviewed By: #kde_connect, nicolasfella, albertvaka

Subscribers: albertvaka, #kde_connect

Tags: #kde_connect

Differential Revision: https://phabricator.kde.org/D7312
2017-09-03 21:45:08 +02:00

46 lines
1.2 KiB
C++

#ifndef QOBJECT_FACTORY_H
#define QOBJECT_FACTORY_H
#include <QObject>
#include <QVariant>
//Wraps a factory function with QObject class to be exposed to qml context as named factory
class ObjectFactory : public QObject
{
Q_OBJECT
typedef QObject* (*Func0)();
typedef QObject* (*Func1)(const QVariant&);
typedef QObject* (*Func2)(const QVariant&, const QVariant&);
public:
ObjectFactory(QObject* parent, Func0 f0) : QObject(parent), m_f0(f0), m_f1(nullptr), m_f2(nullptr) {}
ObjectFactory(QObject* parent, Func1 f1) : QObject(parent), m_f0(nullptr), m_f1(f1), m_f2(nullptr) {}
ObjectFactory(QObject* parent, Func2 f2) : QObject(parent), m_f0(nullptr), m_f1(nullptr), m_f2(f2) {}
~ObjectFactory() override = default;
Q_INVOKABLE QObject* create() {
if (m_f0) return m_f0();
return nullptr;
}
Q_INVOKABLE QObject* create(const QVariant& arg1) {
if (m_f1) return m_f1(arg1);
return nullptr;
}
Q_INVOKABLE QObject* create(const QVariant& arg1, const QVariant& arg2) {
if (m_f2) return m_f2(arg1, arg2);
return nullptr;
}
private:
Func0 m_f0;
Func1 m_f1;
Func2 m_f2;
};
#endif