Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(44)

Side by Side Diff: mojo/services/view_manager/view_manager_service_impl.cc

Issue 513923004: More viewmanager renaming: (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: sim30 Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 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 #include "mojo/services/view_manager/view_manager_service_impl.h" 5 #include "mojo/services/view_manager/view_manager_service_impl.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "mojo/services/public/cpp/geometry/geometry_type_converters.h" 8 #include "mojo/services/public/cpp/geometry/geometry_type_converters.h"
9 #include "mojo/services/public/cpp/input_events/input_events_type_converters.h" 9 #include "mojo/services/public/cpp/input_events/input_events_type_converters.h"
10 #include "mojo/services/view_manager/connection_manager.h"
10 #include "mojo/services/view_manager/default_access_policy.h" 11 #include "mojo/services/view_manager/default_access_policy.h"
11 #include "mojo/services/view_manager/node.h" 12 #include "mojo/services/view_manager/server_view.h"
12 #include "mojo/services/view_manager/root_node_manager.h"
13 #include "mojo/services/view_manager/window_manager_access_policy.h" 13 #include "mojo/services/view_manager/window_manager_access_policy.h"
14 #include "third_party/skia/include/core/SkBitmap.h" 14 #include "third_party/skia/include/core/SkBitmap.h"
15 #include "ui/aura/window.h" 15 #include "ui/aura/window.h"
16 #include "ui/gfx/codec/png_codec.h" 16 #include "ui/gfx/codec/png_codec.h"
17 17
18 namespace mojo { 18 namespace mojo {
19 namespace service { 19 namespace service {
20 20
21 ViewManagerServiceImpl::ViewManagerServiceImpl( 21 ViewManagerServiceImpl::ViewManagerServiceImpl(
22 RootNodeManager* root_node_manager, 22 ConnectionManager* connection_manager,
23 ConnectionSpecificId creator_id, 23 ConnectionSpecificId creator_id,
24 const std::string& creator_url, 24 const std::string& creator_url,
25 const std::string& url, 25 const std::string& url,
26 const NodeId& root_id, 26 const ViewId& root_id,
27 InterfaceRequest<ServiceProvider> service_provider) 27 InterfaceRequest<ServiceProvider> service_provider)
28 : root_node_manager_(root_node_manager), 28 : connection_manager_(connection_manager),
29 id_(root_node_manager_->GetAndAdvanceNextConnectionId()), 29 id_(connection_manager_->GetAndAdvanceNextConnectionId()),
30 url_(url), 30 url_(url),
31 creator_id_(creator_id), 31 creator_id_(creator_id),
32 creator_url_(creator_url), 32 creator_url_(creator_url),
33 delete_on_connection_error_(false), 33 delete_on_connection_error_(false),
34 service_provider_(service_provider.Pass()) { 34 service_provider_(service_provider.Pass()) {
35 CHECK(GetNode(root_id)); 35 CHECK(GetView(root_id));
36 roots_.insert(NodeIdToTransportId(root_id)); 36 roots_.insert(ViewIdToTransportId(root_id));
37 if (root_id == RootNodeId()) 37 if (root_id == RootViewId())
38 access_policy_.reset(new WindowManagerAccessPolicy(id_, this)); 38 access_policy_.reset(new WindowManagerAccessPolicy(id_, this));
39 else 39 else
40 access_policy_.reset(new DefaultAccessPolicy(id_, this)); 40 access_policy_.reset(new DefaultAccessPolicy(id_, this));
41 } 41 }
42 42
43 ViewManagerServiceImpl::~ViewManagerServiceImpl() { 43 ViewManagerServiceImpl::~ViewManagerServiceImpl() {
44 // Delete any nodes we created. 44 // Delete any views we created.
45 if (!node_map_.empty()) { 45 if (!view_map_.empty()) {
46 RootNodeManager::ScopedChange change(this, root_node_manager_, true); 46 ConnectionManager::ScopedChange change(this, connection_manager_, true);
47 while (!node_map_.empty()) 47 while (!view_map_.empty())
48 delete node_map_.begin()->second; 48 delete view_map_.begin()->second;
49 } 49 }
50 50
51 root_node_manager_->RemoveConnection(this); 51 connection_manager_->RemoveConnection(this);
52 } 52 }
53 53
54 const Node* ViewManagerServiceImpl::GetNode(const NodeId& id) const { 54 const ServerView* ViewManagerServiceImpl::GetView(const ViewId& id) const {
55 if (id_ == id.connection_id) { 55 if (id_ == id.connection_id) {
56 NodeMap::const_iterator i = node_map_.find(id.node_id); 56 ViewMap::const_iterator i = view_map_.find(id.view_id);
57 return i == node_map_.end() ? NULL : i->second; 57 return i == view_map_.end() ? NULL : i->second;
58 } 58 }
59 return root_node_manager_->GetNode(id); 59 return connection_manager_->GetView(id);
60 } 60 }
61 61
62 bool ViewManagerServiceImpl::HasRoot(const NodeId& id) const { 62 bool ViewManagerServiceImpl::HasRoot(const ViewId& id) const {
63 return roots_.find(NodeIdToTransportId(id)) != roots_.end(); 63 return roots_.find(ViewIdToTransportId(id)) != roots_.end();
64 } 64 }
65 65
66 void ViewManagerServiceImpl::OnViewManagerServiceImplDestroyed( 66 void ViewManagerServiceImpl::OnViewManagerServiceImplDestroyed(
67 ConnectionSpecificId id) { 67 ConnectionSpecificId id) {
68 if (creator_id_ == id) 68 if (creator_id_ == id)
69 creator_id_ = kInvalidConnectionId; 69 creator_id_ = kInvalidConnectionId;
70 } 70 }
71 71
72 void ViewManagerServiceImpl::ProcessNodeBoundsChanged( 72 void ViewManagerServiceImpl::ProcessViewBoundsChanged(
73 const Node* node, 73 const ServerView* view,
74 const gfx::Rect& old_bounds, 74 const gfx::Rect& old_bounds,
75 const gfx::Rect& new_bounds, 75 const gfx::Rect& new_bounds,
76 bool originated_change) { 76 bool originated_change) {
77 if (originated_change || !IsNodeKnown(node)) 77 if (originated_change || !IsViewKnown(view))
78 return; 78 return;
79 client()->OnViewBoundsChanged(NodeIdToTransportId(node->id()), 79 client()->OnViewBoundsChanged(ViewIdToTransportId(view->id()),
80 Rect::From(old_bounds), 80 Rect::From(old_bounds),
81 Rect::From(new_bounds)); 81 Rect::From(new_bounds));
82 } 82 }
83 83
84 void ViewManagerServiceImpl::ProcessNodeHierarchyChanged( 84 void ViewManagerServiceImpl::ProcessViewHierarchyChanged(
85 const Node* node, 85 const ServerView* view,
86 const Node* new_parent, 86 const ServerView* new_parent,
87 const Node* old_parent, 87 const ServerView* old_parent,
88 bool originated_change) { 88 bool originated_change) {
89 if (originated_change && !IsNodeKnown(node) && new_parent && 89 if (originated_change && !IsViewKnown(view) && new_parent &&
90 IsNodeKnown(new_parent)) { 90 IsViewKnown(new_parent)) {
91 std::vector<const Node*> unused; 91 std::vector<const ServerView*> unused;
92 GetUnknownNodesFrom(node, &unused); 92 GetUnknownViewsFrom(view, &unused);
93 } 93 }
94 if (originated_change || root_node_manager_->is_processing_delete_node() || 94 if (originated_change || connection_manager_->is_processing_delete_view() ||
95 root_node_manager_->DidConnectionMessageClient(id_)) { 95 connection_manager_->DidConnectionMessageClient(id_)) {
96 return; 96 return;
97 } 97 }
98 98
99 if (!access_policy_->ShouldNotifyOnHierarchyChange( 99 if (!access_policy_->ShouldNotifyOnHierarchyChange(
100 node, &new_parent, &old_parent)) { 100 view, &new_parent, &old_parent)) {
101 return; 101 return;
102 } 102 }
103 // Inform the client of any new nodes and update the set of nodes we know 103 // Inform the client of any new views and update the set of views we know
104 // about. 104 // about.
105 std::vector<const Node*> to_send; 105 std::vector<const ServerView*> to_send;
106 if (!IsNodeKnown(node)) 106 if (!IsViewKnown(view))
107 GetUnknownNodesFrom(node, &to_send); 107 GetUnknownViewsFrom(view, &to_send);
108 const NodeId new_parent_id(new_parent ? new_parent->id() : NodeId()); 108 const ViewId new_parent_id(new_parent ? new_parent->id() : ViewId());
109 const NodeId old_parent_id(old_parent ? old_parent->id() : NodeId()); 109 const ViewId old_parent_id(old_parent ? old_parent->id() : ViewId());
110 client()->OnViewHierarchyChanged(NodeIdToTransportId(node->id()), 110 client()->OnViewHierarchyChanged(ViewIdToTransportId(view->id()),
111 NodeIdToTransportId(new_parent_id), 111 ViewIdToTransportId(new_parent_id),
112 NodeIdToTransportId(old_parent_id), 112 ViewIdToTransportId(old_parent_id),
113 NodesToViewDatas(to_send)); 113 ViewsToViewDatas(to_send));
114 root_node_manager_->OnConnectionMessagedClient(id_); 114 connection_manager_->OnConnectionMessagedClient(id_);
115 } 115 }
116 116
117 void ViewManagerServiceImpl::ProcessNodeReorder(const Node* node, 117 void ViewManagerServiceImpl::ProcessViewReorder(const ServerView* view,
118 const Node* relative_node, 118 const ServerView* relative_view,
119 OrderDirection direction, 119 OrderDirection direction,
120 bool originated_change) { 120 bool originated_change) {
121 if (originated_change || !IsNodeKnown(node) || !IsNodeKnown(relative_node)) 121 if (originated_change || !IsViewKnown(view) || !IsViewKnown(relative_view))
122 return; 122 return;
123 123
124 client()->OnViewReordered(NodeIdToTransportId(node->id()), 124 client()->OnViewReordered(ViewIdToTransportId(view->id()),
125 NodeIdToTransportId(relative_node->id()), 125 ViewIdToTransportId(relative_view->id()),
126 direction); 126 direction);
127 } 127 }
128 128
129 void ViewManagerServiceImpl::ProcessNodeDeleted(const NodeId& node, 129 void ViewManagerServiceImpl::ProcessViewDeleted(const ViewId& view,
130 bool originated_change) { 130 bool originated_change) {
131 node_map_.erase(node.node_id); 131 view_map_.erase(view.view_id);
132 132
133 const bool in_known = known_nodes_.erase(NodeIdToTransportId(node)) > 0; 133 const bool in_known = known_views_.erase(ViewIdToTransportId(view)) > 0;
134 roots_.erase(NodeIdToTransportId(node)); 134 roots_.erase(ViewIdToTransportId(view));
135 135
136 if (originated_change) 136 if (originated_change)
137 return; 137 return;
138 138
139 if (in_known) { 139 if (in_known) {
140 client()->OnViewDeleted(NodeIdToTransportId(node)); 140 client()->OnViewDeleted(ViewIdToTransportId(view));
141 root_node_manager_->OnConnectionMessagedClient(id_); 141 connection_manager_->OnConnectionMessagedClient(id_);
142 } 142 }
143 } 143 }
144 144
145 void ViewManagerServiceImpl::OnConnectionError() { 145 void ViewManagerServiceImpl::OnConnectionError() {
146 if (delete_on_connection_error_) 146 if (delete_on_connection_error_)
147 delete this; 147 delete this;
148 } 148 }
149 149
150 bool ViewManagerServiceImpl::IsNodeKnown(const Node* node) const { 150 bool ViewManagerServiceImpl::IsViewKnown(const ServerView* view) const {
151 return known_nodes_.count(NodeIdToTransportId(node->id())) > 0; 151 return known_views_.count(ViewIdToTransportId(view->id())) > 0;
152 } 152 }
153 153
154 bool ViewManagerServiceImpl::CanReorderNode(const Node* node, 154 bool ViewManagerServiceImpl::CanReorderView(const ServerView* view,
155 const Node* relative_node, 155 const ServerView* relative_view,
156 OrderDirection direction) const { 156 OrderDirection direction) const {
157 if (!node || !relative_node) 157 if (!view || !relative_view)
158 return false; 158 return false;
159 159
160 if (!node->parent() || node->parent() != relative_node->parent()) 160 if (!view->parent() || view->parent() != relative_view->parent())
161 return false; 161 return false;
162 162
163 if (!access_policy_->CanReorderNode(node, relative_node, direction)) 163 if (!access_policy_->CanReorderView(view, relative_view, direction))
164 return false; 164 return false;
165 165
166 std::vector<const Node*> children = node->parent()->GetChildren(); 166 std::vector<const ServerView*> children = view->parent()->GetChildren();
167 const size_t child_i = 167 const size_t child_i =
168 std::find(children.begin(), children.end(), node) - children.begin(); 168 std::find(children.begin(), children.end(), view) - children.begin();
169 const size_t target_i = 169 const size_t target_i =
170 std::find(children.begin(), children.end(), relative_node) - 170 std::find(children.begin(), children.end(), relative_view) -
171 children.begin(); 171 children.begin();
172 if ((direction == ORDER_DIRECTION_ABOVE && child_i == target_i + 1) || 172 if ((direction == ORDER_DIRECTION_ABOVE && child_i == target_i + 1) ||
173 (direction == ORDER_DIRECTION_BELOW && child_i + 1 == target_i)) { 173 (direction == ORDER_DIRECTION_BELOW && child_i + 1 == target_i)) {
174 return false; 174 return false;
175 } 175 }
176 176
177 return true; 177 return true;
178 } 178 }
179 179
180 bool ViewManagerServiceImpl::DeleteNodeImpl(ViewManagerServiceImpl* source, 180 bool ViewManagerServiceImpl::DeleteViewImpl(ViewManagerServiceImpl* source,
181 Node* node) { 181 ServerView* view) {
182 DCHECK(node); 182 DCHECK(view);
183 DCHECK_EQ(node->id().connection_id, id_); 183 DCHECK_EQ(view->id().connection_id, id_);
184 RootNodeManager::ScopedChange change(source, root_node_manager_, true); 184 ConnectionManager::ScopedChange change(source, connection_manager_, true);
185 delete node; 185 delete view;
186 return true; 186 return true;
187 } 187 }
188 188
189 void ViewManagerServiceImpl::GetUnknownNodesFrom( 189 void ViewManagerServiceImpl::GetUnknownViewsFrom(
190 const Node* node, 190 const ServerView* view,
191 std::vector<const Node*>* nodes) { 191 std::vector<const ServerView*>* views) {
192 if (IsNodeKnown(node) || !access_policy_->CanGetNodeTree(node)) 192 if (IsViewKnown(view) || !access_policy_->CanGetViewTree(view))
193 return; 193 return;
194 nodes->push_back(node); 194 views->push_back(view);
195 known_nodes_.insert(NodeIdToTransportId(node->id())); 195 known_views_.insert(ViewIdToTransportId(view->id()));
196 if (!access_policy_->CanDescendIntoNodeForNodeTree(node)) 196 if (!access_policy_->CanDescendIntoViewForViewTree(view))
197 return; 197 return;
198 std::vector<const Node*> children(node->GetChildren()); 198 std::vector<const ServerView*> children(view->GetChildren());
199 for (size_t i = 0 ; i < children.size(); ++i) 199 for (size_t i = 0 ; i < children.size(); ++i)
200 GetUnknownNodesFrom(children[i], nodes); 200 GetUnknownViewsFrom(children[i], views);
201 } 201 }
202 202
203 void ViewManagerServiceImpl::RemoveFromKnown(const Node* node, 203 void ViewManagerServiceImpl::RemoveFromKnown(
204 std::vector<Node*>* local_nodes) { 204 const ServerView* view,
205 if (node->id().connection_id == id_) { 205 std::vector<ServerView*>* local_views) {
206 if (local_nodes) 206 if (view->id().connection_id == id_) {
207 local_nodes->push_back(GetNode(node->id())); 207 if (local_views)
208 local_views->push_back(GetView(view->id()));
208 return; 209 return;
209 } 210 }
210 known_nodes_.erase(NodeIdToTransportId(node->id())); 211 known_views_.erase(ViewIdToTransportId(view->id()));
211 std::vector<const Node*> children = node->GetChildren(); 212 std::vector<const ServerView*> children = view->GetChildren();
212 for (size_t i = 0; i < children.size(); ++i) 213 for (size_t i = 0; i < children.size(); ++i)
213 RemoveFromKnown(children[i], local_nodes); 214 RemoveFromKnown(children[i], local_views);
214 } 215 }
215 216
216 void ViewManagerServiceImpl::AddRoot( 217 void ViewManagerServiceImpl::AddRoot(
217 const NodeId& node_id, 218 const ViewId& view_id,
218 InterfaceRequest<ServiceProvider> service_provider) { 219 InterfaceRequest<ServiceProvider> service_provider) {
219 const Id transport_node_id(NodeIdToTransportId(node_id)); 220 const Id transport_view_id(ViewIdToTransportId(view_id));
220 CHECK(roots_.count(transport_node_id) == 0); 221 CHECK(roots_.count(transport_view_id) == 0);
221 222
222 CHECK_EQ(creator_id_, node_id.connection_id); 223 CHECK_EQ(creator_id_, view_id.connection_id);
223 roots_.insert(transport_node_id); 224 roots_.insert(transport_view_id);
224 const Node* node = GetNode(node_id); 225 const ServerView* view = GetView(view_id);
225 CHECK(node); 226 CHECK(view);
226 std::vector<const Node*> to_send; 227 std::vector<const ServerView*> to_send;
227 if (!IsNodeKnown(node)) { 228 if (!IsViewKnown(view)) {
228 GetUnknownNodesFrom(node, &to_send); 229 GetUnknownViewsFrom(view, &to_send);
229 } else { 230 } else {
230 // Even though the connection knows about the new root we need to tell it 231 // Even though the connection knows about the new root we need to tell it
231 // |node| is now a root. 232 // |view| is now a root.
232 to_send.push_back(node); 233 to_send.push_back(view);
233 } 234 }
234 235
235 client()->OnEmbed(id_, creator_url_, NodeToViewData(to_send.front()), 236 client()->OnEmbed(id_,
237 creator_url_,
238 ViewToViewData(to_send.front()),
236 service_provider.Pass()); 239 service_provider.Pass());
237 root_node_manager_->OnConnectionMessagedClient(id_); 240 connection_manager_->OnConnectionMessagedClient(id_);
238 } 241 }
239 242
240 void ViewManagerServiceImpl::RemoveRoot(const NodeId& node_id) { 243 void ViewManagerServiceImpl::RemoveRoot(const ViewId& view_id) {
241 const Id transport_node_id(NodeIdToTransportId(node_id)); 244 const Id transport_view_id(ViewIdToTransportId(view_id));
242 CHECK(roots_.count(transport_node_id) > 0); 245 CHECK(roots_.count(transport_view_id) > 0);
243 246
244 roots_.erase(transport_node_id); 247 roots_.erase(transport_view_id);
245 248
246 // No need to do anything if we created the node. 249 // No need to do anything if we created the view.
247 if (node_id.connection_id == id_) 250 if (view_id.connection_id == id_)
248 return; 251 return;
249 252
250 client()->OnViewDeleted(transport_node_id); 253 client()->OnViewDeleted(transport_view_id);
251 root_node_manager_->OnConnectionMessagedClient(id_); 254 connection_manager_->OnConnectionMessagedClient(id_);
252 255
253 // This connection no longer knows about the node. Unparent any nodes that 256 // This connection no longer knows about the view. Unparent any views that
254 // were parented to nodes in the root. 257 // were parented to views in the root.
255 std::vector<Node*> local_nodes; 258 std::vector<ServerView*> local_views;
256 RemoveFromKnown(GetNode(node_id), &local_nodes); 259 RemoveFromKnown(GetView(view_id), &local_views);
257 for (size_t i = 0; i < local_nodes.size(); ++i) 260 for (size_t i = 0; i < local_views.size(); ++i)
258 local_nodes[i]->parent()->Remove(local_nodes[i]); 261 local_views[i]->parent()->Remove(local_views[i]);
259 } 262 }
260 263
261 void ViewManagerServiceImpl::RemoveChildrenAsPartOfEmbed( 264 void ViewManagerServiceImpl::RemoveChildrenAsPartOfEmbed(
262 const NodeId& node_id) { 265 const ViewId& view_id) {
263 Node* node = GetNode(node_id); 266 ServerView* view = GetView(view_id);
264 CHECK(node); 267 CHECK(view);
265 CHECK(node->id().connection_id == node_id.connection_id); 268 CHECK(view->id().connection_id == view_id.connection_id);
266 std::vector<Node*> children = node->GetChildren(); 269 std::vector<ServerView*> children = view->GetChildren();
267 for (size_t i = 0; i < children.size(); ++i) 270 for (size_t i = 0; i < children.size(); ++i)
268 node->Remove(children[i]); 271 view->Remove(children[i]);
269 } 272 }
270 273
271 Array<ViewDataPtr> ViewManagerServiceImpl::NodesToViewDatas( 274 Array<ViewDataPtr> ViewManagerServiceImpl::ViewsToViewDatas(
272 const std::vector<const Node*>& nodes) { 275 const std::vector<const ServerView*>& views) {
273 Array<ViewDataPtr> array(nodes.size()); 276 Array<ViewDataPtr> array(views.size());
274 for (size_t i = 0; i < nodes.size(); ++i) 277 for (size_t i = 0; i < views.size(); ++i)
275 array[i] = NodeToViewData(nodes[i]).Pass(); 278 array[i] = ViewToViewData(views[i]).Pass();
276 return array.Pass(); 279 return array.Pass();
277 } 280 }
278 281
279 ViewDataPtr ViewManagerServiceImpl::NodeToViewData(const Node* node) { 282 ViewDataPtr ViewManagerServiceImpl::ViewToViewData(const ServerView* view) {
280 DCHECK(IsNodeKnown(node)); 283 DCHECK(IsViewKnown(view));
281 const Node* parent = node->parent(); 284 const ServerView* parent = view->parent();
282 // If the parent isn't known, it means the parent is not visible to us (not 285 // If the parent isn't known, it means the parent is not visible to us (not
283 // in roots), and should not be sent over. 286 // in roots), and should not be sent over.
284 if (parent && !IsNodeKnown(parent)) 287 if (parent && !IsViewKnown(parent))
285 parent = NULL; 288 parent = NULL;
286 ViewDataPtr view_data(ViewData::New()); 289 ViewDataPtr view_data(ViewData::New());
287 view_data->parent_id = NodeIdToTransportId(parent ? parent->id() : NodeId()); 290 view_data->parent_id = ViewIdToTransportId(parent ? parent->id() : ViewId());
288 view_data->view_id = NodeIdToTransportId(node->id()); 291 view_data->view_id = ViewIdToTransportId(view->id());
289 view_data->bounds = Rect::From(node->bounds()); 292 view_data->bounds = Rect::From(view->bounds());
290 return view_data.Pass(); 293 return view_data.Pass();
291 } 294 }
292 295
293 void ViewManagerServiceImpl::GetNodeTreeImpl( 296 void ViewManagerServiceImpl::GetViewTreeImpl(
294 const Node* node, 297 const ServerView* view,
295 std::vector<const Node*>* nodes) const { 298 std::vector<const ServerView*>* views) const {
296 DCHECK(node); 299 DCHECK(view);
297 300
298 if (!access_policy_->CanGetNodeTree(node)) 301 if (!access_policy_->CanGetViewTree(view))
299 return; 302 return;
300 303
301 nodes->push_back(node); 304 views->push_back(view);
302 305
303 if (!access_policy_->CanDescendIntoNodeForNodeTree(node)) 306 if (!access_policy_->CanDescendIntoViewForViewTree(view))
304 return; 307 return;
305 308
306 std::vector<const Node*> children(node->GetChildren()); 309 std::vector<const ServerView*> children(view->GetChildren());
307 for (size_t i = 0 ; i < children.size(); ++i) 310 for (size_t i = 0 ; i < children.size(); ++i)
308 GetNodeTreeImpl(children[i], nodes); 311 GetViewTreeImpl(children[i], views);
309 } 312 }
310 313
311 void ViewManagerServiceImpl::CreateView( 314 void ViewManagerServiceImpl::CreateView(
312 Id transport_view_id, 315 Id transport_view_id,
313 const Callback<void(ErrorCode)>& callback) { 316 const Callback<void(ErrorCode)>& callback) {
314 const NodeId node_id(NodeIdFromTransportId(transport_view_id)); 317 const ViewId view_id(ViewIdFromTransportId(transport_view_id));
315 ErrorCode error_code = ERROR_CODE_NONE; 318 ErrorCode error_code = ERROR_CODE_NONE;
316 if (node_id.connection_id != id_) { 319 if (view_id.connection_id != id_) {
317 error_code = ERROR_CODE_ILLEGAL_ARGUMENT; 320 error_code = ERROR_CODE_ILLEGAL_ARGUMENT;
318 } else if (node_map_.find(node_id.node_id) != node_map_.end()) { 321 } else if (view_map_.find(view_id.view_id) != view_map_.end()) {
319 error_code = ERROR_CODE_VALUE_IN_USE; 322 error_code = ERROR_CODE_VALUE_IN_USE;
320 } else { 323 } else {
321 node_map_[node_id.node_id] = new Node(root_node_manager_, node_id); 324 view_map_[view_id.view_id] = new ServerView(connection_manager_, view_id);
322 known_nodes_.insert(transport_view_id); 325 known_views_.insert(transport_view_id);
323 } 326 }
324 callback.Run(error_code); 327 callback.Run(error_code);
325 } 328 }
326 329
327 void ViewManagerServiceImpl::DeleteView( 330 void ViewManagerServiceImpl::DeleteView(
328 Id transport_view_id, 331 Id transport_view_id,
329 const Callback<void(bool)>& callback) { 332 const Callback<void(bool)>& callback) {
330 Node* node = GetNode(NodeIdFromTransportId(transport_view_id)); 333 ServerView* view = GetView(ViewIdFromTransportId(transport_view_id));
331 bool success = false; 334 bool success = false;
332 if (node && access_policy_->CanDeleteNode(node)) { 335 if (view && access_policy_->CanDeleteView(view)) {
333 ViewManagerServiceImpl* connection = root_node_manager_->GetConnection( 336 ViewManagerServiceImpl* connection =
334 node->id().connection_id); 337 connection_manager_->GetConnection(view->id().connection_id);
335 success = connection && connection->DeleteNodeImpl(this, node); 338 success = connection && connection->DeleteViewImpl(this, view);
336 } 339 }
337 callback.Run(success); 340 callback.Run(success);
338 } 341 }
339 342
340 void ViewManagerServiceImpl::AddView( 343 void ViewManagerServiceImpl::AddView(
341 Id parent_id, 344 Id parent_id,
342 Id child_id, 345 Id child_id,
343 const Callback<void(bool)>& callback) { 346 const Callback<void(bool)>& callback) {
344 bool success = false; 347 bool success = false;
345 Node* parent = GetNode(NodeIdFromTransportId(parent_id)); 348 ServerView* parent = GetView(ViewIdFromTransportId(parent_id));
346 Node* child = GetNode(NodeIdFromTransportId(child_id)); 349 ServerView* child = GetView(ViewIdFromTransportId(child_id));
347 if (parent && child && child->parent() != parent && 350 if (parent && child && child->parent() != parent &&
348 !child->Contains(parent) && access_policy_->CanAddNode(parent, child)) { 351 !child->Contains(parent) && access_policy_->CanAddView(parent, child)) {
349 success = true; 352 success = true;
350 RootNodeManager::ScopedChange change(this, root_node_manager_, false); 353 ConnectionManager::ScopedChange change(this, connection_manager_, false);
351 parent->Add(child); 354 parent->Add(child);
352 } 355 }
353 callback.Run(success); 356 callback.Run(success);
354 } 357 }
355 358
356 void ViewManagerServiceImpl::RemoveViewFromParent( 359 void ViewManagerServiceImpl::RemoveViewFromParent(
357 Id view_id, 360 Id view_id,
358 const Callback<void(bool)>& callback) { 361 const Callback<void(bool)>& callback) {
359 bool success = false; 362 bool success = false;
360 Node* node = GetNode(NodeIdFromTransportId(view_id)); 363 ServerView* view = GetView(ViewIdFromTransportId(view_id));
361 if (node && node->parent() && 364 if (view && view->parent() && access_policy_->CanRemoveViewFromParent(view)) {
362 access_policy_->CanRemoveNodeFromParent(node)) {
363 success = true; 365 success = true;
364 RootNodeManager::ScopedChange change(this, root_node_manager_, false); 366 ConnectionManager::ScopedChange change(this, connection_manager_, false);
365 node->parent()->Remove(node); 367 view->parent()->Remove(view);
366 } 368 }
367 callback.Run(success); 369 callback.Run(success);
368 } 370 }
369 371
370 void ViewManagerServiceImpl::ReorderView(Id view_id, 372 void ViewManagerServiceImpl::ReorderView(Id view_id,
371 Id relative_view_id, 373 Id relative_view_id,
372 OrderDirection direction, 374 OrderDirection direction,
373 const Callback<void(bool)>& callback) { 375 const Callback<void(bool)>& callback) {
374 bool success = false; 376 bool success = false;
375 Node* node = GetNode(NodeIdFromTransportId(view_id)); 377 ServerView* view = GetView(ViewIdFromTransportId(view_id));
376 Node* relative_node = GetNode(NodeIdFromTransportId(relative_view_id)); 378 ServerView* relative_view = GetView(ViewIdFromTransportId(relative_view_id));
377 if (CanReorderNode(node, relative_node, direction)) { 379 if (CanReorderView(view, relative_view, direction)) {
378 success = true; 380 success = true;
379 RootNodeManager::ScopedChange change(this, root_node_manager_, false); 381 ConnectionManager::ScopedChange change(this, connection_manager_, false);
380 node->parent()->Reorder(node, relative_node, direction); 382 view->parent()->Reorder(view, relative_view, direction);
381 root_node_manager_->ProcessNodeReorder(node, relative_node, direction); 383 connection_manager_->ProcessViewReorder(view, relative_view, direction);
382 } 384 }
383 callback.Run(success); 385 callback.Run(success);
384 } 386 }
385 387
386 void ViewManagerServiceImpl::GetViewTree( 388 void ViewManagerServiceImpl::GetViewTree(
387 Id view_id, 389 Id view_id,
388 const Callback<void(Array<ViewDataPtr>)>& callback) { 390 const Callback<void(Array<ViewDataPtr>)>& callback) {
389 Node* node = GetNode(NodeIdFromTransportId(view_id)); 391 ServerView* view = GetView(ViewIdFromTransportId(view_id));
390 std::vector<const Node*> nodes; 392 std::vector<const ServerView*> views;
391 if (node) { 393 if (view) {
392 GetNodeTreeImpl(node, &nodes); 394 GetViewTreeImpl(view, &views);
393 // TODO(sky): this should map in nodes that weren't none. 395 // TODO(sky): this should map in views that weren't none.
394 } 396 }
395 callback.Run(NodesToViewDatas(nodes)); 397 callback.Run(ViewsToViewDatas(views));
396 } 398 }
397 399
398 void ViewManagerServiceImpl::SetViewContents( 400 void ViewManagerServiceImpl::SetViewContents(
399 Id view_id, 401 Id view_id,
400 ScopedSharedBufferHandle buffer, 402 ScopedSharedBufferHandle buffer,
401 uint32_t buffer_size, 403 uint32_t buffer_size,
402 const Callback<void(bool)>& callback) { 404 const Callback<void(bool)>& callback) {
403 // TODO(sky): add coverage of not being able to set for random node. 405 // TODO(sky): add coverage of not being able to set for random view.
404 Node* node = GetNode(NodeIdFromTransportId(view_id)); 406 ServerView* view = GetView(ViewIdFromTransportId(view_id));
405 if (!node || !access_policy_->CanSetNodeContents(node)) { 407 if (!view || !access_policy_->CanSetViewContents(view)) {
406 callback.Run(false); 408 callback.Run(false);
407 return; 409 return;
408 } 410 }
409 void* handle_data; 411 void* handle_data;
410 if (MapBuffer(buffer.get(), 0, buffer_size, &handle_data, 412 if (MapBuffer(buffer.get(), 0, buffer_size, &handle_data,
411 MOJO_MAP_BUFFER_FLAG_NONE) != MOJO_RESULT_OK) { 413 MOJO_MAP_BUFFER_FLAG_NONE) != MOJO_RESULT_OK) {
412 callback.Run(false); 414 callback.Run(false);
413 return; 415 return;
414 } 416 }
415 SkBitmap bitmap; 417 SkBitmap bitmap;
416 gfx::PNGCodec::Decode(static_cast<const unsigned char*>(handle_data), 418 gfx::PNGCodec::Decode(static_cast<const unsigned char*>(handle_data),
417 buffer_size, &bitmap); 419 buffer_size, &bitmap);
418 node->SetBitmap(bitmap); 420 view->SetBitmap(bitmap);
419 UnmapBuffer(handle_data); 421 UnmapBuffer(handle_data);
420 callback.Run(true); 422 callback.Run(true);
421 } 423 }
422 424
423 void ViewManagerServiceImpl::SetViewBounds( 425 void ViewManagerServiceImpl::SetViewBounds(
424 Id view_id, 426 Id view_id,
425 RectPtr bounds, 427 RectPtr bounds,
426 const Callback<void(bool)>& callback) { 428 const Callback<void(bool)>& callback) {
427 Node* node = GetNode(NodeIdFromTransportId(view_id)); 429 ServerView* view = GetView(ViewIdFromTransportId(view_id));
428 const bool success = node && access_policy_->CanSetNodeBounds(node); 430 const bool success = view && access_policy_->CanSetViewBounds(view);
429 if (success) { 431 if (success) {
430 RootNodeManager::ScopedChange change(this, root_node_manager_, false); 432 ConnectionManager::ScopedChange change(this, connection_manager_, false);
431 node->SetBounds(bounds.To<gfx::Rect>()); 433 view->SetBounds(bounds.To<gfx::Rect>());
432 } 434 }
433 callback.Run(success); 435 callback.Run(success);
434 } 436 }
435 437
436 void ViewManagerServiceImpl::SetViewVisibility( 438 void ViewManagerServiceImpl::SetViewVisibility(
437 Id transport_view_id, 439 Id transport_view_id,
438 bool visible, 440 bool visible,
439 const Callback<void(bool)>& callback) { 441 const Callback<void(bool)>& callback) {
440 Node* node = GetNode(NodeIdFromTransportId(transport_view_id)); 442 ServerView* view = GetView(ViewIdFromTransportId(transport_view_id));
441 const bool success = node && node->visible() != visible && 443 const bool success = view && view->visible() != visible &&
442 access_policy_->CanChangeNodeVisibility(node); 444 access_policy_->CanChangeViewVisibility(view);
443 if (success) { 445 if (success) {
444 DCHECK(node); 446 DCHECK(view);
445 node->SetVisible(visible); 447 view->SetVisible(visible);
446 } 448 }
447 // TODO(sky): need to notify of visibility changes. 449 // TODO(sky): need to notify of visibility changes.
448 callback.Run(success); 450 callback.Run(success);
449 } 451 }
450 452
451 void ViewManagerServiceImpl::Embed( 453 void ViewManagerServiceImpl::Embed(
452 const String& url, 454 const String& url,
453 Id transport_view_id, 455 Id transport_view_id,
454 ServiceProviderPtr service_provider, 456 ServiceProviderPtr service_provider,
455 const Callback<void(bool)>& callback) { 457 const Callback<void(bool)>& callback) {
456 InterfaceRequest<ServiceProvider> spir; 458 InterfaceRequest<ServiceProvider> spir;
457 spir.Bind(service_provider.PassMessagePipe()); 459 spir.Bind(service_provider.PassMessagePipe());
458 460
459 if (NodeIdFromTransportId(transport_view_id) == InvalidNodeId()) { 461 if (ViewIdFromTransportId(transport_view_id) == InvalidViewId()) {
460 root_node_manager_->EmbedRoot(url, spir.Pass()); 462 connection_manager_->EmbedRoot(url, spir.Pass());
461 callback.Run(true); 463 callback.Run(true);
462 return; 464 return;
463 } 465 }
464 const Node* node = GetNode(NodeIdFromTransportId(transport_view_id)); 466 const ServerView* view = GetView(ViewIdFromTransportId(transport_view_id));
465 bool success = node && access_policy_->CanEmbed(node); 467 bool success = view && access_policy_->CanEmbed(view);
466 if (success) { 468 if (success) {
467 // Only allow a node to be the root for one connection. 469 // Only allow a view to be the root for one connection.
468 const NodeId node_id(NodeIdFromTransportId(transport_view_id)); 470 const ViewId view_id(ViewIdFromTransportId(transport_view_id));
469 ViewManagerServiceImpl* connection_by_url = 471 ViewManagerServiceImpl* connection_by_url =
470 root_node_manager_->GetConnectionByCreator(id_, url.To<std::string>()); 472 connection_manager_->GetConnectionByCreator(id_, url.To<std::string>());
471 ViewManagerServiceImpl* connection_with_node_as_root = 473 ViewManagerServiceImpl* connection_with_view_as_root =
472 root_node_manager_->GetConnectionWithRoot(node_id); 474 connection_manager_->GetConnectionWithRoot(view_id);
473 if ((connection_by_url != connection_with_node_as_root || 475 if ((connection_by_url != connection_with_view_as_root ||
474 (!connection_by_url && !connection_with_node_as_root)) && 476 (!connection_by_url && !connection_with_view_as_root)) &&
475 (!connection_by_url || !connection_by_url->HasRoot(node_id))) { 477 (!connection_by_url || !connection_by_url->HasRoot(view_id))) {
476 RootNodeManager::ScopedChange change(this, root_node_manager_, true); 478 ConnectionManager::ScopedChange change(this, connection_manager_, true);
477 RemoveChildrenAsPartOfEmbed(node_id); 479 RemoveChildrenAsPartOfEmbed(view_id);
478 // Never message the originating connection. 480 // Never message the originating connection.
479 root_node_manager_->OnConnectionMessagedClient(id_); 481 connection_manager_->OnConnectionMessagedClient(id_);
480 if (connection_with_node_as_root) 482 if (connection_with_view_as_root)
481 connection_with_node_as_root->RemoveRoot(node_id); 483 connection_with_view_as_root->RemoveRoot(view_id);
482 if (connection_by_url) { 484 if (connection_by_url) {
483 connection_by_url->AddRoot(node_id, spir.Pass()); 485 connection_by_url->AddRoot(view_id, spir.Pass());
484 } else { 486 } else {
485 root_node_manager_->Embed(id_, url, transport_view_id, spir.Pass()); 487 connection_manager_->Embed(id_, url, transport_view_id, spir.Pass());
486 } 488 }
487 } else { 489 } else {
488 success = false; 490 success = false;
489 } 491 }
490 } 492 }
491 callback.Run(success); 493 callback.Run(success);
492 } 494 }
493 495
494 void ViewManagerServiceImpl::DispatchOnViewInputEvent(Id transport_view_id, 496 void ViewManagerServiceImpl::DispatchOnViewInputEvent(Id transport_view_id,
495 EventPtr event) { 497 EventPtr event) {
496 // We only allow the WM to dispatch events. At some point this function will 498 // We only allow the WM to dispatch events. At some point this function will
497 // move to a separate interface and the check can go away. 499 // move to a separate interface and the check can go away.
498 if (id_ != kWindowManagerConnection) 500 if (id_ != kWindowManagerConnection)
499 return; 501 return;
500 502
501 const NodeId node_id(NodeIdFromTransportId(transport_view_id)); 503 const ViewId view_id(ViewIdFromTransportId(transport_view_id));
502 504
503 // If another app is embedded at this node, we forward the input event to the 505 // If another app is embedded at this view, we forward the input event to the
504 // embedded app, rather than the app that created the node. 506 // embedded app, rather than the app that created the view.
505 ViewManagerServiceImpl* connection = 507 ViewManagerServiceImpl* connection =
506 root_node_manager_->GetConnectionWithRoot(node_id); 508 connection_manager_->GetConnectionWithRoot(view_id);
507 if (!connection) 509 if (!connection)
508 connection = root_node_manager_->GetConnection(node_id.connection_id); 510 connection = connection_manager_->GetConnection(view_id.connection_id);
509 if (connection) { 511 if (connection) {
510 connection->client()->OnViewInputEvent( 512 connection->client()->OnViewInputEvent(
511 transport_view_id, 513 transport_view_id,
512 event.Pass(), 514 event.Pass(),
513 base::Bind(&base::DoNothing)); 515 base::Bind(&base::DoNothing));
514 } 516 }
515 } 517 }
516 518
517 void ViewManagerServiceImpl::OnConnectionEstablished() { 519 void ViewManagerServiceImpl::OnConnectionEstablished() {
518 root_node_manager_->AddConnection(this); 520 connection_manager_->AddConnection(this);
519 521
520 std::vector<const Node*> to_send; 522 std::vector<const ServerView*> to_send;
521 for (NodeIdSet::const_iterator i = roots_.begin(); i != roots_.end(); ++i) 523 for (ViewIdSet::const_iterator i = roots_.begin(); i != roots_.end(); ++i)
522 GetUnknownNodesFrom(GetNode(NodeIdFromTransportId(*i)), &to_send); 524 GetUnknownViewsFrom(GetView(ViewIdFromTransportId(*i)), &to_send);
523 525
524 client()->OnEmbed(id_, creator_url_, NodeToViewData(to_send.front()), 526 client()->OnEmbed(id_,
527 creator_url_,
528 ViewToViewData(to_send.front()),
525 service_provider_.Pass()); 529 service_provider_.Pass());
526 } 530 }
527 531
528 const base::hash_set<Id>& 532 const base::hash_set<Id>&
529 ViewManagerServiceImpl::GetRootsForAccessPolicy() const { 533 ViewManagerServiceImpl::GetRootsForAccessPolicy() const {
530 return roots_; 534 return roots_;
531 } 535 }
532 536
533 bool ViewManagerServiceImpl::IsNodeKnownForAccessPolicy( 537 bool ViewManagerServiceImpl::IsViewKnownForAccessPolicy(
534 const Node* node) const { 538 const ServerView* view) const {
535 return IsNodeKnown(node); 539 return IsViewKnown(view);
536 } 540 }
537 541
538 bool ViewManagerServiceImpl::IsNodeRootOfAnotherConnectionForAccessPolicy( 542 bool ViewManagerServiceImpl::IsViewRootOfAnotherConnectionForAccessPolicy(
539 const Node* node) const { 543 const ServerView* view) const {
540 ViewManagerServiceImpl* connection = 544 ViewManagerServiceImpl* connection =
541 root_node_manager_->GetConnectionWithRoot(node->id()); 545 connection_manager_->GetConnectionWithRoot(view->id());
542 return connection && connection != this; 546 return connection && connection != this;
543 } 547 }
544 548
545 } // namespace service 549 } // namespace service
546 } // namespace mojo 550 } // namespace mojo
OLDNEW
« no previous file with comments | « mojo/services/view_manager/view_manager_service_impl.h ('k') | mojo/services/view_manager/view_manager_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698