diff --git a/CHANGELOG.md b/CHANGELOG.md index 502077f283..463778efcb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,7 @@ * Added excluded leaks to text report [#119](https://github.com/square/leakcanary/issues/119). * Added LeakCanary SHA to text report [#120](https://github.com/square/leakcanary/issues/120). * Renamed all resources to begin with `leak_canary_` instead of `__leak_canary`[#161](https://github.com/square/leakcanary/pull/161) +* No crash when heap dump fails [#226](https://github.com/square/leakcanary/issues/226). ### Public API changes diff --git a/leakcanary-android/src/main/java/com/squareup/leakcanary/AndroidHeapDumper.java b/leakcanary-android/src/main/java/com/squareup/leakcanary/AndroidHeapDumper.java index 7ab85f9de3..943355616a 100644 --- a/leakcanary-android/src/main/java/com/squareup/leakcanary/AndroidHeapDumper.java +++ b/leakcanary-android/src/main/java/com/squareup/leakcanary/AndroidHeapDumper.java @@ -27,7 +27,6 @@ import com.squareup.leakcanary.internal.FutureResult; import com.squareup.leakcanary.internal.LeakCanaryInternals; import java.io.File; -import java.io.IOException; import static com.squareup.leakcanary.internal.LeakCanaryInternals.isExternalStorageWritable; import static com.squareup.leakcanary.internal.LeakCanaryInternals.storageDirectory; @@ -69,7 +68,7 @@ public AndroidHeapDumper(Context context) { Debug.dumpHprofData(heapDumpFile.getAbsolutePath()); cancelToast(toast); return heapDumpFile; - } catch (IOException e) { + } catch (Exception e) { cleanup(); Log.e(TAG, "Could not perform heap dump", e); // Abort heap dump