summaryrefslogtreecommitdiffstats
path: root/src/com/android/browser/CrashRecoveryHandler.java
diff options
context:
space:
mode:
authorJohn Reck <jreck@google.com>2011-06-24 15:33:57 -0700
committerJohn Reck <jreck@google.com>2011-06-24 15:46:41 -0700
commitcfeae6d3dc6f62f2d475bf50c0fc26a0e9c730de (patch)
tree45759ca17530053a0d92ad28115dcc39c4b5e085 /src/com/android/browser/CrashRecoveryHandler.java
parentf7b45bc4344aec44506ac0fa0a1517148ba8a2cb (diff)
downloadpackages_apps_browser-cfeae6d3dc6f62f2d475bf50c0fc26a0e9c730de.zip
packages_apps_browser-cfeae6d3dc6f62f2d475bf50c0fc26a0e9c730de.tar.gz
packages_apps_browser-cfeae6d3dc6f62f2d475bf50c0fc26a0e9c730de.tar.bz2
Attempt to automatically restore after crash
Use a timestamp based approach to determine if we should automatically restore or prompt the user Change-Id: I4b8d1d76e0dfc02879f3708241cb78ff1673a57c
Diffstat (limited to 'src/com/android/browser/CrashRecoveryHandler.java')
-rw-r--r--src/com/android/browser/CrashRecoveryHandler.java47
1 files changed, 43 insertions, 4 deletions
diff --git a/src/com/android/browser/CrashRecoveryHandler.java b/src/com/android/browser/CrashRecoveryHandler.java
index 6d8d921..5140952 100644
--- a/src/com/android/browser/CrashRecoveryHandler.java
+++ b/src/com/android/browser/CrashRecoveryHandler.java
@@ -22,6 +22,7 @@ import android.content.DialogInterface;
import android.content.DialogInterface.OnCancelListener;
import android.content.DialogInterface.OnClickListener;
import android.content.Intent;
+import android.content.SharedPreferences;
import android.os.Bundle;
import android.os.Handler;
import android.os.HandlerThread;
@@ -38,8 +39,16 @@ public class CrashRecoveryHandler {
private static final String LOGTAG = "BrowserCrashRecovery";
private static final String STATE_FILE = "browser_state.parcel";
+ private static final String RECOVERY_PREFERENCES = "browser_recovery_prefs";
+ private static final String KEY_LAST_RECOVERED = "last_recovered";
private static final int BUFFER_SIZE = 4096;
private static final long BACKUP_DELAY = 500; // 500ms between writes
+ /* This is the duration for which we will prompt to restore
+ * instead of automatically restoring. The first time the browser crashes,
+ * we will automatically restore. If we then crash again within XX minutes,
+ * we will prompt instead of automatically restoring.
+ */
+ private static final long PROMPT_INTERVAL = 30 * 60 * 1000; // 30 minutes
private static CrashRecoveryHandler sInstance;
@@ -136,6 +145,7 @@ public class CrashRecoveryHandler {
.setPositiveButton(R.string.recover_yes, new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
+ updateLastRecovered();
mController.doStart(state, intent);
}
})
@@ -155,7 +165,30 @@ public class CrashRecoveryHandler {
.show();
}
+ private boolean shouldPrompt() {
+ Context context = mController.getActivity();
+ SharedPreferences prefs = context.getSharedPreferences(
+ RECOVERY_PREFERENCES, Context.MODE_PRIVATE);
+ long lastRecovered = prefs.getLong(KEY_LAST_RECOVERED,
+ System.currentTimeMillis());
+ long timeSinceLastRecover = System.currentTimeMillis() - lastRecovered;
+ if (timeSinceLastRecover > PROMPT_INTERVAL) {
+ return false;
+ }
+ return true;
+ }
+
+ private void updateLastRecovered() {
+ Context context = mController.getActivity();
+ SharedPreferences prefs = context.getSharedPreferences(
+ RECOVERY_PREFERENCES, Context.MODE_PRIVATE);
+ prefs.edit()
+ .putLong(KEY_LAST_RECOVERED, System.currentTimeMillis())
+ .commit();
+ }
+
public void startRecovery(Intent intent) {
+ Bundle state = null;
Parcel parcel = Parcel.obtain();
try {
Context context = mController.getActivity();
@@ -169,16 +202,22 @@ public class CrashRecoveryHandler {
byte[] data = dataStream.toByteArray();
parcel.unmarshall(data, 0, data.length);
parcel.setDataPosition(0);
- Bundle state = parcel.readBundle();
- promptToRecover(state, intent);
+ state = parcel.readBundle();
+ if (shouldPrompt()) {
+ promptToRecover(state, intent);
+ return;
+ } else {
+ updateLastRecovered();
+ }
} catch (FileNotFoundException e) {
// No state to recover
- mController.doStart(null, intent);
+ state = null;
} catch (Exception e) {
Log.w(LOGTAG, "Failed to recover state!", e);
- mController.doStart(null, intent);
+ state = null;
} finally {
parcel.recycle();
}
+ mController.doStart(state, intent);
}
}