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

Unified Diff: ash/common/devtools/ash_devtools_dom_agent.cc

Issue 2537163002: Hook up views/widgets to AshDevToolsDOMAgent (Closed)
Patch Set: sadruls comments Created 4 years, 1 month 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ash/common/devtools/ash_devtools_dom_agent.h ('k') | ash/common/devtools/ash_devtools_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ash/common/devtools/ash_devtools_dom_agent.cc
diff --git a/ash/common/devtools/ash_devtools_dom_agent.cc b/ash/common/devtools/ash_devtools_dom_agent.cc
index f178179ad0886317c74af82110699b6cdc3213ba..2dc2740e8cbcdd20648287d3eac1c4ee0109f466 100644
--- a/ash/common/devtools/ash_devtools_dom_agent.cc
+++ b/ash/common/devtools/ash_devtools_dom_agent.cc
@@ -66,6 +66,19 @@ WmWindow* FindPreviousSibling(WmWindow* window) {
return it == siblings.begin() ? nullptr : *std::prev(it);
}
+views::View* FindPreviousSibling(views::View* view) {
+ views::View* parent = view->parent();
+ int view_index = -1;
+ for (int i = 0, count = parent->child_count(); i < count; i++) {
+ if (view == parent->child_at(i)) {
+ view_index = i;
+ break;
+ }
+ }
+ DCHECK_GE(view_index, 0);
+ return view_index == 0 ? nullptr : parent->child_at(view_index - 1);
+}
+
} // namespace
AshDevToolsDOMAgent::AshDevToolsDOMAgent(ash::WmShell* shell) : shell_(shell) {
@@ -73,7 +86,7 @@ AshDevToolsDOMAgent::AshDevToolsDOMAgent(ash::WmShell* shell) : shell_(shell) {
}
AshDevToolsDOMAgent::~AshDevToolsDOMAgent() {
- RemoveObserverFromAllWindows();
+ RemoveObservers();
}
ui::devtools::protocol::Response AshDevToolsDOMAgent::disable() {
@@ -118,6 +131,26 @@ void AshDevToolsDOMAgent::OnWindowStackingChanged(WmWindow* window) {
AddWindowTree(window);
}
+void AshDevToolsDOMAgent::OnWillRemoveView(views::Widget* widget,
+ views::View* view) {
+ if (view == widget->GetRootView())
+ RemoveViewTree(view, nullptr, true);
+}
+
+void AshDevToolsDOMAgent::OnChildViewRemoved(views::View* view,
+ views::View* parent) {
+ RemoveViewTree(view, parent, true);
+}
+
+void AshDevToolsDOMAgent::OnChildViewAdded(views::View* view) {
+ AddViewTree(view);
+}
+
+void AshDevToolsDOMAgent::OnChildViewReordered(views::View* view) {
+ RemoveViewTree(view, view->parent(), false);
+ AddViewTree(view);
+}
+
WmWindow* AshDevToolsDOMAgent::GetWindowFromNodeId(int nodeId) {
return node_id_to_window_map_.count(nodeId) ? node_id_to_window_map_[nodeId]
: nullptr;
@@ -182,7 +215,8 @@ std::unique_ptr<DOM::Node> AshDevToolsDOMAgent::BuildTreeForRootWidget(
children->addItem(BuildTreeForView(widget->GetRootView()));
std::unique_ptr<ui::devtools::protocol::DOM::Node> node =
BuildNode("Widget", GetAttributes(widget), std::move(children));
- // TODO(mhashmi): Add WidgetRemovalsObserver here
+ if (!widget->HasRemovalsObserver(this))
+ widget->AddRemovalsObserver(this);
widget_to_node_id_map_[widget] = node->getNodeId();
node_id_to_widget_map_[node->getNodeId()] = widget;
return node;
@@ -196,7 +230,8 @@ std::unique_ptr<DOM::Node> AshDevToolsDOMAgent::BuildTreeForView(
children->addItem(BuildTreeForView(view->child_at(i)));
std::unique_ptr<ui::devtools::protocol::DOM::Node> node =
BuildNode("View", GetAttributes(view), std::move(children));
- // TODO(mhashmi): Add ViewObserver here
+ if (!view->HasObserver(this))
+ view->AddObserver(this);
view_to_node_id_map_[view] = node->getNodeId();
node_id_to_view_map_[node->getNodeId()] = view;
return node;
@@ -238,6 +273,7 @@ void AshDevToolsDOMAgent::RemoveWindowNode(WmWindow* window,
if (remove_observer)
window->RemoveObserver(this);
+
node_id_to_window_map_.erase(node_id_to_window_it);
window_to_node_id_map_.erase(window_to_node_id_it);
frontend()->childNodeRemoved(parent_id, node_id);
@@ -261,8 +297,8 @@ void AshDevToolsDOMAgent::RemoveWidgetNode(views::Widget* widget,
int parent_id =
GetNodeIdFromWindow(WmLookup::Get()->GetWindowForWidget(widget));
- // TODO(mhashmi): Add WidgetRemovalsObserver and remove it here based on
- // |remove_observer|
+ if (remove_observer)
+ widget->RemoveRemovalsObserver(this);
NodeIdToWidgetMap::iterator node_id_to_widget_it =
node_id_to_widget_map_.find(node_id);
@@ -273,6 +309,15 @@ void AshDevToolsDOMAgent::RemoveWidgetNode(views::Widget* widget,
frontend()->childNodeRemoved(parent_id, node_id);
}
+void AshDevToolsDOMAgent::AddViewTree(views::View* view) {
+ DCHECK(view_to_node_id_map_.count(view->parent()));
+ views::View* prev_sibling = FindPreviousSibling(view);
+ frontend()->childNodeInserted(
+ view_to_node_id_map_[view->parent()],
+ prev_sibling ? view_to_node_id_map_[prev_sibling] : 0,
+ BuildTreeForView(view));
+}
+
void AshDevToolsDOMAgent::RemoveViewTree(views::View* view,
views::View* parent,
bool remove_observer) {
@@ -296,8 +341,8 @@ void AshDevToolsDOMAgent::RemoveViewNode(views::View* view,
else // views::RootView
parent_id = GetNodeIdFromWidget(view->GetWidget());
- // TODO(mhashmi): Add ViewObserver and remove it here based on
- // |remove_observer|
+ if (remove_observer)
+ view->RemoveObserver(this);
NodeIdToViewMap::iterator node_id_to_view_it =
node_id_to_view_map_.find(node_id);
@@ -308,13 +353,17 @@ void AshDevToolsDOMAgent::RemoveViewNode(views::View* view,
frontend()->childNodeRemoved(parent_id, node_id);
}
-void AshDevToolsDOMAgent::RemoveObserverFromAllWindows() {
+void AshDevToolsDOMAgent::RemoveObservers() {
for (auto& pair : window_to_node_id_map_)
pair.first->RemoveObserver(this);
+ for (auto& pair : widget_to_node_id_map_)
+ pair.first->RemoveRemovalsObserver(this);
+ for (auto& pair : view_to_node_id_map_)
+ pair.first->RemoveObserver(this);
}
void AshDevToolsDOMAgent::Reset() {
- RemoveObserverFromAllWindows();
+ RemoveObservers();
window_to_node_id_map_.clear();
widget_to_node_id_map_.clear();
view_to_node_id_map_.clear();
« no previous file with comments | « ash/common/devtools/ash_devtools_dom_agent.h ('k') | ash/common/devtools/ash_devtools_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698