From a611bb22f7dedd0377397c2e42a2bb9d6e1a4110 Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Fri, 1 Jan 2016 17:19:28 -0800 Subject: 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 --- subsurface-core/gpslocation.cpp | 25 +++++++++++++------------ subsurface-core/gpslocation.h | 1 + 2 files changed, 14 insertions(+), 12 deletions(-) (limited to 'subsurface-core') 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; -- cgit v1.2.3-70-g09d2