From 5ee40c7d613907c833b29d7a40072d6c17faa0f5 Mon Sep 17 00:00:00 2001 From: Ido Ben-Hur Date: Sat, 6 Aug 2022 17:59:38 +0300 Subject: [PATCH] OpenDelta: Reliably show when an update is pending a reboot --- src/eu/chainfire/opendelta/UpdateService.java | 29 ++++++++++++------- 1 file changed, 19 insertions(+), 10 deletions(-) diff --git a/src/eu/chainfire/opendelta/UpdateService.java b/src/eu/chainfire/opendelta/UpdateService.java index c653257..7faeec5 100644 --- a/src/eu/chainfire/opendelta/UpdateService.java +++ b/src/eu/chainfire/opendelta/UpdateService.java @@ -528,6 +528,18 @@ public class UpdateService extends Service implements OnNetworkStateListener, return; } + // Check if a previous update was done already + if (prefs.getBoolean(PREF_PENDING_REBOOT, false) || + this.state.equals(STATE_ACTION_AB_FINISHED)) { + updateState(STATE_ACTION_AB_FINISHED); + return; + } + if (ABUpdate.isInstallingUpdate(this)) { + final String lastFilename = prefs.getString(PREF_CURRENT_AB_FILENAME_NAME, null); + ABUpdate.pokeStatus(lastFilename, this); + return; + } + // Check if we're currently installing an A/B update if (Config.isABDevice() && ABUpdate.isInstallingUpdate(this)) { // resume listening to progress @@ -555,14 +567,6 @@ public class UpdateService extends Service implements OnNetworkStateListener, } } - // Check if a previous update was done already - if (prefs.getBoolean(PREF_PENDING_REBOOT, false)) { - final String lastFilename = prefs.getString(PREF_CURRENT_AB_FILENAME_NAME, null); - prefs.edit().putBoolean(PREF_PENDING_REBOOT, false).apply(); - ABUpdate.pokeStatus(lastFilename, this); - return; - } - // let's check if we have a .part file that is still latest List latestFullBuildWithUrl = getNewestFullBuild(); String latestFullBuild; @@ -1371,8 +1375,12 @@ public class UpdateService extends Service implements OnNetworkStateListener, return false; // Check if a previous update was done already - if (prefs.getBoolean(PREF_PENDING_REBOOT, false) || - ABUpdate.isInstallingUpdate(this)) { + if (this.state.equals(STATE_ACTION_AB_FINISHED)) return false; + if (prefs.getBoolean(PREF_PENDING_REBOOT, false)) { + updateState(STATE_ACTION_AB_FINISHED); + return false; + } + if (ABUpdate.isInstallingUpdate(this)) { final String lastFilename = prefs.getString(PREF_CURRENT_AB_FILENAME_NAME, null); ABUpdate.pokeStatus(lastFilename, this); return false; @@ -1827,6 +1835,7 @@ public class UpdateService extends Service implements OnNetworkStateListener, } protected void onUpdateCompleted(int status, int errorCode) { + Logger.d("onUpdateCompleted status = " + status); stopNotification(); updateRunning = false; if (status == UpdateEngine.ErrorCodeConstants.SUCCESS) {