Skip to content

Commit

Permalink
Don't use Qt private API
Browse files Browse the repository at this point in the history
Closes: #4
  • Loading branch information
plfiorini committed May 28, 2017
1 parent e93c1d5 commit e0ebda6
Show file tree
Hide file tree
Showing 7 changed files with 29 additions and 20 deletions.
4 changes: 2 additions & 2 deletions src/accountsservice/accountsservice.qbs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ LiriModule {
targetName: "Qt5AccountsService"
version: "0.0.0"

Depends { name: "Qt"; submodules: ["core", "core-private", "dbus", "gui"] }
Depends { name: "Qt"; submodules: ["core", "dbus", "gui"] }

cpp.defines: base.concat([
"QTACCOUNTSSERVICE_VERSION=" + project.version,
Expand Down Expand Up @@ -58,7 +58,7 @@ LiriModule {

Export {
Depends { name: "cpp" }
Depends { name: "Qt"; submodules: ["core", "core-private", "dbus", "gui"] }
Depends { name: "Qt"; submodules: ["core", "dbus", "gui"] }

cpp.includePaths: product.generatedHeadersDir
}
Expand Down
12 changes: 7 additions & 5 deletions src/accountsservice/useraccount.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,14 @@ namespace QtAccountsService {
* UserAccountPrivate
*/

UserAccountPrivate::UserAccountPrivate()
: QObjectPrivate()
, bus(QDBusConnection::systemBus())
UserAccountPrivate::UserAccountPrivate(UserAccount *q)
: bus(QDBusConnection::systemBus())
, user(nullptr)
, accountType(UserAccount::StandardAccountType)
, locked(false)
, automaticLogin(false)
, passwordMode(UserAccount::NonePasswordMode)
, q_ptr(q)
{
}

Expand Down Expand Up @@ -103,7 +103,8 @@ void UserAccountPrivate::emitSignals()
Constructs a UserAccount object for the currently logged in user.
*/
UserAccount::UserAccount(const QDBusConnection &bus, QObject *parent)
: QObject(*new UserAccountPrivate(), parent)
: QObject(parent)
, d_ptr(new UserAccountPrivate(this))
{
Q_D(UserAccount);

Expand All @@ -120,7 +121,8 @@ UserAccount::UserAccount(const QDBusConnection &bus, QObject *parent)
\param objectPath Accounts Service object path for the user account.
*/
UserAccount::UserAccount(const QString &objectPath, const QDBusConnection &bus, QObject *parent)
: QObject(*new UserAccountPrivate(), parent)
: QObject(parent)
, d_ptr(new UserAccountPrivate(this))
{
Q_D(UserAccount);
d->initialize(bus, objectPath);
Expand Down
2 changes: 2 additions & 0 deletions src/accountsservice/useraccount.h
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,8 @@ class Q_ACCOUNTS_SERVICE_EXPORT UserAccount : public QObject
friend class AccountsManager;
friend class AccountsManagerPrivate;

UserAccountPrivate *const d_ptr;

UserAccount(const QString &objectPath,
const QDBusConnection &bus = QDBusConnection::systemBus(),
QObject *parent = nullptr);
Expand Down
9 changes: 5 additions & 4 deletions src/accountsservice/useraccount_p.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,6 @@
#ifndef QTACCOUNTSSERVICE_USERACCOUNT_P_H
#define QTACCOUNTSSERVICE_USERACCOUNT_P_H

#include <QtCore/private/qobject_p.h>

#include "useraccount.h"
#include "user_interface.h"

Expand All @@ -42,12 +40,12 @@

namespace QtAccountsService {

class UserAccountPrivate : public QObjectPrivate
class UserAccountPrivate
{
Q_DECLARE_PUBLIC(UserAccount)
Q_DISABLE_COPY(UserAccountPrivate)
public:
explicit UserAccountPrivate();
explicit UserAccountPrivate(UserAccount *q);

void initialize(const QDBusConnection &connection, const QString &objectPath);
void emitSignals();
Expand All @@ -68,6 +66,9 @@ class UserAccountPrivate : public QObjectPrivate
QString language;
QString location;
QString xsession;

protected:
UserAccount *q_ptr;
};

}
Expand Down
9 changes: 5 additions & 4 deletions src/accountsservice/usersmodel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,10 @@ namespace QtAccountsService {
* UsersModelPrivate
*/

UsersModelPrivate::UsersModelPrivate()
: QAbstractItemModelPrivate()
UsersModelPrivate::UsersModelPrivate(UsersModel *q)
: manager(new AccountsManager())
, q_ptr(q)
{
manager = new AccountsManager();
}

UsersModelPrivate::~UsersModelPrivate()
Expand Down Expand Up @@ -79,7 +79,8 @@ void UsersModelPrivate::_q_userDeleted(qlonglong uid)
*/

UsersModel::UsersModel(QObject *parent)
: QAbstractListModel(*new UsersModelPrivate(), parent)
: QAbstractListModel(parent)
, d_ptr(new UsersModelPrivate(this))
{
Q_D(UsersModel);

Expand Down
4 changes: 3 additions & 1 deletion src/accountsservice/usersmodel.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ class UsersModelPrivate;
class Q_ACCOUNTS_SERVICE_EXPORT UsersModel : public QAbstractListModel
{
Q_OBJECT
Q_DECLARE_PRIVATE(UsersModel)
public:
enum Roles {
UserAccountRole = Qt::UserRole + 1,
Expand Down Expand Up @@ -74,7 +75,8 @@ class Q_ACCOUNTS_SERVICE_EXPORT UsersModel : public QAbstractListModel
UserAccount *userAccount(const QModelIndex &index) const;

private:
Q_DECLARE_PRIVATE(UsersModel)
UsersModelPrivate *const d_ptr;

Q_PRIVATE_SLOT(d_func(), void _q_userAdded(UserAccount *account))
Q_PRIVATE_SLOT(d_func(), void _q_userDeleted(qlonglong uid))
};
Expand Down
9 changes: 5 additions & 4 deletions src/accountsservice/usersmodel_p.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,6 @@
#include <Qt5AccountsService/AccountsManager>
#include <Qt5AccountsService/UserAccount>

#include <QtCore/private/qabstractitemmodel_p.h>

//
// W A R N I N G
// -------------
Expand All @@ -44,11 +42,11 @@ namespace QtAccountsService {

class UsersModel;

class UsersModelPrivate : public QAbstractItemModelPrivate
class UsersModelPrivate
{
Q_DECLARE_PUBLIC(UsersModel)
public:
UsersModelPrivate();
UsersModelPrivate(UsersModel *q);
~UsersModelPrivate();

void populate();
Expand All @@ -59,6 +57,9 @@ class UsersModelPrivate : public QAbstractItemModelPrivate
public Q_SLOTS:
void _q_userAdded(UserAccount *account);
void _q_userDeleted(qlonglong uid);

protected:
UsersModel *q_ptr;
};

}
Expand Down

0 comments on commit e0ebda6

Please sign in to comment.