OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2012 Google Inc. All rights reserved. | 2 * Copyright (C) 2012 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
6 * met: | 6 * met: |
7 * | 7 * |
8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
(...skipping 16 matching lines...) Expand all Loading... | |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
29 */ | 29 */ |
30 | 30 |
31 /** | 31 /** |
32 * @constructor | 32 * @constructor |
33 * @param {!WebInspector.Workspace} workspace | 33 * @param {!WebInspector.Workspace} workspace |
34 */ | 34 */ |
35 WebInspector.PresentationConsoleMessageHelper = function(workspace) | 35 WebInspector.PresentationConsoleMessageHelper = function(workspace) |
36 { | 36 { |
37 /** | 37 this._workspace = workspace; |
38 * @type {!Object.<string, !Array.<!WebInspector.ConsoleMessage>>} | 38 |
39 */ | 39 /** @type {!Object.<string, !Array.<!WebInspector.ConsoleMessage>>} */ |
40 this._pendingConsoleMessages = {}; | 40 this._pendingConsoleMessages = {}; |
41 | |
42 /** @type {!Array.<!WebInspector.PresentationConsoleMessage>} */ | |
41 this._presentationConsoleMessages = []; | 43 this._presentationConsoleMessages = []; |
42 this._workspace = workspace; | 44 |
45 /** @type {!Map.<!WebInspector.UISourceCode, !Array.<!WebInspector.Presentat ionConsoleMessage>>} */ | |
46 this._uiSourceCodeToMessages = new Map(); | |
47 | |
48 /** @type {!Map.<!WebInspector.UISourceCode, !WebInspector.Object>} */ | |
49 this._uiSourceCodeToEventTarget = new Map(); | |
apavlov
2014/08/17 21:32:05
This thing is never cleared.
vsevik
2014/08/18 05:53:07
It should be!
| |
43 | 50 |
44 WebInspector.multitargetConsoleModel.addEventListener(WebInspector.ConsoleMo del.Events.ConsoleCleared, this._consoleCleared, this); | 51 WebInspector.multitargetConsoleModel.addEventListener(WebInspector.ConsoleMo del.Events.ConsoleCleared, this._consoleCleared, this); |
45 WebInspector.multitargetConsoleModel.addEventListener(WebInspector.ConsoleMo del.Events.MessageAdded, this._onConsoleMessageAdded, this); | 52 WebInspector.multitargetConsoleModel.addEventListener(WebInspector.ConsoleMo del.Events.MessageAdded, this._onConsoleMessageAdded, this); |
46 WebInspector.multitargetConsoleModel.messages().forEach(this._consoleMessage Added, this); | 53 WebInspector.multitargetConsoleModel.messages().forEach(this._consoleMessage Added, this); |
47 WebInspector.targetManager.addModelListener(WebInspector.DebuggerModel, WebI nspector.DebuggerModel.Events.ParsedScriptSource, this._parsedScriptSource, this ); | 54 WebInspector.targetManager.addModelListener(WebInspector.DebuggerModel, WebI nspector.DebuggerModel.Events.ParsedScriptSource, this._parsedScriptSource, this ); |
48 WebInspector.targetManager.addModelListener(WebInspector.DebuggerModel, WebI nspector.DebuggerModel.Events.FailedToParseScriptSource, this._parsedScriptSourc e, this); | 55 WebInspector.targetManager.addModelListener(WebInspector.DebuggerModel, WebI nspector.DebuggerModel.Events.FailedToParseScriptSource, this._parsedScriptSourc e, this); |
49 WebInspector.targetManager.addModelListener(WebInspector.DebuggerModel, WebI nspector.DebuggerModel.Events.GlobalObjectCleared, this._debuggerReset, this); | 56 WebInspector.targetManager.addModelListener(WebInspector.DebuggerModel, WebI nspector.DebuggerModel.Events.GlobalObjectCleared, this._debuggerReset, this); |
50 } | 57 } |
51 | 58 |
59 /** | |
60 * @enum {string} | |
61 */ | |
62 WebInspector.PresentationConsoleMessageHelper.Events = { | |
63 ConsoleMessageAdded: "ConsoleMessageAdded", | |
64 ConsoleMessageRemoved: "ConsoleMessageRemoved", | |
65 ConsoleMessagesCleared: "ConsoleMessagesCleared", | |
66 } | |
67 | |
52 WebInspector.PresentationConsoleMessageHelper.prototype = { | 68 WebInspector.PresentationConsoleMessageHelper.prototype = { |
53 /** | 69 /** |
70 * @param {!WebInspector.PresentationConsoleMessageHelper.Events} eventType | |
71 * @param {!WebInspector.UISourceCode} uiSourceCode | |
72 * @param {function(!WebInspector.Event)} listener | |
73 * @param {!Object=} thisObject | |
74 */ | |
75 addConsoleMessageEventListener: function(eventType, uiSourceCode, listener, thisObject) | |
76 { | |
77 var target = this._uiSourceCodeToEventTarget.get(uiSourceCode); | |
78 if (!target) { | |
79 target = new WebInspector.Object(); | |
80 this._uiSourceCodeToEventTarget.put(uiSourceCode, target); | |
81 } | |
82 target.addEventListener(eventType, listener, thisObject); | |
83 }, | |
84 | |
85 /** | |
86 * @param {!WebInspector.PresentationConsoleMessageHelper.Events} eventType | |
87 * @param {!WebInspector.UISourceCode} uiSourceCode | |
88 * @param {function(!WebInspector.Event)} listener | |
89 * @param {!Object=} thisObject | |
90 */ | |
91 removeConsoleMessageEventListener: function(eventType, uiSourceCode, listene r, thisObject) | |
92 { | |
93 var target = this._uiSourceCodeToEventTarget.get(uiSourceCode); | |
94 if (!target) | |
95 return; | |
96 target.removeEventListener(eventType, listener, thisObject); | |
97 }, | |
98 | |
99 /** | |
100 * @param {!WebInspector.UISourceCode} uiSourceCode | |
101 * @return {!Array.<!WebInspector.PresentationConsoleMessage>} | |
102 */ | |
103 consoleMessages: function(uiSourceCode) | |
104 { | |
105 return this._uiSourceCodeToMessages.get(uiSourceCode) || []; | |
106 }, | |
107 | |
108 /** | |
109 * @param {!WebInspector.PresentationConsoleMessageHelper.Events} eventType | |
110 * @param {!WebInspector.UISourceCode} uiSourceCode | |
111 * @param {!WebInspector.PresentationConsoleMessage=} message | |
112 */ | |
113 _dispatchConsoleEvent: function(eventType, uiSourceCode, message) | |
114 { | |
115 var target = this._uiSourceCodeToEventTarget.get(uiSourceCode); | |
116 if (!target) | |
117 return; | |
118 target.dispatchEventToListeners(eventType, message); | |
119 }, | |
120 | |
121 /** | |
54 * @param {!WebInspector.Event} event | 122 * @param {!WebInspector.Event} event |
55 */ | 123 */ |
56 _onConsoleMessageAdded: function(event) | 124 _onConsoleMessageAdded: function(event) |
57 { | 125 { |
58 var message = /** @type {!WebInspector.ConsoleMessage} */ (event.data); | 126 var message = /** @type {!WebInspector.ConsoleMessage} */ (event.data); |
59 this._consoleMessageAdded(message) | 127 this._consoleMessageAdded(message) |
60 }, | 128 }, |
61 | 129 |
62 /** | 130 /** |
63 * @param {!WebInspector.ConsoleMessage} message | 131 * @param {!WebInspector.ConsoleMessage} message |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
127 else | 195 else |
128 pendingMessages.push(message); | 196 pendingMessages.push(message); |
129 } | 197 } |
130 | 198 |
131 if (pendingMessages.length) | 199 if (pendingMessages.length) |
132 this._pendingConsoleMessages[script.sourceURL] = pendingMessages; | 200 this._pendingConsoleMessages[script.sourceURL] = pendingMessages; |
133 else | 201 else |
134 delete this._pendingConsoleMessages[script.sourceURL]; | 202 delete this._pendingConsoleMessages[script.sourceURL]; |
135 }, | 203 }, |
136 | 204 |
205 /** | |
206 * @param {!WebInspector.PresentationConsoleMessage} message | |
207 */ | |
208 _presentationConsoleMessageAdded: function(message) | |
209 { | |
210 var uiSourceCode = message._uiLocation.uiSourceCode; | |
211 var messages = this._uiSourceCodeToMessages.get(uiSourceCode); | |
212 if (!messages) { | |
213 messages = []; | |
214 this._uiSourceCodeToMessages.put(uiSourceCode, messages); | |
215 } | |
216 messages.push(message); | |
217 this._dispatchConsoleEvent(WebInspector.PresentationConsoleMessageHelper .Events.ConsoleMessageAdded, uiSourceCode, message); | |
218 }, | |
219 | |
220 /** | |
221 * @param {!WebInspector.PresentationConsoleMessage} message | |
222 */ | |
223 _presentationConsoleMessageRemoved: function(message) | |
224 { | |
225 var uiSourceCode = message._uiLocation.uiSourceCode; | |
226 var messages = this._uiSourceCodeToMessages.get(uiSourceCode); | |
227 if (!messages) | |
228 return; | |
229 messages.remove(message); | |
230 this._dispatchConsoleEvent(WebInspector.PresentationConsoleMessageHelper .Events.ConsoleMessageRemoved, uiSourceCode, message); | |
231 }, | |
232 | |
137 _consoleCleared: function() | 233 _consoleCleared: function() |
138 { | 234 { |
139 this._pendingConsoleMessages = {}; | 235 this._pendingConsoleMessages = {}; |
140 for (var i = 0; i < this._presentationConsoleMessages.length; ++i) | 236 for (var i = 0; i < this._presentationConsoleMessages.length; ++i) |
141 this._presentationConsoleMessages[i].dispose(); | 237 this._presentationConsoleMessages[i].dispose(); |
142 this._presentationConsoleMessages = []; | 238 this._presentationConsoleMessages = []; |
143 var uiSourceCodes = this._workspace.uiSourceCodes(); | 239 var targets = this._uiSourceCodeToEventTarget.values(); |
144 for (var i = 0; i < uiSourceCodes.length; ++i) | 240 for (var i = 0; i < targets.length; ++i) |
145 uiSourceCodes[i].consoleMessagesCleared(); | 241 targets[i].dispatchEventToListeners(WebInspector.PresentationConsole MessageHelper.Events.ConsoleMessagesCleared); |
242 this._uiSourceCodeToMessages.clear(); | |
146 }, | 243 }, |
147 | 244 |
148 _debuggerReset: function() | 245 _debuggerReset: function() |
149 { | 246 { |
150 this._pendingConsoleMessages = {}; | 247 this._pendingConsoleMessages = {}; |
151 this._presentationConsoleMessages = []; | 248 this._presentationConsoleMessages = []; |
152 } | 249 } |
153 } | 250 } |
154 | 251 |
155 /** | 252 /** |
156 * @constructor | 253 * @constructor |
157 * @implements {WebInspector.PresentationMessage} | |
158 * @param {!WebInspector.ConsoleMessage} message | 254 * @param {!WebInspector.ConsoleMessage} message |
159 * @param {!WebInspector.DebuggerModel.Location} rawLocation | 255 * @param {!WebInspector.DebuggerModel.Location} rawLocation |
160 */ | 256 */ |
161 WebInspector.PresentationConsoleMessage = function(message, rawLocation) | 257 WebInspector.PresentationConsoleMessage = function(message, rawLocation) |
162 { | 258 { |
163 this.originalMessage = message; | 259 this.originalMessage = message; |
164 this._liveLocation = WebInspector.debuggerWorkspaceBinding.createLiveLocatio n(rawLocation, this._updateLocation.bind(this)); | 260 this._liveLocation = WebInspector.debuggerWorkspaceBinding.createLiveLocatio n(rawLocation, this._updateLocation.bind(this)); |
165 } | 261 } |
166 | 262 |
167 WebInspector.PresentationConsoleMessage.prototype = { | 263 WebInspector.PresentationConsoleMessage.prototype = { |
168 /** | 264 /** |
169 * @param {!WebInspector.UILocation} uiLocation | 265 * @param {!WebInspector.UILocation} uiLocation |
170 */ | 266 */ |
171 _updateLocation: function(uiLocation) | 267 _updateLocation: function(uiLocation) |
172 { | 268 { |
173 if (this._uiLocation) | 269 if (this._uiLocation) |
174 this._uiLocation.uiSourceCode.consoleMessageRemoved(this); | 270 WebInspector.presentationConsoleMessageHelper._presentationConsoleMe ssageRemoved(this); |
175 this._uiLocation = uiLocation; | 271 this._uiLocation = uiLocation; |
176 this._uiLocation.uiSourceCode.consoleMessageAdded(this); | 272 WebInspector.presentationConsoleMessageHelper._presentationConsoleMessag eAdded(this); |
177 }, | 273 }, |
178 | 274 |
179 get lineNumber() | 275 get lineNumber() |
180 { | 276 { |
181 return this._uiLocation.lineNumber; | 277 return this._uiLocation.lineNumber; |
182 }, | 278 }, |
183 | 279 |
184 dispose: function() | 280 dispose: function() |
185 { | 281 { |
186 this._liveLocation.dispose(); | 282 this._liveLocation.dispose(); |
187 } | 283 } |
188 } | 284 } |
285 | |
286 /** @type {!WebInspector.PresentationConsoleMessageHelper} */ | |
287 WebInspector.presentationConsoleMessageHelper; | |
OLD | NEW |