@angular-devkit/build-angular 0.12.0-beta.0 → 0.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/package.json +11 -11
  2. package/src/angular-cli-files/models/build-options.d.ts +5 -5
  3. package/src/angular-cli-files/models/build-options.js +1 -1
  4. package/src/angular-cli-files/models/webpack-configs/browser.js +8 -4
  5. package/src/angular-cli-files/models/webpack-configs/common.d.ts +1 -1
  6. package/src/angular-cli-files/models/webpack-configs/common.js +48 -38
  7. package/src/angular-cli-files/models/webpack-configs/server.js +3 -3
  8. package/src/angular-cli-files/models/webpack-configs/styles.js +4 -4
  9. package/src/angular-cli-files/models/webpack-configs/test.js +3 -3
  10. package/src/angular-cli-files/models/webpack-configs/typescript.js +3 -3
  11. package/src/angular-cli-files/plugins/cleancss-webpack-plugin.js +4 -15
  12. package/src/angular-cli-files/plugins/scripts-webpack-plugin.js +7 -31
  13. package/src/browser/index.d.ts +1 -6
  14. package/src/browser/index.js +3 -11
  15. package/src/browser/schema.d.ts +27 -2
  16. package/src/browser/schema.json +23 -4
  17. package/src/dev-server/index.d.ts +2 -2
  18. package/src/dev-server/index.js +7 -14
  19. package/src/dev-server/schema.json +22 -2
  20. package/src/extract-i18n/index.d.ts +1 -1
  21. package/src/extract-i18n/index.js +5 -2
  22. package/src/karma/index.d.ts +1 -6
  23. package/src/karma/index.js +4 -12
  24. package/src/karma/schema.d.ts +10 -0
  25. package/src/protractor/index.js +2 -2
  26. package/src/server/index.d.ts +2 -2
  27. package/src/server/index.js +3 -9
  28. package/src/server/schema.d.ts +17 -3
  29. package/src/server/schema.json +22 -3
  30. package/src/tslint/index.js +12 -8
  31. package/src/utils/index.d.ts +2 -0
  32. package/src/utils/index.js +3 -1
  33. package/src/utils/normalize-asset-patterns.d.ts +1 -2
  34. package/src/utils/normalize-asset-patterns.js +28 -32
  35. package/src/utils/normalize-builder-schema.d.ts +13 -0
  36. package/src/utils/normalize-builder-schema.js +40 -0
  37. package/src/utils/normalize-file-replacements.d.ts +1 -2
  38. package/src/utils/normalize-file-replacements.js +12 -12
  39. package/src/utils/normalize-optimization.d.ts +13 -0
  40. package/src/utils/normalize-optimization.js +19 -0
  41. package/src/utils/normalize-source-maps.d.ts +4 -5
  42. package/src/utils/normalize-source-maps.js +9 -10
@@ -22,21 +22,15 @@ class ServerBuilder {
22
22
  this.context = context;
23
23
  }
