aboutsummaryrefslogtreecommitdiffstats
path: root/main
diff options
context:
space:
mode:
authorrsudev <rasch@munin-soft.de>2014-05-12 18:45:51 +0200
committerrsudev <rasch@munin-soft.de>2014-05-12 18:45:51 +0200
commit082aacd72dd226ffc9f91c017efff8c5522a8940 (patch)
treed1761c6069eb8c3a5eba2e2288f889ca0c720aa5 /main
parent5ed79ef276880358dcb88c103a507c9dbf5ef61c (diff)
downloadcgeo-082aacd72dd226ffc9f91c017efff8c5522a8940.zip
cgeo-082aacd72dd226ffc9f91c017efff8c5522a8940.tar.gz
cgeo-082aacd72dd226ffc9f91c017efff8c5522a8940.tar.bz2
Dump memory on OOM to investigate #3818
Diffstat (limited to 'main')
-rw-r--r--main/src/cgeo/geocaching/CgeoApplication.java31
1 files changed, 31 insertions, 0 deletions
diff --git a/main/src/cgeo/geocaching/CgeoApplication.java b/main/src/cgeo/geocaching/CgeoApplication.java
index 09aee93..d503969 100644
--- a/main/src/cgeo/geocaching/CgeoApplication.java
+++ b/main/src/cgeo/geocaching/CgeoApplication.java
@@ -11,6 +11,9 @@ import rx.observables.ConnectableObservable;
import android.app.Application;
+import java.io.IOException;
+import java.lang.Thread.UncaughtExceptionHandler;
+
public class CgeoApplication extends Application {
private boolean forceRelog = false; // c:geo needs to log into cache providers
@@ -22,6 +25,34 @@ public class CgeoApplication extends Application {
private volatile IGeoData currentGeo = null;
private volatile float currentDirection = 0.0f;
+ private static final UncaughtExceptionHandler defaultHandler;
+
+ static {
+ defaultHandler = Thread.getDefaultUncaughtExceptionHandler();
+
+ Thread.setDefaultUncaughtExceptionHandler(new UncaughtExceptionHandler() {
+
+ @Override
+ public void uncaughtException(Thread thread, Throwable ex) {
+ Log.e("UncaughtException", ex);
+ Throwable exx = ex;
+ while (exx.getCause() != null) {
+ exx = exx.getCause();
+ }
+ if (exx.getClass().equals(OutOfMemoryError.class))
+ {
+ try {
+ Log.e("OutOfMemory");
+ android.os.Debug.dumpHprofData("/sdcard/dump.hprof");
+ } catch (IOException e) {
+ Log.e("Error writing dump", e);
+ }
+ }
+ defaultHandler.uncaughtException(thread, ex);
+ }
+ });
+ }
+
public CgeoApplication() {
setInstance(this);
}