OLD | NEW |
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/node.h" | 10 #include "mojo/services/view_manager/node.h" |
(...skipping 29 matching lines...) Expand all Loading... |
40 const std::string& url) | 40 const std::string& url) |
41 : root_node_manager_(root_node_manager), | 41 : root_node_manager_(root_node_manager), |
42 id_(root_node_manager_->GetAndAdvanceNextConnectionId()), | 42 id_(root_node_manager_->GetAndAdvanceNextConnectionId()), |
43 url_(url), | 43 url_(url), |
44 creator_id_(creator_id), | 44 creator_id_(creator_id), |
45 creator_url_(creator_url), | 45 creator_url_(creator_url), |
46 delete_on_connection_error_(false) { | 46 delete_on_connection_error_(false) { |
47 } | 47 } |
48 | 48 |
49 ViewManagerServiceImpl::~ViewManagerServiceImpl() { | 49 ViewManagerServiceImpl::~ViewManagerServiceImpl() { |
50 // Delete any views we own. | 50 // Delete any views we created. |
51 while (!view_map_.empty()) { | 51 while (!view_map_.empty()) { |
52 bool result = DeleteViewImpl(this, view_map_.begin()->second->id()); | 52 bool result = DeleteViewImpl(this, view_map_.begin()->second->id()); |
53 DCHECK(result); | 53 DCHECK(result); |
54 } | 54 } |
55 | 55 |
56 // We're about to destroy all our nodes. Detach any views from them. | 56 // Ditto the nodes. |
57 for (NodeMap::iterator i = node_map_.begin(); i != node_map_.end(); ++i) { | |
58 if (i->second->view()) { | |
59 bool result = SetViewImpl(i->second, ViewId()); | |
60 DCHECK(result); | |
61 } | |
62 } | |
63 | |
64 if (!node_map_.empty()) { | 57 if (!node_map_.empty()) { |
65 RootNodeManager::ScopedChange change( | 58 RootNodeManager::ScopedChange change( |
66 this, root_node_manager_, | 59 this, root_node_manager_, |
67 RootNodeManager::CHANGE_TYPE_ADVANCE_SERVER_CHANGE_ID, true); | 60 RootNodeManager::CHANGE_TYPE_ADVANCE_SERVER_CHANGE_ID, true); |
68 while (!node_map_.empty()) { | 61 while (!node_map_.empty()) |
69 scoped_ptr<Node> node(node_map_.begin()->second); | 62 delete node_map_.begin()->second; |
70 Node* parent = node->GetParent(); | |
71 const NodeId node_id(node->id()); | |
72 if (parent) | |
73 parent->Remove(node.get()); | |
74 root_node_manager_->ProcessNodeDeleted(node_id); | |
75 node_map_.erase(NodeIdToTransportId(node_id)); | |
76 } | |
77 } | 63 } |
78 | 64 |
79 root_node_manager_->RemoveConnection(this); | 65 root_node_manager_->RemoveConnection(this); |
80 } | 66 } |
81 | 67 |
82 const Node* ViewManagerServiceImpl::GetNode(const NodeId& id) const { | 68 const Node* ViewManagerServiceImpl::GetNode(const NodeId& id) const { |
83 if (id_ == id.connection_id) { | 69 if (id_ == id.connection_id) { |
84 NodeMap::const_iterator i = node_map_.find(id.node_id); | 70 NodeMap::const_iterator i = node_map_.find(id.node_id); |
85 return i == node_map_.end() ? NULL : i->second; | 71 return i == node_map_.end() ? NULL : i->second; |
86 } | 72 } |
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
198 ViewIdToTransportId(new_view->id()) : 0; | 184 ViewIdToTransportId(new_view->id()) : 0; |
199 const Id old_view_id = old_view ? | 185 const Id old_view_id = old_view ? |
200 ViewIdToTransportId(old_view->id()) : 0; | 186 ViewIdToTransportId(old_view->id()) : 0; |
201 client()->OnNodeViewReplaced(NodeIdToTransportId(node->id()), | 187 client()->OnNodeViewReplaced(NodeIdToTransportId(node->id()), |
202 new_view_id, old_view_id); | 188 new_view_id, old_view_id); |
203 } | 189 } |
204 | 190 |
205 void ViewManagerServiceImpl::ProcessNodeDeleted(const NodeId& node, | 191 void ViewManagerServiceImpl::ProcessNodeDeleted(const NodeId& node, |
206 Id server_change_id, | 192 Id server_change_id, |
207 bool originated_change) { | 193 bool originated_change) { |
| 194 node_map_.erase(node.node_id); |
| 195 |
208 const bool in_known = known_nodes_.erase(NodeIdToTransportId(node)) > 0; | 196 const bool in_known = known_nodes_.erase(NodeIdToTransportId(node)) > 0; |
209 const bool in_roots = roots_.erase(NodeIdToTransportId(node)) > 0; | 197 const bool in_roots = roots_.erase(NodeIdToTransportId(node)) > 0; |
210 | 198 |
211 if (in_roots && roots_.empty()) | 199 if (in_roots && roots_.empty()) |
212 roots_.insert(NodeIdToTransportId(InvalidNodeId())); | 200 roots_.insert(NodeIdToTransportId(InvalidNodeId())); |
213 | 201 |
214 if (originated_change) | 202 if (originated_change) |
215 return; | 203 return; |
216 | 204 |
217 if (in_known) { | 205 if (in_known) { |
(...skipping 157 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
375 | 363 |
376 bool ViewManagerServiceImpl::DeleteNodeImpl(ViewManagerServiceImpl* source, | 364 bool ViewManagerServiceImpl::DeleteNodeImpl(ViewManagerServiceImpl* source, |
377 const NodeId& node_id) { | 365 const NodeId& node_id) { |
378 DCHECK_EQ(node_id.connection_id, id_); | 366 DCHECK_EQ(node_id.connection_id, id_); |
379 Node* node = GetNode(node_id); | 367 Node* node = GetNode(node_id); |
380 if (!node) | 368 if (!node) |
381 return false; | 369 return false; |
382 RootNodeManager::ScopedChange change( | 370 RootNodeManager::ScopedChange change( |
383 source, root_node_manager_, | 371 source, root_node_manager_, |
384 RootNodeManager::CHANGE_TYPE_ADVANCE_SERVER_CHANGE_ID, true); | 372 RootNodeManager::CHANGE_TYPE_ADVANCE_SERVER_CHANGE_ID, true); |
385 if (node->GetParent()) | |
386 node->GetParent()->Remove(node); | |
387 std::vector<Node*> children(node->GetChildren()); | |
388 for (size_t i = 0; i < children.size(); ++i) | |
389 node->Remove(children[i]); | |
390 DCHECK(node->GetChildren().empty()); | |
391 node_map_.erase(node_id.node_id); | |
392 delete node; | 373 delete node; |
393 node = NULL; | |
394 root_node_manager_->ProcessNodeDeleted(node_id); | |
395 return true; | 374 return true; |
396 } | 375 } |
397 | 376 |
398 bool ViewManagerServiceImpl::DeleteViewImpl(ViewManagerServiceImpl* source, | 377 bool ViewManagerServiceImpl::DeleteViewImpl(ViewManagerServiceImpl* source, |
399 const ViewId& view_id) { | 378 const ViewId& view_id) { |
400 DCHECK_EQ(view_id.connection_id, id_); | 379 DCHECK_EQ(view_id.connection_id, id_); |
401 View* view = GetView(view_id); | 380 View* view = GetView(view_id); |
402 if (!view) | 381 if (!view) |
403 return false; | 382 return false; |
404 RootNodeManager::ScopedChange change( | 383 RootNodeManager::ScopedChange change( |
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
563 | 542 |
564 void ViewManagerServiceImpl::CreateNode( | 543 void ViewManagerServiceImpl::CreateNode( |
565 Id transport_node_id, | 544 Id transport_node_id, |
566 const Callback<void(bool)>& callback) { | 545 const Callback<void(bool)>& callback) { |
567 const NodeId node_id(NodeIdFromTransportId(transport_node_id)); | 546 const NodeId node_id(NodeIdFromTransportId(transport_node_id)); |
568 if (node_id.connection_id != id_ || | 547 if (node_id.connection_id != id_ || |
569 node_map_.find(node_id.node_id) != node_map_.end()) { | 548 node_map_.find(node_id.node_id) != node_map_.end()) { |
570 callback.Run(false); | 549 callback.Run(false); |
571 return; | 550 return; |
572 } | 551 } |
573 node_map_[node_id.node_id] = new Node(this, node_id); | 552 node_map_[node_id.node_id] = new Node(root_node_manager_, node_id); |
574 known_nodes_.insert(transport_node_id); | 553 known_nodes_.insert(transport_node_id); |
575 callback.Run(true); | 554 callback.Run(true); |
576 } | 555 } |
577 | 556 |
578 void ViewManagerServiceImpl::DeleteNode( | 557 void ViewManagerServiceImpl::DeleteNode( |
579 Id transport_node_id, | 558 Id transport_node_id, |
580 Id server_change_id, | 559 Id server_change_id, |
581 const Callback<void(bool)>& callback) { | 560 const Callback<void(bool)>& callback) { |
582 const NodeId node_id(NodeIdFromTransportId(transport_node_id)); | 561 const NodeId node_id(NodeIdFromTransportId(transport_node_id)); |
583 bool success = false; | 562 bool success = false; |
(...skipping 211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
795 ViewManagerServiceImpl* connection = root_node_manager_->GetConnection( | 774 ViewManagerServiceImpl* connection = root_node_manager_->GetConnection( |
796 view_id.connection_id); | 775 view_id.connection_id); |
797 if (connection) { | 776 if (connection) { |
798 connection->client()->OnViewInputEvent( | 777 connection->client()->OnViewInputEvent( |
799 transport_view_id, | 778 transport_view_id, |
800 event.Pass(), | 779 event.Pass(), |
801 base::Bind(&base::DoNothing)); | 780 base::Bind(&base::DoNothing)); |
802 } | 781 } |
803 } | 782 } |
804 | 783 |
805 void ViewManagerServiceImpl::OnNodeHierarchyChanged(const Node* node, | |
806 const Node* new_parent, | |
807 const Node* old_parent) { | |
808 root_node_manager_->ProcessNodeHierarchyChanged(node, new_parent, old_parent); | |
809 } | |
810 | |
811 void ViewManagerServiceImpl::OnNodeBoundsChanged(const Node* node, | |
812 const gfx::Rect& old_bounds, | |
813 const gfx::Rect& new_bounds) { | |
814 root_node_manager_->ProcessNodeBoundsChanged(node, old_bounds, new_bounds); | |
815 } | |
816 | |
817 void ViewManagerServiceImpl::OnNodeViewReplaced(const Node* node, | |
818 const View* new_view, | |
819 const View* old_view) { | |
820 root_node_manager_->ProcessNodeViewReplaced(node, new_view, old_view); | |
821 } | |
822 | |
823 void ViewManagerServiceImpl::OnViewInputEvent(const View* view, | |
824 const ui::Event* event) { | |
825 root_node_manager_->DispatchViewInputEventToWindowManager(view, event); | |
826 } | |
827 | |
828 void ViewManagerServiceImpl::OnConnectionEstablished() { | 784 void ViewManagerServiceImpl::OnConnectionEstablished() { |
829 root_node_manager_->AddConnection(this); | 785 root_node_manager_->AddConnection(this); |
830 | 786 |
831 std::vector<const Node*> to_send; | 787 std::vector<const Node*> to_send; |
832 if (roots_.empty()) { | 788 if (roots_.empty()) { |
833 GetUnknownNodesFrom(root_node_manager_->root(), &to_send); | 789 GetUnknownNodesFrom(root_node_manager_->root(), &to_send); |
834 } else { | 790 } else { |
835 for (NodeIdSet::const_iterator i = roots_.begin(); i != roots_.end(); ++i) | 791 for (NodeIdSet::const_iterator i = roots_.begin(); i != roots_.end(); ++i) |
836 GetUnknownNodesFrom(GetNode(NodeIdFromTransportId(*i)), &to_send); | 792 GetUnknownNodesFrom(GetNode(NodeIdFromTransportId(*i)), &to_send); |
837 } | 793 } |
838 | 794 |
839 client()->OnViewManagerConnectionEstablished( | 795 client()->OnViewManagerConnectionEstablished( |
840 id_, | 796 id_, |
841 creator_url_, | 797 creator_url_, |
842 root_node_manager_->next_server_change_id(), | 798 root_node_manager_->next_server_change_id(), |
843 NodesToNodeDatas(to_send)); | 799 NodesToNodeDatas(to_send)); |
844 } | 800 } |
845 | 801 |
846 } // namespace service | 802 } // namespace service |
847 } // namespace view_manager | 803 } // namespace view_manager |
848 } // namespace mojo | 804 } // namespace mojo |
OLD | NEW |