102 lines
4.8 KiB
Diff
102 lines
4.8 KiB
Diff
From: Serg <serg.zhukovsky@gmail.com>
|
|
Date: Tue, 31 Jan 2017 22:12:27 -0500
|
|
Subject: Add exit menu item
|
|
|
|
Corrected Exit functionality
|
|
---
|
|
chrome/android/java/res/menu/main_menu.xml | 4 ++++
|
|
chrome/android/java/res/menu/main_menu_regroup.xml | 3 +++
|
|
.../src/org/chromium/chrome/browser/app/ChromeActivity.java | 6 ++++++
|
|
.../chrome/browser/init/ChromeLifetimeController.java | 6 +++++-
|
|
.../browser/ui/android/strings/android_chrome_strings.grd | 3 +++
|
|
5 files changed, 21 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/chrome/android/java/res/menu/main_menu.xml b/chrome/android/java/res/menu/main_menu.xml
|
|
--- a/chrome/android/java/res/menu/main_menu.xml
|
|
+++ b/chrome/android/java/res/menu/main_menu.xml
|
|
@@ -119,6 +119,8 @@
|
|
android:icon="@drawable/vr_headset" />
|
|
<item android:id="@+id/managed_by_menu_id"
|
|
android:title="@string/managed" />
|
|
+ <item android:id="@+id/exit_id"
|
|
+ android:title="@string/menu_exit" />
|
|
</group>
|
|
|
|
<!-- Items shown only in the tab switcher -->
|
|
@@ -153,6 +155,8 @@
|
|
<item android:id="@id/preferences_id"
|
|
android:title="@string/menu_settings"
|
|
android:icon="@drawable/settings_cog" />
|
|
+ <item android:id="@+id/exit_id"
|
|
+ android:title="@string/menu_exit" />
|
|
</group>
|
|
|
|
<!-- Items shown only in the tab switcher when start surface is enabled -->
|
|
diff --git a/chrome/android/java/res/menu/main_menu_regroup.xml b/chrome/android/java/res/menu/main_menu_regroup.xml
|
|
--- a/chrome/android/java/res/menu/main_menu_regroup.xml
|
|
+++ b/chrome/android/java/res/menu/main_menu_regroup.xml
|
|
@@ -181,6 +181,9 @@
|
|
android:icon="@drawable/vr_headset" />
|
|
<item android:id="@+id/managed_by_menu_id"
|
|
android:title="@string/managed" />
|
|
+ <item android:id="@+id/exit_id"
|
|
+ android:title="@string/menu_exit"
|
|
+ android:icon="@drawable/ic_exit_to_app_white_24dp"/>
|
|
</group>
|
|
|
|
<!-- Items shown only in the tab switcher -->
|
|
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java b/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java
|
|
--- a/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java
|
|
+++ b/chrome/android/java/src/org/chromium/chrome/browser/app/ChromeActivity.java
|
|
@@ -54,6 +54,7 @@ import org.chromium.base.supplier.OneshotSupplierImpl;
|
|
import org.chromium.chrome.R;
|
|
import org.chromium.chrome.browser.ActivityTabProvider;
|
|
import org.chromium.chrome.browser.AppHooks;
|
|
+import org.chromium.chrome.browser.ApplicationLifetime;
|
|
import org.chromium.chrome.browser.ChromeActivitySessionTracker;
|
|
import org.chromium.chrome.browser.ChromeApplication;
|
|
import org.chromium.chrome.browser.ChromeWindow;
|
|
@@ -1950,6 +1951,11 @@ public abstract class ChromeActivity<C extends ChromeActivityComponent>
|
|
RecordUserAction.record("MobileMenuSettings");
|
|
}
|
|
|
|
+ if (id == R.id.exit_id) {
|
|
+ ApplicationLifetime.terminate(false);
|
|
+ return true;
|
|
+ }
|
|
+
|
|
if (id == R.id.update_menu_id) {
|
|
UpdateMenuItemHelper.getInstance().onMenuItemClicked(this);
|
|
return true;
|
|
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeLifetimeController.java b/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeLifetimeController.java
|
|
--- a/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeLifetimeController.java
|
|
+++ b/chrome/android/java/src/org/chromium/chrome/browser/init/ChromeLifetimeController.java
|
|
@@ -82,7 +82,11 @@ class ChromeLifetimeController implements ApplicationLifetime.Observer,
|
|
|
|
// Kick off a timer to kill the process after a delay, which fires only if the Activities
|
|
// take too long to be finished.
|
|
- mHandler.postDelayed(mRestartRunnable, WATCHDOG_DELAY_MS);
|
|
+ if (restart) {
|
|
+ mHandler.postDelayed(mRestartRunnable, WATCHDOG_DELAY_MS);
|
|
+ } else {
|
|
+ fireBrowserRestartActivityIntent();
|
|
+ }
|
|
}
|
|
|
|
@Override
|
|
diff --git a/chrome/browser/ui/android/strings/android_chrome_strings.grd b/chrome/browser/ui/android/strings/android_chrome_strings.grd
|
|
--- a/chrome/browser/ui/android/strings/android_chrome_strings.grd
|
|
+++ b/chrome/browser/ui/android/strings/android_chrome_strings.grd
|
|
@@ -2901,6 +2901,9 @@ Data from your Incognito session will only be cleared from Chrome when you <ph n
|
|
<message name="IDS_MENU_SETTINGS" desc="Menu item for opening browser settings. [CHAR-LIMIT=27]">
|
|
Settings
|
|
</message>
|
|
+ <message name="IDS_MENU_EXIT" desc="Menu item for exit browser. [CHAR-LIMIT=27]">
|
|
+ Exit
|
|
+ </message>
|
|
<message name="IDS_MENU_CLOSE_ALL_TABS" desc="Menu item for closing all open tabs. [CHAR-LIMIT=27]">
|
|
Close all tabs
|
|
</message>
|
|
--
|
|
2.17.1
|
|
|