8653cd8d34e9689ffe3c49d1c47192df6bc2f7df
[profile/ivi/qtxmlpatterns.git] / src / xmlpatterns / api / qnetworkaccessdelegator_p.h
1 /****************************************************************************
2 **
3 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/
5 **
6 ** This file is part of the QtXmlPatterns module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** GNU Lesser General Public License Usage
10 ** This file may be used under the terms of the GNU Lesser General Public
11 ** License version 2.1 as published by the Free Software Foundation and
12 ** appearing in the file LICENSE.LGPL included in the packaging of this
13 ** file. Please review the following information to ensure the GNU Lesser
14 ** General Public License version 2.1 requirements will be met:
15 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
16 **
17 ** In addition, as a special exception, Nokia gives you certain additional
18 ** rights. These rights are described in the Nokia Qt LGPL Exception
19 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
20 **
21 ** GNU General Public License Usage
22 ** Alternatively, this file may be used under the terms of the GNU General
23 ** Public License version 3.0 as published by the Free Software Foundation
24 ** and appearing in the file LICENSE.GPL included in the packaging of this
25 ** file. Please review the following information to ensure the GNU General
26 ** Public License version 3.0 requirements will be met:
27 ** http://www.gnu.org/copyleft/gpl.html.
28 **
29 ** Other Usage
30 ** Alternatively, this file may be used in accordance with the terms and
31 ** conditions contained in a signed written agreement between you and Nokia.
32 **
33 **
34 **
35 **
36 **
37 **
38 ** $QT_END_LICENSE$
39 **
40 ****************************************************************************/
41
42 //
43 //  W A R N I N G
44 //  -------------
45 //
46 // This file is not part of the Qt API.  It exists purely as an
47 // implementation detail.  This header file may change from version to
48 // version without notice, or even be removed.
49 //
50 // We mean it.
51
52 #ifndef QNETWORKACCESSDELEGATOR_P_H
53 #define QNETWORKACCESSDELEGATOR_P_H
54
55 #include <QObject>
56 #include <QPointer>
57 #include <QSharedData>
58
59 QT_BEGIN_HEADER
60 QT_BEGIN_NAMESPACE
61
62 class QNetworkAccessManager;
63 class QUrl;
64
65 namespace QPatternist
66 {
67     /**
68      * @short A value based class that hands out QNetworkAccessManager
69      * appropriately for variable bindings.
70      *
71      * NetworkAccessDelegator is an indirection mechanism which takes care of
72      * the fact that QIODevice instances are injected into the data model by
73      * having them represented using a URI. managerFor() returns appropriately
74      * the right network access manager depending on whether the URI refers to
75      * a variable, or to something else.
76      *
77      * The constructor take a pointer to two NetworkAccessDelegator instances.
78      * First is a generic one, the second is the one which handles variable
79      * bindings. managerFor() then returns the appropriate one depending on the
80      * URI.
81      *
82      * @since 4.5
83      * @see AccelTreeResourceLoader::load()
84      * @author Frans Englich <frans.englich@nokia.com>
85      */
86     class Q_AUTOTEST_EXPORT NetworkAccessDelegator : public QObject
87                                                    , public QSharedData
88     {
89     public:
90         typedef QExplicitlySharedDataPointer<NetworkAccessDelegator> Ptr;
91         NetworkAccessDelegator(QNetworkAccessManager *const genericManager,
92                                QNetworkAccessManager *const variableURIManager);
93
94         QNetworkAccessManager *managerFor(const QUrl &uri);
95
96         QPointer<QNetworkAccessManager> m_genericManager;
97         QPointer<QNetworkAccessManager> m_variableURIManager;
98     private:
99         Q_DISABLE_COPY(NetworkAccessDelegator)
100     };
101 }
102
103 QT_END_NAMESPACE
104 QT_END_HEADER
105
106 #endif