summaryrefslogtreecommitdiff
path: root/TelepathyQt/abstract-adaptor.cpp
blob: fa37a35719817a00af3b9ad39732282aaa7aae2a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/**
 * This file is part of TelepathyQt
 *
 * @copyright Copyright (C) 2012 Collabora Ltd. <http://www.collabora.co.uk/>
 * @copyright Copyright (C) 2012 Nokia Corporation
 * @license LGPL 2.1
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */

#include <TelepathyQt/AbstractAdaptor>

#include "TelepathyQt/_gen/abstract-adaptor.moc.hpp"

#include "TelepathyQt/debug-internal.h"

#include <QDBusConnection>

namespace Tp
{

struct TP_QT_NO_EXPORT AbstractAdaptor::Private
{
    Private(const QDBusConnection &dbusConnection, QObject *adaptee)
        : dbusConnection(dbusConnection),
          adaptee(adaptee)
    {
    }

    QDBusConnection dbusConnection;
    QObject *adaptee;
};

/**
 * \class AbstractAdaptor
 * \ingroup servicesideimpl
 * \headerfile TelepathyQt/abstract-adaptor.h <TelepathyQt/AbstractAdaptor>
 *
 * \brief Base class for all the low-level service-side adaptors.
 *
 * This class serves as the parent for all the generated low-level service-side
 * adaptors. Adaptors provide the interface of an object on the bus.
 *
 * The implementation of this interface should be provided in a special object
 * called the adaptee. The adaptee is meant to provide properties, signals
 * and slots that are connected automatically with the adaptor using Qt's meta-object
 * system.
 */

/**
 * Construct a new AbstractAdaptor that operates on the given
 * \a dbusConnection and redirects calls to the given \a adaptee.
 *
 * \param dbusConnection The D-Bus connection to use.
 * \param adaptee The class the provides the implementation of the calls.
 * \param parent The QObject parent of this adaptor.
 */
AbstractAdaptor::AbstractAdaptor(const QDBusConnection &dbusConnection,
        QObject *adaptee, QObject *parent)
    : QDBusAbstractAdaptor(parent),
      mPriv(new Private(dbusConnection, adaptee))
{
    setAutoRelaySignals(false);
}

/**
 * Class destructor.
 */
AbstractAdaptor::~AbstractAdaptor()
{
    delete mPriv;
}

/**
 * Return the D-Bus connection associated with this adaptor.
 *
 * \return The D-Bus connection associated with this adaptor.
 */
QDBusConnection AbstractAdaptor::dbusConnection() const
{
    return mPriv->dbusConnection;
}

/**
 * Return the adaptee object, i.e. the object that provides the implementation
 * of this adaptor.
 *
 * \return The adaptee object.
 */
QObject *AbstractAdaptor::adaptee() const
{
    return mPriv->adaptee;
}

}