Chromium Code Reviews| Index: third_party/WebKit/Source/devtools/front_end/sdk/DOMDebuggerModel.js |
| diff --git a/third_party/WebKit/Source/devtools/front_end/sdk/DOMDebuggerModel.js b/third_party/WebKit/Source/devtools/front_end/sdk/DOMDebuggerModel.js |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..566c5d9ca20270e195dfdc0337837f01ca360558 |
| --- /dev/null |
| +++ b/third_party/WebKit/Source/devtools/front_end/sdk/DOMDebuggerModel.js |
| @@ -0,0 +1,280 @@ |
| +// Copyright (c) 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +/** |
| + * @constructor |
| + * @extends {WebInspector.SDKModel} |
| + * @param {!WebInspector.Target} target |
| + */ |
| +WebInspector.DOMDebuggerModel = function(target) |
|
lushnikov
2016/08/08 19:53:07
the class has many similar API methods. Let's redu
chenwilliam
2016/08/10 19:48:36
Done.
|
| +{ |
| + WebInspector.SDKModel.call(this, WebInspector.DOMDebuggerModel, target); |
| + this._agent = target.domdebuggerAgent(); |
| + this._domBreakpointsSetting = WebInspector.settings.createLocalSetting("domBreakpoints", []); |
| + this._breakpoints = {}; |
|
lushnikov
2016/08/08 19:53:07
/** @type {!Map<.., ...>} */
this._breakpoints = n
chenwilliam
2016/08/10 19:48:35
Done.
|
| + WebInspector.targetManager.addModelListener(WebInspector.DOMModel, WebInspector.DOMModel.Events.NodeRemoved, this._nodeRemoved, this); |
| + WebInspector.targetManager.addEventListener(WebInspector.TargetManager.Events.InspectedURLChanged, this._inspectedURLChanged, this); |
| +} |
| + |
| +WebInspector.DOMDebuggerModel.Marker = "breakpoint-marker"; |
| + |
| +WebInspector.DOMDebuggerModel.Events = { |
| + BreakpointsChanged: "BreakpointsChanged" |
| +}; |
| + |
| +WebInspector.DOMDebuggerModel.prototype = { |
| + /** |
| + * @return {!Object} |
|
lushnikov
2016/08/08 19:53:07
please annotate with proper type
chenwilliam
2016/08/10 19:48:36
Done.
|
| + */ |
| + domBreakpoints: function() |
| + { |
| + return this._breakpoints; |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + * @param {boolean} enabled |
| + */ |
| + setBreakpoint: function(node, type, enabled) |
| + { |
| + this._setBreakpointWithoutSave(node, type, enabled); |
| + this._saveBreakpoints(); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + * @param {boolean} enabled |
| + */ |
| + _setBreakpointWithoutSave: function(node, type, enabled) |
|
lushnikov
2016/08/08 19:53:07
_innerSetBreakpoint
chenwilliam
2016/08/10 19:48:36
Done.
|
| + { |
| + var breakpointId = this.createBreakpointId(node.id, type); |
| + this._breakpoints[breakpointId] = { |
| + node: node, |
|
lushnikov
2016/08/08 19:53:07
let's create a type for this
chenwilliam
2016/08/10 19:48:36
Done.
|
| + type: type, |
| + url: this._inspectedURL, |
| + path: node.path(), |
| + enabled: enabled |
| + }; |
| + if (enabled) |
| + this._setDOMBreakpoint(node, type); |
| + else |
| + this._removeDOMBreakpoint(node, type); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + */ |
| + removeBreakpoint: function(node, type) |
| + { |
| + this._removeBreakpointWithoutSave(node, type); |
| + this._saveBreakpoints(); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + */ |
| + _removeBreakpointWithoutSave: function(node, type) |
| + { |
| + var breakpointId = this.createBreakpointId(node.id, type); |
| + if (this._breakpoints[breakpointId].enabled) |
| + this._removeDOMBreakpoint(node, type); |
| + delete this._breakpoints[breakpointId]; |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + * @param {!Event} event |
| + */ |
| + checkboxClicked: function(node, type, event) |
|
lushnikov
2016/08/08 19:53:07
the model should not talk in UI terms; this method
chenwilliam
2016/08/10 19:48:36
Done.
|
| + { |
| + this.setBreakpoint(node, type, event.target["checkboxElement"].checked); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + */ |
| + toggleBreakpoint: function(node, type) |
| + { |
| + var nodeBreakpoints = this.nodeBreakpoints(node); |
| + if (!nodeBreakpoints[type]) |
| + this.setBreakpoint(node, type, true); |
| + else |
| + this.removeBreakpoint(node, type); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + */ |
| + removeBreakpointsForNode: function(node) |
| + { |
| + for (var id in this._breakpoints) { |
| + var breakpoint = this._breakpoints[id]; |
| + if (breakpoint.node === node) |
| + this._removeBreakpointWithoutSave(breakpoint.node, breakpoint.type); |
| + } |
| + this._saveBreakpoints(); |
| + }, |
| + |
| + removeAllBreakpoints: function() |
| + { |
| + for (var id in this._breakpoints) { |
| + var breakpoint = this._breakpoints[id]; |
| + this._removeBreakpointWithoutSave(breakpoint.node, breakpoint.type); |
| + } |
| + this._saveBreakpoints(); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @return {!Object<string, boolean>} |
| + */ |
| + nodeBreakpoints: function(node) |
| + { |
| + var nodeBreakpoints = {}; |
| + for (var id in this._breakpoints) { |
| + var breakpoint = this._breakpoints[id]; |
| + if (breakpoint.node === node && breakpoint.enabled) |
| + nodeBreakpoints[breakpoint.type] = true; |
| + } |
| + return nodeBreakpoints; |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMModel} domModel |
| + */ |
| + restoreBreakpoints: function(domModel) |
| + { |
| + var pathToBreakpoints = {}; |
| + |
| + /** |
| + * @param {string} path |
| + * @param {?DOMAgent.NodeId} nodeId |
| + * @this {WebInspector.DOMDebuggerModel} |
| + */ |
| + function didPushNodeByPathToFrontend(path, nodeId) |
| + { |
| + var node = nodeId ? domModel.nodeForId(nodeId) : null; |
| + if (!node) |
| + return; |
| + |
| + for (var breakpoint of pathToBreakpoints[path]) |
| + this._setBreakpointWithoutSave(node, breakpoint.type, breakpoint.enabled); |
| + this.dispatchEventToListeners(WebInspector.DOMDebuggerModel.Events.BreakpointsChanged); |
| + } |
| + |
| + var breakpoints = this._domBreakpointsSetting.get(); |
| + for (var breakpoint of breakpoints) { |
| + if (breakpoint.url !== this._inspectedURL) |
| + continue; |
| + var path = breakpoint.path; |
| + if (!pathToBreakpoints[path]) { |
| + pathToBreakpoints[path] = []; |
| + domModel.pushNodeByPathToFrontend(path, didPushNodeByPathToFrontend.bind(this, path)); |
| + } |
| + pathToBreakpoints[path].push(breakpoint); |
| + } |
| + }, |
| + |
| + _saveBreakpoints: function() |
| + { |
| + var breakpoints = []; |
| + var storedBreakpoints = this._domBreakpointsSetting.get(); |
| + for (var breakpoint of storedBreakpoints) { |
| + if (breakpoint.url !== this._inspectedURL) |
| + breakpoints.push(breakpoint); |
| + } |
| + for (var id in this._breakpoints) { |
| + var breakpoint = this._breakpoints[id]; |
| + breakpoints.push({ |
| + url: this._inspectedURL, |
| + path: breakpoint.node.path(), |
| + type: breakpoint.type, |
| + enabled: breakpoint.enabled |
| + }); |
| + } |
| + this._domBreakpointsSetting.set(breakpoints); |
| + this.dispatchEventToListeners(WebInspector.DOMDebuggerModel.Events.BreakpointsChanged); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + */ |
| + _setDOMBreakpoint: function(node, type) |
|
lushnikov
2016/08/08 19:53:07
let's inline
chenwilliam
2016/08/10 19:48:36
Done.
|
| + { |
| + this._agent.setDOMBreakpoint(node.id, type); |
| + node.setMarker(WebInspector.DOMDebuggerModel.Marker, true); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + */ |
| + _removeDOMBreakpoint: function(node, type) |
|
lushnikov
2016/08/08 19:53:07
let's inline
chenwilliam
2016/08/10 19:48:35
Done.
|
| + { |
| + this._agent.removeDOMBreakpoint(node.id, type); |
| + node.setMarker(WebInspector.DOMDebuggerModel.Marker, this._hasOtherBreakpoints(node, type) ? true : null); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.DOMNode} node |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + * @return {boolean} |
| + */ |
| + _hasOtherBreakpoints: function(node, type) |
| + { |
| + for (var id in this._breakpoints) { |
| + var breakpoint = this._breakpoints[id]; |
| + if (breakpoint.node === node && breakpoint.type !== type && breakpoint.enabled) |
| + return true; |
| + } |
| + return false; |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.Event} event |
| + */ |
| + _nodeRemoved: function(event) |
|
lushnikov
2016/08/08 19:53:07
this method is not used?
chenwilliam
2016/08/10 19:48:35
It's used as a model listener.
WebInspector.targe
|
| + { |
| + var node = event.data.node; |
| + this.removeBreakpointsForNode(node); |
| + var children = node.children(); |
| + if (!children) |
| + return; |
| + for (var child of children) |
| + this.removeBreakpointsForNode(child); |
| + this._saveBreakpoints(); |
| + }, |
| + |
| + /** |
| + * @param {!WebInspector.Event} event |
| + */ |
| + _inspectedURLChanged: function(event) |
| + { |
| + var target = /** @type {!WebInspector.Target} */ (event.data); |
| + if (target !== WebInspector.targetManager.mainTarget()) |
| + return; |
| + this._inspectedURL = target.inspectedURL().removeURLFragment(); |
| + this._breakpoints = {}; |
| + this.dispatchEventToListeners(WebInspector.DOMDebuggerModel.Events.BreakpointsChanged); |
| + }, |
| + |
| + /** |
| + * @param {number} nodeId |
| + * @param {!DOMDebuggerAgent.DOMBreakpointType} type |
| + * @return {string} |
| + */ |
| + createBreakpointId: function(nodeId, type) |
|
lushnikov
2016/08/08 19:53:07
this is used only by the DOMBreakpointsSidebarPane
chenwilliam
2016/08/10 19:48:35
OK, I have moved this method to DOMBreakpointsSide
|
| + { |
| + return `${nodeId}:${type}`; |
| + }, |
| + |
| + __proto__: WebInspector.SDKModel.prototype |
| +}; |