From 6a9df3bba3021b95f354c0590c79a458dbeca45b Mon Sep 17 00:00:00 2001 From: Berthold Stoeger Date: Tue, 13 Aug 2019 22:48:18 +0200 Subject: Mobile: transform DiveObjectHelper into value-type Instead of handing a reference-to-dive to QML, prerender all the needed properties and store them as values in DiveObjectHelper. Exception: - date(): generated from timestamp - time(): generated from timestamp - cylinderList(): does not depend on dive anyway and should be made static. This hopefully avoids the random mobile crashes that we are seeing. Clearly, this code needs to be optimized, but it is a start. Signed-off-by: Berthold Stoeger --- mobile-widgets/qmlmanager.cpp | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) (limited to 'mobile-widgets') diff --git a/mobile-widgets/qmlmanager.cpp b/mobile-widgets/qmlmanager.cpp index 369c6d14d..4978db02f 100644 --- a/mobile-widgets/qmlmanager.cpp +++ b/mobile-widgets/qmlmanager.cpp @@ -954,8 +954,8 @@ bool QMLManager::checkLocation(const DiveObjectHelper &myDive, struct dive *d, Q { bool diveChanged = false; struct dive_site *ds = get_dive_site_for_dive(d); - qDebug() << "checkLocation" << location << "gps" << gps << "dive had" << myDive.location() << "gps" << myDive.gas(); - if (myDive.location() != location) { + qDebug() << "checkLocation" << location << "gps" << gps << "dive had" << myDive.location << "gps" << myDive.gas; + if (myDive.location != location) { diveChanged = true; ds = get_dive_site_by_name(qPrintable(location), &dive_site_table); if (!ds && !location.isEmpty()) @@ -968,12 +968,12 @@ bool QMLManager::checkLocation(const DiveObjectHelper &myDive, struct dive *d, Q // now make sure that the GPS coordinates match - if the user changed the name but not // the GPS coordinates, this still does the right thing as the now new dive site will // have no coordinates, so the coordinates from the edit screen will get added - if (myDive.gps() != gps) { + if (myDive.gps != gps) { double lat, lon; if (parseGpsText(gps, &lat, &lon)) { qDebug() << "parsed GPS, using it"; // there are valid GPS coordinates - just use them - setupDivesite(d, ds, lat, lon, qPrintable(myDive.location())); + setupDivesite(d, ds, lat, lon, qPrintable(myDive.location)); diveChanged = true; } else if (gps == GPS_CURRENT_POS) { qDebug() << "gps was our default text for no GPS"; @@ -982,7 +982,7 @@ bool QMLManager::checkLocation(const DiveObjectHelper &myDive, struct dive *d, Q if (gpsString != GPS_CURRENT_POS) { qDebug() << "but now I got a valid location" << gpsString; if (parseGpsText(qPrintable(gpsString), &lat, &lon)) { - setupDivesite(d, ds, lat, lon, qPrintable(myDive.location())); + setupDivesite(d, ds, lat, lon, qPrintable(myDive.location)); diveChanged = true; } } else { @@ -998,7 +998,7 @@ bool QMLManager::checkLocation(const DiveObjectHelper &myDive, struct dive *d, Q bool QMLManager::checkDuration(const DiveObjectHelper &myDive, struct dive *d, QString duration) { - if (myDive.duration() != duration) { + if (myDive.duration != duration) { int h = 0, m = 0, s = 0; QRegExp r1(QStringLiteral("(\\d*)\\s*%1[\\s,:]*(\\d*)\\s*%2[\\s,:]*(\\d*)\\s*%3").arg(tr("h")).arg(tr("min")).arg(tr("sec")), Qt::CaseInsensitive); QRegExp r2(QStringLiteral("(\\d*)\\s*%1[\\s,:]*(\\d*)\\s*%2").arg(tr("h")).arg(tr("min")), Qt::CaseInsensitive); @@ -1037,7 +1037,7 @@ bool QMLManager::checkDuration(const DiveObjectHelper &myDive, struct dive *d, Q bool QMLManager::checkDepth(const DiveObjectHelper &myDive, dive *d, QString depth) { - if (myDive.depth() != depth) { + if (myDive.depth != depth) { int depthValue = parseLengthToMm(depth); // the QML code should stop negative depth, but massively huge depth can make // the profile extremely slow or even run out of memory and crash, so keep @@ -1084,15 +1084,15 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q diveChanged |= checkDepth(myDive, d, depth); - if (myDive.airTemp() != airtemp) { + if (myDive.airTemp != airtemp) { diveChanged = true; d->airtemp.mkelvin = parseTemperatureToMkelvin(airtemp); } - if (myDive.waterTemp() != watertemp) { + if (myDive.waterTemp != watertemp) { diveChanged = true; d->watertemp.mkelvin = parseTemperatureToMkelvin(watertemp); } - if (myDive.sumWeight() != weight) { + if (myDive.sumWeight != weight) { diveChanged = true; // not sure what we'd do if there was more than one weight system // defined - for now just ignore that case @@ -1104,7 +1104,7 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q } } // start and end pressures for first cylinder only - if (myDive.startPressure() != startpressure || myDive.endPressure() != endpressure) { + if (myDive.startPressure != startpressure || myDive.endPressure != endpressure) { diveChanged = true; for ( int i = 0, j = 0 ; j < startpressure.length() && j < endpressure.length() ; i++ ) { if (state != "add" && !is_cylinder_used(d, i)) @@ -1119,7 +1119,7 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q } } // gasmix for first cylinder - if (myDive.firstGas() != gasmix) { + if (myDive.firstGas != gasmix) { for ( int i = 0, j = 0 ; j < gasmix.length() ; i++ ) { if (state != "add" && !is_cylinder_used(d, i)) continue; @@ -1138,7 +1138,7 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q } } // info for first cylinder - if (myDive.getCylinder() != usedCylinder) { + if (myDive.getCylinder != usedCylinder) { diveChanged = true; unsigned long i; int size = 0, wp = 0, j = 0, k = 0; @@ -1164,12 +1164,12 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q k++; } } - if (myDive.suit() != suit) { + if (myDive.suit != suit) { diveChanged = true; free(d->suit); d->suit = copy_qstring(suit); } - if (myDive.buddy() != buddy) { + if (myDive.buddy != buddy) { if (buddy.contains(",")){ buddy = buddy.replace(QRegExp("\\s*,\\s*"), ", "); } @@ -1177,7 +1177,7 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q free(d->buddy); d->buddy = copy_qstring(buddy); } - if (myDive.divemaster() != diveMaster) { + if (myDive.divemaster != diveMaster) { if (diveMaster.contains(",")){ diveMaster = diveMaster.replace(QRegExp("\\s*,\\s*"), ", "); } @@ -1185,15 +1185,15 @@ void QMLManager::commitChanges(QString diveId, QString date, QString location, Q free(d->divemaster); d->divemaster = copy_qstring(diveMaster); } - if (myDive.rating() != rating) { + if (myDive.rating != rating) { diveChanged = true; d->rating = rating; } - if (myDive.visibility() != visibility) { + if (myDive.visibility != visibility) { diveChanged = true; d->visibility = visibility; } - if (myDive.notes() != notes) { + if (myDive.notes != notes) { diveChanged = true; free(d->notes); d->notes = copy_qstring(notes); -- cgit v1.2.3-70-g09d2