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

Unified Diff: chrome/browser/chromeos/login/ui/login_display_host_impl.cc

Issue 2690283002: mash: Fix content_browser shutdown crash if ash exits at the login screen (Closed)
Patch Set: typo Created 3 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
« no previous file with comments | « chrome/browser/chromeos/login/ui/login_display_host_impl.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/chromeos/login/ui/login_display_host_impl.cc
diff --git a/chrome/browser/chromeos/login/ui/login_display_host_impl.cc b/chrome/browser/chromeos/login/ui/login_display_host_impl.cc
index 493781ec422edf6cf91c4924b6ca391da6a9b2df..bfce397553c44154431dd665ecfc5fae3b5d693f 100644
--- a/chrome/browser/chromeos/login/ui/login_display_host_impl.cc
+++ b/chrome/browser/chromeos/login/ui/login_display_host_impl.cc
@@ -279,26 +279,6 @@ void EnableSystemSoundsForAccessibility() {
chromeos::AccessibilityManager::Get()->EnableSystemSounds(true);
}
-// A login implementation of WidgetDelegate.
-class LoginWidgetDelegate : public views::WidgetDelegate {
- public:
- explicit LoginWidgetDelegate(views::Widget* widget) : widget_(widget) {
- }
- ~LoginWidgetDelegate() override {}
-
- // Overridden from WidgetDelegate:
- void DeleteDelegate() override { delete this; }
- views::Widget* GetWidget() override { return widget_; }
- const views::Widget* GetWidget() const override { return widget_; }
- bool CanActivate() const override { return true; }
- bool ShouldAdvanceFocusToTopLevelWidget() const override { return true; }
-
- private:
- views::Widget* widget_;
-
- DISALLOW_COPY_AND_ASSIGN(LoginWidgetDelegate);
-};
-
// Disables virtual keyboard overscroll. Login UI will scroll user pods
// into view on JS side when virtual keyboard is shown.
void DisableKeyboardOverscroll() {
@@ -318,6 +298,39 @@ namespace chromeos {
// static
const int LoginDisplayHostImpl::kShowLoginWebUIid = 0x1111;
+// A login implementation of WidgetDelegate.
+class LoginDisplayHostImpl::LoginWidgetDelegate : public views::WidgetDelegate {
+ public:
+ LoginWidgetDelegate(views::Widget* widget, LoginDisplayHostImpl* host)
+ : widget_(widget), login_display_host_(host) {
+ DCHECK(widget_);
+ DCHECK(login_display_host_);
+ }
+ ~LoginWidgetDelegate() override {}
+
+ // Overridden from WidgetDelegate:
+ void WindowClosing() override {
+ // Reset the cached Widget and View pointers. The Widget may close due to:
+ // * Login completion
+ // * Ash crash at the login screen on mustash
+ // In the latter case the mash root process will trigger a clean restart
+ // of content_browser.
+ if (chrome::IsRunningInMash())
+ login_display_host_->ResetLoginWindowAndView();
+ }
+ void DeleteDelegate() override { delete this; }
+ views::Widget* GetWidget() override { return widget_; }
+ const views::Widget* GetWidget() const override { return widget_; }
+ bool CanActivate() const override { return true; }
+ bool ShouldAdvanceFocusToTopLevelWidget() const override { return true; }
+
+ private:
+ views::Widget* widget_;
+ LoginDisplayHostImpl* login_display_host_;
+
+ DISALLOW_COPY_AND_ASSIGN(LoginWidgetDelegate);
+};
+
////////////////////////////////////////////////////////////////////////////////
// LoginDisplayHostImpl, public
@@ -1206,7 +1219,7 @@ void LoginDisplayHostImpl::InitLoginWindowAndView() {
ash::kShellWindowId_LockScreenContainer);
}
login_window_ = new views::Widget;
- params.delegate = new LoginWidgetDelegate(login_window_);
+ params.delegate = new LoginWidgetDelegate(login_window_, this);
login_window_->Init(params);
login_view_ = new WebUILoginView(WebUILoginView::WebViewSettings());
@@ -1350,6 +1363,7 @@ void ShowLoginWizard(OobeScreen first_screen) {
? session_manager::SessionState::LOGIN_PRIMARY
: session_manager::SessionState::OOBE);
+ // Manages its own lifetime. See ShutdownDisplayHost().
LoginDisplayHostImpl* display_host = new LoginDisplayHostImpl(screen_bounds);
bool show_app_launch_splash_screen =
« no previous file with comments | « chrome/browser/chromeos/login/ui/login_display_host_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698