1
0
mirror of https://codeberg.org/Freeyourgadget/Gadgetbridge synced 2025-01-11 18:35:49 +01:00

Huawei: Mark downloaded GPS file as complete only after parsing

Otherwise the icon does not show up in the workout list properly at
first.
This commit is contained in:
Martin.JM 2024-11-24 20:11:04 +01:00 committed by José Rebelo
parent 8746577c4e
commit 5e62bd3cc6

View File

@ -2329,11 +2329,11 @@ public class HuaweiSupportProvider {
new HuaweiFileDownloadManager.FileDownloadCallback() { new HuaweiFileDownloadManager.FileDownloadCallback() {
@Override @Override
public void downloadComplete(HuaweiFileDownloadManager.FileRequest fileRequest) { public void downloadComplete(HuaweiFileDownloadManager.FileRequest fileRequest) {
syncState.stopWorkoutGpsDownload(); // TODO: delay until the file is actually parsed...
extraCallbackAction.run(); extraCallbackAction.run();
if (fileRequest.getData().length == 0) { if (fileRequest.getData().length == 0) {
LOG.debug("GPS file empty"); LOG.debug("GPS file empty");
syncState.stopWorkoutGpsDownload();
return; return;
} }
@ -2345,6 +2345,7 @@ public class HuaweiSupportProvider {
if (points.length == 0) { if (points.length == 0) {
LOG.debug("No GPS points returned"); LOG.debug("No GPS points returned");
syncState.stopWorkoutGpsDownload();
return; return;
} }
@ -2384,6 +2385,7 @@ public class HuaweiSupportProvider {
} catch (IOException e) { } catch (IOException e) {
GB.toast(context, "Could not open Workout GPS file to write to", Toast.LENGTH_SHORT, GB.ERROR, e); GB.toast(context, "Could not open Workout GPS file to write to", Toast.LENGTH_SHORT, GB.ERROR, e);
LOG.error("Could not open Workout GPS file to write to", e); LOG.error("Could not open Workout GPS file to write to", e);
syncState.stopWorkoutGpsDownload();
return; return;
} }
@ -2394,6 +2396,7 @@ public class HuaweiSupportProvider {
} catch (IOException | ActivityTrackExporter.GPXTrackEmptyException e) { } catch (IOException | ActivityTrackExporter.GPXTrackEmptyException e) {
GB.toast(context, "Failed to export Workout GPX file", Toast.LENGTH_SHORT, GB.ERROR, e); GB.toast(context, "Failed to export Workout GPX file", Toast.LENGTH_SHORT, GB.ERROR, e);
LOG.error("Failed to export Workout GPX file", e); LOG.error("Failed to export Workout GPX file", e);
syncState.stopWorkoutGpsDownload();
return; return;
} }
@ -2401,6 +2404,7 @@ public class HuaweiSupportProvider {
if (databaseId == null) { if (databaseId == null) {
GB.toast(context, "Cannot link GPX to workout", Toast.LENGTH_SHORT, GB.ERROR); GB.toast(context, "Cannot link GPX to workout", Toast.LENGTH_SHORT, GB.ERROR);
LOG.error("Cannot link GPX to workout"); LOG.error("Cannot link GPX to workout");
syncState.stopWorkoutGpsDownload();
return; return;
} }
@ -2412,12 +2416,14 @@ public class HuaweiSupportProvider {
} catch (Exception e) { } catch (Exception e) {
GB.toast(context, "Failed to save Workout GPX file location", Toast.LENGTH_SHORT, GB.ERROR, e); GB.toast(context, "Failed to save Workout GPX file location", Toast.LENGTH_SHORT, GB.ERROR, e);
LOG.error("Failed to save Workout GPX file location", e); LOG.error("Failed to save Workout GPX file location", e);
syncState.stopWorkoutGpsDownload();
return; return;
} }
new HuaweiWorkoutGbParser(getDevice()).parseWorkout(databaseId); new HuaweiWorkoutGbParser(getDevice()).parseWorkout(databaseId);
LOG.debug("Completed workout GPS parsing and inserting"); LOG.debug("Completed workout GPS parsing and inserting");
syncState.stopWorkoutGpsDownload();
} }
@Override @Override