OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "ui/base/x/x11_foreign_window_manager.h" | |
6 | |
7 #include <X11/Xlib.h> | |
8 | |
9 #include "base/memory/singleton.h" | |
10 | |
11 namespace ui { | |
12 | |
13 // static | |
14 XForeignWindowManager* XForeignWindowManager::GetInstance() { | |
15 return Singleton<XForeignWindowManager>::get(); | |
16 } | |
17 | |
18 int XForeignWindowManager::RequestEvents(XID xid, long event_mask) { | |
19 request_map_[xid].push_back(Request(next_request_id_, event_mask)); | |
20 UpdateSelectedEvents(xid); | |
21 return next_request_id_++; | |
22 } | |
23 | |
24 void XForeignWindowManager::CancelRequest(int request_id) { | |
25 for (std::map<XID, RequestList>::iterator map_it = request_map_.begin(); | |
26 map_it != request_map_.end(); ++map_it) { | |
27 RequestList* list = &map_it->second; | |
28 for (RequestList::iterator list_it = list->begin(); | |
29 list_it != list->end(); ++list_it) { | |
30 if (list_it->request_id == request_id) { | |
31 XID xid = map_it->first; | |
32 | |
33 list->erase(list_it); | |
34 if (list->empty()) | |
35 request_map_.erase(map_it); | |
36 UpdateSelectedEvents(xid); | |
37 return; | |
38 } | |
39 } | |
40 } | |
41 } | |
42 | |
43 void XForeignWindowManager::OnWindowDestroyed(XID xid) { | |
44 request_map_.erase(xid); | |
45 } | |
46 | |
47 XForeignWindowManager::XForeignWindowManager() : next_request_id_(0) { | |
48 } | |
49 | |
50 XForeignWindowManager::~XForeignWindowManager() { | |
51 } | |
52 | |
53 void XForeignWindowManager::UpdateSelectedEvents(XID xid) { | |
54 std::map<XID, RequestList>::iterator it = request_map_.find(xid); | |
55 if (it == request_map_.end()) | |
Daniel Erat
2014/07/25 19:38:44
i think there's a bug here. when removing the last
pkotwicz
2014/07/26 20:09:53
You're right. Thanks for catching the bug!
| |
56 return; | |
57 | |
58 long event_mask = NoEventMask; | |
59 const RequestList& list = it->second; | |
60 for (size_t i = 0; i < list.size(); ++i) | |
61 event_mask |= list[i].event_mask; | |
62 | |
63 XSelectInput(gfx::GetXDisplay(), xid, event_mask); | |
Daniel Erat
2014/07/25 19:38:44
do we crash in response to X errors? i'm wondering
pkotwicz
2014/07/26 20:09:53
We do not crash. We just log errors via ui::LogErr
| |
64 } | |
65 | |
66 XForeignWindowManager::Request::Request(int request_id, long event_mask) | |
67 : request_id(request_id), | |
68 event_mask(event_mask) { | |
69 } | |
70 | |
71 XForeignWindowManager::Request::~Request() { | |
72 } | |
73 | |
74 } // namespace ui | |
OLD | NEW |