summaryrefslogtreecommitdiffstats
path: root/src/location/qgeopositioninfosourcefactory.cpp
blob: 1b53ed48136453546d763b0c175087a1f8892fc2 (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
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
/****************************************************************************
**
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** This file is part of the Qt Mobility Components.
**
** $QT_BEGIN_LICENSE:LGPL$
** No Commercial Usage
** This file contains pre-release code and may not be distributed.
** You may use this file in accordance with the terms and conditions
** contained in the Technology Preview License Agreement accompanying
** this package.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file.  Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights.  These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** If you have questions regarding the use of this file, please contact
** Nokia at qt-info@nokia.com.
**
**
**
**
**
**
**
**
** $QT_END_LICENSE$
**
****************************************************************************/

#include "qgeopositioninfosourcefactory.h"

QTM_BEGIN_NAMESPACE

/*!
  \class QGeoPositionInfoSourceFactory

  \brief The QGeoPositionInfoSourceFactory class is a factory class used
  as the plugin interface for external providers of positioning data.

  \inmodule QtLocation

  \ingroup location

  Implementers must provide a unique combination of sourceName() and
  sourceVersion() per plugin.

  The other functions must be overridden by all plugins, other than
  sourcePriority() which defaults to returning 0. Higher values of
  priority will be preferred to lower ones.

  \section1 Default plugins

  Normally, the platform default position source will always overrule any
  plugin-based position source during a call to createDefaultSource().
  However, a limited measure is available where needed to change this behaviour,
  using a system-wide configuration file.

  The configuration file is in the system's default QSettings format, under
  \c Nokia/QtLocationPosAndSat (for example, on most Linux variants this is
  \c /etc/xdg/Nokia/QtLocationPosAndSat.conf). To set a default plugin source,
  set the value \c position.plugin.operator.whitelist to a string of the format
  \c "name,filename,hash,size" where \a name is the same as returned by the
  plugin's \c sourceName() function, \a size is the size of the shared library
  and \a hash is the library's SHA1 hash in hex format.
  */

/*!
  \fn QGeoPositionInfoSource *QGeoPositionInfoSourceFactory::positionInfoSource(QObject *parent)

  Returns a new QGeoPositionInfoSource associated with this plugin
  with parent \a parent . Can also return 0, in which case the factory
  with the next highest priority will be used instead.
  */

/*!
  \fn QGeoSatelliteInfoSource *QGeoPositionInfoSourceFactory::satelliteInfoSource(QObject *parent)

  Returns a new QGeoSatelliteInfoSource associated with this plugin
  with parent \a parent. Can also return 0, in which case the factory
  with the next highest priority will be used instead.
  */

/*!
  \fn QString QGeoPositionInfoSourceFactory::sourceName() const

  Returns the string used to identify the position provider behind this
  implementation.

  The combination of sourceName() and sourceVersion() should be unique
  amongst the plugins.
  */

/*!
  \fn int QGeoPositionInfoSourceFactory::sourceVersion() const

  Returns the version of the plugin.

  The combination of sourceName() and sourceVersion() should be unique
  amongst the plugins.
  */

/*!
  Returns the priority of this factory in the list of available
  factories. Factories with higher values of priority will be preferred
  to those with lower values.
  */
int QGeoPositionInfoSourceFactory::sourcePriority() const
{
    return 0;
}

/*!
    Destroys the position info source factory.
*/
QGeoPositionInfoSourceFactory::~QGeoPositionInfoSourceFactory()
{}

QTM_END_NAMESPACE