diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2016-01-01 17:19:28 -0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2016-01-01 17:26:09 -0800 |
commit | a611bb22f7dedd0377397c2e42a2bb9d6e1a4110 (patch) | |
tree | d28c28f48720a2e7f7eecad453300f085f6a2732 | |
parent | 87fc84a5eee6f6dbdfc2269b7ddf27324473d94e (diff) | |
download | subsurface-a611bb22f7dedd0377397c2e42a2bb9d6e1a4110.tar.gz |
Location service: restructure the way GpsSource is managed
It makes much more sense to have this as a private member of the class instead
of a static in one of the functions.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | subsurface-core/gpslocation.cpp | 25 | ||||
-rw-r--r-- | subsurface-core/gpslocation.h | 1 |
2 files changed, 14 insertions, 12 deletions
diff --git a/subsurface-core/gpslocation.cpp b/subsurface-core/gpslocation.cpp index fd6b43049..5790bc2d8 100644 --- a/subsurface-core/gpslocation.cpp +++ b/subsurface-core/gpslocation.cpp @@ -19,10 +19,15 @@ GpsLocation::GpsLocation(void (*showMsgCB)(const char *), QObject *parent) { Q_ASSERT_X(m_Instance == NULL, "GpsLocation", "GpsLocation recreated"); m_Instance = this; + m_GpsSource = 0; showMessageCB = showMsgCB; // create a QSettings object that's separate from the main application settings geoSettings = new QSettings(QSettings::NativeFormat, QSettings::UserScope, QString("org.subsurfacedivelog"), QString("subsurfacelocation"), this); +#ifdef SUBSURFACE_MOBILE + if (hasLocationsSource()) + status("Found GPS"); +#endif userAgent = getUserAgent(); } @@ -40,28 +45,24 @@ GpsLocation::~GpsLocation() QGeoPositionInfoSource *GpsLocation::getGpsSource() { - static QGeoPositionInfoSource *gpsSource = NULL; - static bool initGpsSource = false; - - if (!initGpsSource) { - gpsSource = QGeoPositionInfoSource::createDefaultSource(this); - initGpsSource = true; - if (gpsSource != 0) { + if (!m_GpsSource) { + m_GpsSource = QGeoPositionInfoSource::createDefaultSource(this); + if (m_GpsSource != 0) { #ifndef SUBSURFACE_MOBILE if (verbose) #endif status("created GPS source"); - QString msg = QString("have position source %1").arg(gpsSource->sourceName()); - connect(gpsSource, SIGNAL(positionUpdated(QGeoPositionInfo)), this, SLOT(newPosition(QGeoPositionInfo))); - connect(gpsSource, SIGNAL(updateTimeout()), this, SLOT(updateTimeout())); - gpsSource->setUpdateInterval(5 * 60 * 1000); // 5 minutes so the device doesn't drain the battery + QString msg = QString("have position source %1").arg(m_GpsSource->sourceName()); + connect(m_GpsSource, SIGNAL(positionUpdated(QGeoPositionInfo)), this, SLOT(newPosition(QGeoPositionInfo))); + connect(m_GpsSource, SIGNAL(updateTimeout()), this, SLOT(updateTimeout())); + m_GpsSource->setUpdateInterval(5 * 60 * 1000); // 5 minutes so the device doesn't drain the battery } else { #ifdef SUBSURFACE_MOBILE status("don't have GPS source"); #endif } } - return gpsSource; + return m_GpsSource; } bool GpsLocation::hasLocationsSource() diff --git a/subsurface-core/gpslocation.h b/subsurface-core/gpslocation.h index 8fb3bb947..c527fdd2a 100644 --- a/subsurface-core/gpslocation.h +++ b/subsurface-core/gpslocation.h @@ -24,6 +24,7 @@ public: private: QGeoPositionInfo lastPos; QGeoPositionInfoSource *getGpsSource(); + QGeoPositionInfoSource *m_GpsSource; void status(QString msg); QSettings *geoSettings; QNetworkReply *reply; |