Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 Sources.SourceFormatData = class { | 5 Sources.SourceFormatData = class { |
| 6 /** | 6 /** |
| 7 * @param {!Workspace.UISourceCode} originalSourceCode | 7 * @param {!Workspace.UISourceCode} originalSourceCode |
| 8 * @param {!Workspace.UISourceCode} formattedSourceCode | 8 * @param {!Workspace.UISourceCode} formattedSourceCode |
| 9 * @param {!Sources.FormatterSourceMapping} mapping | 9 * @param {!Sources.FormatterSourceMapping} mapping |
| 10 */ | 10 */ |
| (...skipping 18 matching lines...) Expand all Loading... | |
| 29 | 29 |
| 30 Sources.SourceFormatData._formatDataSymbol = Symbol('formatData'); | 30 Sources.SourceFormatData._formatDataSymbol = Symbol('formatData'); |
| 31 | 31 |
| 32 Sources.SourceFormatter = class { | 32 Sources.SourceFormatter = class { |
| 33 constructor() { | 33 constructor() { |
| 34 this._projectId = 'formatter:'; | 34 this._projectId = 'formatter:'; |
| 35 this._project = new Bindings.ContentProviderBasedProject( | 35 this._project = new Bindings.ContentProviderBasedProject( |
| 36 Workspace.workspace, this._projectId, Workspace.projectTypes.Formatter, 'formatter', | 36 Workspace.workspace, this._projectId, Workspace.projectTypes.Formatter, 'formatter', |
| 37 true /* isServiceProject */); | 37 true /* isServiceProject */); |
| 38 | 38 |
| 39 /** @type {!Map<string, !Workspace.UISourceCode>} */ | 39 /** @type {!Map<string, !Promise<!Sources.SourceFormatData>>} */ |
| 40 this._formattedPaths = new Map(); | 40 this._formattedPaths = new Map(); |
| 41 this._scriptMapping = new Sources.SourceFormatter.ScriptMapping(); | 41 this._scriptMapping = new Sources.SourceFormatter.ScriptMapping(); |
| 42 this._styleMapping = new Sources.SourceFormatter.StyleMapping(); | 42 this._styleMapping = new Sources.SourceFormatter.StyleMapping(); |
| 43 Workspace.workspace.addEventListener( | 43 Workspace.workspace.addEventListener( |
| 44 Workspace.Workspace.Events.UISourceCodeRemoved, this._onUISourceCodeRemo ved, this); | 44 Workspace.Workspace.Events.UISourceCodeRemoved, this._onUISourceCodeRemo ved, this); |
| 45 } | 45 } |
| 46 | 46 |
| 47 /** | 47 /** |
| 48 * @param {!Common.Event} event | 48 * @param {!Common.Event} event |
| 49 */ | 49 */ |
| 50 _onUISourceCodeRemoved(event) { | 50 _onUISourceCodeRemoved(event) { |
| 51 var uiSourceCode = /** @type {!Workspace.UISourceCode} */ (event.data); | 51 var uiSourceCode = /** @type {!Workspace.UISourceCode} */ (event.data); |
| 52 var formattedUISourceCode = this._formattedPaths.get(uiSourceCode.project(). id() + ':' + uiSourceCode.url()); | 52 var formatDataPromise = this._formattedPaths.get(uiSourceCode.project().id() + ':' + uiSourceCode.url()); |
| 53 if (formattedUISourceCode) | 53 if (formatDataPromise) |
| 54 this.discardFormattedUISourceCode(formattedUISourceCode); | 54 formatDataPromise.then(formatData => this.discardFormattedUISourceCode(for matData.formattedSourceCode)); |
|
lushnikov
2017/05/17 23:39:08
Since you're caching per projectId + uiSourceCodeU
lushnikov
2017/05/17 23:57:32
this._formattedPath.delete(path);
| |
| 55 } | 55 } |
| 56 | 56 |
| 57 /** | 57 /** |
| 58 * @param {!Workspace.UISourceCode} formattedUISourceCode | 58 * @param {!Workspace.UISourceCode} formattedUISourceCode |
| 59 * @return {?Workspace.UISourceCode} | 59 * @return {?Workspace.UISourceCode} |
| 60 */ | 60 */ |
| 61 discardFormattedUISourceCode(formattedUISourceCode) { | 61 discardFormattedUISourceCode(formattedUISourceCode) { |
| 62 var formatData = Sources.SourceFormatData._for(formattedUISourceCode); | 62 var formatData = Sources.SourceFormatData._for(formattedUISourceCode); |
| 63 if (!formatData) | 63 if (!formatData) |
| 64 return null; | 64 return null; |
| 65 | 65 |
| 66 delete formattedUISourceCode[Sources.SourceFormatData._formatDataSymbol]; | 66 delete formattedUISourceCode[Sources.SourceFormatData._formatDataSymbol]; |
| 67 this._scriptMapping._setSourceMappingEnabled(formatData, false); | 67 this._scriptMapping._setSourceMappingEnabled(formatData, false); |
| 68 this._styleMapping._setSourceMappingEnabled(formatData, false); | 68 this._styleMapping._setSourceMappingEnabled(formatData, false); |
| 69 this._project.removeFile(formattedUISourceCode.url()); | 69 this._project.removeFile(formattedUISourceCode.url()); |
| 70 this._formattedPaths.remove(formatData.originalPath()); | 70 var originalSourceCode = formatData.originalSourceCode; |
| 71 return formatData.originalSourceCode; | 71 this._formattedPaths.remove(originalSourceCode.project().id() + ':' + origin alSourceCode.url()); |
| 72 return originalSourceCode; | |
| 72 } | 73 } |
| 73 | 74 |
| 74 /** | 75 /** |
| 75 * @param {!Workspace.UISourceCode} uiSourceCode | 76 * @param {!Workspace.UISourceCode} uiSourceCode |
| 76 * @return {boolean} | 77 * @return {boolean} |
| 77 */ | 78 */ |
| 78 hasFormatted(uiSourceCode) { | 79 hasFormatted(uiSourceCode) { |
| 79 return this._formattedPaths.has(uiSourceCode.project().id() + ':' + uiSource Code.url()); | 80 return this._formattedPaths.has(uiSourceCode.project().id() + ':' + uiSource Code.url()); |
| 80 } | 81 } |
| 81 | 82 |
| 82 /** | 83 /** |
| 83 * @param {!Workspace.UISourceCode} uiSourceCode | 84 * @param {!Workspace.UISourceCode} uiSourceCode |
| 84 * @return {!Promise<!Sources.SourceFormatData>} | 85 * @return {!Promise<!Sources.SourceFormatData>} |
| 85 */ | 86 */ |
| 86 async format(uiSourceCode) { | 87 async format(uiSourceCode) { |
| 87 var formattedUISourceCode = this._formattedPaths.get(uiSourceCode.project(). id() + ':' + uiSourceCode.url()); | 88 var path = uiSourceCode.project().id() + ':' + uiSourceCode.url(); |
| 88 if (formattedUISourceCode) | 89 var resultPromise = this._formattedPaths.get(path); |
| 89 return Sources.SourceFormatData._for(formattedUISourceCode); | 90 if (resultPromise) |
| 91 return resultPromise; | |
| 90 | 92 |
| 93 var fulfillFormatPromise; | |
| 94 resultPromise = new Promise(fulfill => { | |
| 95 fulfillFormatPromise = fulfill; | |
| 96 }); | |
| 97 this._formattedPaths.set(path, resultPromise); | |
| 91 var content = await uiSourceCode.requestContent(); | 98 var content = await uiSourceCode.requestContent(); |
| 92 var highlighterType = Bindings.NetworkProject.uiSourceCodeMimeType(uiSourceC ode); | 99 var highlighterType = Bindings.NetworkProject.uiSourceCodeMimeType(uiSourceC ode); |
| 93 var fulfillFormatPromise; | |
| 94 var resultPromise = new Promise(fulfill => { | |
| 95 fulfillFormatPromise = fulfill; | |
| 96 }); | |
| 97 Sources.Formatter.format(uiSourceCode.contentType(), highlighterType, conten t || '', innerCallback.bind(this)); | 100 Sources.Formatter.format(uiSourceCode.contentType(), highlighterType, conten t || '', innerCallback.bind(this)); |
| 98 return resultPromise; | 101 return resultPromise; |
| 99 | 102 |
| 100 /** | 103 /** |
| 101 * @this Sources.SourceFormatter | 104 * @this Sources.SourceFormatter |
| 102 * @param {string} formattedContent | 105 * @param {string} formattedContent |
| 103 * @param {!Sources.FormatterSourceMapping} formatterMapping | 106 * @param {!Sources.FormatterSourceMapping} formatterMapping |
| 104 */ | 107 */ |
| 105 function innerCallback(formattedContent, formatterMapping) { | 108 function innerCallback(formattedContent, formatterMapping) { |
| 106 var formattedURL = uiSourceCode.url() + ':formatted'; | 109 var formattedURL = uiSourceCode.url() + ':formatted'; |
|
lushnikov
2017/05/17 23:57:32
if (this._formattedPaths.get(path) !== resultPromi
caseq
2017/05/18 02:04:37
Done.
| |
| 107 var contentProvider = | 110 var contentProvider = |
| 108 Common.StaticContentProvider.fromString(formattedURL, uiSourceCode.con tentType(), formattedContent); | 111 Common.StaticContentProvider.fromString(formattedURL, uiSourceCode.con tentType(), formattedContent); |
| 109 var formattedUISourceCode = this._project.addContentProvider(formattedURL, contentProvider); | 112 var formattedUISourceCode = this._project.addContentProvider(formattedURL, contentProvider); |
| 110 var formatData = new Sources.SourceFormatData(uiSourceCode, formattedUISou rceCode, formatterMapping); | 113 var formatData = new Sources.SourceFormatData(uiSourceCode, formattedUISou rceCode, formatterMapping); |
| 111 formattedUISourceCode[Sources.SourceFormatData._formatDataSymbol] = format Data; | 114 formattedUISourceCode[Sources.SourceFormatData._formatDataSymbol] = format Data; |
| 112 this._scriptMapping._setSourceMappingEnabled(formatData, true); | 115 this._scriptMapping._setSourceMappingEnabled(formatData, true); |
| 113 this._styleMapping._setSourceMappingEnabled(formatData, true); | 116 this._styleMapping._setSourceMappingEnabled(formatData, true); |
| 114 | 117 |
| 115 var path = formatData.originalPath(); | |
| 116 this._formattedPaths.set(path, formattedUISourceCode); | |
| 117 | |
| 118 for (var decoration of uiSourceCode.allDecorations()) { | 118 for (var decoration of uiSourceCode.allDecorations()) { |
| 119 var range = decoration.range(); | 119 var range = decoration.range(); |
| 120 var startLocation = formatterMapping.originalToFormatted(range.startLine , range.startColumn); | 120 var startLocation = formatterMapping.originalToFormatted(range.startLine , range.startColumn); |
| 121 var endLocation = formatterMapping.originalToFormatted(range.endLine, ra nge.endColumn); | 121 var endLocation = formatterMapping.originalToFormatted(range.endLine, ra nge.endColumn); |
| 122 | 122 |
| 123 formattedUISourceCode.addDecoration( | 123 formattedUISourceCode.addDecoration( |
| 124 new TextUtils.TextRange(startLocation[0], startLocation[1], endLocat ion[0], endLocation[1]), | 124 new TextUtils.TextRange(startLocation[0], startLocation[1], endLocat ion[0], endLocation[1]), |
| 125 /** @type {string} */ (decoration.type()), decoration.data()); | 125 /** @type {string} */ (decoration.type()), decoration.data()); |
| 126 } | 126 } |
| 127 | 127 |
| (...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 283 return; | 283 return; |
| 284 if (enable) | 284 if (enable) |
| 285 styleHeader[Sources.SourceFormatData._formatDataSymbol] = formatData; | 285 styleHeader[Sources.SourceFormatData._formatDataSymbol] = formatData; |
| 286 else | 286 else |
| 287 delete styleHeader[Sources.SourceFormatData._formatDataSymbol]; | 287 delete styleHeader[Sources.SourceFormatData._formatDataSymbol]; |
| 288 Bindings.cssWorkspaceBinding.updateLocations(styleHeader); | 288 Bindings.cssWorkspaceBinding.updateLocations(styleHeader); |
| 289 } | 289 } |
| 290 }; | 290 }; |
| 291 | 291 |
| 292 Sources.sourceFormatter = new Sources.SourceFormatter(); | 292 Sources.sourceFormatter = new Sources.SourceFormatter(); |
| OLD | NEW |