24
24
  run(builderConfig) {
25
- let options = builderConfig.options;
26
25
  const root = this.context.workspace.root;
27
26
  const projectRoot = core_1.resolve(root, builderConfig.root);
28
27
  const host = new core_1.virtualFs.AliasHost(this.context.host);
29
28
  const webpackBuilder = new build_webpack_1.WebpackBuilder(Object.assign({}, this.context, { host }));
29
+ const options = utils_1.normalizeBuilderSchema(host, root, builderConfig);
30
30
  // TODO: verify using of(null) to kickstart things is a pattern.
31
31
  return rxjs_1.of(null).pipe(operators_1.concatMap(() => options.deleteOutputPath
32
32
  ? this._deleteOutputDir(root, core_1.normalize(options.outputPath), this.context.host)
33
- : rxjs_1.of(null)), operators_1.concatMap(() => utils_1.normalizeFileReplacements(options.fileReplacements, host, root)), operators_1.tap(fileReplacements => options.fileReplacements = fileReplacements), operators_1.tap(() => {
34
- const normalizedOptions = utils_1.normalizeSourceMaps(options.sourceMap);
35
- // todo: remove when removing the deprecations
36
- normalizedOptions.vendorSourceMap
37
- = normalizedOptions.vendorSourceMap || !!options.vendorSourceMap;
38
- options = Object.assign({}, options, normalizedOptions);
39
- }), operators_1.concatMap(() => {
33
+ : rxjs_1.of(null)), operators_1.concatMap(() => {
40
34
  const webpackConfig = this.buildWebpackConfig(root, projectRoot, host, options);
41
35
  return webpackBuilder.runWebpack(webpackConfig, browser_1.getBrowserLoggingCb(options.verbose));
42
36
  }));
@@ -90,4 +84,4 @@ class ServerBuilder {
90
84
  }
91
85
  exports.ServerBuilder = ServerBuilder;
92
86
  exports.default = ServerBuilder;
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/server/index.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 */\n\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { WebpackBuilder } from '@angular-devkit/build-webpack';\nimport { Path, getSystemPath, normalize, resolve, virtualFs } from '@angular-devkit/core';\nimport { Stats } from 'fs';\nimport { Observable, concat, of } from 'rxjs';\nimport { concatMap, last, tap } from 'rxjs/operators';\nimport * as ts from 'typescript'; // tslint:disable-line:no-implicit-dependencies\nimport { WebpackConfigOptions } from '../angular-cli-files/models/build-options';\nimport {\n  getAotConfig,\n  getCommonConfig,\n  getNonAotConfig,\n  getServerConfig,\n  getStatsConfig,\n  getStylesConfig,\n} from '../angular-cli-files/models/webpack-configs';\nimport { readTsconfig } from '../angular-cli-files/utilities/read-tsconfig';\nimport { requireProjectModule } from '../angular-cli-files/utilities/require-project-module';\nimport { getBrowserLoggingCb } from '../browser';\nimport { defaultProgress, normalizeFileReplacements, normalizeSourceMaps } from '../utils';\nimport { BuildWebpackServerSchema } from './schema';\nconst webpackMerge = require('webpack-merge');\n\n\nexport class ServerBuilder implements Builder<BuildWebpackServerSchema> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<BuildWebpackServerSchema>): Observable<BuildEvent> {\n    let options = builderConfig.options;\n    const root = this.context.workspace.root;\n    const projectRoot = resolve(root, builderConfig.root);\n    const host = new virtualFs.AliasHost(this.context.host as virtualFs.Host<Stats>);\n    const webpackBuilder = new WebpackBuilder({ ...this.context, host });\n\n    // TODO: verify using of(null) to kickstart things is a pattern.\n    return of(null).pipe(\n      concatMap(() => options.deleteOutputPath\n        ? this._deleteOutputDir(root, normalize(options.outputPath), this.context.host)\n        : of(null)),\n      concatMap(() => normalizeFileReplacements(options.fileReplacements, host, root)),\n      tap(fileReplacements => options.fileReplacements = fileReplacements),\n      tap(() => {\n        const normalizedOptions = normalizeSourceMaps(options.sourceMap);\n        // todo: remove when removing the deprecations\n        normalizedOptions.vendorSourceMap\n          = normalizedOptions.vendorSourceMap || !!options.vendorSourceMap;\n\n        options = {\n          ...options,\n          ...normalizedOptions,\n        };\n      }),\n      concatMap(() => {\n        const webpackConfig = this.buildWebpackConfig(root, projectRoot, host, options);\n\n        return webpackBuilder.runWebpack(webpackConfig, getBrowserLoggingCb(options.verbose));\n      }),\n    );\n  }\n\n  buildWebpackConfig(root: Path, projectRoot: Path,\n                     host: virtualFs.Host<Stats>,\n                     options: BuildWebpackServerSchema) {\n    let wco: WebpackConfigOptions;\n\n    // TODO: make target defaults into configurations instead\n    // options = this.addTargetDefaults(options);\n\n    const tsConfigPath = getSystemPath(normalize(resolve(root, normalize(options.tsConfig))));\n    const tsConfig = readTsconfig(tsConfigPath);\n\n    const projectTs = requireProjectModule(getSystemPath(projectRoot), 'typescript') as typeof ts;\n\n    const supportES2015 = tsConfig.options.target !== projectTs.ScriptTarget.ES3\n      && tsConfig.options.target !== projectTs.ScriptTarget.ES5;\n\n    const buildOptions: typeof wco['buildOptions'] = {\n      ...options as {} as typeof wco['buildOptions'],\n    };\n\n    wco = {\n      root: getSystemPath(root),\n      logger: this.context.logger,\n      projectRoot: getSystemPath(projectRoot),\n      // TODO: use only this.options, it contains all flags and configs items already.\n      buildOptions: {\n        ...buildOptions,\n        buildOptimizer: false,\n        aot: true,\n        platform: 'server',\n        scripts: [],\n        styles: [],\n      },\n      tsConfig,\n      tsConfigPath,\n      supportES2015,\n    };\n\n    wco.buildOptions.progress = defaultProgress(wco.buildOptions.progress);\n\n    const webpackConfigs: {}[] = [\n      getCommonConfig(wco),\n      getServerConfig(wco),\n      getStylesConfig(wco),\n      getStatsConfig(wco),\n    ];\n\n    if (wco.buildOptions.main || wco.buildOptions.polyfills) {\n      const typescriptConfigPartial = wco.buildOptions.aot\n        ? getAotConfig(wco, host)\n        : getNonAotConfig(wco, host);\n      webpackConfigs.push(typescriptConfigPartial);\n    }\n\n    return webpackMerge(webpackConfigs);\n  }\n\n  private _deleteOutputDir(root: Path, outputPath: Path, host: virtualFs.Host) {\n    const resolvedOutputPath = resolve(root, outputPath);\n    if (resolvedOutputPath === root) {\n      throw new Error('Output path MUST not be project root directory!');\n    }\n\n    return host.exists(resolvedOutputPath).pipe(\n      concatMap(exists => exists\n        // TODO: remove this concat once host ops emit an event.\n        ? concat(host.delete(resolvedOutputPath), of(null)).pipe(last())\n        // ? of(null)\n        : of(null)),\n    );\n  }\n}\n\nexport default ServerBuilder;\n"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/server/index.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 */\n\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { WebpackBuilder } from '@angular-devkit/build-webpack';\nimport { Path, getSystemPath, normalize, resolve, virtualFs } from '@angular-devkit/core';\nimport { Stats } from 'fs';\nimport { Observable, concat, of } from 'rxjs';\nimport { concatMap, last } from 'rxjs/operators';\nimport * as ts from 'typescript'; // tslint:disable-line:no-implicit-dependencies\nimport { WebpackConfigOptions } from '../angular-cli-files/models/build-options';\nimport {\n  getAotConfig,\n  getCommonConfig,\n  getNonAotConfig,\n  getServerConfig,\n  getStatsConfig,\n  getStylesConfig,\n} from '../angular-cli-files/models/webpack-configs';\nimport { readTsconfig } from '../angular-cli-files/utilities/read-tsconfig';\nimport { requireProjectModule } from '../angular-cli-files/utilities/require-project-module';\nimport { getBrowserLoggingCb } from '../browser';\nimport { defaultProgress, normalizeBuilderSchema } from '../utils';\nimport { BuildWebpackServerSchema, NormalizedServerBuilderServerSchema } from './schema';\nconst webpackMerge = require('webpack-merge');\n\n\nexport class ServerBuilder implements Builder<BuildWebpackServerSchema> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<BuildWebpackServerSchema>): Observable<BuildEvent> {\n    const root = this.context.workspace.root;\n    const projectRoot = resolve(root, builderConfig.root);\n    const host = new virtualFs.AliasHost(this.context.host as virtualFs.Host<Stats>);\n    const webpackBuilder = new WebpackBuilder({ ...this.context, host });\n\n    const options = normalizeBuilderSchema(\n      host,\n      root,\n      builderConfig,\n    );\n\n    // TODO: verify using of(null) to kickstart things is a pattern.\n    return of(null).pipe(\n      concatMap(() => options.deleteOutputPath\n        ? this._deleteOutputDir(root, normalize(options.outputPath), this.context.host)\n        : of(null)),\n      concatMap(() => {\n        const webpackConfig = this.buildWebpackConfig(root, projectRoot, host, options);\n\n        return webpackBuilder.runWebpack(webpackConfig, getBrowserLoggingCb(options.verbose));\n      }),\n    );\n  }\n\n  buildWebpackConfig(root: Path, projectRoot: Path,\n                     host: virtualFs.Host<Stats>,\n                     options: NormalizedServerBuilderServerSchema) {\n    let wco: WebpackConfigOptions;\n\n    // TODO: make target defaults into configurations instead\n    // options = this.addTargetDefaults(options);\n\n    const tsConfigPath = getSystemPath(normalize(resolve(root, normalize(options.tsConfig))));\n    const tsConfig = readTsconfig(tsConfigPath);\n\n    const projectTs = requireProjectModule(getSystemPath(projectRoot), 'typescript') as typeof ts;\n\n    const supportES2015 = tsConfig.options.target !== projectTs.ScriptTarget.ES3\n      && tsConfig.options.target !== projectTs.ScriptTarget.ES5;\n\n    const buildOptions: typeof wco['buildOptions'] = {\n      ...options as {} as typeof wco['buildOptions'],\n    };\n\n    wco = {\n      root: getSystemPath(root),\n      logger: this.context.logger,\n      projectRoot: getSystemPath(projectRoot),\n      // TODO: use only this.options, it contains all flags and configs items already.\n      buildOptions: {\n        ...buildOptions,\n        buildOptimizer: false,\n        aot: true,\n        platform: 'server',\n        scripts: [],\n        styles: [],\n      },\n      tsConfig,\n      tsConfigPath,\n      supportES2015,\n    };\n\n    wco.buildOptions.progress = defaultProgress(wco.buildOptions.progress);\n\n    const webpackConfigs: {}[] = [\n      getCommonConfig(wco),\n      getServerConfig(wco),\n      getStylesConfig(wco),\n      getStatsConfig(wco),\n    ];\n\n    if (wco.buildOptions.main || wco.buildOptions.polyfills) {\n      const typescriptConfigPartial = wco.buildOptions.aot\n        ? getAotConfig(wco, host)\n        : getNonAotConfig(wco, host);\n      webpackConfigs.push(typescriptConfigPartial);\n    }\n\n    return webpackMerge(webpackConfigs);\n  }\n\n  private _deleteOutputDir(root: Path, outputPath: Path, host: virtualFs.Host) {\n    const resolvedOutputPath = resolve(root, outputPath);\n    if (resolvedOutputPath === root) {\n      throw new Error('Output path MUST not be project root directory!');\n    }\n\n    return host.exists(resolvedOutputPath).pipe(\n      concatMap(exists => exists\n        // TODO: remove this concat once host ops emit an event.\n        ? concat(host.delete(resolvedOutputPath), of(null)).pipe(last())\n        // ? of(null)\n        : of(null)),\n    );\n  }\n}\n\nexport default ServerBuilder;\n"]}
@@ -6,7 +6,12 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
 
9
- import { BrowserBuilderSchema, FileReplacement, SourceMapOptions } from '../browser/schema';
9
+ import {
10
+ BrowserBuilderSchema,
11
+ FileReplacement,
12
+ OptimizationObject,
13
+ SourceMapOptions,
14
+ } from '../browser/schema';
10
15
 
11
16
  export interface BuildWebpackServerSchema {
12
17
  /**
@@ -57,7 +62,7 @@ export interface BuildWebpackServerSchema {
57
62
  resourcesOutputPath: string;
58
63
  /**
59
64
  * Generates a 'stats.json' file which can be analyzed using tools such as:
60
- * #webpack-bundle-analyzer' or https: //webpack.github.io/analyse.
65
+ * #webpack-bundle-analyzer' or https://webpack.github.io/analyse.
61
66
  */
62
67
  statsJson?: boolean;
63
68
  /**
@@ -72,7 +77,7 @@ export interface BuildWebpackServerSchema {
72
77
  /**
73
78
  * Enables optimization of the build output.
74
79
  */
75
- optimization?: boolean;
80
+ optimization?: OptimizationObject;
76
81
  /**
77
82
  * Log progress to the console while building.
78
83
  */
@@ -168,3 +173,12 @@ export interface StylePreprocessorOptions {
168
173
  */
169
174
  includePaths?: string[];
170
175
  }
176
+
177
+ export interface NormalizedServerBuilderServerSchema extends Pick<
178
+ BuildWebpackServerSchema,
179
+ Exclude<keyof BuildWebpackServerSchema, 'sourceMap' | 'optimization'>
180
+ > {
181
+ fileReplacements: CurrentFileReplacement[];
182
+ sourceMap: NormalizedSourceMaps;
183
+ optimization: NormalizedOptimization;
184
+ }
@@ -28,9 +28,28 @@
28
28
  "additionalProperties": false
29
29
  },
30
30
  "optimization": {
31
- "type": "boolean",
32
31
  "description": "Enables optimization of the build output.",
33
- "default": false
32
+ "oneOf": [
33
+ {
34
+ "type": "object",
35
+ "properties": {
36
+ "scripts": {
37
+ "type": "boolean",
38
+ "description": "Enables optimization of the scripts output.",
39
+ "default": true
40
+ },
41
+ "styles": {
42
+ "type": "boolean",
43
+ "description": "Enables optimization of the styles output.",
44
+ "default": true
45
+ }
46
+ },
47
+ "additionalProperties": false
48
+ },
49
+ {
50
+ "type": "boolean"
51
+ }
52
+ ]
34
53
  },
35
54
  "fileReplacements": {
36
55
  "description": "Replace files with other files in the build.",
@@ -182,7 +201,7 @@
182
201
  },
183
202
  "statsJson": {
184
203
  "type": "boolean",
185
- "description": "Generates a 'stats.json' file which can be analyzed using tools such as: 'webpack-bundle-analyzer' or https: //webpack.github.io/analyse.",
204
+ "description": "Generates a 'stats.json' file which can be analyzed using tools such as: 'webpack-bundle-analyzer' or https://webpack.github.io/analyse.",
186
205
  "default": false
187
206
  },
188
207
  "forkTypeChecker": {
@@ -37,6 +37,14 @@ class TslintBuilder {
37
37
  const root = this.context.workspace.root;
38
38
  const systemRoot = core_1.getSystemPath(root);
39
39
  const options = builderConfig.options;
40
+ const targetSpecifier = this.context.targetSpecifier;
41
+ const projectName = targetSpecifier && targetSpecifier.project || '';
42
+ // Print formatter output only for non human-readable formats.
43
+ const printInfo = ['prose', 'verbose', 'stylish'].includes(options.format)
44
+ && !options.silent;
45
+ if (printInfo) {
46
+ this.context.logger.info(`Linting ${JSON.stringify(projectName)}...`);
47
+ }
40
48
  if (!options.tsConfig && options.typeCheck) {
41
49
  throw new Error('A "project" must be specified to enable type checking.');
42
50
  }
@@ -85,17 +93,13 @@ class TslintBuilder {
85
93
  this.context.logger.info(output);
86
94
  }
87
95
  }
88
- // Print formatter output directly for non human-readable formats.
89
- if (['prose', 'verbose', 'stylish'].indexOf(options.format) == -1) {
90
- options.silent = true;
91
- }
92
- if (result.warningCount > 0 && !options.silent) {
96
+ if (result.warningCount > 0 && printInfo) {
93
97
  this.context.logger.warn('Lint warnings found in the listed files.');
94
98
  }
95
- if (result.errorCount > 0 && !options.silent) {
99
+ if (result.errorCount > 0 && printInfo) {
96
100
  this.context.logger.error('Lint errors found in the listed files.');
97
101
  }
98
- if (result.warningCount === 0 && result.errorCount === 0 && !options.silent) {
102
+ if (result.warningCount === 0 && result.errorCount === 0 && printInfo) {
99
103
  this.context.logger.info('All files pass linting.');
100
104
  }
101
105
  const success = options.force || result.errorCount === 0;
@@ -169,4 +173,4 @@ function getFileContents(file, options, program) {
169
173
  throw new Error(`Could not read file '${file}'.`);
170
174
  }
171
175
  }
172
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/tslint/index.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;AAQH,+CAAqD;AACrD,2BAAkC;AAClC,6BAA6B;AAC7B,yCAAsC;AACtC,6BAA6B;AAC7B,+BAAwC;AACxC,8CAA2C;AAG3C,wEAAoE;AAcpE,MAAqB,aAAa;IAEhC,YAAmB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAI,CAAC;IAEvC,KAAK,CAAC,UAAU;QACtB,IAAI,MAAM,CAAC;QACX,IAAI;YACF,MAAM,GAAG,2CAAa,QAAQ,EAAC,CAAC,CAAC,+CAA+C;SACjF;QAAC,WAAM;YACN,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;SACvE;QAED,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1E,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE;YACtF,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;SAC1D;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,GAAG,CAAC,aAAyD;QAE3D,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC;QACzC,MAAM,UAAU,GAAG,oBAAa,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC;QAEtC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,SAAS,EAAE;YAC1C,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;SAC3E;QAED,OAAO,WAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,IAAI,CAAC,qBAAS,CAAC,aAAa,CAAC,EAAE,CAAC,IAAI,iBAAU,CAAC,GAAG,CAAC,EAAE;YAClF,MAAM,gBAAgB,GAAG,OAAO,CAAC,YAAY;gBAC3C,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,YAAY,CAAC;gBAChD,CAAC,CAAC,IAAI,CAAC;YACT,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC;YAEpC,IAAI,MAAqC,CAAC;YAC1C,IAAI,OAAO,CAAC,QAAQ,EAAE;gBACpB,MAAM,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;gBAE1F,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;oBAChC,MAAM,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;oBACzE,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,gBAAgB,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;oBACpF,IAAI,MAAM,IAAI,SAAS,EAAE;wBACvB,MAAM,GAAG,OAAO,CAAC;qBAClB;yBAAM;wBACL,MAAM,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ;6BAC9B,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;6BACjE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;wBAE5B,6DAA6D;wBAC7D,+EAA+E;wBAC/E,MAAM,CAAC,UAAU,IAAI,OAAO,CAAC,UAAU,CAAC;wBACxC,MAAM,CAAC,YAAY,IAAI,OAAO,CAAC,YAAY,CAAC;wBAE5C,IAAI,OAAO,CAAC,KAAK,EAAE;4BACjB,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;yBAClF;qBACF;iBACF;aACF;iBAAM;gBACL,MAAM,GAAG,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,gBAAgB,EAAE,OAAO,CAAC,CAAC;aACrE;YAED,IAAI,MAAM,IAAI,SAAS,EAAE;gBACvB,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;aACjE;YAED,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBACnB,MAAM,SAAS,GAAG,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC9D,IAAI,CAAC,SAAS,EAAE;oBACd,MAAM,IAAI,KAAK,CAAC,wBAAwB,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC;iBAC7D;gBACD,MAAM,SAAS,GAAG,IAAI,SAAS,EAAE,CAAC;gBAElC,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC/D,IAAI,MAAM,EAAE;oBACV,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;iBAClC;aACF;YAED,kEAAkE;YAClE,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE;gBACjE,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;aACvB;YAED,IAAI,MAAM,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBAC9C,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAC;aACtE;YAED,IAAI,MAAM,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBAC5C,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;aACrE;YAED,IAAI,MAAM,CAAC,YAAY,KAAK,CAAC,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBAC3E,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;aACrD;YAED,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,IAAI,MAAM,CAAC,UAAU,KAAK,CAAC,CAAC;YACzD,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;YAEtB,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC,CAAC,CAAC;IACP,CAAC;CACF;AAxGD,gCAwGC;AAED,SAAS,IAAI,CACX,aAA4B,EAC5B,UAAkB,EAClB,gBAA+B,EAC/B,OAA6B,EAC7B,OAAoB;IAEpB,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC;IACpC,MAAM,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC;IAElD,MAAM,KAAK,GAAG,cAAc,CAAC,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACnE,MAAM,WAAW,GAAG;QAClB,GAAG,EAAE,OAAO,CAAC,GAAG;QAChB,SAAS,EAAE,OAAO,CAAC,MAAM;KAC1B,CAAC;IAEF,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IAEhD,IAAI,aAAa,CAAC;IAClB,IAAI,UAAU,CAAC;IACf,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;QACxB,MAAM,QAAQ,GAAG,eAAe,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;QAEzD,0DAA0D;QAC1D,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,gBAAgB,KAAK,aAAa,EAAE;YACtC,UAAU,GAAG,aAAa,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;YACrE,aAAa,GAAG,gBAAgB,CAAC;SAClC;QAED,IAAI,QAAQ,IAAI,UAAU,EAAE;YAC1B,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC,OAAO,CAAC,CAAC;SACjD;KACF;IAED,OAAO,MAAM,CAAC,SAAS,EAAE,CAAC;AAC5B,CAAC;AAED,SAAS,cAAc,CACrB,IAAY,EACZ,OAA6B,EAC7B,MAA4B,EAC5B,OAAoB;IAEpB,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAE/B,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;QAC5B,OAAO,OAAO,CAAC,KAAK;aACjB,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;aAChE,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC;aAC7C,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;KACvC;IAED,IAAI,CAAC,OAAO,EAAE;QACZ,OAAO,EAAE,CAAC;KACX;IAED,IAAI,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAEhD,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;QAC/B,gCAAgC;QAChC,MAAM,cAAc,GAAG,MAAM;aAC1B,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,IAAI,qBAAS,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAEzE,YAAY,GAAG,YAAY;aACxB,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;KAC9F;IAED,OAAO,YAAY,CAAC;AACtB,CAAC;AAED,SAAS,eAAe,CACtB,IAAY,EACZ,OAA6B,EAC7B,OAAoB;IAEpB,4EAA4E;IAC5E,IAAI,OAAO,EAAE;QACX,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,SAAS,EAAE;YAC5C,MAAM,OAAO,GAAG,SAAS,IAAI,4CAA4C,OAAO,CAAC,QAAQ,IAAI,CAAC;YAC9F,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC;SAC1B;QAED,+FAA+F;QAC/F,oBAAoB;KACrB;IAED,sFAAsF;IACtF,IAAI;QACF,OAAO,oBAAQ,CAAC,iBAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;KAC9C;IAAC,WAAM;QACN,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,IAAI,CAAC,CAAC;KACnD;AACH,CAAC","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 */\n\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { getSystemPath } from '@angular-devkit/core';\nimport { readFileSync } from 'fs';\nimport * as glob from 'glob';\nimport { Minimatch } from 'minimatch';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\nimport * as tslint from 'tslint'; // tslint:disable-line:no-implicit-dependencies\nimport * as ts from 'typescript'; // tslint:disable-line:no-implicit-dependencies\nimport { stripBom } from '../angular-cli-files/utilities/strip-bom';\n\nexport interface TslintBuilderOptions {\n  tslintConfig?: string;\n  tsConfig?: string | string[];\n  fix: boolean;\n  typeCheck: boolean;\n  force: boolean;\n  silent: boolean;\n  format: string;\n  exclude: string[];\n  files: string[];\n}\n\nexport default class TslintBuilder implements Builder<TslintBuilderOptions> {\n\n  constructor(public context: BuilderContext) { }\n\n  private async loadTslint() {\n    let tslint;\n    try {\n      tslint = await import('tslint'); // tslint:disable-line:no-implicit-dependencies\n    } catch {\n      throw new Error('Unable to find TSLint. Ensure TSLint is installed.');\n    }\n\n    const version = tslint.Linter.VERSION && tslint.Linter.VERSION.split('.');\n    if (!version || version.length < 2 || Number(version[0]) < 5 || Number(version[1]) < 5) {\n      throw new Error('TSLint must be version 5.5 or higher.');\n    }\n\n    return tslint;\n  }\n\n  run(builderConfig: BuilderConfiguration<TslintBuilderOptions>): Observable<BuildEvent> {\n\n    const root = this.context.workspace.root;\n    const systemRoot = getSystemPath(root);\n    const options = builderConfig.options;\n\n    if (!options.tsConfig && options.typeCheck) {\n      throw new Error('A \"project\" must be specified to enable type checking.');\n    }\n\n    return from(this.loadTslint()).pipe(concatMap(projectTslint => new Observable(obs => {\n      const tslintConfigPath = options.tslintConfig\n        ? path.resolve(systemRoot, options.tslintConfig)\n        : null;\n      const Linter = projectTslint.Linter;\n\n      let result: undefined | tslint.LintResult;\n      if (options.tsConfig) {\n        const tsConfigs = Array.isArray(options.tsConfig) ? options.tsConfig : [options.tsConfig];\n\n        for (const tsConfig of tsConfigs) {\n          const program = Linter.createProgram(path.resolve(systemRoot, tsConfig));\n          const partial = lint(projectTslint, systemRoot, tslintConfigPath, options, program);\n          if (result == undefined) {\n            result = partial;\n          } else {\n            result.failures = result.failures\n              .filter(curr => !partial.failures.some(prev => curr.equals(prev)))\n              .concat(partial.failures);\n\n            // we are not doing much with 'errorCount' and 'warningCount'\n            // apart from checking if they are greater than 0 thus no need to dedupe these.\n            result.errorCount += partial.errorCount;\n            result.warningCount += partial.warningCount;\n\n            if (partial.fixes) {\n              result.fixes = result.fixes ? result.fixes.concat(partial.fixes) : partial.fixes;\n            }\n          }\n        }\n      } else {\n        result = lint(projectTslint, systemRoot, tslintConfigPath, options);\n      }\n\n      if (result == undefined) {\n        throw new Error('Invalid lint configuration. Nothing to lint.');\n      }\n\n      if (!options.silent) {\n        const Formatter = projectTslint.findFormatter(options.format);\n        if (!Formatter) {\n          throw new Error(`Invalid lint format \"${options.format}\".`);\n        }\n        const formatter = new Formatter();\n\n        const output = formatter.format(result.failures, result.fixes);\n        if (output) {\n          this.context.logger.info(output);\n        }\n      }\n\n      // Print formatter output directly for non human-readable formats.\n      if (['prose', 'verbose', 'stylish'].indexOf(options.format) == -1) {\n        options.silent = true;\n      }\n\n      if (result.warningCount > 0 && !options.silent) {\n        this.context.logger.warn('Lint warnings found in the listed files.');\n      }\n\n      if (result.errorCount > 0 && !options.silent) {\n        this.context.logger.error('Lint errors found in the listed files.');\n      }\n\n      if (result.warningCount === 0 && result.errorCount === 0 && !options.silent) {\n        this.context.logger.info('All files pass linting.');\n      }\n\n      const success = options.force || result.errorCount === 0;\n      obs.next({ success });\n\n      return obs.complete();\n    })));\n  }\n}\n\nfunction lint(\n  projectTslint: typeof tslint,\n  systemRoot: string,\n  tslintConfigPath: string | null,\n  options: TslintBuilderOptions,\n  program?: ts.Program,\n) {\n  const Linter = projectTslint.Linter;\n  const Configuration = projectTslint.Configuration;\n\n  const files = getFilesToLint(systemRoot, options, Linter, program);\n  const lintOptions = {\n    fix: options.fix,\n    formatter: options.format,\n  };\n\n  const linter = new Linter(lintOptions, program);\n\n  let lastDirectory;\n  let configLoad;\n  for (const file of files) {\n    const contents = getFileContents(file, options, program);\n\n    // Only check for a new tslint config if the path changes.\n    const currentDirectory = path.dirname(file);\n    if (currentDirectory !== lastDirectory) {\n      configLoad = Configuration.findConfiguration(tslintConfigPath, file);\n      lastDirectory = currentDirectory;\n    }\n\n    if (contents && configLoad) {\n      linter.lint(file, contents, configLoad.results);\n    }\n  }\n\n  return linter.getResult();\n}\n\nfunction getFilesToLint(\n  root: string,\n  options: TslintBuilderOptions,\n  linter: typeof tslint.Linter,\n  program?: ts.Program,\n): string[] {\n  const ignore = options.exclude;\n\n  if (options.files.length > 0) {\n    return options.files\n      .map(file => glob.sync(file, { cwd: root, ignore, nodir: true }))\n      .reduce((prev, curr) => prev.concat(curr), [])\n      .map(file => path.join(root, file));\n  }\n\n  if (!program) {\n    return [];\n  }\n\n  let programFiles = linter.getFileNames(program);\n\n  if (ignore && ignore.length > 0) {\n    // normalize to support ./ paths\n    const ignoreMatchers = ignore\n      .map(pattern => new Minimatch(path.normalize(pattern), { dot: true }));\n\n    programFiles = programFiles\n      .filter(file => !ignoreMatchers.some(matcher => matcher.match(path.relative(root, file))));\n  }\n\n  return programFiles;\n}\n\nfunction getFileContents(\n  file: string,\n  options: TslintBuilderOptions,\n  program?: ts.Program,\n): string | undefined {\n  // The linter retrieves the SourceFile TS node directly if a program is used\n  if (program) {\n    if (program.getSourceFile(file) == undefined) {\n      const message = `File '${file}' is not part of the TypeScript project '${options.tsConfig}'.`;\n      throw new Error(message);\n    }\n\n    // TODO: this return had to be commented out otherwise no file would be linted, figure out why.\n    // return undefined;\n  }\n\n  // NOTE: The tslint CLI checks for and excludes MPEG transport streams; this does not.\n  try {\n    return stripBom(readFileSync(file, 'utf-8'));\n  } catch {\n    throw new Error(`Could not read file '${file}'.`);\n  }\n}\n"]}
176
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/tslint/index.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 */\n\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { getSystemPath } from '@angular-devkit/core';\nimport { readFileSync } from 'fs';\nimport * as glob from 'glob';\nimport { Minimatch } from 'minimatch';\nimport * as path from 'path';\nimport { Observable, from } from 'rxjs';\nimport { concatMap } from 'rxjs/operators';\nimport * as tslint from 'tslint'; // tslint:disable-line:no-implicit-dependencies\nimport * as ts from 'typescript'; // tslint:disable-line:no-implicit-dependencies\nimport { stripBom } from '../angular-cli-files/utilities/strip-bom';\n\nexport interface TslintBuilderOptions {\n  tslintConfig?: string;\n  tsConfig?: string | string[];\n  fix: boolean;\n  typeCheck: boolean;\n  force: boolean;\n  silent: boolean;\n  format: string;\n  exclude: string[];\n  files: string[];\n}\n\nexport default class TslintBuilder implements Builder<TslintBuilderOptions> {\n\n  constructor(public context: BuilderContext) { }\n\n  private async loadTslint() {\n    let tslint;\n    try {\n      tslint = await import('tslint'); // tslint:disable-line:no-implicit-dependencies\n    } catch {\n      throw new Error('Unable to find TSLint. Ensure TSLint is installed.');\n    }\n\n    const version = tslint.Linter.VERSION && tslint.Linter.VERSION.split('.');\n    if (!version || version.length < 2 || Number(version[0]) < 5 || Number(version[1]) < 5) {\n      throw new Error('TSLint must be version 5.5 or higher.');\n    }\n\n    return tslint;\n  }\n\n  run(builderConfig: BuilderConfiguration<TslintBuilderOptions>): Observable<BuildEvent> {\n\n    const root = this.context.workspace.root;\n    const systemRoot = getSystemPath(root);\n    const options = builderConfig.options;\n    const targetSpecifier = this.context.targetSpecifier;\n    const projectName = targetSpecifier && targetSpecifier.project || '';\n\n    // Print formatter output only for non human-readable formats.\n    const printInfo = ['prose', 'verbose', 'stylish'].includes(options.format)\n      && !options.silent;\n\n    if (printInfo) {\n      this.context.logger.info(`Linting ${JSON.stringify(projectName)}...`);\n    }\n\n    if (!options.tsConfig && options.typeCheck) {\n      throw new Error('A \"project\" must be specified to enable type checking.');\n    }\n\n    return from(this.loadTslint()).pipe(concatMap(projectTslint => new Observable(obs => {\n      const tslintConfigPath = options.tslintConfig\n        ? path.resolve(systemRoot, options.tslintConfig)\n        : null;\n      const Linter = projectTslint.Linter;\n\n      let result: undefined | tslint.LintResult;\n      if (options.tsConfig) {\n        const tsConfigs = Array.isArray(options.tsConfig) ? options.tsConfig : [options.tsConfig];\n\n        for (const tsConfig of tsConfigs) {\n          const program = Linter.createProgram(path.resolve(systemRoot, tsConfig));\n          const partial = lint(projectTslint, systemRoot, tslintConfigPath, options, program);\n          if (result == undefined) {\n            result = partial;\n          } else {\n            result.failures = result.failures\n              .filter(curr => !partial.failures.some(prev => curr.equals(prev)))\n              .concat(partial.failures);\n\n            // we are not doing much with 'errorCount' and 'warningCount'\n            // apart from checking if they are greater than 0 thus no need to dedupe these.\n            result.errorCount += partial.errorCount;\n            result.warningCount += partial.warningCount;\n\n            if (partial.fixes) {\n              result.fixes = result.fixes ? result.fixes.concat(partial.fixes) : partial.fixes;\n            }\n          }\n        }\n      } else {\n        result = lint(projectTslint, systemRoot, tslintConfigPath, options);\n      }\n\n      if (result == undefined) {\n        throw new Error('Invalid lint configuration. Nothing to lint.');\n      }\n\n      if (!options.silent) {\n        const Formatter = projectTslint.findFormatter(options.format);\n        if (!Formatter) {\n          throw new Error(`Invalid lint format \"${options.format}\".`);\n        }\n        const formatter = new Formatter();\n\n        const output = formatter.format(result.failures, result.fixes);\n        if (output) {\n          this.context.logger.info(output);\n        }\n      }\n\n      if (result.warningCount > 0 && printInfo) {\n        this.context.logger.warn('Lint warnings found in the listed files.');\n      }\n\n      if (result.errorCount > 0 && printInfo) {\n        this.context.logger.error('Lint errors found in the listed files.');\n      }\n\n      if (result.warningCount === 0 && result.errorCount === 0 && printInfo) {\n        this.context.logger.info('All files pass linting.');\n      }\n\n      const success = options.force || result.errorCount === 0;\n      obs.next({ success });\n\n      return obs.complete();\n    })));\n  }\n}\n\nfunction lint(\n  projectTslint: typeof tslint,\n  systemRoot: string,\n  tslintConfigPath: string | null,\n  options: TslintBuilderOptions,\n  program?: ts.Program,\n) {\n  const Linter = projectTslint.Linter;\n  const Configuration = projectTslint.Configuration;\n\n  const files = getFilesToLint(systemRoot, options, Linter, program);\n  const lintOptions = {\n    fix: options.fix,\n    formatter: options.format,\n  };\n\n  const linter = new Linter(lintOptions, program);\n\n  let lastDirectory;\n  let configLoad;\n  for (const file of files) {\n    const contents = getFileContents(file, options, program);\n\n    // Only check for a new tslint config if the path changes.\n    const currentDirectory = path.dirname(file);\n    if (currentDirectory !== lastDirectory) {\n      configLoad = Configuration.findConfiguration(tslintConfigPath, file);\n      lastDirectory = currentDirectory;\n    }\n\n    if (contents && configLoad) {\n      linter.lint(file, contents, configLoad.results);\n    }\n  }\n\n  return linter.getResult();\n}\n\nfunction getFilesToLint(\n  root: string,\n  options: TslintBuilderOptions,\n  linter: typeof tslint.Linter,\n  program?: ts.Program,\n): string[] {\n  const ignore = options.exclude;\n\n  if (options.files.length > 0) {\n    return options.files\n      .map(file => glob.sync(file, { cwd: root, ignore, nodir: true }))\n      .reduce((prev, curr) => prev.concat(curr), [])\n      .map(file => path.join(root, file));\n  }\n\n  if (!program) {\n    return [];\n  }\n\n  let programFiles = linter.getFileNames(program);\n\n  if (ignore && ignore.length > 0) {\n    // normalize to support ./ paths\n    const ignoreMatchers = ignore\n      .map(pattern => new Minimatch(path.normalize(pattern), { dot: true }));\n\n    programFiles = programFiles\n      .filter(file => !ignoreMatchers.some(matcher => matcher.match(path.relative(root, file))));\n  }\n\n  return programFiles;\n}\n\nfunction getFileContents(\n  file: string,\n  options: TslintBuilderOptions,\n  program?: ts.Program,\n): string | undefined {\n  // The linter retrieves the SourceFile TS node directly if a program is used\n  if (program) {\n    if (program.getSourceFile(file) == undefined) {\n      const message = `File '${file}' is not part of the TypeScript project '${options.tsConfig}'.`;\n      throw new Error(message);\n    }\n\n    // TODO: this return had to be commented out otherwise no file would be linted, figure out why.\n    // return undefined;\n  }\n\n  // NOTE: The tslint CLI checks for and excludes MPEG transport streams; this does not.\n  try {\n    return stripBom(readFileSync(file, 'utf-8'));\n  } catch {\n    throw new Error(`Could not read file '${file}'.`);\n  }\n}\n"]}
@@ -10,3 +10,5 @@ export * from './run-module-as-observable-fork';
10
10
  export * from './normalize-file-replacements';
11
11
  export * from './normalize-asset-patterns';
12
12
  export * from './normalize-source-maps';
13
+ export * from './normalize-optimization';
14
+ export * from './normalize-builder-schema';
@@ -15,4 +15,6 @@ __export(require("./run-module-as-observable-fork"));
15
15
  __export(require("./normalize-file-replacements"));
16
16
  __export(require("./normalize-asset-patterns"));
17
17
  __export(require("./normalize-source-maps"));
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL3V0aWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7Ozs7O0FBRUgsd0NBQW1DO0FBQ25DLHFEQUFnRDtBQUNoRCxtREFBOEM7QUFDOUMsZ0RBQTJDO0FBQzNDLDZDQUF3QyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9kZWZhdWx0LXByb2dyZXNzJztcbmV4cG9ydCAqIGZyb20gJy4vcnVuLW1vZHVsZS1hcy1vYnNlcnZhYmxlLWZvcmsnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3JtYWxpemUtZmlsZS1yZXBsYWNlbWVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3JtYWxpemUtYXNzZXQtcGF0dGVybnMnO1xuZXhwb3J0ICogZnJvbSAnLi9ub3JtYWxpemUtc291cmNlLW1hcHMnO1xuIl19
18
+ __export(require("./normalize-optimization"));
19
+ __export(require("./normalize-builder-schema"));
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiLi8iLCJzb3VyY2VzIjpbInBhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL3V0aWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7Ozs7O0FBRUgsd0NBQW1DO0FBQ25DLHFEQUFnRDtBQUNoRCxtREFBOEM7QUFDOUMsZ0RBQTJDO0FBQzNDLDZDQUF3QztBQUN4Qyw4Q0FBeUM7QUFDekMsZ0RBQTJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2RlZmF1bHQtcHJvZ3Jlc3MnO1xuZXhwb3J0ICogZnJvbSAnLi9ydW4tbW9kdWxlLWFzLW9ic2VydmFibGUtZm9yayc7XG5leHBvcnQgKiBmcm9tICcuL25vcm1hbGl6ZS1maWxlLXJlcGxhY2VtZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL25vcm1hbGl6ZS1hc3NldC1wYXR0ZXJucyc7XG5leHBvcnQgKiBmcm9tICcuL25vcm1hbGl6ZS1zb3VyY2UtbWFwcyc7XG5leHBvcnQgKiBmcm9tICcuL25vcm1hbGl6ZS1vcHRpbWl6YXRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9ub3JtYWxpemUtYnVpbGRlci1zY2hlbWEnO1xuIl19
@@ -6,9 +6,8 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  import { BaseException, Path, virtualFs } from '@angular-devkit/core';
9
- import { Observable } from 'rxjs';
10
9
  import { AssetPattern, AssetPatternObject } from '../browser/schema';
11
10
  export declare class MissingAssetSourceRootException extends BaseException {
12
11
  constructor(path: String);
13
12
  }
14
- export declare function normalizeAssetPatterns(assetPatterns: AssetPattern[], host: virtualFs.Host, root: Path, projectRoot: Path, maybeSourceRoot: Path | undefined): Observable<AssetPatternObject[]>;
13
+ export declare function normalizeAssetPatterns(assetPatterns: AssetPattern[], host: virtualFs.SyncDelegateHost, root: Path, projectRoot: Path, maybeSourceRoot: Path | undefined): AssetPatternObject[];
@@ -8,8 +8,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
8
8
  * found in the LICENSE file at https://angular.io/license
9
9
  */
10
10
  const core_1 = require("@angular-devkit/core");
11
- const rxjs_1 = require("rxjs");
12
- const operators_1 = require("rxjs/operators");
13
11
  class MissingAssetSourceRootException extends core_1.BaseException {
14
12
  constructor(path) {
15
13
  super(`The ${path} asset path must start with the project source root.`);
@@ -21,12 +19,9 @@ function normalizeAssetPatterns(assetPatterns, host, root, projectRoot, maybeSou
21
19
  const sourceRoot = maybeSourceRoot || core_1.join(projectRoot, 'src');
22
20
  const resolvedSourceRoot = core_1.resolve(root, sourceRoot);
23
21
  if (assetPatterns.length === 0) {
24
- // If there are no asset patterns, return an empty array.
25
- // It's important to do this because forkJoin with an empty array will immediately complete
26
- // the observable.
27
- return rxjs_1.of([]);
22
+ return [];
28
23
  }
29
- const assetPatternObjectObservables = assetPatterns
24
+ return assetPatterns
30
25
  .map(assetPattern => {
31
26
  // Normalize string asset patterns to objects.
32
27
  if (typeof assetPattern === 'string') {
@@ -36,35 +31,36 @@ function normalizeAssetPatterns(assetPatterns, host, root, projectRoot, maybeSou
36
31
  if (!resolvedAssetPath.startsWith(resolvedSourceRoot)) {
37
32
  throw new MissingAssetSourceRootException(assetPattern);
38
33
  }
39
- return host.isDirectory(resolvedAssetPath).pipe(
40
- // If the path doesn't exist at all, pretend it is a directory.
41
- operators_1.catchError(() => rxjs_1.of(true)), operators_1.map(isDirectory => {
42
- let glob, input, output;
43
- if (isDirectory) {
44
- // Folders get a recursive star glob.
45
- glob = '**/*';
46
- // Input directory is their original path.
47
- input = assetPath;
48
- }
49
- else {
50
- // Files are their own glob.
51
- glob = core_1.basename(assetPath);
52
- // Input directory is their original dirname.
53
- input = core_1.dirname(assetPath);
54
- }
55
- // Output directory for both is the relative path from source root to input.
56
- output = core_1.relative(resolvedSourceRoot, core_1.resolve(root, input));
57
- // Return the asset pattern in object format.
58
- return { glob, input, output };
59
- }));
34
+ let glob, input, output;
35
+ let isDirectory = false;
36
+ try {
37
+ isDirectory = host.isDirectory(resolvedAssetPath);
38
+ }
39
+ catch (_a) {
40
+ isDirectory = true;
41
+ }
42
+ if (isDirectory) {
43
+ // Folders get a recursive star glob.
44
+ glob = '**/*';
45
+ // Input directory is their original path.
46
+ input = assetPath;
47
+ }
48
+ else {
49
+ // Files are their own glob.
50
+ glob = core_1.basename(assetPath);
51
+ // Input directory is their original dirname.
52
+ input = core_1.dirname(assetPath);
53
+ }
54
+ // Output directory for both is the relative path from source root to input.
55
+ output = core_1.relative(resolvedSourceRoot, core_1.resolve(root, input));
56
+ // Return the asset pattern in object format.
57
+ return { glob, input, output };
60
58
  }
61
59
  else {
62
60
  // It's already an AssetPatternObject, no need to convert.
63
- return rxjs_1.of(assetPattern);
61
+ return assetPattern;
64
62
  }
65
63
  });
66
- // Wait for all the asset patterns and return them as an array.
67
- return rxjs_1.forkJoin(assetPatternObjectObservables);
68
64
  }
69
65
  exports.normalizeAssetPatterns = normalizeAssetPatterns;
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLWFzc2V0LXBhdHRlcm5zLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy91dGlscy9ub3JtYWxpemUtYXNzZXQtcGF0dGVybnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCwrQ0FVOEI7QUFDOUIsK0JBQWdEO0FBQ2hELDhDQUFpRDtBQUlqRCxNQUFhLCtCQUFnQyxTQUFRLG9CQUFhO0lBQ2hFLFlBQVksSUFBWTtRQUN0QixLQUFLLENBQUMsT0FBTyxJQUFJLHNEQUFzRCxDQUFDLENBQUM7SUFDM0UsQ0FBQztDQUNGO0FBSkQsMEVBSUM7QUFFRCxTQUFnQixzQkFBc0IsQ0FDcEMsYUFBNkIsRUFDN0IsSUFBb0IsRUFDcEIsSUFBVSxFQUNWLFdBQWlCLEVBQ2pCLGVBQWlDO0lBRWpDLHNFQUFzRTtJQUN0RSxNQUFNLFVBQVUsR0FBRyxlQUFlLElBQUksV0FBSSxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUMvRCxNQUFNLGtCQUFrQixHQUFHLGNBQU8sQ0FBQyxJQUFJLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFFckQsSUFBSSxhQUFhLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUM5Qix5REFBeUQ7UUFDekQsMkZBQTJGO1FBQzNGLGtCQUFrQjtRQUNsQixPQUFPLFNBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztLQUNmO0lBRUQsTUFBTSw2QkFBNkIsR0FBcUMsYUFBYTtTQUNsRixHQUFHLENBQUMsWUFBWSxDQUFDLEVBQUU7UUFDbEIsOENBQThDO1FBQzlDLElBQUksT0FBTyxZQUFZLEtBQUssUUFBUSxFQUFFO1lBQ3BDLE1BQU0sU0FBUyxHQUFHLGdCQUFTLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDMUMsTUFBTSxpQkFBaUIsR0FBRyxjQUFPLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBRW5ELGtEQUFrRDtZQUNsRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLGtCQUFrQixDQUFDLEVBQUU7Z0JBQ3JELE1BQU0sSUFBSSwrQkFBK0IsQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUN6RDtZQUVELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLElBQUk7WUFDN0MsK0RBQStEO1lBQy9ELHNCQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBRSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQzFCLGVBQUcsQ0FBQyxXQUFXLENBQUMsRUFBRTtnQkFDaEIsSUFBSSxJQUFZLEVBQUUsS0FBVyxFQUFFLE1BQVksQ0FBQztnQkFDNUMsSUFBSSxXQUFXLEVBQUU7b0JBQ2YscUNBQXFDO29CQUNyQyxJQUFJLEdBQUcsTUFBTSxDQUFDO29CQUNkLDBDQUEwQztvQkFDMUMsS0FBSyxHQUFHLFNBQVMsQ0FBQztpQkFDbkI7cUJBQU07b0JBQ0wsNEJBQTRCO29CQUM1QixJQUFJLEdBQUcsZUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDO29CQUMzQiw2Q0FBNkM7b0JBQzdDLEtBQUssR0FBRyxjQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7aUJBQzVCO2dCQUVELDRFQUE0RTtnQkFDNUUsTUFBTSxHQUFHLGVBQVEsQ0FBQyxrQkFBa0IsRUFBRSxjQUFPLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7Z0JBRTVELDZDQUE2QztnQkFDN0MsT0FBTyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLENBQUM7WUFDakMsQ0FBQyxDQUFDLENBQ0gsQ0FBQztTQUNIO2FBQU07WUFDTCwwREFBMEQ7WUFDMUQsT0FBTyxTQUFFLENBQUMsWUFBWSxDQUFDLENBQUM7U0FDekI7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUVMLCtEQUErRDtJQUMvRCxPQUFPLGVBQVEsQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0FBQ2pELENBQUM7QUE5REQsd0RBOERDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtcbiAgQmFzZUV4Y2VwdGlvbixcbiAgUGF0aCxcbiAgYmFzZW5hbWUsXG4gIGRpcm5hbWUsXG4gIGpvaW4sXG4gIG5vcm1hbGl6ZSxcbiAgcmVsYXRpdmUsXG4gIHJlc29sdmUsXG4gIHZpcnR1YWxGcyxcbn0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgZm9ya0pvaW4sIG9mIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBjYXRjaEVycm9yLCBtYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBBc3NldFBhdHRlcm4sIEFzc2V0UGF0dGVybk9iamVjdCB9IGZyb20gJy4uL2Jyb3dzZXIvc2NoZW1hJztcblxuXG5leHBvcnQgY2xhc3MgTWlzc2luZ0Fzc2V0U291cmNlUm9vdEV4Y2VwdGlvbiBleHRlbmRzIEJhc2VFeGNlcHRpb24ge1xuICBjb25zdHJ1Y3RvcihwYXRoOiBTdHJpbmcpIHtcbiAgICBzdXBlcihgVGhlICR7cGF0aH0gYXNzZXQgcGF0aCBtdXN0IHN0YXJ0IHdpdGggdGhlIHByb2plY3Qgc291cmNlIHJvb3QuYCk7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG5vcm1hbGl6ZUFzc2V0UGF0dGVybnMoXG4gIGFzc2V0UGF0dGVybnM6IEFzc2V0UGF0dGVybltdLFxuICBob3N0OiB2aXJ0dWFsRnMuSG9zdCxcbiAgcm9vdDogUGF0aCxcbiAgcHJvamVjdFJvb3Q6IFBhdGgsXG4gIG1heWJlU291cmNlUm9vdDogUGF0aCB8IHVuZGVmaW5lZCxcbik6IE9ic2VydmFibGU8QXNzZXRQYXR0ZXJuT2JqZWN0W10+IHtcbiAgLy8gV2hlbiBzb3VyY2VSb290IGlzIG5vdCBhdmFpbGFibGUsIHdlIGRlZmF1bHQgdG8gJHtwcm9qZWN0Um9vdH0vc3JjLlxuICBjb25zdCBzb3VyY2VSb290ID0gbWF5YmVTb3VyY2VSb290IHx8IGpvaW4ocHJvamVjdFJvb3QsICdzcmMnKTtcbiAgY29uc3QgcmVzb2x2ZWRTb3VyY2VSb290ID0gcmVzb2x2ZShyb290LCBzb3VyY2VSb290KTtcblxuICBpZiAoYXNzZXRQYXR0ZXJucy5sZW5ndGggPT09IDApIHtcbiAgICAvLyBJZiB0aGVyZSBhcmUgbm8gYXNzZXQgcGF0dGVybnMsIHJldHVybiBhbiBlbXB0eSBhcnJheS5cbiAgICAvLyBJdCdzIGltcG9ydGFudCB0byBkbyB0aGlzIGJlY2F1c2UgZm9ya0pvaW4gd2l0aCBhbiBlbXB0eSBhcnJheSB3aWxsIGltbWVkaWF0ZWx5IGNvbXBsZXRlXG4gICAgLy8gdGhlIG9ic2VydmFibGUuXG4gICAgcmV0dXJuIG9mKFtdKTtcbiAgfVxuXG4gIGNvbnN0IGFzc2V0UGF0dGVybk9iamVjdE9ic2VydmFibGVzOiBPYnNlcnZhYmxlPEFzc2V0UGF0dGVybk9iamVjdD5bXSA9IGFzc2V0UGF0dGVybnNcbiAgICAubWFwKGFzc2V0UGF0dGVybiA9PiB7XG4gICAgICAvLyBOb3JtYWxpemUgc3RyaW5nIGFzc2V0IHBhdHRlcm5zIHRvIG9iamVjdHMuXG4gICAgICBpZiAodHlwZW9mIGFzc2V0UGF0dGVybiA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgY29uc3QgYXNzZXRQYXRoID0gbm9ybWFsaXplKGFzc2V0UGF0dGVybik7XG4gICAgICAgIGNvbnN0IHJlc29sdmVkQXNzZXRQYXRoID0gcmVzb2x2ZShyb290LCBhc3NldFBhdGgpO1xuXG4gICAgICAgIC8vIENoZWNrIGlmIHRoZSBzdHJpbmcgYXNzZXQgaXMgd2l0aGluIHNvdXJjZVJvb3QuXG4gICAgICAgIGlmICghcmVzb2x2ZWRBc3NldFBhdGguc3RhcnRzV2l0aChyZXNvbHZlZFNvdXJjZVJvb3QpKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IE1pc3NpbmdBc3NldFNvdXJjZVJvb3RFeGNlcHRpb24oYXNzZXRQYXR0ZXJuKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBob3N0LmlzRGlyZWN0b3J5KHJlc29sdmVkQXNzZXRQYXRoKS5waXBlKFxuICAgICAgICAgIC8vIElmIHRoZSBwYXRoIGRvZXNuJ3QgZXhpc3QgYXQgYWxsLCBwcmV0ZW5kIGl0IGlzIGEgZGlyZWN0b3J5LlxuICAgICAgICAgIGNhdGNoRXJyb3IoKCkgPT4gb2YodHJ1ZSkpLFxuICAgICAgICAgIG1hcChpc0RpcmVjdG9yeSA9PiB7XG4gICAgICAgICAgICBsZXQgZ2xvYjogc3RyaW5nLCBpbnB1dDogUGF0aCwgb3V0cHV0OiBQYXRoO1xuICAgICAgICAgICAgaWYgKGlzRGlyZWN0b3J5KSB7XG4gICAgICAgICAgICAgIC8vIEZvbGRlcnMgZ2V0IGEgcmVjdXJzaXZlIHN0YXIgZ2xvYi5cbiAgICAgICAgICAgICAgZ2xvYiA9ICcqKi8qJztcbiAgICAgICAgICAgICAgLy8gSW5wdXQgZGlyZWN0b3J5IGlzIHRoZWlyIG9yaWdpbmFsIHBhdGguXG4gICAgICAgICAgICAgIGlucHV0ID0gYXNzZXRQYXRoO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgLy8gRmlsZXMgYXJlIHRoZWlyIG93biBnbG9iLlxuICAgICAgICAgICAgICBnbG9iID0gYmFzZW5hbWUoYXNzZXRQYXRoKTtcbiAgICAgICAgICAgICAgLy8gSW5wdXQgZGlyZWN0b3J5IGlzIHRoZWlyIG9yaWdpbmFsIGRpcm5hbWUuXG4gICAgICAgICAgICAgIGlucHV0ID0gZGlybmFtZShhc3NldFBhdGgpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAvLyBPdXRwdXQgZGlyZWN0b3J5IGZvciBib3RoIGlzIHRoZSByZWxhdGl2ZSBwYXRoIGZyb20gc291cmNlIHJvb3QgdG8gaW5wdXQuXG4gICAgICAgICAgICBvdXRwdXQgPSByZWxhdGl2ZShyZXNvbHZlZFNvdXJjZVJvb3QsIHJlc29sdmUocm9vdCwgaW5wdXQpKTtcblxuICAgICAgICAgICAgLy8gUmV0dXJuIHRoZSBhc3NldCBwYXR0ZXJuIGluIG9iamVjdCBmb3JtYXQuXG4gICAgICAgICAgICByZXR1cm4geyBnbG9iLCBpbnB1dCwgb3V0cHV0IH07XG4gICAgICAgICAgfSksXG4gICAgICAgICk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBJdCdzIGFscmVhZHkgYW4gQXNzZXRQYXR0ZXJuT2JqZWN0LCBubyBuZWVkIHRvIGNvbnZlcnQuXG4gICAgICAgIHJldHVybiBvZihhc3NldFBhdHRlcm4pO1xuICAgICAgfVxuICAgIH0pO1xuXG4gIC8vIFdhaXQgZm9yIGFsbCB0aGUgYXNzZXQgcGF0dGVybnMgYW5kIHJldHVybiB0aGVtIGFzIGFuIGFycmF5LlxuICByZXR1cm4gZm9ya0pvaW4oYXNzZXRQYXR0ZXJuT2JqZWN0T2JzZXJ2YWJsZXMpO1xufVxuIl19
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLWFzc2V0LXBhdHRlcm5zLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy91dGlscy9ub3JtYWxpemUtYXNzZXQtcGF0dGVybnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7Ozs7O0dBTUc7QUFDSCwrQ0FVOEI7QUFJOUIsTUFBYSwrQkFBZ0MsU0FBUSxvQkFBYTtJQUNoRSxZQUFZLElBQVk7UUFDdEIsS0FBSyxDQUFDLE9BQU8sSUFBSSxzREFBc0QsQ0FBQyxDQUFDO0lBQzNFLENBQUM7Q0FDRjtBQUpELDBFQUlDO0FBRUQsU0FBZ0Isc0JBQXNCLENBQ3BDLGFBQTZCLEVBQzdCLElBQWdDLEVBQ2hDLElBQVUsRUFDVixXQUFpQixFQUNqQixlQUFpQztJQUVqQyxzRUFBc0U7SUFDdEUsTUFBTSxVQUFVLEdBQUcsZUFBZSxJQUFJLFdBQUksQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDL0QsTUFBTSxrQkFBa0IsR0FBRyxjQUFPLENBQUMsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBRXJELElBQUksYUFBYSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDOUIsT0FBTyxFQUFFLENBQUM7S0FDWDtJQUVELE9BQU8sYUFBYTtTQUNqQixHQUFHLENBQUMsWUFBWSxDQUFDLEVBQUU7UUFDbEIsOENBQThDO1FBQzlDLElBQUksT0FBTyxZQUFZLEtBQUssUUFBUSxFQUFFO1lBQ3BDLE1BQU0sU0FBUyxHQUFHLGdCQUFTLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDMUMsTUFBTSxpQkFBaUIsR0FBRyxjQUFPLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBRW5ELGtEQUFrRDtZQUNsRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLGtCQUFrQixDQUFDLEVBQUU7Z0JBQ3JELE1BQU0sSUFBSSwrQkFBK0IsQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUN6RDtZQUVELElBQUksSUFBWSxFQUFFLEtBQVcsRUFBRSxNQUFZLENBQUM7WUFDNUMsSUFBSSxXQUFXLEdBQUcsS0FBSyxDQUFDO1lBRXhCLElBQUk7Z0JBQ0YsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsQ0FBQzthQUNuRDtZQUFDLFdBQU07Z0JBQ04sV0FBVyxHQUFHLElBQUksQ0FBQzthQUNwQjtZQUVELElBQUksV0FBVyxFQUFFO2dCQUNmLHFDQUFxQztnQkFDckMsSUFBSSxHQUFHLE1BQU0sQ0FBQztnQkFDZCwwQ0FBMEM7Z0JBQzFDLEtBQUssR0FBRyxTQUFTLENBQUM7YUFDbkI7aUJBQU07Z0JBQ0wsNEJBQTRCO2dCQUM1QixJQUFJLEdBQUcsZUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDO2dCQUMzQiw2Q0FBNkM7Z0JBQzdDLEtBQUssR0FBRyxjQUFPLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDNUI7WUFFRCw0RUFBNEU7WUFDNUUsTUFBTSxHQUFHLGVBQVEsQ0FBQyxrQkFBa0IsRUFBRSxjQUFPLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFFNUQsNkNBQTZDO1lBQzdDLE9BQU8sRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxDQUFDO1NBQ2hDO2FBQU07WUFDTCwwREFBMEQ7WUFDMUQsT0FBTyxZQUFZLENBQUM7U0FDckI7SUFDSCxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUM7QUExREQsd0RBMERDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtcbiAgQmFzZUV4Y2VwdGlvbixcbiAgUGF0aCxcbiAgYmFzZW5hbWUsXG4gIGRpcm5hbWUsXG4gIGpvaW4sXG4gIG5vcm1hbGl6ZSxcbiAgcmVsYXRpdmUsXG4gIHJlc29sdmUsXG4gIHZpcnR1YWxGcyxcbn0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0IHsgQXNzZXRQYXR0ZXJuLCBBc3NldFBhdHRlcm5PYmplY3QgfSBmcm9tICcuLi9icm93c2VyL3NjaGVtYSc7XG5cblxuZXhwb3J0IGNsYXNzIE1pc3NpbmdBc3NldFNvdXJjZVJvb3RFeGNlcHRpb24gZXh0ZW5kcyBCYXNlRXhjZXB0aW9uIHtcbiAgY29uc3RydWN0b3IocGF0aDogU3RyaW5nKSB7XG4gICAgc3VwZXIoYFRoZSAke3BhdGh9IGFzc2V0IHBhdGggbXVzdCBzdGFydCB3aXRoIHRoZSBwcm9qZWN0IHNvdXJjZSByb290LmApO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBub3JtYWxpemVBc3NldFBhdHRlcm5zKFxuICBhc3NldFBhdHRlcm5zOiBBc3NldFBhdHRlcm5bXSxcbiAgaG9zdDogdmlydHVhbEZzLlN5bmNEZWxlZ2F0ZUhvc3QsXG4gIHJvb3Q6IFBhdGgsXG4gIHByb2plY3RSb290OiBQYXRoLFxuICBtYXliZVNvdXJjZVJvb3Q6IFBhdGggfCB1bmRlZmluZWQsXG4pOiBBc3NldFBhdHRlcm5PYmplY3RbXSB7XG4gIC8vIFdoZW4gc291cmNlUm9vdCBpcyBub3QgYXZhaWxhYmxlLCB3ZSBkZWZhdWx0IHRvICR7cHJvamVjdFJvb3R9L3NyYy5cbiAgY29uc3Qgc291cmNlUm9vdCA9IG1heWJlU291cmNlUm9vdCB8fCBqb2luKHByb2plY3RSb290LCAnc3JjJyk7XG4gIGNvbnN0IHJlc29sdmVkU291cmNlUm9vdCA9IHJlc29sdmUocm9vdCwgc291cmNlUm9vdCk7XG5cbiAgaWYgKGFzc2V0UGF0dGVybnMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIFtdO1xuICB9XG5cbiAgcmV0dXJuIGFzc2V0UGF0dGVybnNcbiAgICAubWFwKGFzc2V0UGF0dGVybiA9PiB7XG4gICAgICAvLyBOb3JtYWxpemUgc3RyaW5nIGFzc2V0IHBhdHRlcm5zIHRvIG9iamVjdHMuXG4gICAgICBpZiAodHlwZW9mIGFzc2V0UGF0dGVybiA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgY29uc3QgYXNzZXRQYXRoID0gbm9ybWFsaXplKGFzc2V0UGF0dGVybik7XG4gICAgICAgIGNvbnN0IHJlc29sdmVkQXNzZXRQYXRoID0gcmVzb2x2ZShyb290LCBhc3NldFBhdGgpO1xuXG4gICAgICAgIC8vIENoZWNrIGlmIHRoZSBzdHJpbmcgYXNzZXQgaXMgd2l0aGluIHNvdXJjZVJvb3QuXG4gICAgICAgIGlmICghcmVzb2x2ZWRBc3NldFBhdGguc3RhcnRzV2l0aChyZXNvbHZlZFNvdXJjZVJvb3QpKSB7XG4gICAgICAgICAgdGhyb3cgbmV3IE1pc3NpbmdBc3NldFNvdXJjZVJvb3RFeGNlcHRpb24oYXNzZXRQYXR0ZXJuKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBnbG9iOiBzdHJpbmcsIGlucHV0OiBQYXRoLCBvdXRwdXQ6IFBhdGg7XG4gICAgICAgIGxldCBpc0RpcmVjdG9yeSA9IGZhbHNlO1xuXG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgaXNEaXJlY3RvcnkgPSBob3N0LmlzRGlyZWN0b3J5KHJlc29sdmVkQXNzZXRQYXRoKTtcbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgaXNEaXJlY3RvcnkgPSB0cnVlO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGlzRGlyZWN0b3J5KSB7XG4gICAgICAgICAgLy8gRm9sZGVycyBnZXQgYSByZWN1cnNpdmUgc3RhciBnbG9iLlxuICAgICAgICAgIGdsb2IgPSAnKiovKic7XG4gICAgICAgICAgLy8gSW5wdXQgZGlyZWN0b3J5IGlzIHRoZWlyIG9yaWdpbmFsIHBhdGguXG4gICAgICAgICAgaW5wdXQgPSBhc3NldFBhdGg7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgLy8gRmlsZXMgYXJlIHRoZWlyIG93biBnbG9iLlxuICAgICAgICAgIGdsb2IgPSBiYXNlbmFtZShhc3NldFBhdGgpO1xuICAgICAgICAgIC8vIElucHV0IGRpcmVjdG9yeSBpcyB0aGVpciBvcmlnaW5hbCBkaXJuYW1lLlxuICAgICAgICAgIGlucHV0ID0gZGlybmFtZShhc3NldFBhdGgpO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gT3V0cHV0IGRpcmVjdG9yeSBmb3IgYm90aCBpcyB0aGUgcmVsYXRpdmUgcGF0aCBmcm9tIHNvdXJjZSByb290IHRvIGlucHV0LlxuICAgICAgICBvdXRwdXQgPSByZWxhdGl2ZShyZXNvbHZlZFNvdXJjZVJvb3QsIHJlc29sdmUocm9vdCwgaW5wdXQpKTtcblxuICAgICAgICAvLyBSZXR1cm4gdGhlIGFzc2V0IHBhdHRlcm4gaW4gb2JqZWN0IGZvcm1hdC5cbiAgICAgICAgcmV0dXJuIHsgZ2xvYiwgaW5wdXQsIG91dHB1dCB9O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gSXQncyBhbHJlYWR5IGFuIEFzc2V0UGF0dGVybk9iamVjdCwgbm8gbmVlZCB0byBjb252ZXJ0LlxuICAgICAgICByZXR1cm4gYXNzZXRQYXR0ZXJuO1xuICAgICAgfVxuICAgIH0pO1xufVxuIl19
@@ -0,0 +1,13 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { BuilderConfiguration } from '@angular-devkit/architect';
9
+ import { Path, virtualFs } from '@angular-devkit/core';
10
+ import { BrowserBuilderSchema, NormalizedBrowserBuilderSchema } from '../browser/schema';
11
+ import { KarmaBuilderSchema, NormalizedKarmaBuilderSchema } from '../karma/schema';
12
+ import { BuildWebpackServerSchema, NormalizedServerBuilderServerSchema } from '../server/schema';
13
+ export declare function normalizeBuilderSchema<BuilderConfigurationT extends BuilderConfiguration<BrowserBuilderSchema | BuildWebpackServerSchema | KarmaBuilderSchema>, OptionsT = BuilderConfigurationT['options']>(host: virtualFs.Host<{}>, root: Path, builderConfig: BuilderConfigurationT): OptionsT extends BrowserBuilderSchema ? NormalizedBrowserBuilderSchema : OptionsT extends BuildWebpackServerSchema ? NormalizedServerBuilderServerSchema : OptionsT extends KarmaBuilderSchema ? NormalizedKarmaBuilderSchema : any;
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google Inc. All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ const core_1 = require("@angular-devkit/core");
11
+ const normalize_asset_patterns_1 = require("./normalize-asset-patterns");
12
+ const normalize_file_replacements_1 = require("./normalize-file-replacements");
13
+ const normalize_optimization_1 = require("./normalize-optimization");
14
+ const normalize_source_maps_1 = require("./normalize-source-maps");
15
+ function normalizeBuilderSchema(host, root, builderConfig) {
16
+ const { options } = builderConfig;
17
+ const projectRoot = core_1.resolve(root, builderConfig.root);
18
+ const syncHost = new core_1.virtualFs.SyncDelegateHost(host);
19
+ // todo: this should be unknown
20
+ // tslint:disable-next-line:no-any
21
+ const isKarmaBuilderSchema = (options) => !options.hasOwnProperty('optimization');
22
+ // todo: this should be unknown
23
+ // tslint:disable-next-line:no-any
24
+ const isBuildWebpackServerSchema = (options) => !options.hasOwnProperty('assets');
25
+ const assets = isBuildWebpackServerSchema(options)
26
+ ? {}
27
+ : {
28
+ assets: normalize_asset_patterns_1.normalizeAssetPatterns(options.assets, syncHost, root, projectRoot, builderConfig.sourceRoot),
29
+ };
30
+ const normalizedSourceMapOptions = normalize_source_maps_1.normalizeSourceMaps(options.sourceMap);
31
+ // todo: remove when removing the deprecations
32
+ normalizedSourceMapOptions.vendor
33
+ = normalizedSourceMapOptions.vendor || !!options.vendorSourceMap;
34
+ const optimization = isKarmaBuilderSchema(options)
35
+ ? {}
36
+ : options.optimization || {};
37
+ return Object.assign({}, options, assets, { fileReplacements: normalize_file_replacements_1.normalizeFileReplacements(options.fileReplacements, syncHost, root), optimization: normalize_optimization_1.normalizeOptimization(optimization), sourceMap: normalize_source_maps_1.normalizeSourceMaps(options.sourceMap) });
38
+ }
39
+ exports.normalizeBuilderSchema = normalizeBuilderSchema;
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLWJ1aWxkZXItc2NoZW1hLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy91dGlscy9ub3JtYWxpemUtYnVpbGRlci1zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBOzs7Ozs7R0FNRzs7QUFJSCwrQ0FBZ0U7QUFJaEUseUVBQW9FO0FBQ3BFLCtFQUEwRTtBQUMxRSxxRUFBaUU7QUFDakUsbUVBQThEO0FBRTlELFNBQWdCLHNCQUFzQixDQUc5QixJQUF3QixFQUN4QixJQUFVLEVBQ1YsYUFBb0M7SUFPeEMsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLGFBQWEsQ0FBQztJQUNsQyxNQUFNLFdBQVcsR0FBRyxjQUFPLENBQUMsSUFBSSxFQUFFLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN0RCxNQUFNLFFBQVEsR0FBRyxJQUFJLGdCQUFTLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFFdEQsK0JBQStCO0lBQy9CLGtDQUFrQztJQUNsQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsT0FBWSxFQUFpQyxFQUFFLENBQ3pFLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUU1QywrQkFBK0I7SUFDL0Isa0NBQWtDO0lBQ2xDLE1BQU0sMEJBQTBCLEdBQUcsQ0FBQyxPQUFZLEVBQXVDLEVBQUUsQ0FDckYsQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBRXRDLE1BQU0sTUFBTSxHQUFHLDBCQUEwQixDQUFDLE9BQU8sQ0FBQztRQUM5QyxDQUFDLENBQUMsRUFBRTtRQUNKLENBQUMsQ0FBQztZQUNFLE1BQU0sRUFBRSxpREFBc0IsQ0FDMUIsT0FBTyxDQUFDLE1BQU0sRUFDZCxRQUFRLEVBQ1IsSUFBSSxFQUNKLFdBQVcsRUFDWCxhQUFhLENBQUMsVUFBVSxDQUMzQjtTQUNKLENBQUM7SUFFTixNQUFNLDBCQUEwQixHQUFHLDJDQUFtQixDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMxRSw4Q0FBOEM7SUFDOUMsMEJBQTBCLENBQUMsTUFBTTtVQUMzQiwwQkFBMEIsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUM7SUFFckUsTUFBTSxZQUFZLEdBQUcsb0JBQW9CLENBQUMsT0FBTyxDQUFDO1FBQzlDLENBQUMsQ0FBQyxFQUFFO1FBQ0osQ0FBQyxDQUFDLE9BQU8sQ0FBQyxZQUFZLElBQUksRUFBRSxDQUFDO0lBRWpDLHlCQUdPLE9BQWMsRUFDZCxNQUFNLElBQ1QsZ0JBQWdCLEVBQUUsdURBQXlCLENBQUMsT0FBTyxDQUFDLGdCQUFnQixFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsRUFDckYsWUFBWSxFQUFFLDhDQUFxQixDQUFDLFlBQVksQ0FBQyxFQUNqRCxTQUFTLEVBQUUsMkNBQW1CLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUNuRDtBQUNOLENBQUM7QUF4REQsd0RBd0RDIiwic291cmNlc0NvbnRlbnQiOlsiXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cblxuaW1wb3J0IHsgQnVpbGRlckNvbmZpZ3VyYXRpb24gfSBmcm9tICdAYW5ndWxhci1kZXZraXQvYXJjaGl0ZWN0JztcbmltcG9ydCB7IFBhdGgsIHJlc29sdmUsIHZpcnR1YWxGcyB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9jb3JlJztcbmltcG9ydCB7IEJyb3dzZXJCdWlsZGVyU2NoZW1hLCBOb3JtYWxpemVkQnJvd3NlckJ1aWxkZXJTY2hlbWEgfSBmcm9tICcuLi9icm93c2VyL3NjaGVtYSc7XG5pbXBvcnQgeyBLYXJtYUJ1aWxkZXJTY2hlbWEsIE5vcm1hbGl6ZWRLYXJtYUJ1aWxkZXJTY2hlbWEgfSBmcm9tICcuLi9rYXJtYS9zY2hlbWEnO1xuaW1wb3J0IHsgQnVpbGRXZWJwYWNrU2VydmVyU2NoZW1hLCBOb3JtYWxpemVkU2VydmVyQnVpbGRlclNlcnZlclNjaGVtYSB9IGZyb20gJy4uL3NlcnZlci9zY2hlbWEnO1xuaW1wb3J0IHsgbm9ybWFsaXplQXNzZXRQYXR0ZXJucyB9IGZyb20gJy4vbm9ybWFsaXplLWFzc2V0LXBhdHRlcm5zJztcbmltcG9ydCB7IG5vcm1hbGl6ZUZpbGVSZXBsYWNlbWVudHMgfSBmcm9tICcuL25vcm1hbGl6ZS1maWxlLXJlcGxhY2VtZW50cyc7XG5pbXBvcnQgeyBub3JtYWxpemVPcHRpbWl6YXRpb24gfSBmcm9tICcuL25vcm1hbGl6ZS1vcHRpbWl6YXRpb24nO1xuaW1wb3J0IHsgbm9ybWFsaXplU291cmNlTWFwcyB9IGZyb20gJy4vbm9ybWFsaXplLXNvdXJjZS1tYXBzJztcblxuZXhwb3J0IGZ1bmN0aW9uIG5vcm1hbGl6ZUJ1aWxkZXJTY2hlbWE8QnVpbGRlckNvbmZpZ3VyYXRpb25UIGV4dGVuZHNcbiAgICBCdWlsZGVyQ29uZmlndXJhdGlvbjxCcm93c2VyQnVpbGRlclNjaGVtYSB8IEJ1aWxkV2VicGFja1NlcnZlclNjaGVtYSB8IEthcm1hQnVpbGRlclNjaGVtYT4sXG4gICAgT3B0aW9uc1QgPSBCdWlsZGVyQ29uZmlndXJhdGlvblRbJ29wdGlvbnMnXT4oXG4gICAgICAgIGhvc3Q6IHZpcnR1YWxGcy5Ib3N0PHt9PixcbiAgICAgICAgcm9vdDogUGF0aCxcbiAgICAgICAgYnVpbGRlckNvbmZpZzogQnVpbGRlckNvbmZpZ3VyYXRpb25ULFxuKTpcbiAgICBPcHRpb25zVCBleHRlbmRzIEJyb3dzZXJCdWlsZGVyU2NoZW1hID8gTm9ybWFsaXplZEJyb3dzZXJCdWlsZGVyU2NoZW1hIDpcbiAgICBPcHRpb25zVCBleHRlbmRzIEJ1aWxkV2VicGFja1NlcnZlclNjaGVtYSA/IE5vcm1hbGl6ZWRTZXJ2ZXJCdWlsZGVyU2VydmVyU2NoZW1hIDpcbiAgICAvLyB0b2RvIHNob3VsZCBiZSB1bmtub3duXG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWFueVxuICAgIE9wdGlvbnNUIGV4dGVuZHMgS2FybWFCdWlsZGVyU2NoZW1hID8gTm9ybWFsaXplZEthcm1hQnVpbGRlclNjaGVtYSA6IGFueSB7XG4gICAgY29uc3QgeyBvcHRpb25zIH0gPSBidWlsZGVyQ29uZmlnO1xuICAgIGNvbnN0IHByb2plY3RSb290ID0gcmVzb2x2ZShyb290LCBidWlsZGVyQ29uZmlnLnJvb3QpO1xuICAgIGNvbnN0IHN5bmNIb3N0ID0gbmV3IHZpcnR1YWxGcy5TeW5jRGVsZWdhdGVIb3N0KGhvc3QpO1xuXG4gICAgLy8gdG9kbzogdGhpcyBzaG91bGQgYmUgdW5rbm93blxuICAgIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpuby1hbnlcbiAgICBjb25zdCBpc0thcm1hQnVpbGRlclNjaGVtYSA9IChvcHRpb25zOiBhbnkpOiBvcHRpb25zIGlzIEthcm1hQnVpbGRlclNjaGVtYSA9PlxuICAgICAgICAhb3B0aW9ucy5oYXNPd25Qcm9wZXJ0eSgnb3B0aW1pemF0aW9uJyk7XG5cbiAgICAvLyB0b2RvOiB0aGlzIHNob3VsZCBiZSB1bmtub3duXG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWFueVxuICAgIGNvbnN0IGlzQnVpbGRXZWJwYWNrU2VydmVyU2NoZW1hID0gKG9wdGlvbnM6IGFueSk6IG9wdGlvbnMgaXMgQnVpbGRXZWJwYWNrU2VydmVyU2NoZW1hID0+XG4gICAgICAgICFvcHRpb25zLmhhc093blByb3BlcnR5KCdhc3NldHMnKTtcblxuICAgIGNvbnN0IGFzc2V0cyA9IGlzQnVpbGRXZWJwYWNrU2VydmVyU2NoZW1hKG9wdGlvbnMpXG4gICAgICAgID8ge31cbiAgICAgICAgOiB7XG4gICAgICAgICAgICBhc3NldHM6IG5vcm1hbGl6ZUFzc2V0UGF0dGVybnMoXG4gICAgICAgICAgICAgICAgb3B0aW9ucy5hc3NldHMsXG4gICAgICAgICAgICAgICAgc3luY0hvc3QsXG4gICAgICAgICAgICAgICAgcm9vdCxcbiAgICAgICAgICAgICAgICBwcm9qZWN0Um9vdCxcbiAgICAgICAgICAgICAgICBidWlsZGVyQ29uZmlnLnNvdXJjZVJvb3QsXG4gICAgICAgICAgICApLFxuICAgICAgICB9O1xuXG4gICAgY29uc3Qgbm9ybWFsaXplZFNvdXJjZU1hcE9wdGlvbnMgPSBub3JtYWxpemVTb3VyY2VNYXBzKG9wdGlvbnMuc291cmNlTWFwKTtcbiAgICAvLyB0b2RvOiByZW1vdmUgd2hlbiByZW1vdmluZyB0aGUgZGVwcmVjYXRpb25zXG4gICAgbm9ybWFsaXplZFNvdXJjZU1hcE9wdGlvbnMudmVuZG9yXG4gICAgICAgID0gbm9ybWFsaXplZFNvdXJjZU1hcE9wdGlvbnMudmVuZG9yIHx8ICEhb3B0aW9ucy52ZW5kb3JTb3VyY2VNYXA7XG5cbiAgICBjb25zdCBvcHRpbWl6YXRpb24gPSBpc0thcm1hQnVpbGRlclNjaGVtYShvcHRpb25zKVxuICAgICAgICA/IHt9XG4gICAgICAgIDogb3B0aW9ucy5vcHRpbWl6YXRpb24gfHwge307XG5cbiAgICByZXR1cm4ge1xuICAgICAgICAvLyB0b2RvIHJlbW92ZSBhbnkgY2FzaW5nIHdoZW4gdXNpbmcgdHlwZXNjcmlwdCAzLjJcbiAgICAgICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOm5vLWFueVxuICAgICAgICAuLi5vcHRpb25zIGFzIGFueSxcbiAgICAgICAgLi4uYXNzZXRzLFxuICAgICAgICBmaWxlUmVwbGFjZW1lbnRzOiBub3JtYWxpemVGaWxlUmVwbGFjZW1lbnRzKG9wdGlvbnMuZmlsZVJlcGxhY2VtZW50cywgc3luY0hvc3QsIHJvb3QpLFxuICAgICAgICBvcHRpbWl6YXRpb246IG5vcm1hbGl6ZU9wdGltaXphdGlvbihvcHRpbWl6YXRpb24pLFxuICAgICAgICBzb3VyY2VNYXA6IG5vcm1hbGl6ZVNvdXJjZU1hcHMob3B0aW9ucy5zb3VyY2VNYXApLFxuICAgIH07XG59XG4iXX0=
@@ -6,7 +6,6 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  import { BaseException, Path, virtualFs } from '@angular-devkit/core';
9
- import { Observable } from 'rxjs';
10
9
  import { FileReplacement } from '../browser/schema';
11
10
  export declare class MissingFileReplacementException extends BaseException {
12
11
  constructor(path: String);
@@ -15,4 +14,4 @@ export interface NormalizedFileReplacement {
15
14
  replace: Path;
16
15
  with: Path;
17
16
  }
18
- export declare function normalizeFileReplacements(fileReplacements: FileReplacement[], host: virtualFs.Host, root: Path): Observable<NormalizedFileReplacement[]>;
17
+ export declare function normalizeFileReplacements(fileReplacements: FileReplacement[], host: virtualFs.SyncDelegateHost, root: Path): NormalizedFileReplacement[];
@@ -8,8 +8,6 @@
8
8
  */
9
9
  Object.defineProperty(exports, "__esModule", { value: true });
10
10
  const core_1 = require("@angular-devkit/core");
11
- const rxjs_1 = require("rxjs");
12
- const operators_1 = require("rxjs/operators");
13
11
  class MissingFileReplacementException extends core_1.BaseException {
14
12
  constructor(path) {
15
13
  super(`The ${path} path in file replacements does not exist.`);
@@ -18,17 +16,19 @@ class MissingFileReplacementException extends core_1.BaseException {
18
16
  exports.MissingFileReplacementException = MissingFileReplacementException;
19
17
  function normalizeFileReplacements(fileReplacements, host, root) {
20
18
  if (fileReplacements.length === 0) {
21
- return rxjs_1.of([]);
19
+ return [];
22
20
  }
23
- // Ensure all the replacements exist.
24
- const errorOnFalse = (path) => operators_1.tap((exists) => {
25
- if (!exists) {
26
- throw new MissingFileReplacementException(core_1.getSystemPath(path));
21
+ const normalizedReplacement = fileReplacements
22
+ .map(replacement => normalizeFileReplacement(replacement, root));
23
+ for (const { replace, with: replacementWith } of normalizedReplacement) {
24
+ if (!host.exists(replacementWith)) {
25
+ throw new MissingFileReplacementException(core_1.getSystemPath(replacementWith));
27
26
  }
28
- });
29
- return rxjs_1.from(fileReplacements).pipe(operators_1.map(replacement => normalizeFileReplacement(replacement, root)), operators_1.concatMap(normalized => {
30
- return rxjs_1.from([normalized.replace, normalized.with]).pipe(operators_1.mergeMap(path => host.exists(path).pipe(errorOnFalse(path))), operators_1.ignoreElements(), operators_1.concat(rxjs_1.of(normalized)));
31
- }), operators_1.toArray());
27
+ if (!host.exists(replace)) {
28
+ throw new MissingFileReplacementException(core_1.getSystemPath(replace));
29
+ }
30
+ }
31
+ return normalizedReplacement;
32
32
  }
33
33
  exports.normalizeFileReplacements = normalizeFileReplacements;
34
34
  function normalizeFileReplacement(fileReplacement, root) {
@@ -53,4 +53,4 @@ function normalizeFileReplacement(fileReplacement, root) {
53
53
  }
54
54
  return { replace: replacePath, with: withPath };
55
55
  }
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLWZpbGUtcmVwbGFjZW1lbnRzLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy91dGlscy9ub3JtYWxpemUtZmlsZS1yZXBsYWNlbWVudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7QUFFSCwrQ0FPOEI7QUFDOUIsK0JBQTRDO0FBQzVDLDhDQUFnRztBQVFoRyxNQUFhLCtCQUFnQyxTQUFRLG9CQUFhO0lBQ2hFLFlBQVksSUFBWTtRQUN0QixLQUFLLENBQUMsT0FBTyxJQUFJLDRDQUE0QyxDQUFDLENBQUM7SUFDakUsQ0FBQztDQUNGO0FBSkQsMEVBSUM7QUFPRCxTQUFnQix5QkFBeUIsQ0FDdkMsZ0JBQW1DLEVBQ25DLElBQW9CLEVBQ3BCLElBQVU7SUFFVixJQUFJLGdCQUFnQixDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDakMsT0FBTyxTQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7S0FDZjtJQUVELHFDQUFxQztJQUNyQyxNQUFNLFlBQVksR0FBRyxDQUFDLElBQVUsRUFBRSxFQUFFLENBQUMsZUFBRyxDQUFDLENBQUMsTUFBZSxFQUFFLEVBQUU7UUFDM0QsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNYLE1BQU0sSUFBSSwrQkFBK0IsQ0FBQyxvQkFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7U0FDaEU7SUFDSCxDQUFDLENBQUMsQ0FBQztJQUVILE9BQU8sV0FBSSxDQUFDLGdCQUFnQixDQUFDLENBQUMsSUFBSSxDQUNoQyxlQUFHLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUMsRUFDL0QscUJBQVMsQ0FBQyxVQUFVLENBQUMsRUFBRTtRQUNyQixPQUFPLFdBQUksQ0FBQyxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUNyRCxvQkFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFDNUQsMEJBQWMsRUFBRSxFQUNoQixrQkFBTSxDQUFDLFNBQUUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUN2QixDQUFDO0lBQ0osQ0FBQyxDQUFDLEVBQ0YsbUJBQU8sRUFBRSxDQUNWLENBQUM7QUFDSixDQUFDO0FBM0JELDhEQTJCQztBQUVELFNBQVMsd0JBQXdCLENBQy9CLGVBQWdDLEVBQ2hDLElBQVc7SUFFWCxNQUFNLGFBQWEsR0FBRyxlQUF5QyxDQUFDO0lBQ2hFLE1BQU0sY0FBYyxHQUFHLGVBQTJDLENBQUM7SUFFbkUsSUFBSSxXQUFpQixDQUFDO0lBQ3RCLElBQUksUUFBYyxDQUFDO0lBQ25CLElBQUksY0FBYyxDQUFDLEdBQUcsSUFBSSxjQUFjLENBQUMsV0FBVyxFQUFFO1FBQ3BELFdBQVcsR0FBRyxnQkFBUyxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUM1QyxRQUFRLEdBQUcsZ0JBQVMsQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDLENBQUM7S0FDbEQ7U0FBTTtRQUNMLFdBQVcsR0FBRyxnQkFBUyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMvQyxRQUFRLEdBQUcsZ0JBQVMsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7S0FDMUM7SUFFRCx5REFBeUQ7SUFDekQsSUFBSSxJQUFJLEVBQUU7UUFDUixXQUFXLEdBQUcsV0FBSSxDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztLQUN2QztJQUNELElBQUksSUFBSSxFQUFFO1FBQ1IsUUFBUSxHQUFHLFdBQUksQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7S0FDakM7SUFFRCxPQUFPLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsUUFBUSxFQUFFLENBQUM7QUFDbEQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtcbiAgQmFzZUV4Y2VwdGlvbixcbiAgUGF0aCxcbiAgZ2V0U3lzdGVtUGF0aCxcbiAgam9pbixcbiAgbm9ybWFsaXplLFxuICB2aXJ0dWFsRnMsXG59IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIGZyb20sIG9mIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBjb25jYXQsIGNvbmNhdE1hcCwgaWdub3JlRWxlbWVudHMsIG1hcCwgbWVyZ2VNYXAsIHRhcCwgdG9BcnJheSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7XG4gIEN1cnJlbnRGaWxlUmVwbGFjZW1lbnQsXG4gIERlcHJlY2F0ZWRGaWxlUmVwbGFjbWVudCxcbiAgRmlsZVJlcGxhY2VtZW50LFxufSBmcm9tICcuLi9icm93c2VyL3NjaGVtYSc7XG5cblxuZXhwb3J0IGNsYXNzIE1pc3NpbmdGaWxlUmVwbGFjZW1lbnRFeGNlcHRpb24gZXh0ZW5kcyBCYXNlRXhjZXB0aW9uIHtcbiAgY29uc3RydWN0b3IocGF0aDogU3RyaW5nKSB7XG4gICAgc3VwZXIoYFRoZSAke3BhdGh9IHBhdGggaW4gZmlsZSByZXBsYWNlbWVudHMgZG9lcyBub3QgZXhpc3QuYCk7XG4gIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb3JtYWxpemVkRmlsZVJlcGxhY2VtZW50IHtcbiAgcmVwbGFjZTogUGF0aDtcbiAgd2l0aDogUGF0aDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG5vcm1hbGl6ZUZpbGVSZXBsYWNlbWVudHMoXG4gIGZpbGVSZXBsYWNlbWVudHM6IEZpbGVSZXBsYWNlbWVudFtdLFxuICBob3N0OiB2aXJ0dWFsRnMuSG9zdCxcbiAgcm9vdDogUGF0aCxcbik6IE9ic2VydmFibGU8Tm9ybWFsaXplZEZpbGVSZXBsYWNlbWVudFtdPiB7XG4gIGlmIChmaWxlUmVwbGFjZW1lbnRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHJldHVybiBvZihbXSk7XG4gIH1cblxuICAvLyBFbnN1cmUgYWxsIHRoZSByZXBsYWNlbWVudHMgZXhpc3QuXG4gIGNvbnN0IGVycm9yT25GYWxzZSA9IChwYXRoOiBQYXRoKSA9PiB0YXAoKGV4aXN0czogYm9vbGVhbikgPT4ge1xuICAgIGlmICghZXhpc3RzKSB7XG4gICAgICB0aHJvdyBuZXcgTWlzc2luZ0ZpbGVSZXBsYWNlbWVudEV4Y2VwdGlvbihnZXRTeXN0ZW1QYXRoKHBhdGgpKTtcbiAgICB9XG4gIH0pO1xuXG4gIHJldHVybiBmcm9tKGZpbGVSZXBsYWNlbWVudHMpLnBpcGUoXG4gICAgbWFwKHJlcGxhY2VtZW50ID0+IG5vcm1hbGl6ZUZpbGVSZXBsYWNlbWVudChyZXBsYWNlbWVudCwgcm9vdCkpLFxuICAgIGNvbmNhdE1hcChub3JtYWxpemVkID0+IHtcbiAgICAgIHJldHVybiBmcm9tKFtub3JtYWxpemVkLnJlcGxhY2UsIG5vcm1hbGl6ZWQud2l0aF0pLnBpcGUoXG4gICAgICAgIG1lcmdlTWFwKHBhdGggPT4gaG9zdC5leGlzdHMocGF0aCkucGlwZShlcnJvck9uRmFsc2UocGF0aCkpKSxcbiAgICAgICAgaWdub3JlRWxlbWVudHMoKSxcbiAgICAgICAgY29uY2F0KG9mKG5vcm1hbGl6ZWQpKSxcbiAgICAgICk7XG4gICAgfSksXG4gICAgdG9BcnJheSgpLFxuICApO1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVGaWxlUmVwbGFjZW1lbnQoXG4gIGZpbGVSZXBsYWNlbWVudDogRmlsZVJlcGxhY2VtZW50LFxuICByb290PzogUGF0aCxcbik6IE5vcm1hbGl6ZWRGaWxlUmVwbGFjZW1lbnQge1xuICBjb25zdCBjdXJyZW50Rm9ybWF0ID0gZmlsZVJlcGxhY2VtZW50IGFzIEN1cnJlbnRGaWxlUmVwbGFjZW1lbnQ7XG4gIGNvbnN0IG1heWJlT2xkRm9ybWF0ID0gZmlsZVJlcGxhY2VtZW50IGFzIERlcHJlY2F0ZWRGaWxlUmVwbGFjbWVudDtcblxuICBsZXQgcmVwbGFjZVBhdGg6IFBhdGg7XG4gIGxldCB3aXRoUGF0aDogUGF0aDtcbiAgaWYgKG1heWJlT2xkRm9ybWF0LnNyYyAmJiBtYXliZU9sZEZvcm1hdC5yZXBsYWNlV2l0aCkge1xuICAgIHJlcGxhY2VQYXRoID0gbm9ybWFsaXplKG1heWJlT2xkRm9ybWF0LnNyYyk7XG4gICAgd2l0aFBhdGggPSBub3JtYWxpemUobWF5YmVPbGRGb3JtYXQucmVwbGFjZVdpdGgpO1xuICB9IGVsc2Uge1xuICAgIHJlcGxhY2VQYXRoID0gbm9ybWFsaXplKGN1cnJlbnRGb3JtYXQucmVwbGFjZSk7XG4gICAgd2l0aFBhdGggPSBub3JtYWxpemUoY3VycmVudEZvcm1hdC53aXRoKTtcbiAgfVxuXG4gIC8vIFRPRE86IEZvciA3Lnggc2hvdWxkIHRoaXMgb25seSBoYXBwZW4gaWYgbm90IGFic29sdXRlP1xuICBpZiAocm9vdCkge1xuICAgIHJlcGxhY2VQYXRoID0gam9pbihyb290LCByZXBsYWNlUGF0aCk7XG4gIH1cbiAgaWYgKHJvb3QpIHtcbiAgICB3aXRoUGF0aCA9IGpvaW4ocm9vdCwgd2l0aFBhdGgpO1xuICB9XG5cbiAgcmV0dXJuIHsgcmVwbGFjZTogcmVwbGFjZVBhdGgsIHdpdGg6IHdpdGhQYXRoIH07XG59XG4iXX0=
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplLWZpbGUtcmVwbGFjZW1lbnRzLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy91dGlscy9ub3JtYWxpemUtZmlsZS1yZXBsYWNlbWVudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7QUFFSCwrQ0FPOEI7QUFROUIsTUFBYSwrQkFBZ0MsU0FBUSxvQkFBYTtJQUNoRSxZQUFZLElBQVk7UUFDdEIsS0FBSyxDQUFDLE9BQU8sSUFBSSw0Q0FBNEMsQ0FBQyxDQUFDO0lBQ2pFLENBQUM7Q0FDRjtBQUpELDBFQUlDO0FBT0QsU0FBZ0IseUJBQXlCLENBQ3ZDLGdCQUFtQyxFQUNuQyxJQUFnQyxFQUNoQyxJQUFVO0lBRVYsSUFBSSxnQkFBZ0IsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1FBQ2pDLE9BQU8sRUFBRSxDQUFDO0tBQ1g7SUFFRCxNQUFNLHFCQUFxQixHQUFHLGdCQUFnQjtTQUMzQyxHQUFHLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyx3QkFBd0IsQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUVuRSxLQUFLLE1BQU0sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLGVBQWUsRUFBRSxJQUFJLHFCQUFxQixFQUFFO1FBQ3RFLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxFQUFFO1lBQ2pDLE1BQU0sSUFBSSwrQkFBK0IsQ0FBQyxvQkFBYSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUM7U0FDM0U7UUFFRCxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUN6QixNQUFNLElBQUksK0JBQStCLENBQUMsb0JBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO1NBQ25FO0tBQ0Y7SUFFRCxPQUFPLHFCQUFxQixDQUFDO0FBQy9CLENBQUM7QUF2QkQsOERBdUJDO0FBRUQsU0FBUyx3QkFBd0IsQ0FDL0IsZUFBZ0MsRUFDaEMsSUFBVztJQUVYLE1BQU0sYUFBYSxHQUFHLGVBQXlDLENBQUM7SUFDaEUsTUFBTSxjQUFjLEdBQUcsZUFBMkMsQ0FBQztJQUVuRSxJQUFJLFdBQWlCLENBQUM7SUFDdEIsSUFBSSxRQUFjLENBQUM7SUFDbkIsSUFBSSxjQUFjLENBQUMsR0FBRyxJQUFJLGNBQWMsQ0FBQyxXQUFXLEVBQUU7UUFDcEQsV0FBVyxHQUFHLGdCQUFTLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzVDLFFBQVEsR0FBRyxnQkFBUyxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUNsRDtTQUFNO1FBQ0wsV0FBVyxHQUFHLGdCQUFTLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQy9DLFFBQVEsR0FBRyxnQkFBUyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztLQUMxQztJQUVELHlEQUF5RDtJQUN6RCxJQUFJLElBQUksRUFBRTtRQUNSLFdBQVcsR0FBRyxXQUFJLENBQUMsSUFBSSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0tBQ3ZDO0lBQ0QsSUFBSSxJQUFJLEVBQUU7UUFDUixRQUFRLEdBQUcsV0FBSSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQztLQUNqQztJQUVELE9BQU8sRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsQ0FBQztBQUNsRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge1xuICBCYXNlRXhjZXB0aW9uLFxuICBQYXRoLFxuICBnZXRTeXN0ZW1QYXRoLFxuICBqb2luLFxuICBub3JtYWxpemUsXG4gIHZpcnR1YWxGcyxcbn0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2NvcmUnO1xuaW1wb3J0IHtcbiAgQ3VycmVudEZpbGVSZXBsYWNlbWVudCxcbiAgRGVwcmVjYXRlZEZpbGVSZXBsYWNtZW50LFxuICBGaWxlUmVwbGFjZW1lbnQsXG59IGZyb20gJy4uL2Jyb3dzZXIvc2NoZW1hJztcblxuXG5leHBvcnQgY2xhc3MgTWlzc2luZ0ZpbGVSZXBsYWNlbWVudEV4Y2VwdGlvbiBleHRlbmRzIEJhc2VFeGNlcHRpb24ge1xuICBjb25zdHJ1Y3RvcihwYXRoOiBTdHJpbmcpIHtcbiAgICBzdXBlcihgVGhlICR7cGF0aH0gcGF0aCBpbiBmaWxlIHJlcGxhY2VtZW50cyBkb2VzIG5vdCBleGlzdC5gKTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRGaWxlUmVwbGFjZW1lbnQge1xuICByZXBsYWNlOiBQYXRoO1xuICB3aXRoOiBQYXRoO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbm9ybWFsaXplRmlsZVJlcGxhY2VtZW50cyhcbiAgZmlsZVJlcGxhY2VtZW50czogRmlsZVJlcGxhY2VtZW50W10sXG4gIGhvc3Q6IHZpcnR1YWxGcy5TeW5jRGVsZWdhdGVIb3N0LFxuICByb290OiBQYXRoLFxuKTogTm9ybWFsaXplZEZpbGVSZXBsYWNlbWVudFtdIHtcbiAgaWYgKGZpbGVSZXBsYWNlbWVudHMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIFtdO1xuICB9XG5cbiAgY29uc3Qgbm9ybWFsaXplZFJlcGxhY2VtZW50ID0gZmlsZVJlcGxhY2VtZW50c1xuICAgIC5tYXAocmVwbGFjZW1lbnQgPT4gbm9ybWFsaXplRmlsZVJlcGxhY2VtZW50KHJlcGxhY2VtZW50LCByb290KSk7XG5cbiAgZm9yIChjb25zdCB7IHJlcGxhY2UsIHdpdGg6IHJlcGxhY2VtZW50V2l0aCB9IG9mIG5vcm1hbGl6ZWRSZXBsYWNlbWVudCkge1xuICAgIGlmICghaG9zdC5leGlzdHMocmVwbGFjZW1lbnRXaXRoKSkge1xuICAgICAgdGhyb3cgbmV3IE1pc3NpbmdGaWxlUmVwbGFjZW1lbnRFeGNlcHRpb24oZ2V0U3lzdGVtUGF0aChyZXBsYWNlbWVudFdpdGgpKTtcbiAgICB9XG5cbiAgICBpZiAoIWhvc3QuZXhpc3RzKHJlcGxhY2UpKSB7XG4gICAgICB0aHJvdyBuZXcgTWlzc2luZ0ZpbGVSZXBsYWNlbWVudEV4Y2VwdGlvbihnZXRTeXN0ZW1QYXRoKHJlcGxhY2UpKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gbm9ybWFsaXplZFJlcGxhY2VtZW50O1xufVxuXG5mdW5jdGlvbiBub3JtYWxpemVGaWxlUmVwbGFjZW1lbnQoXG4gIGZpbGVSZXBsYWNlbWVudDogRmlsZVJlcGxhY2VtZW50LFxuICByb290PzogUGF0aCxcbik6IE5vcm1hbGl6ZWRGaWxlUmVwbGFjZW1lbnQge1xuICBjb25zdCBjdXJyZW50Rm9ybWF0ID0gZmlsZVJlcGxhY2VtZW50IGFzIEN1cnJlbnRGaWxlUmVwbGFjZW1lbnQ7XG4gIGNvbnN0IG1heWJlT2xkRm9ybWF0ID0gZmlsZVJlcGxhY2VtZW50IGFzIERlcHJlY2F0ZWRGaWxlUmVwbGFjbWVudDtcblxuICBsZXQgcmVwbGFjZVBhdGg6IFBhdGg7XG4gIGxldCB3aXRoUGF0aDogUGF0aDtcbiAgaWYgKG1heWJlT2xkRm9ybWF0LnNyYyAmJiBtYXliZU9sZEZvcm1hdC5yZXBsYWNlV2l0aCkge1xuICAgIHJlcGxhY2VQYXRoID0gbm9ybWFsaXplKG1heWJlT2xkRm9ybWF0LnNyYyk7XG4gICAgd2l0aFBhdGggPSBub3JtYWxpemUobWF5YmVPbGRGb3JtYXQucmVwbGFjZVdpdGgpO1xuICB9IGVsc2Uge1xuICAgIHJlcGxhY2VQYXRoID0gbm9ybWFsaXplKGN1cnJlbnRGb3JtYXQucmVwbGFjZSk7XG4gICAgd2l0aFBhdGggPSBub3JtYWxpemUoY3VycmVudEZvcm1hdC53aXRoKTtcbiAgfVxuXG4gIC8vIFRPRE86IEZvciA3Lnggc2hvdWxkIHRoaXMgb25seSBoYXBwZW4gaWYgbm90IGFic29sdXRlP1xuICBpZiAocm9vdCkge1xuICAgIHJlcGxhY2VQYXRoID0gam9pbihyb290LCByZXBsYWNlUGF0aCk7XG4gIH1cbiAgaWYgKHJvb3QpIHtcbiAgICB3aXRoUGF0aCA9IGpvaW4ocm9vdCwgd2l0aFBhdGgpO1xuICB9XG5cbiAgcmV0dXJuIHsgcmVwbGFjZTogcmVwbGFjZVBhdGgsIHdpdGg6IHdpdGhQYXRoIH07XG59XG4iXX0=
@@ -0,0 +1,13 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ import { OptimizationOptions } from '../browser/schema';
9
+ export interface NormalizedOptimization {
10
+ scripts: boolean;
11
+ styles: boolean;
12
+ }
13
+ export declare function normalizeOptimization(optimization: OptimizationOptions): NormalizedOptimization;