Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1531)

Unified Diff: chrome/android/java/src/org/chromium/chrome/browser/init/ChromeBrowserInitializer.java

Issue 1579723002: Add a file observer to monitor if there is a crash (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/android/java/src/org/chromium/chrome/browser/init/ChromeBrowserInitializer.java
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeBrowserInitializer.java b/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeBrowserInitializer.java
index e19384c1a63bd4d3304be51988b7ac2c983cbcea..8e2915a89f7e5e84c0aca4cf54a70940bbb717b9 100644
--- a/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeBrowserInitializer.java
+++ b/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeBrowserInitializer.java
@@ -6,10 +6,12 @@ package org.chromium.chrome.browser.init;
import android.app.Activity;
import android.content.Context;
+import android.os.AsyncTask;
import android.os.Handler;
import android.os.Looper;
import android.os.Process;
import android.preference.PreferenceManager;
+import android.text.TextUtils;
import org.chromium.base.ActivityState;
import org.chromium.base.ApplicationStatus;
@@ -28,10 +30,12 @@ import org.chromium.chrome.browser.ChromeApplication;
import org.chromium.chrome.browser.ChromeStrictMode;
import org.chromium.chrome.browser.ChromeSwitches;
import org.chromium.chrome.browser.FileProviderHelper;
+import org.chromium.chrome.browser.crash.MinidumpDirectoryObserver;
import org.chromium.chrome.browser.device.DeviceClassManager;
import org.chromium.chrome.browser.services.GoogleServicesManager;
import org.chromium.chrome.browser.tabmodel.document.DocumentTabModelImpl;
import org.chromium.chrome.browser.webapps.ActivityAssigner;
+import org.chromium.components.variations.VariationsAssociatedData;
import org.chromium.content.app.ContentApplication;
import org.chromium.content.browser.BrowserStartupController;
import org.chromium.content.browser.DeviceUtils;
@@ -59,6 +63,8 @@ public class ChromeBrowserInitializer {
private boolean mPostInflationStartupComplete;
private boolean mNativeInitializationComplete;
+ private MinidumpDirectoryObserver mMinidumpDirectoryObserver;
+
/**
* A callback to be executed when there is a new version available in Play Store.
*/
@@ -341,6 +347,24 @@ public class ChromeBrowserInitializer {
mNativeInitializationComplete = true;
ContentUriUtils.setFileProviderUtil(new FileProviderHelper());
+
+ if (TextUtils.equals("true", VariationsAssociatedData.getVariationParamValue(
+ MinidumpDirectoryObserver.MINIDUMP_EXPERIMENT_NAME, "Enabled"))) {
+
+ // Start the file observer to watch the minidump directory.
+ new AsyncTask<Void, Void, MinidumpDirectoryObserver>() {
+ @Override
+ protected MinidumpDirectoryObserver doInBackground(Void... params) {
+ return new MinidumpDirectoryObserver();
+ }
+
+ @Override
+ protected void onPostExecute(MinidumpDirectoryObserver minidumpDirectoryObserver) {
+ mMinidumpDirectoryObserver = minidumpDirectoryObserver;
+ mMinidumpDirectoryObserver.startWatching();
+ }
+ }.executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
+ }
}
private void waitForDebuggerIfNeeded() {

Powered by Google App Engine
This is Rietveld 408576698