| Index: ui/views/widget/desktop_aura/x11_desktop_handler.cc | 
| diff --git a/ui/views/widget/desktop_aura/x11_desktop_handler.cc b/ui/views/widget/desktop_aura/x11_desktop_handler.cc | 
| index 8ec4b1e7b9aceada7c3a5562ee9c3b3fd966acb5..302eb1b6bff56d4901ded8b57eeca3bb934aff60 100644 | 
| --- a/ui/views/widget/desktop_aura/x11_desktop_handler.cc | 
| +++ b/ui/views/widget/desktop_aura/x11_desktop_handler.cc | 
| @@ -8,6 +8,7 @@ | 
| #include <X11/Xlib.h> | 
|  | 
| #include "base/message_loop/message_loop.h" | 
| +#include "base/strings/string_number_conversions.h" | 
| #include "ui/aura/env.h" | 
| #include "ui/aura/window_event_dispatcher.h" | 
| #include "ui/base/x/x11_foreign_window_manager.h" | 
| @@ -19,9 +20,10 @@ | 
|  | 
| namespace { | 
|  | 
| -const char* kAtomsToCache[] = { | 
| +const char* const kAtomsToCache[] = { | 
| "_NET_ACTIVE_WINDOW", | 
| -  NULL | 
| +  "_NET_CURRENT_DESKTOP", | 
| +  nullptr | 
| }; | 
|  | 
| // Our global instance. Deleted when our Env() is deleted. | 
| @@ -124,6 +126,30 @@ void X11DesktopHandler::ActivateWindow(::Window window) { | 
| } | 
| } | 
|  | 
| +void X11DesktopHandler::AddObserver(X11DesktopHandlerObserver* observer) { | 
| +  observers_.AddObserver(observer); | 
| +} | 
| + | 
| +void X11DesktopHandler::RemoveObserver(X11DesktopHandlerObserver* observer) { | 
| +  observers_.RemoveObserver(observer); | 
| +} | 
| + | 
| +std::string X11DesktopHandler::GetWorkspace() { | 
| +  if (workspace_.empty()) | 
| +    UpdateWorkspace(); | 
| +  return workspace_; | 
| +} | 
| + | 
| +bool X11DesktopHandler::UpdateWorkspace() { | 
| +  int desktop; | 
| +  if (ui::GetCurrentDesktop(&desktop)) { | 
| +    workspace_ = base::IntToString(desktop); | 
| +    return true; | 
| +  } | 
| +  return false; | 
| +} | 
| + | 
| + | 
| void X11DesktopHandler::set_wm_user_time_ms(Time time_ms) { | 
| if (time_ms != CurrentTime) { | 
| int64_t event_time_64 = time_ms; | 
| @@ -184,10 +210,7 @@ bool X11DesktopHandler::CanDispatchEvent(const ui::PlatformEvent& event) { | 
| uint32_t X11DesktopHandler::DispatchEvent(const ui::PlatformEvent& event) { | 
| switch (event->type) { | 
| case PropertyNotify: { | 
| -      // Check for a change to the active window. | 
| -      CHECK_EQ(x_root_window_, event->xproperty.window); | 
| -      ::Atom active_window_atom = atom_cache_.GetAtom("_NET_ACTIVE_WINDOW"); | 
| -      if (event->xproperty.atom == active_window_atom) { | 
| +      if (event->xproperty.atom == atom_cache_.GetAtom("_NET_ACTIVE_WINDOW")) { | 
| ::Window window; | 
| if (ui::GetXIDProperty(x_root_window_, "_NET_ACTIVE_WINDOW", &window) && | 
| window) { | 
| @@ -196,10 +219,15 @@ uint32_t X11DesktopHandler::DispatchEvent(const ui::PlatformEvent& event) { | 
| } else { | 
| x_active_window_ = None; | 
| } | 
| +      } else if (event->xproperty.atom == | 
| +                 atom_cache_.GetAtom("_NET_CURRENT_DESKTOP")) { | 
| +        if (UpdateWorkspace()) { | 
| +          FOR_EACH_OBSERVER(views::X11DesktopHandlerObserver, observers_, | 
| +                            OnWorkspaceChanged(workspace_)); | 
| +        } | 
| } | 
| break; | 
| } | 
| - | 
| case CreateNotify: | 
| OnWindowCreatedOrDestroyed(event->type, event->xcreatewindow.window); | 
| break; | 
|  |