From 86d76510112dbd1349b3ab6797febebd179a725b Mon Sep 17 00:00:00 2001 From: zachh Date: Fri, 11 Aug 2017 15:14:55 -0700 Subject: Fixed some strict mode violations. Many strict mode violations are due to use of shared preferences on main thread, so we now warm up shared preferences in bypass mode in DialtactsActivity.onCreate. (Note that this shouldn't slow it down because we were already accessing them but without bypassing strict mode.) I also added a new "storage" module which caches device protected shared prefs. Before we were not caching them and every access was resulting in a disk access, because #createDeviceProtectedStorageContext returns a new context for each call. (Note that this change is required for warming those prefs to work.) Note that warming up prefs doesn't fix cases where prefs are read from jobs, services, or Application#onCreate (because those things can happen before DialtactsActivity#onCreate) so there is still a need to bypass in those specific places. Finally, there were various other violations which we now bypass though we probably shouldn't; I'm considering these as being grandfathered in and it would be nice to fix them at some point but today I'd like to just get the app into a usable state so devs can keep strict mode enabled. Bug: 64118795 Test: manually navigated bugfood build and observed no/fewer crashes PiperOrigin-RevId: 165031607 Change-Id: I336212a650a7bd93915ebe56a08e976d37818d68 --- .../android/dialer/strictmode/DialerStrictMode.java | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'java/com/android/dialer/strictmode') diff --git a/java/com/android/dialer/strictmode/DialerStrictMode.java b/java/com/android/dialer/strictmode/DialerStrictMode.java index 3c31aa954..ad1a6c60d 100644 --- a/java/com/android/dialer/strictmode/DialerStrictMode.java +++ b/java/com/android/dialer/strictmode/DialerStrictMode.java @@ -103,4 +103,22 @@ public final class DialerStrictMode { enableDeathPenalty(); } } + + /** + * Convenience method for disabling and enabling the death penalty using lambdas. + * + *

For example: + * + *

+ * DialerStrictMode.bypass(() -> doDiskAccessOnMainThread()); + * + */ + public static void bypass(Runnable runnable) { + disableDeathPenalty(); + try { + runnable.run(); + } finally { + enableDeathPenalty(); + } + } } -- cgit v1.2.3