summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--desktop-widgets/mainwindow.cpp4
-rw-r--r--desktop-widgets/subsurfacewebservices.cpp114
2 files changed, 3 insertions, 115 deletions
diff --git a/desktop-widgets/mainwindow.cpp b/desktop-widgets/mainwindow.cpp
index bbccdc064..ad8b39dd7 100644
--- a/desktop-widgets/mainwindow.cpp
+++ b/desktop-widgets/mainwindow.cpp
@@ -111,7 +111,8 @@ MainWindow::MainWindow() : QMainWindow(),
actionPreviousDive(0),
helpView(0),
state(VIEWALL),
- survey(0)
+ survey(0),
+ locationProvider(new GpsLocation(nullptr, this))
{
Q_ASSERT_X(m_Instance == NULL, "MainWindow", "MainWindow recreated!");
m_Instance = this;
@@ -826,7 +827,6 @@ void MainWindow::on_actionDownloadDC_triggered()
void MainWindow::on_actionDownloadWeb_triggered()
{
SubsurfaceWebServices dlg(this);
-
dlg.exec();
}
diff --git a/desktop-widgets/subsurfacewebservices.cpp b/desktop-widgets/subsurfacewebservices.cpp
index b11a910f1..6e4f191d6 100644
--- a/desktop-widgets/subsurfacewebservices.cpp
+++ b/desktop-widgets/subsurfacewebservices.cpp
@@ -35,118 +35,6 @@
struct dive_table gps_location_table;
-// we don't overwrite any existing GPS info in the dive
-// so get the dive site and if there is none or there is one without GPS fix, add it
-static void copy_gps_location(struct dive *from, struct dive *to)
-{
- struct dive_site *ds = get_dive_site_for_dive(to);
- if (!ds || !dive_site_has_gps_location(ds)) {
- struct dive_site *gds = get_dive_site_for_dive(from);
- if (!ds) {
- // simply link to the one created for the fake dive
- to->dive_site_uuid = gds->uuid;
- } else {
- ds->latitude = gds->latitude;
- ds->longitude = gds->longitude;
- if (same_string(ds->name, ""))
- ds->name = copy_string(gds->name);
- }
- }
-}
-
-#define SAME_GROUP 6 * 3600 // six hours
-#define SET_LOCATION(_dive, _gpsfix, _mark) \
-{ \
- copy_gps_location(_gpsfix, _dive); \
- changed ++; \
- tracer = _mark; \
-}
-
-//TODO: C Code. static functions are not good if we plan to have a test for them.
-static bool merge_locations_into_dives(void)
-{
- int i, j, tracer=0, changed=0;
- struct dive *gpsfix, *nextgpsfix, *dive;
-
- sort_table(&gps_location_table);
-
- for_each_dive (i, dive) {
- if (!dive_has_gps_location(dive)) {
- for (j = tracer; (gpsfix = get_dive_from_table(j, &gps_location_table)) !=NULL; j++) {
- if (time_during_dive_with_offset(dive, gpsfix->when, SAME_GROUP)) {
- if (verbose)
- qDebug() << "processing gpsfix @" << get_dive_date_string(gpsfix->when) <<
- "which is withing six hours of dive from" <<
- get_dive_date_string(dive->when) << "until" <<
- get_dive_date_string(dive_endtime(dive));
- /*
- * If position is fixed during dive. This is the good one.
- * Asign and mark position, and end gps_location loop
- */
- if (time_during_dive_with_offset(dive, gpsfix->when, 0)) {
- if (verbose)
- qDebug() << "gpsfix is during the dive, pick that one";
- SET_LOCATION(dive, gpsfix, j);
- break;
- } else {
- /*
- * If it is not, check if there are more position fixes in SAME_GROUP range
- */
- if ((nextgpsfix = get_dive_from_table(j + 1, &gps_location_table)) &&
- time_during_dive_with_offset(dive, nextgpsfix->when, SAME_GROUP)) {
- if (verbose)
- qDebug() << "look at the next gps fix @" << get_dive_date_string(nextgpsfix->when);
- /* we know the gps fixes are sorted; if they are both before the dive, ignore the first,
- * if theay are both after the dive, take the first,
- * if the first is before and the second is after, take the closer one */
- if (nextgpsfix->when < dive->when) {
- if (verbose)
- qDebug() << "which is closer to the start of the dive, do continue with that";
- continue;
- } else if (gpsfix->when > dive_endtime(dive)) {
- if (verbose)
- qDebug() << "which is even later after the end of the dive, so pick the previous one";
- SET_LOCATION(dive, gpsfix, j);
- break;
- } else {
- /* ok, gpsfix is before, nextgpsfix is after */
- if (dive->when - gpsfix->when <= nextgpsfix->when - dive_endtime(dive)) {
- if (verbose)
- qDebug() << "pick the one before as it's closer to the start";
- SET_LOCATION(dive, gpsfix, j);
- break;
- } else {
- if (verbose)
- qDebug() << "pick the one after as it's closer to the start";
- SET_LOCATION(dive, nextgpsfix, j + 1);
- break;
- }
- }
- /*
- * If no more positions in range, the actual is the one. Asign, mark and end loop.
- */
- } else {
- if (verbose)
- qDebug() << "which seems to be the best one for this dive, so pick it";
- SET_LOCATION(dive, gpsfix, j);
- break;
- }
- }
- } else {
- /* If position is out of SAME_GROUP range and in the future, mark position for
- * next dive iteration and end the gps_location loop
- */
- if (gpsfix->when >= dive_endtime(dive) + SAME_GROUP) {
- tracer = j;
- break;
- }
- }
- }
- }
- }
- return changed > 0;
-}
-
// TODO: This looks like should be ported to C code. or a big part of it.
bool DivelogsDeWebServices::prepare_dives_for_divelogs(const QString &tempfile, const bool selected)
{
@@ -427,7 +315,7 @@ void SubsurfaceWebServices::buttonClicked(QAbstractButton *button)
ds->notes = strdup("SubsurfaceWebservice");
}
/* now merge the data in the gps_location table into the dive_table */
- if (merge_locations_into_dives()) {
+ if (GpsLocation::instance()->applyLocations()) {
changed = true;
mark_divelist_changed(true);
MainWindow::instance()->information()->updateDiveInfo();