@angular-devkit/build-optimizer
Advanced tools
Comparing version 0.0.7 to 0.0.8
{ | ||
"name": "@angular-devkit/build-optimizer", | ||
"version": "0.0.7", | ||
"version": "0.0.8", | ||
"description": "Angular Build Optimizer", | ||
@@ -13,3 +13,2 @@ "main": "src/index.js", | ||
"loader-utils": "^1.1.0", | ||
"magic-string": "^0.19.1", | ||
"source-map": "^0.5.6", | ||
@@ -16,0 +15,0 @@ "typescript": "^2.3.3" |
@@ -23,3 +23,3 @@ # Angular Build Optimizer | ||
``` | ||
```typescript | ||
// input | ||
@@ -38,3 +38,3 @@ var Clazz = (function () { function Clazz() { } return Clazz; }()); | ||
``` | ||
```typescript | ||
// input | ||
@@ -61,3 +61,3 @@ import { Injectable, Input } from '@angular/core'; | ||
``` | ||
```typescript | ||
// input | ||
@@ -79,3 +79,3 @@ var Clazz = (function () { function Clazz() { } return Clazz; }()); | ||
``` | ||
```typescript | ||
// input | ||
@@ -101,3 +101,3 @@ var __extends = (this && this.__extends) || function (d, b) { | ||
``` | ||
```typescript | ||
import { buildOptimizer } from '@angular-devkit/build-optimizer'; | ||
@@ -109,3 +109,3 @@ | ||
Available options: | ||
``` | ||
```typescript | ||
export interface BuildOptimizerOptions { | ||
@@ -123,3 +123,3 @@ content?: string; | ||
``` | ||
```typescript | ||
const PurifyPlugin = require('@angular-devkit/build-optimizer').PurifyPlugin; | ||
@@ -148,3 +148,3 @@ | ||
``` | ||
```bash | ||
build-optimizer input.js | ||
@@ -151,0 +151,0 @@ build-optimizer input.js output.js |
@@ -1,3 +0,2 @@ | ||
/// <reference types="source-map" /> | ||
import { RawSourceMap } from 'source-map'; | ||
import { TransformJavascriptOutput } from '../helpers/transform-javascript'; | ||
export interface BuildOptimizerOptions { | ||
@@ -10,5 +9,2 @@ content?: string; | ||
} | ||
export declare function buildOptimizer(options: BuildOptimizerOptions): { | ||
content: string; | ||
sourceMap: RawSourceMap | null; | ||
}; | ||
export declare function buildOptimizer(options: BuildOptimizerOptions): TransformJavascriptOutput; |
@@ -11,3 +11,2 @@ "use strict"; | ||
const fs_1 = require("fs"); | ||
const MagicString = require('magic-string'); | ||
const transform_javascript_1 = require("../helpers/transform-javascript"); | ||
@@ -21,10 +20,10 @@ const class_fold_1 = require("../transforms/class-fold"); | ||
const hasTsHelpers = /var (__extends|__decorate|__metadata|__param) = /; | ||
const isAngularPackage = /(\\|\/)node_modules(\\|\/)@angular(\\|\/)/; | ||
function buildOptimizer(options) { | ||
options.emitSourceMap = !!options.emitSourceMap; | ||
const { inputFilePath, emitSourceMap, outputFilePath, strict } = options; | ||
const { inputFilePath } = options; | ||
let { content } = options; | ||
if (!inputFilePath && !content) { | ||
if (!inputFilePath && content === undefined) { | ||
throw new Error('Either filePath or content must be specified in options.'); | ||
} | ||
if (!content) { | ||
if (content === undefined) { | ||
content = fs_1.readFileSync(inputFilePath, 'UTF-8'); | ||
@@ -37,42 +36,17 @@ } | ||
} | ||
if (hasDecorators.test(content) || hasCtorParameters.test(content)) { | ||
if (inputFilePath && isAngularPackage.test(inputFilePath)) { | ||
// Order matters, getPrefixFunctionsTransformer needs to be called before | ||
// getFoldFileTransformer. | ||
getTransforms.push(...[ | ||
prefix_functions_1.getPrefixFunctionsTransformer, | ||
scrub_file_1.getScrubFileTransformer, | ||
class_fold_1.getFoldFileTransformer, | ||
]); | ||
getTransforms.push( | ||
// getPrefixFunctionsTransformer is rather dangerous. | ||
// It will mark both `require()` calls and `console.log(stuff)` as pure. | ||
// We only apply it to @angular/* packages, since we know they are safe. | ||
prefix_functions_1.getPrefixFunctionsTransformer, scrub_file_1.getScrubFileTransformer, class_fold_1.getFoldFileTransformer); | ||
} | ||
if (getTransforms.length > 0) { | ||
// Only transform if there are transforms to apply. | ||
return transform_javascript_1.transformJavascript({ | ||
content, | ||
getTransforms, | ||
emitSourceMap, | ||
inputFilePath, | ||
outputFilePath, | ||
strict, | ||
}); | ||
else if (hasDecorators.test(content) || hasCtorParameters.test(content)) { | ||
getTransforms.push(scrub_file_1.getScrubFileTransformer, class_fold_1.getFoldFileTransformer); | ||
} | ||
else if (emitSourceMap) { | ||
// Emit a sourcemap with no changes. | ||
const ms = new MagicString(content); | ||
return { | ||
content, | ||
sourceMap: ms.generateMap({ | ||
source: inputFilePath, | ||
file: outputFilePath ? `${outputFilePath}.map` : null, | ||
includeContent: true, | ||
}), | ||
}; | ||
} | ||
else { | ||
return { | ||
content, | ||
sourceMap: null, | ||
}; | ||
} | ||
return transform_javascript_1.transformJavascript(Object.assign({}, options, { getTransforms, content })); | ||
} | ||
exports.buildOptimizer = buildOptimizer; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtb3B0aW1pemVyLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9oYW5zbC9Tb3VyY2VzL2RldmtpdC8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX29wdGltaXplci9zcmMvYnVpbGQtb3B0aW1pemVyL2J1aWxkLW9wdGltaXplci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILDJCQUFrQztBQUVsQyxNQUFNLFdBQVcsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUM7QUFFNUMsMEVBQXNFO0FBQ3RFLHlEQUFrRTtBQUNsRSw2REFBdUU7QUFDdkUscUVBQStFO0FBQy9FLHlEQUFtRTtBQUduRSxNQUFNLGFBQWEsR0FBRyxZQUFZLENBQUM7QUFDbkMsTUFBTSxpQkFBaUIsR0FBRyxnQkFBZ0IsQ0FBQztBQUMzQyxNQUFNLFlBQVksR0FBRyxrREFBa0QsQ0FBQztBQVV4RSx3QkFBK0IsT0FBOEI7SUFHM0QsT0FBTyxDQUFDLGFBQWEsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQztJQUNoRCxNQUFNLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDO0lBQ3pFLElBQUksRUFBRSxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUM7SUFFMUIsRUFBRSxDQUFDLENBQUMsQ0FBQyxhQUFhLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQy9CLE1BQU0sSUFBSSxLQUFLLENBQUMsMERBQTBELENBQUMsQ0FBQztJQUM5RSxDQUFDO0lBRUQsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1FBQ2IsT0FBTyxHQUFHLGlCQUFZLENBQUMsYUFBdUIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQsdUNBQXVDO0lBQ3ZDLE1BQU0sYUFBYSxHQUFHLEVBQUUsQ0FBQztJQUV6QixFQUFFLENBQUMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMvQixhQUFhLENBQUMsSUFBSSxDQUFDLHdDQUF5QixDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUdELEVBQUUsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNuRSx5RUFBeUU7UUFDekUsMEJBQTBCO1FBQzFCLGFBQWEsQ0FBQyxJQUFJLENBQUMsR0FBRztZQUNwQixnREFBNkI7WUFDN0Isb0NBQXVCO1lBQ3ZCLG1DQUFzQjtTQUN2QixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsRUFBRSxDQUFDLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzdCLG1EQUFtRDtRQUNuRCxNQUFNLENBQUMsMENBQW1CLENBQUM7WUFDekIsT0FBTztZQUNQLGFBQWE7WUFDYixhQUFhO1lBQ2IsYUFBYTtZQUNiLGNBQWM7WUFDZCxNQUFNO1NBQ1AsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO1FBQ3pCLG9DQUFvQztRQUNwQyxNQUFNLEVBQUUsR0FBRyxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVwQyxNQUFNLENBQUM7WUFDTCxPQUFPO1lBQ1AsU0FBUyxFQUFFLEVBQUUsQ0FBQyxXQUFXLENBQUM7Z0JBQ3hCLE1BQU0sRUFBRSxhQUFhO2dCQUNyQixJQUFJLEVBQUUsY0FBYyxHQUFHLEdBQUcsY0FBYyxNQUFNLEdBQUcsSUFBSTtnQkFDckQsY0FBYyxFQUFFLElBQUk7YUFDckIsQ0FBQztTQUNILENBQUM7SUFDSixDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDTixNQUFNLENBQUM7WUFDTCxPQUFPO1lBQ1AsU0FBUyxFQUFFLElBQUk7U0FDaEIsQ0FBQztJQUNKLENBQUM7QUFDSCxDQUFDO0FBN0RELHdDQTZEQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IHJlYWRGaWxlU3luYyB9IGZyb20gJ2ZzJztcbmltcG9ydCB7IFJhd1NvdXJjZU1hcCB9IGZyb20gJ3NvdXJjZS1tYXAnO1xuY29uc3QgTWFnaWNTdHJpbmcgPSByZXF1aXJlKCdtYWdpYy1zdHJpbmcnKTtcblxuaW1wb3J0IHsgdHJhbnNmb3JtSmF2YXNjcmlwdCB9IGZyb20gJy4uL2hlbHBlcnMvdHJhbnNmb3JtLWphdmFzY3JpcHQnO1xuaW1wb3J0IHsgZ2V0Rm9sZEZpbGVUcmFuc2Zvcm1lciB9IGZyb20gJy4uL3RyYW5zZm9ybXMvY2xhc3MtZm9sZCc7XG5pbXBvcnQgeyBnZXRJbXBvcnRUc2xpYlRyYW5zZm9ybWVyIH0gZnJvbSAnLi4vdHJhbnNmb3Jtcy9pbXBvcnQtdHNsaWInO1xuaW1wb3J0IHsgZ2V0UHJlZml4RnVuY3Rpb25zVHJhbnNmb3JtZXIgfSBmcm9tICcuLi90cmFuc2Zvcm1zL3ByZWZpeC1mdW5jdGlvbnMnO1xuaW1wb3J0IHsgZ2V0U2NydWJGaWxlVHJhbnNmb3JtZXIgfSBmcm9tICcuLi90cmFuc2Zvcm1zL3NjcnViLWZpbGUnO1xuXG5cbmNvbnN0IGhhc0RlY29yYXRvcnMgPSAvZGVjb3JhdG9ycy87XG5jb25zdCBoYXNDdG9yUGFyYW1ldGVycyA9IC9jdG9yUGFyYW1ldGVycy87XG5jb25zdCBoYXNUc0hlbHBlcnMgPSAvdmFyIChfX2V4dGVuZHN8X19kZWNvcmF0ZXxfX21ldGFkYXRhfF9fcGFyYW0pID0gLztcblxuZXhwb3J0IGludGVyZmFjZSBCdWlsZE9wdGltaXplck9wdGlvbnMge1xuICBjb250ZW50Pzogc3RyaW5nO1xuICBpbnB1dEZpbGVQYXRoPzogc3RyaW5nO1xuICBvdXRwdXRGaWxlUGF0aD86IHN0cmluZztcbiAgZW1pdFNvdXJjZU1hcD86IGJvb2xlYW47XG4gIHN0cmljdD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBidWlsZE9wdGltaXplcihvcHRpb25zOiBCdWlsZE9wdGltaXplck9wdGlvbnMpOlxuICB7IGNvbnRlbnQ6IHN0cmluZywgc291cmNlTWFwOiBSYXdTb3VyY2VNYXAgfCBudWxsIH0ge1xuXG4gIG9wdGlvbnMuZW1pdFNvdXJjZU1hcCA9ICEhb3B0aW9ucy5lbWl0U291cmNlTWFwO1xuICBjb25zdCB7IGlucHV0RmlsZVBhdGgsIGVtaXRTb3VyY2VNYXAsIG91dHB1dEZpbGVQYXRoLCBzdHJpY3QgfSA9IG9wdGlvbnM7XG4gIGxldCB7IGNvbnRlbnQgfSA9IG9wdGlvbnM7XG5cbiAgaWYgKCFpbnB1dEZpbGVQYXRoICYmICFjb250ZW50KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdFaXRoZXIgZmlsZVBhdGggb3IgY29udGVudCBtdXN0IGJlIHNwZWNpZmllZCBpbiBvcHRpb25zLicpO1xuICB9XG5cbiAgaWYgKCFjb250ZW50KSB7XG4gICAgY29udGVudCA9IHJlYWRGaWxlU3luYyhpbnB1dEZpbGVQYXRoIGFzIHN0cmluZywgJ1VURi04Jyk7XG4gIH1cblxuICAvLyBEZXRlcm1pbmUgd2hpY2ggdHJhbnNmb3JtcyB0byBhcHBseS5cbiAgY29uc3QgZ2V0VHJhbnNmb3JtcyA9IFtdO1xuXG4gIGlmIChoYXNUc0hlbHBlcnMudGVzdChjb250ZW50KSkge1xuICAgIGdldFRyYW5zZm9ybXMucHVzaChnZXRJbXBvcnRUc2xpYlRyYW5zZm9ybWVyKTtcbiAgfVxuXG5cbiAgaWYgKGhhc0RlY29yYXRvcnMudGVzdChjb250ZW50KSB8fCBoYXNDdG9yUGFyYW1ldGVycy50ZXN0KGNvbnRlbnQpKSB7XG4gICAgLy8gT3JkZXIgbWF0dGVycywgZ2V0UHJlZml4RnVuY3Rpb25zVHJhbnNmb3JtZXIgbmVlZHMgdG8gYmUgY2FsbGVkIGJlZm9yZVxuICAgIC8vIGdldEZvbGRGaWxlVHJhbnNmb3JtZXIuXG4gICAgZ2V0VHJhbnNmb3Jtcy5wdXNoKC4uLltcbiAgICAgIGdldFByZWZpeEZ1bmN0aW9uc1RyYW5zZm9ybWVyLFxuICAgICAgZ2V0U2NydWJGaWxlVHJhbnNmb3JtZXIsXG4gICAgICBnZXRGb2xkRmlsZVRyYW5zZm9ybWVyLFxuICAgIF0pO1xuICB9XG5cbiAgaWYgKGdldFRyYW5zZm9ybXMubGVuZ3RoID4gMCkge1xuICAgIC8vIE9ubHkgdHJhbnNmb3JtIGlmIHRoZXJlIGFyZSB0cmFuc2Zvcm1zIHRvIGFwcGx5LlxuICAgIHJldHVybiB0cmFuc2Zvcm1KYXZhc2NyaXB0KHtcbiAgICAgIGNvbnRlbnQsXG4gICAgICBnZXRUcmFuc2Zvcm1zLFxuICAgICAgZW1pdFNvdXJjZU1hcCxcbiAgICAgIGlucHV0RmlsZVBhdGgsXG4gICAgICBvdXRwdXRGaWxlUGF0aCxcbiAgICAgIHN0cmljdCxcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChlbWl0U291cmNlTWFwKSB7XG4gICAgLy8gRW1pdCBhIHNvdXJjZW1hcCB3aXRoIG5vIGNoYW5nZXMuXG4gICAgY29uc3QgbXMgPSBuZXcgTWFnaWNTdHJpbmcoY29udGVudCk7XG5cbiAgICByZXR1cm4ge1xuICAgICAgY29udGVudCxcbiAgICAgIHNvdXJjZU1hcDogbXMuZ2VuZXJhdGVNYXAoe1xuICAgICAgICBzb3VyY2U6IGlucHV0RmlsZVBhdGgsXG4gICAgICAgIGZpbGU6IG91dHB1dEZpbGVQYXRoID8gYCR7b3V0cHV0RmlsZVBhdGh9Lm1hcGAgOiBudWxsLFxuICAgICAgICBpbmNsdWRlQ29udGVudDogdHJ1ZSxcbiAgICAgIH0pLFxuICAgIH07XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNvbnRlbnQsXG4gICAgICBzb3VyY2VNYXA6IG51bGwsXG4gICAgfTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtb3B0aW1pemVyLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9oYW5zbC9Tb3VyY2VzL2RldmtpdC8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX29wdGltaXplci9zcmMvYnVpbGQtb3B0aW1pemVyL2J1aWxkLW9wdGltaXplci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBOzs7Ozs7R0FNRztBQUNILDJCQUFrQztBQUNsQywwRUFBaUc7QUFDakcseURBQWtFO0FBQ2xFLDZEQUF1RTtBQUN2RSxxRUFBK0U7QUFDL0UseURBQW1FO0FBR25FLE1BQU0sYUFBYSxHQUFHLFlBQVksQ0FBQztBQUNuQyxNQUFNLGlCQUFpQixHQUFHLGdCQUFnQixDQUFDO0FBQzNDLE1BQU0sWUFBWSxHQUFHLGtEQUFrRCxDQUFDO0FBQ3hFLE1BQU0sZ0JBQWdCLEdBQUcsMkNBQTJDLENBQUM7QUFVckUsd0JBQStCLE9BQThCO0lBRTNELE1BQU0sRUFBRSxhQUFhLEVBQUUsR0FBRyxPQUFPLENBQUM7SUFDbEMsSUFBSSxFQUFFLE9BQU8sRUFBRSxHQUFHLE9BQU8sQ0FBQztJQUUxQixFQUFFLENBQUMsQ0FBQyxDQUFDLGFBQWEsSUFBSSxPQUFPLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQztRQUM1QyxNQUFNLElBQUksS0FBSyxDQUFDLDBEQUEwRCxDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUVELEVBQUUsQ0FBQyxDQUFDLE9BQU8sS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDO1FBQzFCLE9BQU8sR0FBRyxpQkFBWSxDQUFDLGFBQXVCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUVELHVDQUF1QztJQUN2QyxNQUFNLGFBQWEsR0FBRyxFQUFFLENBQUM7SUFFekIsRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDL0IsYUFBYSxDQUFDLElBQUksQ0FBQyx3Q0FBeUIsQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFRCxFQUFFLENBQUMsQ0FBQyxhQUFhLElBQUksZ0JBQWdCLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRCx5RUFBeUU7UUFDekUsMEJBQTBCO1FBQzFCLGFBQWEsQ0FBQyxJQUFJO1FBQ2hCLHFEQUFxRDtRQUNyRCx3RUFBd0U7UUFDeEUsd0VBQXdFO1FBQ3hFLGdEQUE2QixFQUM3QixvQ0FBdUIsRUFDdkIsbUNBQXNCLENBQ3ZCLENBQUM7SUFDSixDQUFDO0lBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUMxRSxhQUFhLENBQUMsSUFBSSxDQUNoQixvQ0FBdUIsRUFDdkIsbUNBQXNCLENBQ3ZCLENBQUM7SUFDSixDQUFDO0lBRUQsTUFBTSxDQUFDLDBDQUFtQixtQkFBTSxPQUFPLElBQUUsYUFBYSxFQUFFLE9BQU8sSUFBRyxDQUFDO0FBQ3JFLENBQUM7QUF2Q0Qsd0NBdUNDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHsgcmVhZEZpbGVTeW5jIH0gZnJvbSAnZnMnO1xuaW1wb3J0IHsgVHJhbnNmb3JtSmF2YXNjcmlwdE91dHB1dCwgdHJhbnNmb3JtSmF2YXNjcmlwdCB9IGZyb20gJy4uL2hlbHBlcnMvdHJhbnNmb3JtLWphdmFzY3JpcHQnO1xuaW1wb3J0IHsgZ2V0Rm9sZEZpbGVUcmFuc2Zvcm1lciB9IGZyb20gJy4uL3RyYW5zZm9ybXMvY2xhc3MtZm9sZCc7XG5pbXBvcnQgeyBnZXRJbXBvcnRUc2xpYlRyYW5zZm9ybWVyIH0gZnJvbSAnLi4vdHJhbnNmb3Jtcy9pbXBvcnQtdHNsaWInO1xuaW1wb3J0IHsgZ2V0UHJlZml4RnVuY3Rpb25zVHJhbnNmb3JtZXIgfSBmcm9tICcuLi90cmFuc2Zvcm1zL3ByZWZpeC1mdW5jdGlvbnMnO1xuaW1wb3J0IHsgZ2V0U2NydWJGaWxlVHJhbnNmb3JtZXIgfSBmcm9tICcuLi90cmFuc2Zvcm1zL3NjcnViLWZpbGUnO1xuXG5cbmNvbnN0IGhhc0RlY29yYXRvcnMgPSAvZGVjb3JhdG9ycy87XG5jb25zdCBoYXNDdG9yUGFyYW1ldGVycyA9IC9jdG9yUGFyYW1ldGVycy87XG5jb25zdCBoYXNUc0hlbHBlcnMgPSAvdmFyIChfX2V4dGVuZHN8X19kZWNvcmF0ZXxfX21ldGFkYXRhfF9fcGFyYW0pID0gLztcbmNvbnN0IGlzQW5ndWxhclBhY2thZ2UgPSAvKFxcXFx8XFwvKW5vZGVfbW9kdWxlcyhcXFxcfFxcLylAYW5ndWxhcihcXFxcfFxcLykvO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkT3B0aW1pemVyT3B0aW9ucyB7XG4gIGNvbnRlbnQ/OiBzdHJpbmc7XG4gIGlucHV0RmlsZVBhdGg/OiBzdHJpbmc7XG4gIG91dHB1dEZpbGVQYXRoPzogc3RyaW5nO1xuICBlbWl0U291cmNlTWFwPzogYm9vbGVhbjtcbiAgc3RyaWN0PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGJ1aWxkT3B0aW1pemVyKG9wdGlvbnM6IEJ1aWxkT3B0aW1pemVyT3B0aW9ucyk6IFRyYW5zZm9ybUphdmFzY3JpcHRPdXRwdXQge1xuXG4gIGNvbnN0IHsgaW5wdXRGaWxlUGF0aCB9ID0gb3B0aW9ucztcbiAgbGV0IHsgY29udGVudCB9ID0gb3B0aW9ucztcblxuICBpZiAoIWlucHV0RmlsZVBhdGggJiYgY29udGVudCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdFaXRoZXIgZmlsZVBhdGggb3IgY29udGVudCBtdXN0IGJlIHNwZWNpZmllZCBpbiBvcHRpb25zLicpO1xuICB9XG5cbiAgaWYgKGNvbnRlbnQgPT09IHVuZGVmaW5lZCkge1xuICAgIGNvbnRlbnQgPSByZWFkRmlsZVN5bmMoaW5wdXRGaWxlUGF0aCBhcyBzdHJpbmcsICdVVEYtOCcpO1xuICB9XG5cbiAgLy8gRGV0ZXJtaW5lIHdoaWNoIHRyYW5zZm9ybXMgdG8gYXBwbHkuXG4gIGNvbnN0IGdldFRyYW5zZm9ybXMgPSBbXTtcblxuICBpZiAoaGFzVHNIZWxwZXJzLnRlc3QoY29udGVudCkpIHtcbiAgICBnZXRUcmFuc2Zvcm1zLnB1c2goZ2V0SW1wb3J0VHNsaWJUcmFuc2Zvcm1lcik7XG4gIH1cblxuICBpZiAoaW5wdXRGaWxlUGF0aCAmJiBpc0FuZ3VsYXJQYWNrYWdlLnRlc3QoaW5wdXRGaWxlUGF0aCkpIHtcbiAgICAvLyBPcmRlciBtYXR0ZXJzLCBnZXRQcmVmaXhGdW5jdGlvbnNUcmFuc2Zvcm1lciBuZWVkcyB0byBiZSBjYWxsZWQgYmVmb3JlXG4gICAgLy8gZ2V0Rm9sZEZpbGVUcmFuc2Zvcm1lci5cbiAgICBnZXRUcmFuc2Zvcm1zLnB1c2goXG4gICAgICAvLyBnZXRQcmVmaXhGdW5jdGlvbnNUcmFuc2Zvcm1lciBpcyByYXRoZXIgZGFuZ2Vyb3VzLlxuICAgICAgLy8gSXQgd2lsbCBtYXJrIGJvdGggYHJlcXVpcmUoKWAgY2FsbHMgYW5kIGBjb25zb2xlLmxvZyhzdHVmZilgIGFzIHB1cmUuXG4gICAgICAvLyBXZSBvbmx5IGFwcGx5IGl0IHRvIEBhbmd1bGFyLyogcGFja2FnZXMsIHNpbmNlIHdlIGtub3cgdGhleSBhcmUgc2FmZS5cbiAgICAgIGdldFByZWZpeEZ1bmN0aW9uc1RyYW5zZm9ybWVyLFxuICAgICAgZ2V0U2NydWJGaWxlVHJhbnNmb3JtZXIsXG4gICAgICBnZXRGb2xkRmlsZVRyYW5zZm9ybWVyLFxuICAgICk7XG4gIH0gZWxzZSBpZiAoaGFzRGVjb3JhdG9ycy50ZXN0KGNvbnRlbnQpIHx8IGhhc0N0b3JQYXJhbWV0ZXJzLnRlc3QoY29udGVudCkpIHtcbiAgICBnZXRUcmFuc2Zvcm1zLnB1c2goXG4gICAgICBnZXRTY3J1YkZpbGVUcmFuc2Zvcm1lcixcbiAgICAgIGdldEZvbGRGaWxlVHJhbnNmb3JtZXIsXG4gICAgKTtcbiAgfVxuXG4gIHJldHVybiB0cmFuc2Zvcm1KYXZhc2NyaXB0KHsgLi4ub3B0aW9ucywgZ2V0VHJhbnNmb3JtcywgY29udGVudCB9KTtcbn1cbiJdfQ== |
@@ -28,4 +28,9 @@ #!/usr/bin/env node | ||
}); | ||
fs_1.writeFileSync(path_1.join(currentDir, outputFile), boOutput.content); | ||
fs_1.writeFileSync(path_1.join(currentDir, `${outputFile}.map`), JSON.stringify(boOutput.sourceMap)); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9oYW5zbC9Tb3VyY2VzL2RldmtpdC8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX29wdGltaXplci9zcmMvYnVpbGQtb3B0aW1pemVyL2NsaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFRQSwyQkFBbUM7QUFDbkMsK0JBQTRCO0FBQzVCLHVEQUFtRDtBQUduRCxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2RCxNQUFNLElBQUksS0FBSyxDQUFDOzs7OztHQUtmLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7QUFFakMsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNsQyxNQUFNLFlBQVksR0FBRyxXQUFXLENBQUM7QUFFakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUVELHdFQUF3RTtBQUN4RSxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLFNBQVMsQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsTUFBTSxLQUFLLE1BQU0sTUFBTSxFQUFFLENBQUMsQ0FBQztBQUVsRyxNQUFNLFFBQVEsR0FBRyxnQ0FBYyxDQUFDO0lBQzlCLGFBQWEsRUFBRSxXQUFJLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQztJQUMxQyxjQUFjLEVBQUUsV0FBSSxDQUFDLFVBQVUsRUFBRSxVQUFVLENBQUM7SUFDNUMsYUFBYSxFQUFFLElBQUk7Q0FDcEIsQ0FBQyxDQUFDO0FBRUgsa0JBQWEsQ0FBQyxXQUFJLENBQUMsVUFBVSxFQUFFLFVBQVUsQ0FBQyxFQUFFLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztBQUM5RCxrQkFBYSxDQUFDLFdBQUksQ0FBQyxVQUFVLEVBQUUsR0FBRyxVQUFVLE1BQU0sQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyB3cml0ZUZpbGVTeW5jIH0gZnJvbSAnZnMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgYnVpbGRPcHRpbWl6ZXIgfSBmcm9tICcuL2J1aWxkLW9wdGltaXplcic7XG5cblxuaWYgKHByb2Nlc3MuYXJndi5sZW5ndGggPCAzIHx8IHByb2Nlc3MuYXJndi5sZW5ndGggPiA0KSB7XG4gIHRocm93IG5ldyBFcnJvcihgXG4gICAgYnVpbGQtb3B0aW1pemVyIHNob3VsZCBiZSBjYWxsZWQgd2l0aCBlaXRoZXIgb25lIG9yIHR3byBhcmd1bWVudHM6XG5cbiAgICAgIGJ1aWxkLW9wdGltaXplciBpbnB1dC5qc1xuICAgICAgYnVpbGQtb3B0aW1pemVyIGlucHV0LmpzIG91dHB1dC5qc1xuICBgKTtcbn1cblxuY29uc3QgY3VycmVudERpciA9IHByb2Nlc3MuY3dkKCk7XG5cbmNvbnN0IGlucHV0RmlsZSA9IHByb2Nlc3MuYXJndlsyXTtcbmNvbnN0IHRzT3JKc1JlZ0V4cCA9IC9cXC4oanx0KXMkLztcblxuaWYgKCFpbnB1dEZpbGUubWF0Y2godHNPckpzUmVnRXhwKSkge1xuICB0aHJvdyBuZXcgRXJyb3IoYElucHV0IGZpbGUgbXVzdCBiZSAuanMgb3IgLnRzLmApO1xufVxuXG4vLyBVc2UgcHJvdmlkZWQgb3V0cHV0IGZpbGUsIG9yIGFkZCB0aGUgLmJvIHN1ZmZpeCBiZWZvcmUgdGhlIGV4dGVuc2lvbi5cbmNvbnN0IG91dHB1dEZpbGUgPSBwcm9jZXNzLmFyZ3ZbM10gfHwgaW5wdXRGaWxlLnJlcGxhY2UodHNPckpzUmVnRXhwLCAoc3ViU3RyKSA9PiBgLmJvJHtzdWJTdHJ9YCk7XG5cbmNvbnN0IGJvT3V0cHV0ID0gYnVpbGRPcHRpbWl6ZXIoe1xuICBpbnB1dEZpbGVQYXRoOiBqb2luKGN1cnJlbnREaXIsIGlucHV0RmlsZSksXG4gIG91dHB1dEZpbGVQYXRoOiBqb2luKGN1cnJlbnREaXIsIG91dHB1dEZpbGUpLFxuICBlbWl0U291cmNlTWFwOiB0cnVlLFxufSk7XG5cbndyaXRlRmlsZVN5bmMoam9pbihjdXJyZW50RGlyLCBvdXRwdXRGaWxlKSwgYm9PdXRwdXQuY29udGVudCk7XG53cml0ZUZpbGVTeW5jKGpvaW4oY3VycmVudERpciwgYCR7b3V0cHV0RmlsZX0ubWFwYCksIEpTT04uc3RyaW5naWZ5KGJvT3V0cHV0LnNvdXJjZU1hcCkpO1xuIl19 | ||
if (boOutput.emitSkipped) { | ||
console.log('Nothing to emit.'); | ||
} | ||
else { | ||
fs_1.writeFileSync(path_1.join(currentDir, outputFile), boOutput.content); | ||
fs_1.writeFileSync(path_1.join(currentDir, `${outputFile}.map`), JSON.stringify(boOutput.sourceMap)); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9oYW5zbC9Tb3VyY2VzL2RldmtpdC8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX29wdGltaXplci9zcmMvYnVpbGQtb3B0aW1pemVyL2NsaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFRQSwyQkFBbUM7QUFDbkMsK0JBQTRCO0FBQzVCLHVEQUFtRDtBQUduRCxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2RCxNQUFNLElBQUksS0FBSyxDQUFDOzs7OztHQUtmLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7QUFFakMsTUFBTSxTQUFTLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNsQyxNQUFNLFlBQVksR0FBRyxXQUFXLENBQUM7QUFFakMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNuQyxNQUFNLElBQUksS0FBSyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUVELHdFQUF3RTtBQUN4RSxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLFNBQVMsQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsTUFBTSxLQUFLLE1BQU0sTUFBTSxFQUFFLENBQUMsQ0FBQztBQUVsRyxNQUFNLFFBQVEsR0FBRyxnQ0FBYyxDQUFDO0lBQzlCLGFBQWEsRUFBRSxXQUFJLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQztJQUMxQyxjQUFjLEVBQUUsV0FBSSxDQUFDLFVBQVUsRUFBRSxVQUFVLENBQUM7SUFDNUMsYUFBYSxFQUFFLElBQUk7Q0FDcEIsQ0FBQyxDQUFDO0FBRUgsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7SUFDekIsT0FBTyxDQUFDLEdBQUcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBQ2xDLENBQUM7QUFBQyxJQUFJLENBQUMsQ0FBQztJQUNOLGtCQUFhLENBQUMsV0FBSSxDQUFDLFVBQVUsRUFBRSxVQUFVLENBQUMsRUFBRSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUQsa0JBQWEsQ0FBQyxXQUFJLENBQUMsVUFBVSxFQUFFLEdBQUcsVUFBVSxNQUFNLENBQUMsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0FBQzNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIjIS91c3IvYmluL2VudiBub2RlXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgeyB3cml0ZUZpbGVTeW5jIH0gZnJvbSAnZnMnO1xuaW1wb3J0IHsgam9pbiB9IGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgYnVpbGRPcHRpbWl6ZXIgfSBmcm9tICcuL2J1aWxkLW9wdGltaXplcic7XG5cblxuaWYgKHByb2Nlc3MuYXJndi5sZW5ndGggPCAzIHx8IHByb2Nlc3MuYXJndi5sZW5ndGggPiA0KSB7XG4gIHRocm93IG5ldyBFcnJvcihgXG4gICAgYnVpbGQtb3B0aW1pemVyIHNob3VsZCBiZSBjYWxsZWQgd2l0aCBlaXRoZXIgb25lIG9yIHR3byBhcmd1bWVudHM6XG5cbiAgICAgIGJ1aWxkLW9wdGltaXplciBpbnB1dC5qc1xuICAgICAgYnVpbGQtb3B0aW1pemVyIGlucHV0LmpzIG91dHB1dC5qc1xuICBgKTtcbn1cblxuY29uc3QgY3VycmVudERpciA9IHByb2Nlc3MuY3dkKCk7XG5cbmNvbnN0IGlucHV0RmlsZSA9IHByb2Nlc3MuYXJndlsyXTtcbmNvbnN0IHRzT3JKc1JlZ0V4cCA9IC9cXC4oanx0KXMkLztcblxuaWYgKCFpbnB1dEZpbGUubWF0Y2godHNPckpzUmVnRXhwKSkge1xuICB0aHJvdyBuZXcgRXJyb3IoYElucHV0IGZpbGUgbXVzdCBiZSAuanMgb3IgLnRzLmApO1xufVxuXG4vLyBVc2UgcHJvdmlkZWQgb3V0cHV0IGZpbGUsIG9yIGFkZCB0aGUgLmJvIHN1ZmZpeCBiZWZvcmUgdGhlIGV4dGVuc2lvbi5cbmNvbnN0IG91dHB1dEZpbGUgPSBwcm9jZXNzLmFyZ3ZbM10gfHwgaW5wdXRGaWxlLnJlcGxhY2UodHNPckpzUmVnRXhwLCAoc3ViU3RyKSA9PiBgLmJvJHtzdWJTdHJ9YCk7XG5cbmNvbnN0IGJvT3V0cHV0ID0gYnVpbGRPcHRpbWl6ZXIoe1xuICBpbnB1dEZpbGVQYXRoOiBqb2luKGN1cnJlbnREaXIsIGlucHV0RmlsZSksXG4gIG91dHB1dEZpbGVQYXRoOiBqb2luKGN1cnJlbnREaXIsIG91dHB1dEZpbGUpLFxuICBlbWl0U291cmNlTWFwOiB0cnVlLFxufSk7XG5cbmlmIChib091dHB1dC5lbWl0U2tpcHBlZCkge1xuICBjb25zb2xlLmxvZygnTm90aGluZyB0byBlbWl0LicpO1xufSBlbHNlIHtcbiAgd3JpdGVGaWxlU3luYyhqb2luKGN1cnJlbnREaXIsIG91dHB1dEZpbGUpLCBib091dHB1dC5jb250ZW50KTtcbiAgd3JpdGVGaWxlU3luYyhqb2luKGN1cnJlbnREaXIsIGAke291dHB1dEZpbGV9Lm1hcGApLCBKU09OLnN0cmluZ2lmeShib091dHB1dC5zb3VyY2VNYXApKTtcbn1cbiJdfQ== |
@@ -1,2 +0,1 @@ | ||
/// <reference types="source-map" /> | ||
/** | ||
@@ -3,0 +2,0 @@ * @license |
@@ -16,3 +16,16 @@ "use strict"; | ||
const options = loaderUtils.getOptions(this) || {}; | ||
const boOutput = build_optimizer_1.buildOptimizer({ content, emitSourceMap: options.sourceMap }); | ||
const boOutput = build_optimizer_1.buildOptimizer({ | ||
content, | ||
inputFilePath: this.resourcePath, | ||
// Add a name to the build optimizer output. | ||
// Without a name the sourcemaps cannot be properly chained. | ||
outputFilePath: this.resourcePath + '.build-optimizer.js', | ||
emitSourceMap: options.sourceMap, | ||
}); | ||
if (boOutput.emitSkipped || boOutput.content === null) { | ||
// Webpack typings for previousSourceMap are wrong, they are JSON objects and not strings. | ||
// tslint:disable-next-line:no-any | ||
this.callback(null, content, previousSourceMap); | ||
return; | ||
} | ||
const intermediateSourceMap = boOutput.sourceMap; | ||
@@ -24,11 +37,9 @@ let newContent = boOutput.content; | ||
newContent = newContent.replace(/^\/\/# sourceMappingURL=[^\r\n]*/gm, ''); | ||
if (!previousSourceMap) { | ||
// If we're emitting sourcemaps but there is no previous one, then we're the first loader. | ||
newSourceMap = JSON.stringify(intermediateSourceMap); | ||
} | ||
else { | ||
// If there's a previous sourcemap, we're an intermediate loader and we have to chain them. | ||
if (previousSourceMap) { | ||
// If there's a previous sourcemap, we have to chain them. | ||
// See https://github.com/mozilla/source-map/issues/216#issuecomment-150839869 for a simple | ||
// source map chaining example. | ||
// Use http://sokra.github.io/source-map-visualization/ to validate sourcemaps make sense. | ||
// Fill in the intermediate sourcemap source as the previous sourcemap file. | ||
intermediateSourceMap.sources = [previousSourceMap.file]; | ||
intermediateSourceMap.file = previousSourceMap.file; | ||
// Chain the sourcemaps. | ||
@@ -38,8 +49,14 @@ const consumer = new source_map_1.SourceMapConsumer(intermediateSourceMap); | ||
generator.applySourceMap(new source_map_1.SourceMapConsumer(previousSourceMap)); | ||
newSourceMap = JSON.stringify(generator.toJSON()); | ||
newSourceMap = generator.toJSON(); | ||
} | ||
else { | ||
// Otherwise just return our generated sourcemap. | ||
newSourceMap = intermediateSourceMap; | ||
} | ||
} | ||
// Webpack typings for previousSourceMap are wrong, they are JSON objects and not strings. | ||
// tslint:disable-next-line:no-any | ||
this.callback(null, newContent, newSourceMap); | ||
} | ||
exports.default = buildOptimizerLoader; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2VicGFjay1sb2FkZXIuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL2hhbnNsL1NvdXJjZXMvZGV2a2l0LyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfb3B0aW1pemVyL3NyYy9idWlsZC1vcHRpbWl6ZXIvd2VicGFjay1sb2FkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCwyQ0FBaUY7QUFFakYsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBRTVDLHVEQUFtRDtBQU9uRCw4QkFDdUMsT0FBZSxFQUFFLGlCQUErQjtJQUNyRixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDakIsTUFBTSxPQUFPLEdBQWdDLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBRWhGLE1BQU0sUUFBUSxHQUFHLGdDQUFjLENBQUMsRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQy9FLE1BQU0scUJBQXFCLEdBQUcsUUFBUSxDQUFDLFNBQVMsQ0FBQztJQUNqRCxJQUFJLFVBQVUsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDO0lBRWxDLElBQUksWUFBWSxDQUFDO0lBRWpCLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxTQUFTLElBQUkscUJBQXFCLENBQUMsQ0FBQyxDQUFDO1FBQy9DLDJFQUEyRTtRQUMzRSxVQUFVLEdBQUcsVUFBVSxDQUFDLE9BQU8sQ0FBQyxvQ0FBb0MsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUUxRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztZQUN2QiwwRkFBMEY7WUFDMUYsWUFBWSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUN2RCxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTiwyRkFBMkY7WUFDM0YsNEVBQTRFO1lBQzVFLHFCQUFxQixDQUFDLE9BQU8sR0FBRyxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3pELHFCQUFxQixDQUFDLElBQUksR0FBRyxpQkFBaUIsQ0FBQyxJQUFJLENBQUM7WUFFcEQsd0JBQXdCO1lBQ3hCLE1BQU0sUUFBUSxHQUFHLElBQUksOEJBQWlCLENBQUMscUJBQXFCLENBQUMsQ0FBQztZQUM5RCxNQUFNLFNBQVMsR0FBRywrQkFBa0IsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDN0QsU0FBUyxDQUFDLGNBQWMsQ0FBQyxJQUFJLDhCQUFpQixDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztZQUNuRSxZQUFZLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUNwRCxDQUFDO0lBQ0gsQ0FBQztJQUVELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxZQUFZLENBQUMsQ0FBQztBQUNoRCxDQUFDO0FBakNELHVDQWlDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7IFJhd1NvdXJjZU1hcCwgU291cmNlTWFwQ29uc3VtZXIsIFNvdXJjZU1hcEdlbmVyYXRvciB9IGZyb20gJ3NvdXJjZS1tYXAnO1xuaW1wb3J0ICogYXMgd2VicGFjayBmcm9tICd3ZWJwYWNrJztcbmNvbnN0IGxvYWRlclV0aWxzID0gcmVxdWlyZSgnbG9hZGVyLXV0aWxzJyk7XG5cbmltcG9ydCB7IGJ1aWxkT3B0aW1pemVyIH0gZnJvbSAnLi9idWlsZC1vcHRpbWl6ZXInO1xuXG5cbmludGVyZmFjZSBCdWlsZE9wdGltaXplckxvYWRlck9wdGlvbnMge1xuICBzb3VyY2VNYXA6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGJ1aWxkT3B0aW1pemVyTG9hZGVyXG4gICh0aGlzOiB3ZWJwYWNrLmxvYWRlci5Mb2FkZXJDb250ZXh0LCBjb250ZW50OiBzdHJpbmcsIHByZXZpb3VzU291cmNlTWFwOiBSYXdTb3VyY2VNYXApIHtcbiAgdGhpcy5jYWNoZWFibGUoKTtcbiAgY29uc3Qgb3B0aW9uczogQnVpbGRPcHRpbWl6ZXJMb2FkZXJPcHRpb25zID0gbG9hZGVyVXRpbHMuZ2V0T3B0aW9ucyh0aGlzKSB8fCB7fTtcblxuICBjb25zdCBib091dHB1dCA9IGJ1aWxkT3B0aW1pemVyKHsgY29udGVudCwgZW1pdFNvdXJjZU1hcDogb3B0aW9ucy5zb3VyY2VNYXAgfSk7XG4gIGNvbnN0IGludGVybWVkaWF0ZVNvdXJjZU1hcCA9IGJvT3V0cHV0LnNvdXJjZU1hcDtcbiAgbGV0IG5ld0NvbnRlbnQgPSBib091dHB1dC5jb250ZW50O1xuXG4gIGxldCBuZXdTb3VyY2VNYXA7XG5cbiAgaWYgKG9wdGlvbnMuc291cmNlTWFwICYmIGludGVybWVkaWF0ZVNvdXJjZU1hcCkge1xuICAgIC8vIFdlYnBhY2sgZG9lc24ndCBuZWVkIHNvdXJjZU1hcHBpbmdVUkwgc2luY2Ugd2UgcGFzcyB0aGVtIG9uIGV4cGxpY2l0ZWx5LlxuICAgIG5ld0NvbnRlbnQgPSBuZXdDb250ZW50LnJlcGxhY2UoL15cXC9cXC8jIHNvdXJjZU1hcHBpbmdVUkw9W15cXHJcXG5dKi9nbSwgJycpO1xuXG4gICAgaWYgKCFwcmV2aW91c1NvdXJjZU1hcCkge1xuICAgICAgLy8gSWYgd2UncmUgZW1pdHRpbmcgc291cmNlbWFwcyBidXQgdGhlcmUgaXMgbm8gcHJldmlvdXMgb25lLCB0aGVuIHdlJ3JlIHRoZSBmaXJzdCBsb2FkZXIuXG4gICAgICBuZXdTb3VyY2VNYXAgPSBKU09OLnN0cmluZ2lmeShpbnRlcm1lZGlhdGVTb3VyY2VNYXApO1xuICAgIH0gZWxzZSB7XG4gICAgICAvLyBJZiB0aGVyZSdzIGEgcHJldmlvdXMgc291cmNlbWFwLCB3ZSdyZSBhbiBpbnRlcm1lZGlhdGUgbG9hZGVyIGFuZCB3ZSBoYXZlIHRvIGNoYWluIHRoZW0uXG4gICAgICAvLyBGaWxsIGluIHRoZSBpbnRlcm1lZGlhdGUgc291cmNlbWFwIHNvdXJjZSBhcyB0aGUgcHJldmlvdXMgc291cmNlbWFwIGZpbGUuXG4gICAgICBpbnRlcm1lZGlhdGVTb3VyY2VNYXAuc291cmNlcyA9IFtwcmV2aW91c1NvdXJjZU1hcC5maWxlXTtcbiAgICAgIGludGVybWVkaWF0ZVNvdXJjZU1hcC5maWxlID0gcHJldmlvdXNTb3VyY2VNYXAuZmlsZTtcblxuICAgICAgLy8gQ2hhaW4gdGhlIHNvdXJjZW1hcHMuXG4gICAgICBjb25zdCBjb25zdW1lciA9IG5ldyBTb3VyY2VNYXBDb25zdW1lcihpbnRlcm1lZGlhdGVTb3VyY2VNYXApO1xuICAgICAgY29uc3QgZ2VuZXJhdG9yID0gU291cmNlTWFwR2VuZXJhdG9yLmZyb21Tb3VyY2VNYXAoY29uc3VtZXIpO1xuICAgICAgZ2VuZXJhdG9yLmFwcGx5U291cmNlTWFwKG5ldyBTb3VyY2VNYXBDb25zdW1lcihwcmV2aW91c1NvdXJjZU1hcCkpO1xuICAgICAgbmV3U291cmNlTWFwID0gSlNPTi5zdHJpbmdpZnkoZ2VuZXJhdG9yLnRvSlNPTigpKTtcbiAgICB9XG4gIH1cblxuICB0aGlzLmNhbGxiYWNrKG51bGwsIG5ld0NvbnRlbnQsIG5ld1NvdXJjZU1hcCk7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2VicGFjay1sb2FkZXIuanMiLCJzb3VyY2VSb290IjoiL1VzZXJzL2hhbnNsL1NvdXJjZXMvZGV2a2l0LyIsInNvdXJjZXMiOlsicGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfb3B0aW1pemVyL3NyYy9idWlsZC1vcHRpbWl6ZXIvd2VicGFjay1sb2FkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCwyQ0FBaUY7QUFFakYsTUFBTSxXQUFXLEdBQUcsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0FBRTVDLHVEQUFtRDtBQU9uRCw4QkFDdUMsT0FBZSxFQUFFLGlCQUErQjtJQUNyRixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDakIsTUFBTSxPQUFPLEdBQWdDLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBRWhGLE1BQU0sUUFBUSxHQUFHLGdDQUFjLENBQUM7UUFDOUIsT0FBTztRQUNQLGFBQWEsRUFBRSxJQUFJLENBQUMsWUFBWTtRQUNoQyw0Q0FBNEM7UUFDNUMsNERBQTREO1FBQzVELGNBQWMsRUFBRSxJQUFJLENBQUMsWUFBWSxHQUFHLHFCQUFxQjtRQUN6RCxhQUFhLEVBQUUsT0FBTyxDQUFDLFNBQVM7S0FDakMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLFdBQVcsSUFBSSxRQUFRLENBQUMsT0FBTyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDdEQsMEZBQTBGO1FBQzFGLGtDQUFrQztRQUNsQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsaUJBQXdCLENBQUMsQ0FBQztRQUV2RCxNQUFNLENBQUM7SUFDVCxDQUFDO0lBRUQsTUFBTSxxQkFBcUIsR0FBRyxRQUFRLENBQUMsU0FBUyxDQUFDO0lBQ2pELElBQUksVUFBVSxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUM7SUFFbEMsSUFBSSxZQUFZLENBQUM7SUFFakIsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLFNBQVMsSUFBSSxxQkFBcUIsQ0FBQyxDQUFDLENBQUM7UUFDL0MsMkVBQTJFO1FBQzNFLFVBQVUsR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDLG9DQUFvQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRTFFLEVBQUUsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztZQUN0QiwwREFBMEQ7WUFDMUQsMkZBQTJGO1lBQzNGLCtCQUErQjtZQUMvQiwwRkFBMEY7WUFFMUYsNEVBQTRFO1lBQzVFLHFCQUFxQixDQUFDLE9BQU8sR0FBRyxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDO1lBRXpELHdCQUF3QjtZQUN4QixNQUFNLFFBQVEsR0FBRyxJQUFJLDhCQUFpQixDQUFDLHFCQUFxQixDQUFDLENBQUM7WUFDOUQsTUFBTSxTQUFTLEdBQUcsK0JBQWtCLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQzdELFNBQVMsQ0FBQyxjQUFjLENBQUMsSUFBSSw4QkFBaUIsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7WUFDbkUsWUFBWSxHQUFHLFNBQVMsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNwQyxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDTixpREFBaUQ7WUFDakQsWUFBWSxHQUFHLHFCQUFxQixDQUFDO1FBQ3ZDLENBQUM7SUFDSCxDQUFDO0lBRUQsMEZBQTBGO0lBQzFGLGtDQUFrQztJQUNsQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxVQUFVLEVBQUUsWUFBbUIsQ0FBQyxDQUFDO0FBQ3ZELENBQUM7QUF0REQsdUNBc0RDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHsgUmF3U291cmNlTWFwLCBTb3VyY2VNYXBDb25zdW1lciwgU291cmNlTWFwR2VuZXJhdG9yIH0gZnJvbSAnc291cmNlLW1hcCc7XG5pbXBvcnQgKiBhcyB3ZWJwYWNrIGZyb20gJ3dlYnBhY2snO1xuY29uc3QgbG9hZGVyVXRpbHMgPSByZXF1aXJlKCdsb2FkZXItdXRpbHMnKTtcblxuaW1wb3J0IHsgYnVpbGRPcHRpbWl6ZXIgfSBmcm9tICcuL2J1aWxkLW9wdGltaXplcic7XG5cblxuaW50ZXJmYWNlIEJ1aWxkT3B0aW1pemVyTG9hZGVyT3B0aW9ucyB7XG4gIHNvdXJjZU1hcDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gYnVpbGRPcHRpbWl6ZXJMb2FkZXJcbiAgKHRoaXM6IHdlYnBhY2subG9hZGVyLkxvYWRlckNvbnRleHQsIGNvbnRlbnQ6IHN0cmluZywgcHJldmlvdXNTb3VyY2VNYXA6IFJhd1NvdXJjZU1hcCkge1xuICB0aGlzLmNhY2hlYWJsZSgpO1xuICBjb25zdCBvcHRpb25zOiBCdWlsZE9wdGltaXplckxvYWRlck9wdGlvbnMgPSBsb2FkZXJVdGlscy5nZXRPcHRpb25zKHRoaXMpIHx8IHt9O1xuXG4gIGNvbnN0IGJvT3V0cHV0ID0gYnVpbGRPcHRpbWl6ZXIoe1xuICAgIGNvbnRlbnQsXG4gICAgaW5wdXRGaWxlUGF0aDogdGhpcy5yZXNvdXJjZVBhdGgsXG4gICAgLy8gQWRkIGEgbmFtZSB0byB0aGUgYnVpbGQgb3B0aW1pemVyIG91dHB1dC5cbiAgICAvLyBXaXRob3V0IGEgbmFtZSB0aGUgc291cmNlbWFwcyBjYW5ub3QgYmUgcHJvcGVybHkgY2hhaW5lZC5cbiAgICBvdXRwdXRGaWxlUGF0aDogdGhpcy5yZXNvdXJjZVBhdGggKyAnLmJ1aWxkLW9wdGltaXplci5qcycsXG4gICAgZW1pdFNvdXJjZU1hcDogb3B0aW9ucy5zb3VyY2VNYXAsXG4gIH0pO1xuXG4gIGlmIChib091dHB1dC5lbWl0U2tpcHBlZCB8fCBib091dHB1dC5jb250ZW50ID09PSBudWxsKSB7XG4gICAgLy8gV2VicGFjayB0eXBpbmdzIGZvciBwcmV2aW91c1NvdXJjZU1hcCBhcmUgd3JvbmcsIHRoZXkgYXJlIEpTT04gb2JqZWN0cyBhbmQgbm90IHN0cmluZ3MuXG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWFueVxuICAgIHRoaXMuY2FsbGJhY2sobnVsbCwgY29udGVudCwgcHJldmlvdXNTb3VyY2VNYXAgYXMgYW55KTtcblxuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IGludGVybWVkaWF0ZVNvdXJjZU1hcCA9IGJvT3V0cHV0LnNvdXJjZU1hcDtcbiAgbGV0IG5ld0NvbnRlbnQgPSBib091dHB1dC5jb250ZW50O1xuXG4gIGxldCBuZXdTb3VyY2VNYXA7XG5cbiAgaWYgKG9wdGlvbnMuc291cmNlTWFwICYmIGludGVybWVkaWF0ZVNvdXJjZU1hcCkge1xuICAgIC8vIFdlYnBhY2sgZG9lc24ndCBuZWVkIHNvdXJjZU1hcHBpbmdVUkwgc2luY2Ugd2UgcGFzcyB0aGVtIG9uIGV4cGxpY2l0ZWx5LlxuICAgIG5ld0NvbnRlbnQgPSBuZXdDb250ZW50LnJlcGxhY2UoL15cXC9cXC8jIHNvdXJjZU1hcHBpbmdVUkw9W15cXHJcXG5dKi9nbSwgJycpO1xuXG4gICAgaWYgKHByZXZpb3VzU291cmNlTWFwKSB7XG4gICAgICAvLyBJZiB0aGVyZSdzIGEgcHJldmlvdXMgc291cmNlbWFwLCB3ZSBoYXZlIHRvIGNoYWluIHRoZW0uXG4gICAgICAvLyBTZWUgaHR0cHM6Ly9naXRodWIuY29tL21vemlsbGEvc291cmNlLW1hcC9pc3N1ZXMvMjE2I2lzc3VlY29tbWVudC0xNTA4Mzk4NjkgZm9yIGEgc2ltcGxlXG4gICAgICAvLyBzb3VyY2UgbWFwIGNoYWluaW5nIGV4YW1wbGUuXG4gICAgICAvLyBVc2UgaHR0cDovL3Nva3JhLmdpdGh1Yi5pby9zb3VyY2UtbWFwLXZpc3VhbGl6YXRpb24vIHRvIHZhbGlkYXRlIHNvdXJjZW1hcHMgbWFrZSBzZW5zZS5cblxuICAgICAgLy8gRmlsbCBpbiB0aGUgaW50ZXJtZWRpYXRlIHNvdXJjZW1hcCBzb3VyY2UgYXMgdGhlIHByZXZpb3VzIHNvdXJjZW1hcCBmaWxlLlxuICAgICAgaW50ZXJtZWRpYXRlU291cmNlTWFwLnNvdXJjZXMgPSBbcHJldmlvdXNTb3VyY2VNYXAuZmlsZV07XG5cbiAgICAgIC8vIENoYWluIHRoZSBzb3VyY2VtYXBzLlxuICAgICAgY29uc3QgY29uc3VtZXIgPSBuZXcgU291cmNlTWFwQ29uc3VtZXIoaW50ZXJtZWRpYXRlU291cmNlTWFwKTtcbiAgICAgIGNvbnN0IGdlbmVyYXRvciA9IFNvdXJjZU1hcEdlbmVyYXRvci5mcm9tU291cmNlTWFwKGNvbnN1bWVyKTtcbiAgICAgIGdlbmVyYXRvci5hcHBseVNvdXJjZU1hcChuZXcgU291cmNlTWFwQ29uc3VtZXIocHJldmlvdXNTb3VyY2VNYXApKTtcbiAgICAgIG5ld1NvdXJjZU1hcCA9IGdlbmVyYXRvci50b0pTT04oKTtcbiAgICB9IGVsc2Uge1xuICAgICAgLy8gT3RoZXJ3aXNlIGp1c3QgcmV0dXJuIG91ciBnZW5lcmF0ZWQgc291cmNlbWFwLlxuICAgICAgbmV3U291cmNlTWFwID0gaW50ZXJtZWRpYXRlU291cmNlTWFwO1xuICAgIH1cbiAgfVxuXG4gIC8vIFdlYnBhY2sgdHlwaW5ncyBmb3IgcHJldmlvdXNTb3VyY2VNYXAgYXJlIHdyb25nLCB0aGV5IGFyZSBKU09OIG9iamVjdHMgYW5kIG5vdCBzdHJpbmdzLlxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6bm8tYW55XG4gIHRoaXMuY2FsbGJhY2sobnVsbCwgbmV3Q29udGVudCwgbmV3U291cmNlTWFwIGFzIGFueSk7XG59XG4iXX0= |
@@ -0,1 +1,2 @@ | ||
import { RawSourceMap } from 'source-map'; | ||
import * as ts from 'typescript'; | ||
@@ -10,5 +11,7 @@ export interface TransformJavascriptOptions { | ||
} | ||
export declare const transformJavascript: (options: TransformJavascriptOptions) => { | ||
content: string; | ||
sourceMap: any; | ||
}; | ||
export interface TransformJavascriptOutput { | ||
content: string | null; | ||
sourceMap: RawSourceMap | null; | ||
emitSkipped: boolean; | ||
} | ||
export declare function transformJavascript(options: TransformJavascriptOptions): TransformJavascriptOutput; |
@@ -13,7 +13,12 @@ "use strict"; | ||
const ts = require("typescript"); | ||
const MagicString = require('magic-string'); | ||
exports.transformJavascript = (options) => { | ||
options.emitSourceMap = !!options.emitSourceMap; | ||
options.strict = !!options.strict; | ||
const { content, getTransforms, emitSourceMap, inputFilePath, outputFilePath, strict } = options; | ||
function transformJavascript(options) { | ||
const { content, getTransforms, emitSourceMap, inputFilePath, outputFilePath, strict, } = options; | ||
// Bail if there's no transform to do. | ||
if (getTransforms.length === 0) { | ||
return { | ||
content: null, | ||
sourceMap: null, | ||
emitSkipped: true, | ||
}; | ||
} | ||
// Print error diagnostics. | ||
@@ -86,8 +91,5 @@ const checkDiagnostics = (diagnostics) => { | ||
return { | ||
content, | ||
sourceMap: !emitSourceMap ? null : new MagicString(content).generateMap({ | ||
source: inputFilePath, | ||
file: outputFilePath ? `${outputFilePath}.map` : null, | ||
includeContent: true, | ||
}), | ||
content: null, | ||
sourceMap: null, | ||
emitSkipped: true, | ||
}; | ||
@@ -103,3 +105,3 @@ } | ||
if (outputFilePath) { | ||
sourceMap.file = path_1.basename(outputFilePath); | ||
sourceMap.file = outputFilePath; | ||
transformedContent = transformedContent.replace(urlRegExp, `//# sourceMappingURL=${sourceMap.file}.map\n`); | ||
@@ -123,4 +125,6 @@ if (inputFilePath) { | ||
sourceMap, | ||
emitSkipped: false, | ||
}; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transform-javascript.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/build_optimizer/src/helpers/transform-javascript.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { readFileSync } from 'fs';\nimport { basename, dirname, join } from 'path';\nimport { RawSourceMap } from 'source-map';\nimport * as ts from 'typescript';\nconst MagicString = require('magic-string');\n\n\nexport interface TransformJavascriptOptions {\n  content: string;\n  inputFilePath?: string;\n  outputFilePath?: string;\n  emitSourceMap?: boolean;\n  strict?: boolean;\n  getTransforms: Array<(program: ts.Program) => ts.TransformerFactory<ts.SourceFile>>;\n}\n\nexport const transformJavascript = (options: TransformJavascriptOptions) => {\n  options.emitSourceMap = !!options.emitSourceMap;\n  options.strict = !!options.strict;\n  const { content, getTransforms, emitSourceMap, inputFilePath, outputFilePath, strict } = options;\n\n  // Print error diagnostics.\n  const checkDiagnostics = (diagnostics: ts.Diagnostic[]) => {\n    if (diagnostics && diagnostics.length > 0) {\n      let errors = '';\n      errors = errors + '\\n' + ts.formatDiagnostics(diagnostics, {\n        getCurrentDirectory: () => ts.sys.getCurrentDirectory(),\n        getNewLine: () => ts.sys.newLine,\n        getCanonicalFileName: (f: string) => f,\n      });\n\n      return errors;\n    }\n  };\n\n  // Make a in-memory host and populate it with a single file\n  const fileMap = new Map<string, string>();\n  const sourcesMap = new Map<string, ts.SourceFile>();\n  const outputs = new Map<string, string>();\n\n  // We're not actually writing anything to disk, but still need to define an outDir\n  // because otherwise TS will fail to emit JS since it would overwrite the original.\n  const tempOutDir = '$$_temp/';\n  const tempFilename = 'bo-default-file.js';\n  fileMap.set(tempFilename, content);\n\n  // We need to load the default lib for noEmitOnError to work properly.\n  const defaultLibFileName = 'lib.d.ts';\n  const defaultLibContent = readFileSync(join(dirname(require.resolve('typescript')),\n    defaultLibFileName), 'UTF-8');\n  fileMap.set(defaultLibFileName, defaultLibContent);\n\n  fileMap.forEach((v, k) => sourcesMap.set(\n    k, ts.createSourceFile(k, v, ts.ScriptTarget.ES2015)));\n\n  const host: ts.CompilerHost = {\n    getSourceFile: (fileName) => sourcesMap.get(fileName)!,\n    getDefaultLibFileName: () => defaultLibFileName,\n    getCurrentDirectory: () => '',\n    getDirectories: () => [],\n    getCanonicalFileName: (fileName) => fileName,\n    useCaseSensitiveFileNames: () => true,\n    getNewLine: () => '\\n',\n    fileExists: (fileName) => fileMap.has(fileName),\n    readFile: (fileName) => fileMap.has(fileName) ? fileMap.get(fileName)! : '',\n    writeFile: (fileName, text) => outputs.set(fileName, text),\n  };\n\n  const tsOptions: ts.CompilerOptions = {\n    noEmitOnError: true,\n    allowJs: true,\n    // Using just line feed makes test comparisons easier, and doesn't matter for generated files.\n    newLine: ts.NewLineKind.LineFeed,\n    // We target next so that there is no downleveling.\n    target: ts.ScriptTarget.ESNext,\n    skipLibCheck: true,\n    outDir: '$$_temp/',\n    sourceMap: emitSourceMap,\n    inlineSources: emitSourceMap,\n    inlineSourceMap: false,\n  };\n\n  const program = ts.createProgram(Array.from(fileMap.keys()), tsOptions, host);\n\n  // We need the checker inside transforms.\n  const transforms = getTransforms.map((getTf) => getTf(program));\n\n  const { emitSkipped, diagnostics } = program.emit(\n    undefined, host.writeFile, undefined, undefined,\n    { before: transforms, after: [] });\n\n  let transformedContent = outputs.get(`${tempOutDir}${tempFilename}`);\n\n  if (emitSkipped || !transformedContent) {\n    // Throw only if we're in strict mode, otherwise return original content.\n    if (strict) {\n      throw new Error(`\n        TS failed with the following error messages:\n\n        ${checkDiagnostics(diagnostics)}\n      `);\n    } else {\n      return {\n        content,\n        sourceMap: !emitSourceMap ? null : new MagicString(content).generateMap({\n          source: inputFilePath,\n          file: outputFilePath ? `${outputFilePath}.map` : null,\n          includeContent: true,\n        }),\n      };\n    }\n  }\n\n  let sourceMap: RawSourceMap | null = null;\n\n  if (emitSourceMap) {\n    const tsSourceMap = outputs.get(`${tempOutDir}${tempFilename}.map`);\n    const urlRegExp = /^\\/\\/# sourceMappingURL=[^\\r\\n]*/gm;\n    sourceMap = JSON.parse(tsSourceMap as string) as RawSourceMap;\n    // Fix sourcemaps file references.\n    if (outputFilePath) {\n      sourceMap.file = basename(outputFilePath);\n      transformedContent = transformedContent.replace(urlRegExp,\n        `//# sourceMappingURL=${sourceMap.file}.map\\n`);\n      if (inputFilePath) {\n        sourceMap.sources = [inputFilePath];\n      } else {\n        sourceMap.sources = [''];\n      }\n    } else {\n      // TODO: figure out if we should inline sources here.\n      transformedContent = transformedContent.replace(urlRegExp, '');\n      sourceMap.file = '';\n      sourceMap.sources = [''];\n    }\n  }\n\n  return {\n    content: transformedContent,\n    sourceMap,\n  };\n};\n"]} | ||
} | ||
exports.transformJavascript = transformJavascript; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transform-javascript.js","sourceRoot":"/Users/hansl/Sources/devkit/","sources":["packages/angular_devkit/build_optimizer/src/helpers/transform-javascript.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { readFileSync } from 'fs';\nimport { dirname, join } from 'path';\nimport { RawSourceMap } from 'source-map';\nimport * as ts from 'typescript';\n\n\nexport interface TransformJavascriptOptions {\n  content: string;\n  inputFilePath?: string;\n  outputFilePath?: string;\n  emitSourceMap?: boolean;\n  strict?: boolean;\n  getTransforms: Array<(program: ts.Program) => ts.TransformerFactory<ts.SourceFile>>;\n}\n\nexport interface TransformJavascriptOutput {\n  content: string | null;\n  sourceMap: RawSourceMap | null;\n  emitSkipped: boolean;\n}\n\nexport function transformJavascript(\n  options: TransformJavascriptOptions,\n): TransformJavascriptOutput {\n\n  const {\n    content,\n    getTransforms,\n    emitSourceMap,\n    inputFilePath,\n    outputFilePath,\n    strict,\n  } = options;\n\n  // Bail if there's no transform to do.\n  if (getTransforms.length === 0) {\n    return {\n      content: null,\n      sourceMap: null,\n      emitSkipped: true,\n    };\n  }\n\n  // Print error diagnostics.\n  const checkDiagnostics = (diagnostics: ts.Diagnostic[]) => {\n    if (diagnostics && diagnostics.length > 0) {\n      let errors = '';\n      errors = errors + '\\n' + ts.formatDiagnostics(diagnostics, {\n        getCurrentDirectory: () => ts.sys.getCurrentDirectory(),\n        getNewLine: () => ts.sys.newLine,\n        getCanonicalFileName: (f: string) => f,\n      });\n\n      return errors;\n    }\n  };\n\n  // Make a in-memory host and populate it with a single file\n  const fileMap = new Map<string, string>();\n  const sourcesMap = new Map<string, ts.SourceFile>();\n  const outputs = new Map<string, string>();\n\n  // We're not actually writing anything to disk, but still need to define an outDir\n  // because otherwise TS will fail to emit JS since it would overwrite the original.\n  const tempOutDir = '$$_temp/';\n  const tempFilename = 'bo-default-file.js';\n  fileMap.set(tempFilename, content);\n\n  // We need to load the default lib for noEmitOnError to work properly.\n  const defaultLibFileName = 'lib.d.ts';\n  const defaultLibContent = readFileSync(join(dirname(require.resolve('typescript')),\n    defaultLibFileName), 'UTF-8');\n  fileMap.set(defaultLibFileName, defaultLibContent);\n\n  fileMap.forEach((v, k) => sourcesMap.set(\n    k, ts.createSourceFile(k, v, ts.ScriptTarget.ES2015)));\n\n  const host: ts.CompilerHost = {\n    getSourceFile: (fileName) => sourcesMap.get(fileName)!,\n    getDefaultLibFileName: () => defaultLibFileName,\n    getCurrentDirectory: () => '',\n    getDirectories: () => [],\n    getCanonicalFileName: (fileName) => fileName,\n    useCaseSensitiveFileNames: () => true,\n    getNewLine: () => '\\n',\n    fileExists: (fileName) => fileMap.has(fileName),\n    readFile: (fileName) => fileMap.has(fileName) ? fileMap.get(fileName)! : '',\n    writeFile: (fileName, text) => outputs.set(fileName, text),\n  };\n\n  const tsOptions: ts.CompilerOptions = {\n    noEmitOnError: true,\n    allowJs: true,\n    // Using just line feed makes test comparisons easier, and doesn't matter for generated files.\n    newLine: ts.NewLineKind.LineFeed,\n    // We target next so that there is no downleveling.\n    target: ts.ScriptTarget.ESNext,\n    skipLibCheck: true,\n    outDir: '$$_temp/',\n    sourceMap: emitSourceMap,\n    inlineSources: emitSourceMap,\n    inlineSourceMap: false,\n  };\n\n  const program = ts.createProgram(Array.from(fileMap.keys()), tsOptions, host);\n\n  // We need the checker inside transforms.\n  const transforms = getTransforms.map((getTf) => getTf(program));\n\n  const { emitSkipped, diagnostics } = program.emit(\n    undefined, host.writeFile, undefined, undefined,\n    { before: transforms, after: [] });\n\n  let transformedContent = outputs.get(`${tempOutDir}${tempFilename}`);\n\n  if (emitSkipped || !transformedContent) {\n    // Throw only if we're in strict mode, otherwise return original content.\n    if (strict) {\n      throw new Error(`\n        TS failed with the following error messages:\n\n        ${checkDiagnostics(diagnostics)}\n      `);\n    } else {\n      return {\n        content: null,\n        sourceMap: null,\n        emitSkipped: true,\n      };\n    }\n  }\n\n  let sourceMap: RawSourceMap | null = null;\n\n  if (emitSourceMap) {\n    const tsSourceMap = outputs.get(`${tempOutDir}${tempFilename}.map`);\n    const urlRegExp = /^\\/\\/# sourceMappingURL=[^\\r\\n]*/gm;\n    sourceMap = JSON.parse(tsSourceMap as string) as RawSourceMap;\n    // Fix sourcemaps file references.\n    if (outputFilePath) {\n      sourceMap.file = outputFilePath;\n      transformedContent = transformedContent.replace(urlRegExp,\n        `//# sourceMappingURL=${sourceMap.file}.map\\n`);\n      if (inputFilePath) {\n        sourceMap.sources = [inputFilePath];\n      } else {\n        sourceMap.sources = [''];\n      }\n    } else {\n      // TODO: figure out if we should inline sources here.\n      transformedContent = transformedContent.replace(urlRegExp, '');\n      sourceMap.file = '';\n      sourceMap.sources = [''];\n    }\n  }\n\n  return {\n    content: transformedContent,\n    sourceMap,\n    emitSkipped: false,\n  };\n}\n"]} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
154969
3
1098
- Removedmagic-string@^0.19.1
- Removedmagic-string@0.19.1(transitive)
- Removedvlq@0.2.3(transitive)