Commit 47274448 authored by Don Gagne's avatar Don Gagne Committed by GitHub

Merge pull request #5569 from DonLakeFlyer/StableMerge

Stable merge
parents 11474181 d844cba7
...@@ -52,6 +52,7 @@ QGCCacheWorker::QGCCacheWorker() ...@@ -52,6 +52,7 @@ QGCCacheWorker::QGCCacheWorker()
, _defaultCount(0) , _defaultCount(0)
, _lastUpdate(0) , _lastUpdate(0)
, _updateTimeout(SHORT_TIMEOUT) , _updateTimeout(SHORT_TIMEOUT)
, _hostLookupID(0)
{ {
} }
...@@ -73,6 +74,9 @@ QGCCacheWorker::setDatabaseFile(const QString& path) ...@@ -73,6 +74,9 @@ QGCCacheWorker::setDatabaseFile(const QString& path)
void void
QGCCacheWorker::quit() QGCCacheWorker::quit()
{ {
if(_hostLookupID) {
QHostInfo::abortHostLookup(_hostLookupID);
}
_mutex.lock(); _mutex.lock();
while(_taskQueue.count()) { while(_taskQueue.count()) {
QGCMapTask* task = _taskQueue.dequeue(); QGCMapTask* task = _taskQueue.dequeue();
...@@ -1055,12 +1059,24 @@ QGCCacheWorker::_createDB(QSqlDatabase* db, bool createDefault) ...@@ -1055,12 +1059,24 @@ QGCCacheWorker::_createDB(QSqlDatabase* db, bool createDefault)
void void
QGCCacheWorker::_testInternet() QGCCacheWorker::_testInternet()
{ {
QTcpSocket socket; if(!_hostLookupID) {
socket.connectToHost("www.github.com", 80); _hostLookupID = QHostInfo::lookupHost("www.github.com", this, SLOT(_lookupReady(QHostInfo)));
if (socket.waitForConnected(2500)) { }
qCDebug(QGCTileCacheLog) << "Yes Internet Access"; }
emit internetStatus(true);
return; //-----------------------------------------------------------------------------
void
QGCCacheWorker::_lookupReady(QHostInfo info)
{
_hostLookupID = 0;
if(info.error() == QHostInfo::NoError && info.addresses().size()) {
QTcpSocket socket;
socket.connectToHost(info.addresses().first(), 80);
if (socket.waitForConnected(2000)) {
qCDebug(QGCTileCacheLog) << "Yes Internet Access";
emit internetStatus(true);
return;
}
} }
qWarning() << "No Internet Access"; qWarning() << "No Internet Access";
emit internetStatus(false); emit internetStatus(false);
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include <QWaitCondition> #include <QWaitCondition>
#include <QMutexLocker> #include <QMutexLocker>
#include <QtSql/QSqlDatabase> #include <QtSql/QSqlDatabase>
#include <QHostInfo>
#include "QGCLoggingCategory.h" #include "QGCLoggingCategory.h"
...@@ -49,6 +50,9 @@ public: ...@@ -49,6 +50,9 @@ public:
protected: protected:
void run (); void run ();
private slots:
void _lookupReady (QHostInfo info);
private: private:
void _saveTile (QGCMapTask* mtask); void _saveTile (QGCMapTask* mtask);
void _getTile (QGCMapTask* mtask); void _getTile (QGCMapTask* mtask);
...@@ -93,6 +97,7 @@ private: ...@@ -93,6 +97,7 @@ private:
quint32 _defaultCount; quint32 _defaultCount;
time_t _lastUpdate; time_t _lastUpdate;
int _updateTimeout; int _updateTimeout;
int _hostLookupID;
}; };
#endif // QGC_TILE_CACHE_WORKER_H #endif // QGC_TILE_CACHE_WORKER_H
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment