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

Unified Diff: chrome/browser/ui/ash/session_state_delegate.h

Issue 15718003: Add SessionStateObserver with ActiveUserChanged() (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: close button when switching users, notify observers with ActiveUserChanged() when new user logs in Created 7 years, 7 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/browser/ui/ash/session_state_delegate.h
diff --git a/chrome/browser/ui/ash/session_state_delegate.h b/chrome/browser/ui/ash/session_state_delegate.h
index 50a3feb600032ef616e0545af43895d6082c3c01..969b67728e11e9a470224aca6c91f86eb61bd905 100644
--- a/chrome/browser/ui/ash/session_state_delegate.h
+++ b/chrome/browser/ui/ash/session_state_delegate.h
@@ -8,8 +8,22 @@
#include "ash/session_state_delegate.h"
#include "base/basictypes.h"
#include "base/compiler_specific.h"
+#include "base/observer_list.h"
-class SessionStateDelegate : public ash::SessionStateDelegate {
+#if defined(OS_CHROMEOS)
+#include "chrome/browser/chromeos/login/user_manager.h"
+
+namespace chromeos {
+class User;
bartfab (slow) 2013/06/03 09:00:06 When overriding a method, the common pattern I hav
Nikita (slow) 2013/06/03 09:21:28 Done.
+}
+#endif
+
+class SessionStateDelegate
+ :
+#if defined(OS_CHROMEOS)
+ public chromeos::UserManager::UserSessionStateObserver,
+#endif
+ public ash::SessionStateDelegate {
public:
SessionStateDelegate();
virtual ~SessionStateDelegate();
@@ -30,8 +44,19 @@ class SessionStateDelegate : public ash::SessionStateDelegate {
ash::MultiProfileIndex index) const OVERRIDE;
virtual void GetLoggedInUsers(ash::UserEmailList* users) OVERRIDE;
virtual void SwitchActiveUser(const std::string& email) OVERRIDE;
+ virtual void AddSessionStateObserver(
+ ash::SessionStateObserver* observer) OVERRIDE;
+ virtual void RemoveSessionStateObserver(
+ ash::SessionStateObserver* observer) OVERRIDE;
+
+#if defined(OS_CHROMEOS)
+ // UserManager::UserSessionStateObserver:
+ virtual void ActiveUserChanged(const chromeos::User* active_user) OVERRIDE;
+#endif
private:
+ ObserverList<ash::SessionStateObserver> session_state_observer_list_;
bartfab (slow) 2013/06/03 09:00:06 Nit: The list is used in the Chrome OS implementat
Nikita (slow) 2013/06/03 09:21:28 Actually SessionStateObserver is defined for every
bartfab (slow) 2013/06/03 09:26:52 AddSessionStateObserver and RemoveSessionStateObse
Nikita (slow) 2013/06/03 09:46:54 Done.
+
DISALLOW_COPY_AND_ASSIGN(SessionStateDelegate);
};

Powered by Google App Engine
This is Rietveld 408576698