Index: chrome/android/java/src/org/chromium/chrome/browser/tab/TabWebContentsObserver.java |
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/tab/TabWebContentsObserver.java b/chrome/android/java/src/org/chromium/chrome/browser/tab/TabWebContentsObserver.java |
index 755c9dfaf8e21153328a57674df5c1d4459da00c..3cd99b3ad8ce08f2e73e5223290d900b91dd39d3 100644 |
--- a/chrome/android/java/src/org/chromium/chrome/browser/tab/TabWebContentsObserver.java |
+++ b/chrome/android/java/src/org/chromium/chrome/browser/tab/TabWebContentsObserver.java |
@@ -44,6 +44,14 @@ public class TabWebContentsObserver extends WebContentsObserver { |
private static final int TAB_RENDERER_CRASH_STATUS_HIDDEN_IN_BACKGROUND_APP = 2; |
private static final int TAB_RENDERER_CRASH_STATUS_MAX = 3; |
+ // TabRendererExitStatus defined in tools/metrics/histograms/histograms.xml. |
+ // Designed to replace TabRendererCrashStatus if numbers line up. |
+ private static final int TAB_RENDERER_EXIT_STATUS_OOM_PROTECTED_IN_FOREGROUND_APP = 0; |
+ private static final int TAB_RENDERER_EXIT_STATUS_OOM_PROTECTED_IN_BACKGROUND_APP = 1; |
+ private static final int TAB_RENDERER_EXIT_STATUS_NOT_PROTECTED_IN_FOREGROUND_APP = 2; |
+ private static final int TAB_RENDERER_EXIT_STATUS_NOT_PROTECTED_IN_BACKGROUND_APP = 3; |
+ private static final int TAB_RENDERER_EXIT_STATUS_MAX = 4; |
+ |
private final Tab mTab; |
private int mThemeColor; |
@@ -92,6 +100,25 @@ public class TabWebContentsObserver extends WebContentsObserver { |
RecordHistogram.recordEnumeratedHistogram( |
"Tab.RendererCrashStatus", rendererCrashStatus, TAB_RENDERER_CRASH_STATUS_MAX); |
+ // This will replace TabRendererCrashStatus if numbers line up. |
+ boolean applicationInForeground = ApplicationStatus.hasRunningActivities(); |
+ int rendererExitStatus = TAB_RENDERER_EXIT_STATUS_MAX; |
+ if (processWasOomProtected) { |
+ if (applicationInForeground) { |
+ rendererExitStatus = TAB_RENDERER_EXIT_STATUS_OOM_PROTECTED_IN_FOREGROUND_APP; |
+ } else { |
+ rendererExitStatus = TAB_RENDERER_EXIT_STATUS_OOM_PROTECTED_IN_BACKGROUND_APP; |
+ } |
+ } else { |
+ if (applicationInForeground) { |
+ rendererExitStatus = TAB_RENDERER_EXIT_STATUS_NOT_PROTECTED_IN_FOREGROUND_APP; |
+ } else { |
+ rendererExitStatus = TAB_RENDERER_EXIT_STATUS_NOT_PROTECTED_IN_BACKGROUND_APP; |
+ } |
+ } |
+ RecordHistogram.recordEnumeratedHistogram( |
+ "Tab.RendererExitStatus", rendererExitStatus, TAB_RENDERER_EXIT_STATUS_MAX); |
+ |
mTab.handleTabCrash(); |
boolean sadTabShown = mTab.isShowingSadTab(); |