summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-ui/maintab.cpp74
1 files changed, 21 insertions, 53 deletions
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp
index 884f76c07..c7a75d47f 100644
--- a/qt-ui/maintab.cpp
+++ b/qt-ui/maintab.cpp
@@ -860,65 +860,33 @@ void MainTab::updateDiveSite(int divenr)
if (!cd)
return;
- const uint32_t newUuid = displayed_dive_site.uuid;
- const uint32_t pickedUuid = ui.location->currDiveSiteUuid();
+ if (ui.location->text().isEmpty()) {
+ qDebug() << "No location data set, not updating the dive site.";
+ return;
+ }
+
+ uint32_t pickedUuid = ui.location->currDiveSiteUuid();
const QString newName = displayed_dive_site.name;
const uint32_t origUuid = cd->dive_site_uuid;
struct dive_site *origDs = get_dive_site_by_uuid(origUuid);
const QString origName = origDs ? origDs->name : "";
- // the user has accepted the changes made to the displayed_dive_site
- // so let's make them permanent
- if (!origUuid) {
- // the dive edited didn't have a dive site
- qDebug() << "current dive didn't have a dive site before edit";
- if (pickedUuid) {
- qDebug() << "assign dive_site" << pickedUuid << "to current dive";
- cd->dive_site_uuid = pickedUuid;
- } else if (newUuid) {
- // user created a new divesite
- cd->dive_site_uuid = newUuid;
- } else if (!newName.isEmpty()) {
- // user entered a name but didn't pick or create a dive site, so create a divesite
- uint32_t createdUuid = create_dive_site(displayed_dive_site.name, cd->when);
- struct dive_site *newDs = get_dive_site_by_uuid(createdUuid);
- copy_dive_site(&displayed_dive_site, newDs);
- newDs->uuid = createdUuid; // the copy overwrote the uuid
- cd->dive_site_uuid = createdUuid;
- qDebug() << "create a new dive site with name" << newName << "which is now named" << newDs->name << "and assign it as uuid" << createdUuid;
- } else {
- qDebug() << "neither uuid picked, uuid created nor new name found";
- }
- } else {
- qDebug() << "current dive had dive site with uuid" << origUuid;
- if (origUuid == newUuid) {
- // looks like nothing changed
- qDebug() << "same uuid";
- } else if (newName != origName) {
- if (newUuid == 0) {
- // so we created a new site, add it to the global list
- uint32_t createdUuid = create_dive_site(displayed_dive_site.name, cd->when);
- struct dive_site *newDs = get_dive_site_by_uuid(createdUuid);
- copy_dive_site(&displayed_dive_site, newDs);
- newDs->uuid = createdUuid; // the copy overwrote the uuid
- cd->dive_site_uuid = createdUuid;
- qDebug() << "create a new dive site with name" << newName << "which is now named" << newDs->name << "and assign it as uuid" << createdUuid;
- qDebug() << "original dive had site" << origUuid << "and" << (origDs ? QString("notes %1").arg(origDs->notes) : QString("no dive site"));
- if (origDs && same_string(origDs->notes, "SubsurfaceWebservice")) {
- // this is a special case - let's remove the original dive site if this was the only user
- if (!is_dive_site_used(origDs->uuid, false)) {
- qDebug() << "delete the autogenerated dive site" << origDs->name;
- delete_dive_site(origDs->uuid);
- free(newDs->notes);
- newDs->notes = NULL;
- }
- }
- } else {
- qDebug() << "switched to dive site" << newName << "uuid" << newUuid << "for current dive";
- cd->dive_site_uuid = newUuid;
- // what to do with the old site?
- }
+
+ if (pickedUuid == RECENTLY_ADDED_DIVESITE) {
+ pickedUuid = create_dive_site(ui.location->text().isEmpty() ? qPrintable(tr("New dive site")) : qPrintable(ui.location->text()), displayed_dive.when);
+ struct dive_site *newDs = get_dive_site_by_uuid(pickedUuid);
+ copy_dive_site(newDs, &displayed_dive_site);
+ }
+
+ if (origDs && pickedUuid != origDs->uuid && same_string(origDs->notes, "SubsurfaceWebservice")) {
+ // this is a special case - let's remove the original dive site if this was the only user
+ if (!is_dive_site_used(origDs->uuid, false)) {
+ qDebug() << "delete the autogenerated dive site" << origDs->name;
+ delete_dive_site(origDs->uuid);
}
}
+
+ cd->dive_site_uuid = pickedUuid;
+ qDebug() << "Setting the dive site id on the dive:" << pickedUuid;
}
void MainTab::acceptChanges()