| 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 22 matching lines...) Expand all Loading... |
| 33 * @implements {WebInspector.SourceMapping} | 33 * @implements {WebInspector.SourceMapping} |
| 34 * @param {WebInspector.CSSStyleModel} cssModel | 34 * @param {WebInspector.CSSStyleModel} cssModel |
| 35 * @param {WebInspector.Workspace} workspace | 35 * @param {WebInspector.Workspace} workspace |
| 36 */ | 36 */ |
| 37 WebInspector.StylesSourceMapping = function(cssModel, workspace) | 37 WebInspector.StylesSourceMapping = function(cssModel, workspace) |
| 38 { | 38 { |
| 39 this._cssModel = cssModel; | 39 this._cssModel = cssModel; |
| 40 this._workspace = workspace; | 40 this._workspace = workspace; |
| 41 this._workspace.addEventListener(WebInspector.Workspace.Events.ProjectWillRe
set, this._projectWillReset, this); | 41 this._workspace.addEventListener(WebInspector.Workspace.Events.ProjectWillRe
set, this._projectWillReset, this); |
| 42 this._workspace.addEventListener(WebInspector.Workspace.Events.UISourceCodeA
dded, this._uiSourceCodeAddedToWorkspace, this); | 42 this._workspace.addEventListener(WebInspector.Workspace.Events.UISourceCodeA
dded, this._uiSourceCodeAddedToWorkspace, this); |
| 43 this._workspace.addEventListener(WebInspector.Workspace.Events.UISourceCodeR
emoved, this._uiSourceCodeRemoved, this); |
| 43 | 44 |
| 44 WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeMod
el.EventTypes.MainFrameCreatedOrNavigated, this._mainFrameCreatedOrNavigated, th
is); | 45 WebInspector.resourceTreeModel.addEventListener(WebInspector.ResourceTreeMod
el.EventTypes.MainFrameCreatedOrNavigated, this._mainFrameCreatedOrNavigated, th
is); |
| 46 |
| 47 this._cssModel.addEventListener(WebInspector.CSSStyleModel.Events.StyleSheet
Changed, this._styleSheetChanged, this); |
| 45 this._initialize(); | 48 this._initialize(); |
| 46 } | 49 } |
| 47 | 50 |
| 48 WebInspector.StylesSourceMapping.prototype = { | 51 WebInspector.StylesSourceMapping.prototype = { |
| 49 /** | 52 /** |
| 50 * @param {WebInspector.RawLocation} rawLocation | 53 * @param {WebInspector.RawLocation} rawLocation |
| 51 * @return {WebInspector.UILocation} | 54 * @return {WebInspector.UILocation} |
| 52 */ | 55 */ |
| 53 rawLocationToUILocation: function(rawLocation) | 56 rawLocationToUILocation: function(rawLocation) |
| 54 { | 57 { |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 120 this._unbindUISourceCode(uiSourceCode); | 123 this._unbindUISourceCode(uiSourceCode); |
| 121 } | 124 } |
| 122 } | 125 } |
| 123 }, | 126 }, |
| 124 | 127 |
| 125 /** | 128 /** |
| 126 * @param {WebInspector.UISourceCode} uiSourceCode | 129 * @param {WebInspector.UISourceCode} uiSourceCode |
| 127 */ | 130 */ |
| 128 _unbindUISourceCode: function(uiSourceCode) | 131 _unbindUISourceCode: function(uiSourceCode) |
| 129 { | 132 { |
| 130 if (!uiSourceCode.styleFile()) | 133 var styleFile = this._styleFiles.get(uiSourceCode); |
| 134 if (!styleFile) |
| 131 return; | 135 return; |
| 132 uiSourceCode.styleFile().dispose(); | 136 styleFile.dispose(); |
| 133 uiSourceCode.setStyleFile(null); | 137 this._styleFiles.remove(uiSourceCode); |
| 134 }, | 138 }, |
| 135 | 139 |
| 136 /** | 140 /** |
| 137 * @param {WebInspector.Event} event | 141 * @param {WebInspector.Event} event |
| 138 */ | 142 */ |
| 139 _uiSourceCodeAddedToWorkspace: function(event) | 143 _uiSourceCodeAddedToWorkspace: function(event) |
| 140 { | 144 { |
| 141 var uiSourceCode = /** @type {WebInspector.UISourceCode} */ (event.data)
; | 145 var uiSourceCode = /** @type {WebInspector.UISourceCode} */ (event.data)
; |
| 142 var url = uiSourceCode.url; | 146 var url = uiSourceCode.url; |
| 143 if (!url || !this._urlToHeadersByFrameId[url]) | 147 if (!url || !this._urlToHeadersByFrameId[url]) |
| 144 return; | 148 return; |
| 145 this._bindUISourceCode(uiSourceCode, this._urlToHeadersByFrameId[url].va
lues()[0].values()[0]); | 149 this._bindUISourceCode(uiSourceCode, this._urlToHeadersByFrameId[url].va
lues()[0].values()[0]); |
| 146 }, | 150 }, |
| 147 | 151 |
| 148 /** | 152 /** |
| 149 * @param {WebInspector.UISourceCode} uiSourceCode | 153 * @param {WebInspector.UISourceCode} uiSourceCode |
| 150 * @param {WebInspector.CSSStyleSheetHeader} header | 154 * @param {WebInspector.CSSStyleSheetHeader} header |
| 151 */ | 155 */ |
| 152 _bindUISourceCode: function(uiSourceCode, header) | 156 _bindUISourceCode: function(uiSourceCode, header) |
| 153 { | 157 { |
| 154 if (uiSourceCode.styleFile() || header.isInline) | 158 if (this._styleFiles.get(uiSourceCode) || header.isInline) |
| 155 return; | 159 return; |
| 156 var url = uiSourceCode.url; | 160 var url = uiSourceCode.url; |
| 157 uiSourceCode.setStyleFile(new WebInspector.StyleFile(uiSourceCode)); | 161 this._styleFiles.put(uiSourceCode, new WebInspector.StyleFile(uiSourceCo
de, this)); |
| 158 header.updateLocations(); | 162 header.updateLocations(); |
| 159 }, | 163 }, |
| 160 | 164 |
| 161 /** | 165 /** |
| 162 * @param {WebInspector.Event} event | 166 * @param {WebInspector.Event} event |
| 163 */ | 167 */ |
| 164 _projectWillReset: function(event) | 168 _projectWillReset: function(event) |
| 165 { | 169 { |
| 166 var project = /** @type {WebInspector.Project} */ (event.data); | 170 var project = /** @type {WebInspector.Project} */ (event.data); |
| 167 var uiSourceCodes = project.uiSourceCodes(); | 171 var uiSourceCodes = project.uiSourceCodes(); |
| 168 for (var i = 0; i < uiSourceCodes; ++i) | 172 for (var i = 0; i < uiSourceCodes; ++i) |
| 169 delete this._urlToHeadersByFrameId[uiSourceCodes[i].url]; | 173 this._unbindUISourceCode(uiSourceCodes[i]); |
| 174 }, |
| 175 |
| 176 /** |
| 177 * @param {WebInspector.Event} event |
| 178 */ |
| 179 _uiSourceCodeRemoved: function(event) |
| 180 { |
| 181 var uiSourceCode = /** @type {WebInspector.UISourceCode} */ (event.data)
; |
| 182 this._unbindUISourceCode(uiSourceCode); |
| 170 }, | 183 }, |
| 171 | 184 |
| 172 _initialize: function() | 185 _initialize: function() |
| 173 { | 186 { |
| 174 /** @type {!Object.<string, !StringMap.<!StringMap.<!WebInspector.CSSSty
leSheetHeader>>>} */ | 187 /** @type {!Object.<string, !StringMap.<!StringMap.<!WebInspector.CSSSty
leSheetHeader>>>} */ |
| 175 this._urlToHeadersByFrameId = {}; | 188 this._urlToHeadersByFrameId = {}; |
| 189 /** @type {!Map.<WebInspector.UISourceCode, WebInspector.StyleFile>} */ |
| 190 this._styleFiles = new Map(); |
| 176 }, | 191 }, |
| 177 | 192 |
| 178 /** | 193 /** |
| 179 * @param {WebInspector.Event} event | 194 * @param {WebInspector.Event} event |
| 180 */ | 195 */ |
| 181 _mainFrameCreatedOrNavigated: function(event) | 196 _mainFrameCreatedOrNavigated: function(event) |
| 182 { | 197 { |
| 183 for (var url in this._urlToHeadersByFrameId) { | 198 for (var url in this._urlToHeadersByFrameId) { |
| 184 var uiSourceCode = this._workspace.uiSourceCodeForURL(url); | 199 var uiSourceCode = this._workspace.uiSourceCodeForURL(url); |
| 185 if (!uiSourceCode) | 200 if (!uiSourceCode) |
| 186 continue; | 201 continue; |
| 187 this._unbindUISourceCode(uiSourceCode); | 202 this._unbindUISourceCode(uiSourceCode); |
| 188 } | 203 } |
| 189 this._initialize(); | 204 this._initialize(); |
| 205 }, |
| 206 |
| 207 /** |
| 208 * @param {WebInspector.UISourceCode} uiSourceCode |
| 209 * @param {string} content |
| 210 * @param {boolean} majorChange |
| 211 * @param {function(?string)} userCallback |
| 212 */ |
| 213 _setStyleContent: function(uiSourceCode, content, majorChange, userCallback) |
| 214 { |
| 215 var styleSheetIds = this._cssModel.styleSheetIdsForURL(uiSourceCode.url)
; |
| 216 if (!styleSheetIds.length) { |
| 217 userCallback("No stylesheet found: " + uiSourceCode.url); |
| 218 return; |
| 219 } |
| 220 |
| 221 this._isSettingContent = true; |
| 222 function callback(error) |
| 223 { |
| 224 userCallback(error); |
| 225 delete this._isSettingContent; |
| 226 } |
| 227 this._cssModel.setStyleSheetText(styleSheetIds[0], content, majorChange,
callback.bind(this)); |
| 228 }, |
| 229 |
| 230 /** |
| 231 * @param {WebInspector.Event} event |
| 232 */ |
| 233 _styleSheetChanged: function(event) |
| 234 { |
| 235 if (this._isSettingContent) |
| 236 return; |
| 237 |
| 238 if (!event.data.majorChange) |
| 239 return; |
| 240 |
| 241 /** |
| 242 * @param {?string} error |
| 243 * @param {string} content |
| 244 */ |
| 245 function callback(error, content) |
| 246 { |
| 247 if (!error) |
| 248 this._innerStyleSheetChanged(event.data.styleSheetId, content); |
| 249 } |
| 250 CSSAgent.getStyleSheetText(event.data.styleSheetId, callback.bind(this))
; |
| 251 }, |
| 252 |
| 253 /** |
| 254 * @param {CSSAgent.StyleSheetId} styleSheetId |
| 255 * @param {string} content |
| 256 */ |
| 257 _innerStyleSheetChanged: function(styleSheetId, content) |
| 258 { |
| 259 var header = this._cssModel.styleSheetHeaderForId(styleSheetId); |
| 260 if (!header) |
| 261 return; |
| 262 var styleSheetURL = header.resourceURL(); |
| 263 if (!styleSheetURL) |
| 264 return; |
| 265 |
| 266 var uiSourceCode = this._workspace.uiSourceCodeForURL(styleSheetURL) |
| 267 if (!uiSourceCode) |
| 268 return; |
| 269 |
| 270 var styleFile = this._styleFiles.get(uiSourceCode); |
| 271 if (styleFile) |
| 272 styleFile.addRevision(content); |
| 190 } | 273 } |
| 191 } | 274 } |
| 192 | 275 |
| 193 /** | 276 /** |
| 194 * @constructor | 277 * @constructor |
| 195 * @param {WebInspector.UISourceCode} uiSourceCode | 278 * @param {WebInspector.UISourceCode} uiSourceCode |
| 279 * @param {WebInspector.StylesSourceMapping} mapping |
| 196 */ | 280 */ |
| 197 WebInspector.StyleFile = function(uiSourceCode) | 281 WebInspector.StyleFile = function(uiSourceCode, mapping) |
| 198 { | 282 { |
| 199 this._uiSourceCode = uiSourceCode; | 283 this._uiSourceCode = uiSourceCode; |
| 284 this._mapping = mapping; |
| 200 this._uiSourceCode.addEventListener(WebInspector.UISourceCode.Events.Working
CopyChanged, this._workingCopyChanged, this); | 285 this._uiSourceCode.addEventListener(WebInspector.UISourceCode.Events.Working
CopyChanged, this._workingCopyChanged, this); |
| 201 this._uiSourceCode.addEventListener(WebInspector.UISourceCode.Events.Working
CopyCommitted, this._workingCopyCommitted, this); | 286 this._uiSourceCode.addEventListener(WebInspector.UISourceCode.Events.Working
CopyCommitted, this._workingCopyCommitted, this); |
| 202 } | 287 } |
| 203 | 288 |
| 204 WebInspector.StyleFile.updateTimeout = 200; | 289 WebInspector.StyleFile.updateTimeout = 200; |
| 205 | 290 |
| 206 WebInspector.StyleFile.sourceURLRegex = /\n[\040\t]*\/\*#[\040\t]sourceURL=[\040
\t]*([^\s]*)[\040\t]*\*\/[\040\t]*$/m; | 291 WebInspector.StyleFile.sourceURLRegex = /\n[\040\t]*\/\*#[\040\t]sourceURL=[\040
\t]*([^\s]*)[\040\t]*\*\/[\040\t]*$/m; |
| 207 | 292 |
| 208 WebInspector.StyleFile.prototype = { | 293 WebInspector.StyleFile.prototype = { |
| 209 _workingCopyCommitted: function(event) | 294 _workingCopyCommitted: function(event) |
| (...skipping 15 matching lines...) Expand all Loading... |
| 225 } else | 310 } else |
| 226 this._commitIncrementalEdit(false); | 311 this._commitIncrementalEdit(false); |
| 227 }, | 312 }, |
| 228 | 313 |
| 229 /** | 314 /** |
| 230 * @param {boolean} majorChange | 315 * @param {boolean} majorChange |
| 231 */ | 316 */ |
| 232 _commitIncrementalEdit: function(majorChange) | 317 _commitIncrementalEdit: function(majorChange) |
| 233 { | 318 { |
| 234 this._clearIncrementalUpdateTimer(); | 319 this._clearIncrementalUpdateTimer(); |
| 235 WebInspector.styleContentBinding.setStyleContent(this._uiSourceCode, thi
s._uiSourceCode.workingCopy(), majorChange, this._styleContentSet.bind(this)); | 320 this._mapping._setStyleContent(this._uiSourceCode, this._uiSourceCode.wo
rkingCopy(), majorChange, this._styleContentSet.bind(this)); |
| 236 }, | 321 }, |
| 237 | 322 |
| 238 /** | 323 /** |
| 239 * @param {?string} error | 324 * @param {?string} error |
| 240 */ | 325 */ |
| 241 _styleContentSet: function(error) | 326 _styleContentSet: function(error) |
| 242 { | 327 { |
| 243 if (error) | 328 if (error) |
| 244 WebInspector.showErrorMessage(error); | 329 WebInspector.showErrorMessage(error); |
| 245 }, | 330 }, |
| (...skipping 17 matching lines...) Expand all Loading... |
| 263 this._uiSourceCode.addRevision(content); | 348 this._uiSourceCode.addRevision(content); |
| 264 delete this._isAddingRevision; | 349 delete this._isAddingRevision; |
| 265 }, | 350 }, |
| 266 | 351 |
| 267 dispose: function() | 352 dispose: function() |
| 268 { | 353 { |
| 269 this._uiSourceCode.removeEventListener(WebInspector.UISourceCode.Events.
WorkingCopyCommitted, this._workingCopyCommitted, this); | 354 this._uiSourceCode.removeEventListener(WebInspector.UISourceCode.Events.
WorkingCopyCommitted, this._workingCopyCommitted, this); |
| 270 this._uiSourceCode.removeEventListener(WebInspector.UISourceCode.Events.
WorkingCopyChanged, this._workingCopyChanged, this); | 355 this._uiSourceCode.removeEventListener(WebInspector.UISourceCode.Events.
WorkingCopyChanged, this._workingCopyChanged, this); |
| 271 } | 356 } |
| 272 } | 357 } |
| 273 | |
| 274 /** | |
| 275 * @constructor | |
| 276 * @param {WebInspector.CSSStyleModel} cssModel | |
| 277 */ | |
| 278 WebInspector.StyleContentBinding = function(cssModel, workspace) | |
| 279 { | |
| 280 this._cssModel = cssModel; | |
| 281 this._workspace = workspace; | |
| 282 this._cssModel.addEventListener(WebInspector.CSSStyleModel.Events.StyleSheet
Changed, this._styleSheetChanged, this); | |
| 283 } | |
| 284 | |
| 285 WebInspector.StyleContentBinding.prototype = { | |
| 286 /** | |
| 287 * @param {WebInspector.UISourceCode} uiSourceCode | |
| 288 * @param {string} content | |
| 289 * @param {boolean} majorChange | |
| 290 * @param {function(?string)} userCallback | |
| 291 */ | |
| 292 setStyleContent: function(uiSourceCode, content, majorChange, userCallback) | |
| 293 { | |
| 294 var styleSheetIds = this._cssModel.styleSheetIdsForURL(uiSourceCode.url)
; | |
| 295 if (!styleSheetIds.length) { | |
| 296 userCallback("No stylesheet found: " + uiSourceCode.url); | |
| 297 return; | |
| 298 } | |
| 299 | |
| 300 this._isSettingContent = true; | |
| 301 function callback(error) | |
| 302 { | |
| 303 userCallback(error); | |
| 304 delete this._isSettingContent; | |
| 305 } | |
| 306 this._cssModel.setStyleSheetText(styleSheetIds[0], content, majorChange,
callback.bind(this)); | |
| 307 }, | |
| 308 | |
| 309 /** | |
| 310 * @param {WebInspector.Event} event | |
| 311 */ | |
| 312 _styleSheetChanged: function(event) | |
| 313 { | |
| 314 if (this._isSettingContent) | |
| 315 return; | |
| 316 | |
| 317 if (!event.data.majorChange) | |
| 318 return; | |
| 319 | |
| 320 /** | |
| 321 * @param {?string} error | |
| 322 * @param {string} content | |
| 323 */ | |
| 324 function callback(error, content) | |
| 325 { | |
| 326 if (!error) | |
| 327 this._innerStyleSheetChanged(event.data.styleSheetId, content); | |
| 328 } | |
| 329 CSSAgent.getStyleSheetText(event.data.styleSheetId, callback.bind(this))
; | |
| 330 }, | |
| 331 | |
| 332 /** | |
| 333 * @param {CSSAgent.StyleSheetId} styleSheetId | |
| 334 * @param {string} content | |
| 335 */ | |
| 336 _innerStyleSheetChanged: function(styleSheetId, content) | |
| 337 { | |
| 338 var header = this._cssModel.styleSheetHeaderForId(styleSheetId); | |
| 339 if (!header) | |
| 340 return; | |
| 341 var styleSheetURL = header.resourceURL(); | |
| 342 if (!styleSheetURL) | |
| 343 return; | |
| 344 | |
| 345 var uiSourceCode = this._workspace.uiSourceCodeForURL(styleSheetURL) | |
| 346 if (!uiSourceCode) | |
| 347 return; | |
| 348 | |
| 349 if (uiSourceCode.styleFile()) | |
| 350 uiSourceCode.styleFile().addRevision(content); | |
| 351 } | |
| 352 } | |
| 353 | |
| 354 /** | |
| 355 * @type {?WebInspector.StyleContentBinding} | |
| 356 */ | |
| 357 WebInspector.styleContentBinding = null; | |
| OLD | NEW |