Index: ui/base/x/x11_window_event_manager.h |
diff --git a/ui/base/x/x11_window_event_manager.h b/ui/base/x/x11_window_event_manager.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f9e1ad96907b06633d1e6a43fe5aacb02c8b983b |
--- /dev/null |
+++ b/ui/base/x/x11_window_event_manager.h |
@@ -0,0 +1,81 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef UI_BASE_X_X11_WINDOW_EVENT_MANAGER_H_ |
+#define UI_BASE_X_X11_WINDOW_EVENT_MANAGER_H_ |
+ |
+#include <map> |
+#include <vector> |
+ |
+#include "base/compiler_specific.h" |
+#include "base/macros.h" |
+#include "ui/base/x/ui_base_x_export.h" |
+#include "ui/gfx/x/x11_types.h" |
+ |
+// A process wide singleton for selecting events on X windows which were not |
+// created by Chrome. |
+namespace base { |
+template <typename T> |
+struct DefaultSingletonTraits; |
+} |
+ |
+namespace ui { |
+ |
+// Manages the events that Chrome has selected on X windows which were not |
+// created by Chrome. This class allows several clients to select events |
Daniel Erat
2016/09/07 00:37:33
nit: maybe "... allows multiple clients within Chr
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+// on the same X window. |
+class UI_BASE_X_EXPORT XWindowEventManager { |
+ public: |
+ static XWindowEventManager* GetInstance(); |
+ |
+ class ScopedEventSelector { |
Daniel Erat
2016/09/07 00:37:33
nit: add a comment documenting what this does
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+ public: |
+ ScopedEventSelector(XID xid, uint32_t event_mask); |
+ ~ScopedEventSelector(); |
+ |
+ private: |
+ XID xid_; |
+ uint32_t event_mask_; |
+ }; |
+ |
+ // Guarantees that events on |event_mask| will be reported to Chrome. |
Daniel Erat
2016/09/07 00:37:33
nit: s/on/in/
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+ void SelectEvents(XID xid, uint32_t event_mask); |
Daniel Erat
2016/09/07 00:37:33
under what circumstances would a caller use this i
Tom (Use chromium acct)
2016/09/07 18:02:23
There are some classes where an X window is not bo
Daniel Erat
2016/09/07 20:00:07
okay, but can't X11WholeScreenMoveLoop just have a
|
+ |
+ // Deselects events on |event_mask|. Chrome will stop receiving events for |
+ // any set bit in |event_mask| only if no other client has selected that bit. |
+ void DeselectEvents(XID xid, uint32_t event_mask); |
+ |
+ private: |
+ friend struct base::DefaultSingletonTraits<XWindowEventManager>; |
+ |
+ struct MultiMask { |
Daniel Erat
2016/09/07 00:37:33
this should be a class instead of a struct, since
Tom (Use chromium acct)
2016/09/07 18:02:22
Done.
|
+ MultiMask(); |
+ ~MultiMask(); |
+ |
+ void AddMask(uint32_t mask); |
+ void RemoveMask(uint32_t mask); |
+ uint32_t ToMask() const; |
+ |
+ static constexpr auto kMaskSize = 25; |
+ |
+ unsigned int mask_bits[kMaskSize]; |
Daniel Erat
2016/09/07 00:37:33
rename to mask_bits_; also just make this be an in
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+ }; |
Daniel Erat
2016/09/07 00:37:33
DISALLOW_COPY_AND_ASSIGN(MultiMask);
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+ |
+ XWindowEventManager(); |
+ ~XWindowEventManager(); |
+ |
+ void BeforeMaskChanged(XID xid); |
Daniel Erat
2016/09/07 00:37:33
nit: add comments documenting what these methods d
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+ void AfterMaskChanged(XID xid); |
+ |
+ // State for [Before|After]MaskChanged |
+ uint32_t old_mask_; |
+ |
+ std::map<XID, MultiMask> mask_map_; |
Daniel Erat
2016/09/07 00:37:33
std::unique_ptr<MultiMask>
Tom (Use chromium acct)
2016/09/07 18:02:23
Done.
|
+ |
+ DISALLOW_COPY_AND_ASSIGN(XWindowEventManager); |
+}; |
+ |
+} // namespace ui |
+ |
+#endif // UI_BASE_X_X11_FOREIGN_WINDOW_MANAGER_H_ |