| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef UI_BASE_X_SELECTION_REQUESTOR_H_ | 5 #ifndef UI_BASE_X_SELECTION_REQUESTOR_H_ |
| 6 #define UI_BASE_X_SELECTION_REQUESTOR_H_ | 6 #define UI_BASE_X_SELECTION_REQUESTOR_H_ |
| 7 | 7 |
| 8 #include <X11/Xlib.h> | 8 #include <X11/Xlib.h> |
| 9 | 9 |
| 10 // Get rid of a macro from Xlib.h that conflicts with Aura's RootWindow class. | 10 // Get rid of a macro from Xlib.h that conflicts with Aura's RootWindow class. |
| 11 #undef RootWindow | 11 #undef RootWindow |
| 12 | 12 |
| 13 #include <list> | 13 #include <list> |
| 14 #include <vector> | 14 #include <vector> |
| 15 | 15 |
| 16 #include "base/basictypes.h" | 16 #include "base/basictypes.h" |
| 17 #include "base/callback.h" | 17 #include "base/callback.h" |
| 18 #include "base/event_types.h" |
| 18 #include "base/memory/ref_counted_memory.h" | 19 #include "base/memory/ref_counted_memory.h" |
| 19 #include "ui/base/ui_base_export.h" | 20 #include "ui/base/ui_base_export.h" |
| 20 #include "ui/gfx/x/x11_atom_cache.h" | 21 #include "ui/gfx/x/x11_atom_cache.h" |
| 22 #include "ui/gfx/x/x11_types.h" |
| 21 | 23 |
| 22 namespace ui { | 24 namespace ui { |
| 23 class PlatformEventDispatcher; | 25 class PlatformEventDispatcher; |
| 24 class SelectionData; | 26 class SelectionData; |
| 25 | 27 |
| 26 // Requests and later receives data from the X11 server through the selection | 28 // Requests and later receives data from the X11 server through the selection |
| 27 // system. | 29 // system. |
| 28 // | 30 // |
| 29 // X11 uses a system called "selections" to implement clipboards and drag and | 31 // X11 uses a system called "selections" to implement clipboards and drag and |
| 30 // drop. This class interprets messages from the statefull selection request | 32 // drop. This class interprets messages from the statefull selection request |
| 31 // API. SelectionRequestor should only deal with the X11 details; it does not | 33 // API. SelectionRequestor should only deal with the X11 details; it does not |
| 32 // implement per-component fast-paths. | 34 // implement per-component fast-paths. |
| 33 class UI_BASE_EXPORT SelectionRequestor { | 35 class UI_BASE_EXPORT SelectionRequestor { |
| 34 public: | 36 public: |
| 35 SelectionRequestor(Display* xdisplay, | 37 SelectionRequestor(XDisplay* xdisplay, |
| 36 ::Window xwindow, | 38 XID xwindow, |
| 37 ::Atom selection_name, | 39 XAtom selection_name, |
| 38 PlatformEventDispatcher* dispatcher); | 40 PlatformEventDispatcher* dispatcher); |
| 39 ~SelectionRequestor(); | 41 ~SelectionRequestor(); |
| 40 | 42 |
| 41 // Does the work of requesting |target| from the selection we handle, | 43 // Does the work of requesting |target| from the selection we handle, |
| 42 // spinning up the nested message loop, and reading the resulting data | 44 // spinning up the nested message loop, and reading the resulting data |
| 43 // back. The result is stored in |out_data|. | 45 // back. The result is stored in |out_data|. |
| 44 // |out_data_items| is the length of |out_data| in |out_type| items. | 46 // |out_data_items| is the length of |out_data| in |out_type| items. |
| 45 bool PerformBlockingConvertSelection( | 47 bool PerformBlockingConvertSelection( |
| 46 ::Atom target, | 48 XAtom target, |
| 47 scoped_refptr<base::RefCountedMemory>* out_data, | 49 scoped_refptr<base::RefCountedMemory>* out_data, |
| 48 size_t* out_data_items, | 50 size_t* out_data_items, |
| 49 ::Atom* out_type); | 51 XAtom* out_type); |
| 50 | 52 |
| 51 // Requests |target| from the selection that we handle, passing |parameter| | 53 // Requests |target| from the selection that we handle, passing |parameter| |
| 52 // as a parameter to XConvertSelection(). | 54 // as a parameter to XConvertSelection(). |
| 53 void PerformBlockingConvertSelectionWithParameter( | 55 void PerformBlockingConvertSelectionWithParameter( |
| 54 ::Atom target, | 56 XAtom target, |
| 55 const std::vector< ::Atom>& parameter); | 57 const std::vector<XAtom>& parameter); |
| 56 | 58 |
| 57 // Returns the first of |types| offered by the current selection holder, or | 59 // Returns the first of |types| offered by the current selection holder, or |
| 58 // returns NULL if none of those types are available. | 60 // returns NULL if none of those types are available. |
| 59 SelectionData RequestAndWaitForTypes(const std::vector< ::Atom>& types); | 61 SelectionData RequestAndWaitForTypes(const std::vector<XAtom>& types); |
| 60 | 62 |
| 61 // It is our owner's responsibility to plumb X11 SelectionNotify events on | 63 // It is our owner's responsibility to plumb X11 SelectionNotify events on |
| 62 // |xwindow_| to us. | 64 // |xwindow_| to us. |
| 63 void OnSelectionNotify(const XSelectionEvent& event); | 65 void OnSelectionNotify(const XEvent& event); |
| 64 | 66 |
| 65 private: | 67 private: |
| 66 // A request that has been issued and we are waiting for a response to. | 68 // A request that has been issued and we are waiting for a response to. |
| 67 struct PendingRequest { | 69 struct PendingRequest { |
| 68 explicit PendingRequest(Atom target); | 70 explicit PendingRequest(XAtom target); |
| 69 ~PendingRequest(); | 71 ~PendingRequest(); |
| 70 | 72 |
| 71 // Data to the current XConvertSelection request. Used for error detection; | 73 // Data to the current XConvertSelection request. Used for error detection; |
| 72 // we verify it on the return message. | 74 // we verify it on the return message. |
| 73 ::Atom target; | 75 XAtom target; |
| 74 | 76 |
| 75 // Called to terminate the nested message loop. | 77 // Called to terminate the nested message loop. |
| 76 base::Closure quit_closure; | 78 base::Closure quit_closure; |
| 77 | 79 |
| 78 // The property in the returning SelectNotify message is used to signal | 80 // The property in the returning SelectNotify message is used to signal |
| 79 // success. If None, our request failed somehow. If equal to the property | 81 // success. If None, our request failed somehow. If equal to the property |
| 80 // atom that we sent in the XConvertSelection call, we can read that | 82 // atom that we sent in the XConvertSelection call, we can read that |
| 81 // property on |x_window_| for the requested data. | 83 // property on |x_window_| for the requested data. |
| 82 ::Atom returned_property; | 84 XAtom returned_property; |
| 83 | 85 |
| 84 // Set to true when return_property is populated. | 86 // Set to true when return_property is populated. |
| 85 bool returned; | 87 bool returned; |
| 86 }; | 88 }; |
| 87 | 89 |
| 88 // Blocks till SelectionNotify is received for the target specified in | 90 // Blocks till SelectionNotify is received for the target specified in |
| 89 // |request|. | 91 // |request|. |
| 90 void BlockTillSelectionNotifyForRequest(PendingRequest* request); | 92 void BlockTillSelectionNotifyForRequest(PendingRequest* request); |
| 91 | 93 |
| 92 // Our X11 state. | 94 // Our X11 state. |
| 93 Display* x_display_; | 95 XDisplay* x_display_; |
| 94 ::Window x_window_; | 96 XID x_window_; |
| 95 | 97 |
| 96 // The X11 selection that this instance communicates on. | 98 // The X11 selection that this instance communicates on. |
| 97 ::Atom selection_name_; | 99 XAtom selection_name_; |
| 98 | 100 |
| 99 // Dispatcher which handles SelectionNotify and SelectionRequest for | 101 // Dispatcher which handles SelectionNotify and SelectionRequest for |
| 100 // |selection_name_|. PerformBlockingConvertSelection() calls the | 102 // |selection_name_|. PerformBlockingConvertSelection() calls the |
| 101 // dispatcher directly if PerformBlockingConvertSelection() is called after | 103 // dispatcher directly if PerformBlockingConvertSelection() is called after |
| 102 // the PlatformEventSource is destroyed. | 104 // the PlatformEventSource is destroyed. |
| 103 // Not owned. | 105 // Not owned. |
| 104 PlatformEventDispatcher* dispatcher_; | 106 PlatformEventDispatcher* dispatcher_; |
| 105 | 107 |
| 106 // A list of requests for which we are waiting for responses. | 108 // A list of requests for which we are waiting for responses. |
| 107 std::list<PendingRequest*> pending_requests_; | 109 std::list<PendingRequest*> pending_requests_; |
| 108 | 110 |
| 109 X11AtomCache atom_cache_; | 111 X11AtomCache atom_cache_; |
| 110 | 112 |
| 111 DISALLOW_COPY_AND_ASSIGN(SelectionRequestor); | 113 DISALLOW_COPY_AND_ASSIGN(SelectionRequestor); |
| 112 }; | 114 }; |
| 113 | 115 |
| 114 } // namespace ui | 116 } // namespace ui |
| 115 | 117 |
| 116 #endif // UI_BASE_X_SELECTION_REQUESTOR_H_ | 118 #endif // UI_BASE_X_SELECTION_REQUESTOR_H_ |
| OLD | NEW |