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

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

Issue 383763003: Trigger Node destruction notifications from Node's dtor (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 6 years, 5 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 | Annotate | Revision Log
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/node.h" 10 #include "mojo/services/view_manager/node.h"
(...skipping 29 matching lines...) Expand all
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
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
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
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
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
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