| Index: ui/base/x/active_window_watcher_x.cc
|
| diff --git a/ui/base/x/active_window_watcher_x.cc b/ui/base/x/active_window_watcher_x.cc
|
| index 01c4a88ccc786c611229532659ba660fc34a49a7..253ebecf13fb8c9cafee47df3a9007121b2d095d 100644
|
| --- a/ui/base/x/active_window_watcher_x.cc
|
| +++ b/ui/base/x/active_window_watcher_x.cc
|
| @@ -2,15 +2,20 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#include <X11/Xlib.h>
|
| +#include "ui/base/x/active_window_watcher_x.h"
|
| +
|
| #include <gdk/gdk.h>
|
| #include <gdk/gdkx.h>
|
|
|
| -#include "ui/base/x/active_window_watcher_x.h"
|
| +#include "ui/base/x/root_window_property_watcher_x.h"
|
| +#include "ui/base/x/x11_util.h"
|
|
|
| namespace ui {
|
|
|
| -static Atom g_net_active_window_atom = None;
|
| +static const char* kNetActiveWindow = "_NET_ACTIVE_WINDOW";
|
| +
|
| +ActiveWindowWatcherX::Observer::~Observer() {
|
| +}
|
|
|
| // static
|
| ActiveWindowWatcherX* ActiveWindowWatcherX::GetInstance() {
|
| @@ -19,6 +24,8 @@ ActiveWindowWatcherX* ActiveWindowWatcherX::GetInstance() {
|
|
|
| // static
|
| void ActiveWindowWatcherX::AddObserver(Observer* observer) {
|
| + // Ensure that RootWindowPropertyWatcherX exists.
|
| + internal::RootWindowPropertyWatcherX::GetInstance();
|
| GetInstance()->observers_.AddObserver(observer);
|
| }
|
|
|
| @@ -28,37 +35,28 @@ void ActiveWindowWatcherX::RemoveObserver(Observer* observer) {
|
| }
|
|
|
| // static
|
| +Atom ActiveWindowWatcherX::GetPropertyAtom() {
|
| + return GetAtom(kNetActiveWindow);
|
| +}
|
| +
|
| +// static
|
| +void ActiveWindowWatcherX::Notify() {
|
| + GetInstance()->NotifyActiveWindowChanged();
|
| +}
|
| +
|
| +// static
|
| bool ActiveWindowWatcherX::WMSupportsActivation() {
|
| return gdk_x11_screen_supports_net_wm_hint(
|
| gdk_screen_get_default(),
|
| - gdk_atom_intern_static_string("_NET_ACTIVE_WINDOW"));
|
| + gdk_atom_intern_static_string(kNetActiveWindow));
|
| }
|
|
|
| ActiveWindowWatcherX::ActiveWindowWatcherX() {
|
| - Init();
|
| }
|
|
|
| ActiveWindowWatcherX::~ActiveWindowWatcherX() {
|
| }
|
|
|
| -void ActiveWindowWatcherX::Init() {
|
| - GdkAtom net_active_window =
|
| - gdk_atom_intern_static_string("_NET_ACTIVE_WINDOW");
|
| - g_net_active_window_atom = gdk_x11_atom_to_xatom_for_display(
|
| - gdk_screen_get_display(gdk_screen_get_default()), net_active_window);
|
| -
|
| - GdkWindow* root = gdk_get_default_root_window();
|
| -
|
| - // Set up X Event filter to listen for PropertyChange X events. These events
|
| - // tell us when the active window changes.
|
| - // Don't use XSelectInput directly here, as gdk internally seems to cache the
|
| - // mask and reapply XSelectInput after this, resetting any mask we set here.
|
| - gdk_window_set_events(root,
|
| - static_cast<GdkEventMask>(gdk_window_get_events(root) |
|
| - GDK_PROPERTY_CHANGE_MASK));
|
| - gdk_window_add_filter(NULL, &ActiveWindowWatcherX::OnWindowXEventThunk, this);
|
| -}
|
| -
|
| void ActiveWindowWatcherX::NotifyActiveWindowChanged() {
|
| // We don't use gdk_screen_get_active_window() because it caches
|
| // whether or not the window manager supports _NET_ACTIVE_WINDOW.
|
| @@ -70,7 +68,7 @@ void ActiveWindowWatcherX::NotifyActiveWindowChanged() {
|
|
|
| XGetWindowProperty(gdk_x11_get_default_xdisplay(),
|
| GDK_WINDOW_XID(gdk_get_default_root_window()),
|
| - g_net_active_window_atom,
|
| + GetAtom(kNetActiveWindow),
|
| 0, // offset into property data to read
|
| 1, // length to get in 32-bit quantities
|
| False, // deleted
|
| @@ -88,25 +86,10 @@ void ActiveWindowWatcherX::NotifyActiveWindowChanged() {
|
| if (format == 32 && num_items == 1) {
|
| int xid = *reinterpret_cast<int*>(property);
|
| GdkWindow* active_window = gdk_window_lookup(xid);
|
| - FOR_EACH_OBSERVER(
|
| - Observer,
|
| - observers_,
|
| - ActiveWindowChanged(active_window));
|
| + FOR_EACH_OBSERVER(Observer, observers_, ActiveWindowChanged(active_window));
|
| }
|
| if (property)
|
| XFree(property);
|
| }
|
|
|
| -GdkFilterReturn ActiveWindowWatcherX::OnWindowXEvent(GdkXEvent* xevent,
|
| - GdkEvent* event) {
|
| - XEvent* xev = static_cast<XEvent*>(xevent);
|
| -
|
| - if (xev->xany.type == PropertyNotify &&
|
| - xev->xproperty.atom == g_net_active_window_atom) {
|
| - NotifyActiveWindowChanged();
|
| - }
|
| -
|
| - return GDK_FILTER_CONTINUE;
|
| -}
|
| -
|
| } // namespace ui
|
|
|