@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.
- package/package.json +11 -11
- package/src/angular-cli-files/models/build-options.d.ts +5 -5
- package/src/angular-cli-files/models/build-options.js +1 -1
- package/src/angular-cli-files/models/webpack-configs/browser.js +8 -4
- package/src/angular-cli-files/models/webpack-configs/common.d.ts +1 -1
- package/src/angular-cli-files/models/webpack-configs/common.js +48 -38
- package/src/angular-cli-files/models/webpack-configs/server.js +3 -3
- package/src/angular-cli-files/models/webpack-configs/styles.js +4 -4
- package/src/angular-cli-files/models/webpack-configs/test.js +3 -3
- package/src/angular-cli-files/models/webpack-configs/typescript.js +3 -3
- package/src/angular-cli-files/plugins/cleancss-webpack-plugin.js +4 -15
- package/src/angular-cli-files/plugins/scripts-webpack-plugin.js +7 -31
- package/src/browser/index.d.ts +1 -6
- package/src/browser/index.js +3 -11
- package/src/browser/schema.d.ts +27 -2
- package/src/browser/schema.json +23 -4
- package/src/dev-server/index.d.ts +2 -2
- package/src/dev-server/index.js +7 -14
- package/src/dev-server/schema.json +22 -2
- package/src/extract-i18n/index.d.ts +1 -1
- package/src/extract-i18n/index.js +5 -2
- package/src/karma/index.d.ts +1 -6
- package/src/karma/index.js +4 -12
- package/src/karma/schema.d.ts +10 -0
- package/src/protractor/index.js +2 -2
- package/src/server/index.d.ts +2 -2
- package/src/server/index.js +3 -9
- package/src/server/schema.d.ts +17 -3
- package/src/server/schema.json +22 -3
- package/src/tslint/index.js +12 -8
- package/src/utils/index.d.ts +2 -0
- package/src/utils/index.js +3 -1
- package/src/utils/normalize-asset-patterns.d.ts +1 -2
- package/src/utils/normalize-asset-patterns.js +28 -32
- package/src/utils/normalize-builder-schema.d.ts +13 -0
- package/src/utils/normalize-builder-schema.js +40 -0
- package/src/utils/normalize-file-replacements.d.ts +1 -2
- package/src/utils/normalize-file-replacements.js +12 -12
- package/src/utils/normalize-optimization.d.ts +13 -0
- package/src/utils/normalize-optimization.js +19 -0
- package/src/utils/normalize-source-maps.d.ts +4 -5
- package/src/utils/normalize-source-maps.js +9 -10
package/src/server/index.js
CHANGED
|
@@ -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(() =>
|
|
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":";AAAA;;;;;;GAMG;;AAQH,iEAA+D;AAC/D,+CAA0F;AAE1F,+BAA8C;AAC9C,8CAAiD;AAGjD,iFAOqD;AACrD,gFAA4E;AAC5E,kGAA6F;AAC7F,wCAAiD;AACjD,oCAAmE;AAEnE,MAAM,YAAY,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC;AAG9C,MAAa,aAAa;IAExB,YAAmB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAI,CAAC;IAE/C,GAAG,CAAC,aAA6D;QAC/D,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC;QACzC,MAAM,WAAW,GAAG,cAAO,CAAC,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC,CAAC;QACtD,MAAM,IAAI,GAAG,IAAI,gBAAS,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,IAA6B,CAAC,CAAC;QACjF,MAAM,cAAc,GAAG,IAAI,8BAAc,mBAAM,IAAI,CAAC,OAAO,IAAE,IAAI,IAAG,CAAC;QAErE,MAAM,OAAO,GAAG,8BAAsB,CACpC,IAAI,EACJ,IAAI,EACJ,aAAa,CACd,CAAC;QAEF,gEAAgE;QAChE,OAAO,SAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAClB,qBAAS,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,gBAAgB;YACtC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,gBAAS,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;YAC/E,CAAC,CAAC,SAAE,CAAC,IAAI,CAAC,CAAC,EACb,qBAAS,CAAC,GAAG,EAAE;YACb,MAAM,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;YAEhF,OAAO,cAAc,CAAC,UAAU,CAAC,aAAa,EAAE,6BAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC;QACxF,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,IAAU,EAAE,WAAiB,EAC7B,IAA2B,EAC3B,OAA4C;QAC7D,IAAI,GAAyB,CAAC;QAE9B,yDAAyD;QACzD,6CAA6C;QAE7C,MAAM,YAAY,GAAG,oBAAa,CAAC,gBAAS,CAAC,cAAO,CAAC,IAAI,EAAE,gBAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1F,MAAM,QAAQ,GAAG,4BAAY,CAAC,YAAY,CAAC,CAAC;QAE5C,MAAM,SAAS,GAAG,6CAAoB,CAAC,oBAAa,CAAC,WAAW,CAAC,EAAE,YAAY,CAAc,CAAC;QAE9F,MAAM,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAM,KAAK,SAAS,CAAC,YAAY,CAAC,GAAG;eACvE,QAAQ,CAAC,OAAO,CAAC,MAAM,KAAK,SAAS,CAAC,YAAY,CAAC,GAAG,CAAC;QAE5D,MAAM,YAAY,qBACb,OAA2C,CAC/C,CAAC;QAEF,GAAG,GAAG;YACJ,IAAI,EAAE,oBAAa,CAAC,IAAI,CAAC;YACzB,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM;YAC3B,WAAW,EAAE,oBAAa,CAAC,WAAW,CAAC;YACvC,gFAAgF;YAChF,YAAY,oBACP,YAAY,IACf,cAAc,EAAE,KAAK,EACrB,GAAG,EAAE,IAAI,EACT,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,EAAE,EACX,MAAM,EAAE,EAAE,GACX;YACD,QAAQ;YACR,YAAY;YACZ,aAAa;SACd,CAAC;QAEF,GAAG,CAAC,YAAY,CAAC,QAAQ,GAAG,uBAAe,CAAC,GAAG,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAEvE,MAAM,cAAc,GAAS;YAC3B,iCAAe,CAAC,GAAG,CAAC;YACpB,iCAAe,CAAC,GAAG,CAAC;YACpB,iCAAe,CAAC,GAAG,CAAC;YACpB,gCAAc,CAAC,GAAG,CAAC;SACpB,CAAC;QAEF,IAAI,GAAG,CAAC,YAAY,CAAC,IAAI,IAAI,GAAG,CAAC,YAAY,CAAC,SAAS,EAAE;YACvD,MAAM,uBAAuB,GAAG,GAAG,CAAC,YAAY,CAAC,GAAG;gBAClD,CAAC,CAAC,8BAAY,CAAC,GAAG,EAAE,IAAI,CAAC;gBACzB,CAAC,CAAC,iCAAe,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;YAC/B,cAAc,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;SAC9C;QAED,OAAO,YAAY,CAAC,cAAc,CAAC,CAAC;IACtC,CAAC;IAEO,gBAAgB,CAAC,IAAU,EAAE,UAAgB,EAAE,IAAoB;QACzE,MAAM,kBAAkB,GAAG,cAAO,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QACrD,IAAI,kBAAkB,KAAK,IAAI,EAAE;YAC/B,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;SACpE;QAED,OAAO,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,IAAI,CACzC,qBAAS,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM;YACxB,wDAAwD;YACxD,CAAC,CAAC,aAAM,CAAC,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC,EAAE,SAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAI,EAAE,CAAC;YAChE,aAAa;YACb,CAAC,CAAC,SAAE,CAAC,IAAI,CAAC,CAAC,CACd,CAAC;IACJ,CAAC;CACF;AApGD,sCAoGC;AAED,kBAAe,aAAa,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 { 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"]}
|
package/src/server/schema.d.ts
CHANGED
|
@@ -6,7 +6,12 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
|
|
9
|
-
import {
|
|
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
|
|
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?:
|
|
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
|
+
}
|
package/src/server/schema.json
CHANGED
|
@@ -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
|
-
"
|
|
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
|
|
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": {
|
package/src/tslint/index.js
CHANGED
|
@@ -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
|
-
|
|
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 &&
|
|
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 &&
|
|
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":"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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\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":";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;QACtC,MAAM,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;QACrD,MAAM,WAAW,GAAG,eAAe,IAAI,eAAe,CAAC,OAAO,IAAI,EAAE,CAAC;QAErE,8DAA8D;QAC9D,MAAM,SAAS,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC;eACrE,CAAC,OAAO,CAAC,MAAM,CAAC;QAErB,IAAI,SAAS,EAAE;YACb,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;SACvE;QAED,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,IAAI,MAAM,CAAC,YAAY,GAAG,CAAC,IAAI,SAAS,EAAE;gBACxC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAC;aACtE;YAED,IAAI,MAAM,CAAC,UAAU,GAAG,CAAC,IAAI,SAAS,EAAE;gBACtC,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,SAAS,EAAE;gBACrE,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;AA7GD,gCA6GC;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    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"]}
|
package/src/utils/index.d.ts
CHANGED
|
@@ -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';
|
package/src/utils/index.js
CHANGED
|
@@ -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
|
-
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
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
|
|
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,
|
|
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.
|
|
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
|
|
19
|
+
return [];
|
|
22
20
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
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
|
-
|
|
30
|
-
|
|
31
|
-
}
|
|
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,
|
|
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;
|