@angular-devkit/build-angular 17.0.0-next.7 → 17.0.0-next.9
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/builders/application/build-action.d.ts +2 -0
- package/src/builders/application/build-action.js +6 -3
- package/src/builders/application/execute-build.js +40 -70
- package/src/builders/application/execute-post-bundle.d.ts +24 -0
- package/src/builders/application/execute-post-bundle.js +88 -0
- package/src/builders/application/i18n.js +13 -35
- package/src/builders/application/index.d.ts +21 -5
- package/src/builders/application/index.js +25 -10
- package/src/builders/application/options.d.ts +10 -1
- package/src/builders/application/options.js +7 -3
- package/src/builders/application/schema.d.ts +0 -1
- package/src/builders/application/schema.js +1 -1
- package/src/builders/application/schema.json +1 -1
- package/src/builders/browser/schema.d.ts +0 -1
- package/src/builders/browser/schema.js +1 -1
- package/src/builders/browser/schema.json +1 -1
- package/src/builders/browser-esbuild/builder-status-warnings.d.ts +1 -1
- package/src/builders/browser-esbuild/builder-status-warnings.js +6 -7
- package/src/builders/browser-esbuild/index.d.ts +4 -3
- package/src/builders/browser-esbuild/index.js +45 -3
- package/src/builders/browser-esbuild/schema.d.ts +0 -1
- package/src/builders/browser-esbuild/schema.js +1 -1
- package/src/builders/browser-esbuild/schema.json +1 -1
- package/src/builders/dev-server/builder.d.ts +2 -1
- package/src/builders/dev-server/builder.js +10 -4
- package/src/builders/dev-server/load-proxy-config.js +3 -2
- package/src/builders/dev-server/options.d.ts +1 -1
- package/src/builders/dev-server/options.js +4 -3
- package/src/builders/dev-server/schema.d.ts +8 -1
- package/src/builders/dev-server/schema.js +1 -1
- package/src/builders/dev-server/schema.json +7 -1
- package/src/builders/dev-server/vite-server.d.ts +4 -2
- package/src/builders/dev-server/vite-server.js +30 -8
- package/src/builders/dev-server/webpack-server.js +2 -2
- package/src/builders/extract-i18n/application-extraction.js +3 -3
- package/src/builders/extract-i18n/builder.js +4 -3
- package/src/builders/extract-i18n/options.d.ts +1 -1
- package/src/builders/extract-i18n/options.js +4 -3
- package/src/builders/extract-i18n/schema.d.ts +8 -1
- package/src/builders/extract-i18n/schema.js +1 -1
- package/src/builders/extract-i18n/schema.json +7 -1
- package/src/builders/extract-i18n/webpack-extraction.js +2 -2
- package/src/builders/jest/index.js +2 -2
- package/src/builders/protractor/index.js +2 -2
- package/src/index.d.ts +1 -0
- package/src/index.js +4 -2
- package/src/tools/esbuild/angular/compilation-state.d.ts +15 -0
- package/src/tools/esbuild/angular/compilation-state.js +43 -0
- package/src/tools/esbuild/angular/compiler-plugin.d.ts +2 -12
- package/src/tools/esbuild/angular/compiler-plugin.js +34 -52
- package/src/tools/esbuild/angular/component-stylesheets.d.ts +47 -0
- package/src/tools/esbuild/angular/component-stylesheets.js +147 -0
- package/src/tools/esbuild/angular/jit-plugin-callbacks.d.ts +2 -5
- package/src/tools/esbuild/angular/jit-plugin-callbacks.js +11 -6
- package/src/tools/esbuild/angular/source-file-cache.d.ts +19 -0
- package/src/tools/esbuild/angular/source-file-cache.js +67 -0
- package/src/tools/esbuild/angular/uri.d.ts +1 -1
- package/src/tools/esbuild/application-code-bundle.d.ts +1 -1
- package/src/tools/esbuild/application-code-bundle.js +67 -6
- package/src/tools/esbuild/budget-stats.d.ts +19 -0
- package/src/tools/esbuild/budget-stats.js +55 -0
- package/src/tools/esbuild/bundler-context.d.ts +12 -1
- package/src/tools/esbuild/bundler-context.js +29 -3
- package/src/tools/esbuild/bundler-execution-result.d.ts +12 -14
- package/src/tools/esbuild/bundler-execution-result.js +6 -3
- package/src/tools/esbuild/compiler-plugin-options.d.ts +2 -1
- package/src/tools/esbuild/compiler-plugin-options.js +2 -1
- package/src/tools/esbuild/global-styles.js +2 -1
- package/src/tools/esbuild/i18n-inliner.d.ts +3 -3
- package/src/tools/esbuild/i18n-inliner.js +12 -3
- package/src/tools/esbuild/index-html-generator.d.ts +2 -3
- package/src/tools/esbuild/index-html-generator.js +5 -2
- package/src/tools/esbuild/stylesheets/bundle-options.d.ts +2 -24
- package/src/tools/esbuild/stylesheets/bundle-options.js +4 -106
- package/src/tools/esbuild/stylesheets/less-language.js +37 -10
- package/src/tools/esbuild/utils.d.ts +13 -7
- package/src/tools/esbuild/utils.js +109 -37
- package/src/utils/build-options.d.ts +1 -1
- package/src/utils/build-options.js +1 -1
- package/src/utils/bundle-calculator.d.ts +16 -3
- package/src/utils/bundle-calculator.js +21 -10
- package/src/utils/server-rendering/{esm-in-memory-file-loader.d.ts → esm-in-memory-loader/loader-hooks.d.ts} +1 -0
- package/src/utils/server-rendering/esm-in-memory-loader/loader-hooks.js +82 -0
- package/src/utils/server-rendering/esm-in-memory-loader/node-18-utils.d.ts +10 -0
- package/src/utils/server-rendering/esm-in-memory-loader/node-18-utils.js +39 -0
- package/src/utils/server-rendering/esm-in-memory-loader/register-hooks.d.ts +8 -0
- package/src/utils/server-rendering/esm-in-memory-loader/register-hooks.js +16 -0
- package/src/utils/server-rendering/prerender.d.ts +2 -2
- package/src/utils/server-rendering/prerender.js +10 -18
- package/src/utils/server-rendering/render-worker.d.ts +1 -1
- package/src/utils/server-rendering/render-worker.js +1 -1
- package/src/utils/server-rendering/routes-extractor-worker.d.ts +1 -1
- package/src/utils/server-rendering/routes-extractor-worker.js +1 -1
- package/src/utils/service-worker.d.ts +4 -9
- package/src/utils/service-worker.js +5 -2
- package/src/utils/server-rendering/esm-in-memory-file-loader.js +0 -76
|
@@ -6,22 +6,47 @@
|
|
|
6
6
|
* Use of this source code is governed by an MIT-style license that can be
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
12
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
13
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
14
|
+
}
|
|
15
|
+
Object.defineProperty(o, k2, desc);
|
|
16
|
+
}) : (function(o, m, k, k2) {
|
|
17
|
+
if (k2 === undefined) k2 = k;
|
|
18
|
+
o[k2] = m[k];
|
|
19
|
+
}));
|
|
20
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
21
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
22
|
+
}) : function(o, v) {
|
|
23
|
+
o["default"] = v;
|
|
24
|
+
});
|
|
25
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
26
|
+
if (mod && mod.__esModule) return mod;
|
|
27
|
+
var result = {};
|
|
28
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
29
|
+
__setModuleDefault(result, mod);
|
|
30
|
+
return result;
|
|
31
|
+
};
|
|
9
32
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
10
33
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
11
34
|
};
|
|
12
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
exports.transformSupportedBrowsersToTargets = exports.
|
|
36
|
+
exports.getSupportedNodeTargets = exports.transformSupportedBrowsersToTargets = exports.getFullOutputPath = exports.createOutputFileFromData = exports.createOutputFileFromText = exports.writeResultFiles = exports.getFeatureSupport = exports.logMessages = exports.withNoProgress = exports.withSpinner = exports.calculateEstimatedTransferSizes = exports.logBuildStats = void 0;
|
|
14
37
|
const esbuild_1 = require("esbuild");
|
|
15
38
|
const node_crypto_1 = require("node:crypto");
|
|
16
39
|
const node_fs_1 = require("node:fs");
|
|
17
40
|
const promises_1 = __importDefault(require("node:fs/promises"));
|
|
18
|
-
const node_path_1 =
|
|
41
|
+
const node_path_1 = __importStar(require("node:path"));
|
|
19
42
|
const node_util_1 = require("node:util");
|
|
20
43
|
const node_zlib_1 = require("node:zlib");
|
|
44
|
+
const semver_1 = require("semver");
|
|
21
45
|
const spinner_1 = require("../../utils/spinner");
|
|
22
46
|
const stats_1 = require("../webpack/utils/stats");
|
|
47
|
+
const bundler_context_1 = require("./bundler-context");
|
|
23
48
|
const compressAsync = (0, node_util_1.promisify)(node_zlib_1.brotliCompress);
|
|
24
|
-
function logBuildStats(context, metafile, initial, estimatedTransferSizes) {
|
|
49
|
+
function logBuildStats(context, metafile, initial, budgetFailures, estimatedTransferSizes) {
|
|
25
50
|
const stats = [];
|
|
26
51
|
for (const [file, output] of Object.entries(metafile.outputs)) {
|
|
27
52
|
// Only display JavaScript and CSS files
|
|
@@ -33,17 +58,19 @@ function logBuildStats(context, metafile, initial, estimatedTransferSizes) {
|
|
|
33
58
|
if (output['ng-component']) {
|
|
34
59
|
continue;
|
|
35
60
|
}
|
|
61
|
+
let name = initial.get(file)?.name;
|
|
62
|
+
if (name === undefined && output.entryPoint) {
|
|
63
|
+
name = node_path_1.default
|
|
64
|
+
.basename(output.entryPoint)
|
|
65
|
+
.replace(/\.[cm]?[jt]s$/, '')
|
|
66
|
+
.replace(/[\\/.]/g, '-');
|
|
67
|
+
}
|
|
36
68
|
stats.push({
|
|
37
69
|
initial: initial.has(file),
|
|
38
|
-
stats: [
|
|
39
|
-
file,
|
|
40
|
-
initial.get(file)?.name ?? '-',
|
|
41
|
-
output.bytes,
|
|
42
|
-
estimatedTransferSizes?.get(file) ?? '-',
|
|
43
|
-
],
|
|
70
|
+
stats: [file, name ?? '-', output.bytes, estimatedTransferSizes?.get(file) ?? '-'],
|
|
44
71
|
});
|
|
45
72
|
}
|
|
46
|
-
const tableText = (0, stats_1.generateBuildStatsTable)(stats, true, true, !!estimatedTransferSizes,
|
|
73
|
+
const tableText = (0, stats_1.generateBuildStatsTable)(stats, true, true, !!estimatedTransferSizes, budgetFailures);
|
|
47
74
|
context.logger.info('\n' + tableText + '\n');
|
|
48
75
|
}
|
|
49
76
|
exports.logBuildStats = logBuildStats;
|
|
@@ -78,7 +105,7 @@ async function withSpinner(text, action) {
|
|
|
78
105
|
}
|
|
79
106
|
}
|
|
80
107
|
exports.withSpinner = withSpinner;
|
|
81
|
-
async function withNoProgress(
|
|
108
|
+
async function withNoProgress(text, action) {
|
|
82
109
|
return action();
|
|
83
110
|
}
|
|
84
111
|
exports.withNoProgress = withNoProgress;
|
|
@@ -141,75 +168,107 @@ function getFeatureSupport(target) {
|
|
|
141
168
|
return supported;
|
|
142
169
|
}
|
|
143
170
|
exports.getFeatureSupport = getFeatureSupport;
|
|
171
|
+
const MAX_CONCURRENT_WRITES = 64;
|
|
144
172
|
async function writeResultFiles(outputFiles, assetFiles, outputPath) {
|
|
145
173
|
const directoryExists = new Set();
|
|
146
|
-
|
|
174
|
+
// Writes the output file to disk and ensures the containing directories are present
|
|
175
|
+
const writeOutputFile = async (file) => {
|
|
176
|
+
const fullOutputPath = file.fullOutputPath;
|
|
147
177
|
// Ensure output subdirectories exist
|
|
148
|
-
const basePath = node_path_1.default.dirname(
|
|
178
|
+
const basePath = node_path_1.default.dirname(fullOutputPath);
|
|
149
179
|
if (basePath && !directoryExists.has(basePath)) {
|
|
150
180
|
await promises_1.default.mkdir(node_path_1.default.join(outputPath, basePath), { recursive: true });
|
|
151
181
|
directoryExists.add(basePath);
|
|
152
182
|
}
|
|
153
183
|
// Write file contents
|
|
154
|
-
await promises_1.default.writeFile(node_path_1.default.join(outputPath,
|
|
155
|
-
}
|
|
184
|
+
await promises_1.default.writeFile(node_path_1.default.join(outputPath, fullOutputPath), file.contents);
|
|
185
|
+
};
|
|
186
|
+
// Write files in groups of MAX_CONCURRENT_WRITES to avoid too many open files
|
|
187
|
+
for (let fileIndex = 0; fileIndex < outputFiles.length;) {
|
|
188
|
+
const groupMax = Math.min(fileIndex + MAX_CONCURRENT_WRITES, outputFiles.length);
|
|
189
|
+
const actions = [];
|
|
190
|
+
while (fileIndex < groupMax) {
|
|
191
|
+
actions.push(writeOutputFile(outputFiles[fileIndex++]));
|
|
192
|
+
}
|
|
193
|
+
await Promise.all(actions);
|
|
194
|
+
}
|
|
156
195
|
if (assetFiles?.length) {
|
|
157
|
-
|
|
196
|
+
const copyAssetFile = async (asset) => {
|
|
158
197
|
// Ensure output subdirectories exist
|
|
159
|
-
const
|
|
198
|
+
const destPath = (0, node_path_1.join)('browser', asset.destination);
|
|
199
|
+
const basePath = node_path_1.default.dirname(destPath);
|
|
160
200
|
if (basePath && !directoryExists.has(basePath)) {
|
|
161
201
|
await promises_1.default.mkdir(node_path_1.default.join(outputPath, basePath), { recursive: true });
|
|
162
202
|
directoryExists.add(basePath);
|
|
163
203
|
}
|
|
164
204
|
// Copy file contents
|
|
165
|
-
await promises_1.default.copyFile(source, node_path_1.default.join(outputPath,
|
|
166
|
-
}
|
|
205
|
+
await promises_1.default.copyFile(asset.source, node_path_1.default.join(outputPath, destPath), node_fs_1.constants.COPYFILE_FICLONE);
|
|
206
|
+
};
|
|
207
|
+
for (let fileIndex = 0; fileIndex < assetFiles.length;) {
|
|
208
|
+
const groupMax = Math.min(fileIndex + MAX_CONCURRENT_WRITES, assetFiles.length);
|
|
209
|
+
const actions = [];
|
|
210
|
+
while (fileIndex < groupMax) {
|
|
211
|
+
actions.push(copyAssetFile(assetFiles[fileIndex++]));
|
|
212
|
+
}
|
|
213
|
+
await Promise.all(actions);
|
|
214
|
+
}
|
|
167
215
|
}
|
|
168
216
|
}
|
|
169
217
|
exports.writeResultFiles = writeResultFiles;
|
|
170
|
-
function createOutputFileFromText(path, text) {
|
|
218
|
+
function createOutputFileFromText(path, text, type) {
|
|
171
219
|
return {
|
|
172
220
|
path,
|
|
173
221
|
text,
|
|
222
|
+
type,
|
|
174
223
|
get hash() {
|
|
175
224
|
return (0, node_crypto_1.createHash)('sha256').update(this.text).digest('hex');
|
|
176
225
|
},
|
|
177
226
|
get contents() {
|
|
178
227
|
return Buffer.from(this.text, 'utf-8');
|
|
179
228
|
},
|
|
229
|
+
get fullOutputPath() {
|
|
230
|
+
return getFullOutputPath(this);
|
|
231
|
+
},
|
|
232
|
+
clone() {
|
|
233
|
+
return createOutputFileFromText(this.path, this.text, this.type);
|
|
234
|
+
},
|
|
180
235
|
};
|
|
181
236
|
}
|
|
182
237
|
exports.createOutputFileFromText = createOutputFileFromText;
|
|
183
|
-
function createOutputFileFromData(path, data) {
|
|
238
|
+
function createOutputFileFromData(path, data, type) {
|
|
184
239
|
return {
|
|
185
240
|
path,
|
|
241
|
+
type,
|
|
186
242
|
get text() {
|
|
187
243
|
return Buffer.from(data.buffer, data.byteOffset, data.byteLength).toString('utf-8');
|
|
188
244
|
},
|
|
189
245
|
get hash() {
|
|
190
|
-
return (0, node_crypto_1.createHash)('sha256').update(
|
|
246
|
+
return (0, node_crypto_1.createHash)('sha256').update(this.text).digest('hex');
|
|
191
247
|
},
|
|
192
248
|
get contents() {
|
|
193
249
|
return data;
|
|
194
250
|
},
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
exports.createOutputFileFromData = createOutputFileFromData;
|
|
198
|
-
function cloneOutputFile(file) {
|
|
199
|
-
return {
|
|
200
|
-
path: file.path,
|
|
201
|
-
get text() {
|
|
202
|
-
return file.text;
|
|
251
|
+
get fullOutputPath() {
|
|
252
|
+
return getFullOutputPath(this);
|
|
203
253
|
},
|
|
204
|
-
|
|
205
|
-
return
|
|
206
|
-
},
|
|
207
|
-
get contents() {
|
|
208
|
-
return file.contents;
|
|
254
|
+
clone() {
|
|
255
|
+
return createOutputFileFromData(this.path, this.contents, this.type);
|
|
209
256
|
},
|
|
210
257
|
};
|
|
211
258
|
}
|
|
212
|
-
exports.
|
|
259
|
+
exports.createOutputFileFromData = createOutputFileFromData;
|
|
260
|
+
function getFullOutputPath(file) {
|
|
261
|
+
switch (file.type) {
|
|
262
|
+
case bundler_context_1.BuildOutputFileType.Browser:
|
|
263
|
+
case bundler_context_1.BuildOutputFileType.Media:
|
|
264
|
+
return (0, node_path_1.join)('browser', file.path);
|
|
265
|
+
case bundler_context_1.BuildOutputFileType.Server:
|
|
266
|
+
return (0, node_path_1.join)('server', file.path);
|
|
267
|
+
default:
|
|
268
|
+
return file.path;
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
exports.getFullOutputPath = getFullOutputPath;
|
|
213
272
|
/**
|
|
214
273
|
* Transform browserlists result to esbuild target.
|
|
215
274
|
* @see https://esbuild.github.io/api/#target
|
|
@@ -254,4 +313,17 @@ function transformSupportedBrowsersToTargets(supportedBrowsers) {
|
|
|
254
313
|
return transformed;
|
|
255
314
|
}
|
|
256
315
|
exports.transformSupportedBrowsersToTargets = transformSupportedBrowsersToTargets;
|
|
257
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 { BuilderContext } from '@angular-devkit/architect';\nimport { BuildOptions, Metafile, OutputFile, PartialMessage, formatMessages } from 'esbuild';\nimport { createHash } from 'node:crypto';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { promisify } from 'node:util';\nimport { brotliCompress } from 'node:zlib';\nimport { Spinner } from '../../utils/spinner';\nimport { BundleStats, generateBuildStatsTable } from '../webpack/utils/stats';\nimport { InitialFileRecord } from './bundler-context';\n\nconst compressAsync = promisify(brotliCompress);\n\nexport function logBuildStats(\n  context: BuilderContext,\n  metafile: Metafile,\n  initial: Map<string, InitialFileRecord>,\n  estimatedTransferSizes?: Map<string, number>,\n): void {\n  const stats: BundleStats[] = [];\n  for (const [file, output] of Object.entries(metafile.outputs)) {\n    // Only display JavaScript and CSS files\n    if (!file.endsWith('.js') && !file.endsWith('.css')) {\n      continue;\n    }\n    // Skip internal component resources\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    if ((output as any)['ng-component']) {\n      continue;\n    }\n\n    stats.push({\n      initial: initial.has(file),\n      stats: [\n        file,\n        initial.get(file)?.name ?? '-',\n        output.bytes,\n        estimatedTransferSizes?.get(file) ?? '-',\n      ],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(stats, true, true, !!estimatedTransferSizes, undefined);\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n\nexport async function calculateEstimatedTransferSizes(\n  outputFiles: OutputFile[],\n): Promise<Map<string, number>> {\n  const sizes = new Map<string, number>();\n  const pendingCompression = [];\n\n  for (const outputFile of outputFiles) {\n    // Only calculate JavaScript and CSS files\n    if (!outputFile.path.endsWith('.js') && !outputFile.path.endsWith('.css')) {\n      continue;\n    }\n\n    // Skip compressing small files which may end being larger once compressed and will most likely not be\n    // compressed in actual transit.\n    if (outputFile.contents.byteLength < 1024) {\n      sizes.set(outputFile.path, outputFile.contents.byteLength);\n      continue;\n    }\n\n    pendingCompression.push(\n      compressAsync(outputFile.contents).then((result) =>\n        sizes.set(outputFile.path, result.byteLength),\n      ),\n    );\n  }\n\n  await Promise.all(pendingCompression);\n\n  return sizes;\n}\n\nexport async function withSpinner<T>(text: string, action: () => T | Promise<T>): Promise<T> {\n  const spinner = new Spinner(text);\n  spinner.start();\n\n  try {\n    return await action();\n  } finally {\n    spinner.stop();\n  }\n}\n\nexport async function withNoProgress<T>(test: string, action: () => T | Promise<T>): Promise<T> {\n  return action();\n}\n\nexport async function logMessages(\n  context: BuilderContext,\n  { errors, warnings }: { errors?: PartialMessage[]; warnings?: PartialMessage[] },\n): Promise<void> {\n  if (warnings?.length) {\n    const warningMessages = await formatMessages(warnings, { kind: 'warning', color: true });\n    context.logger.warn(warningMessages.join('\\n'));\n  }\n\n  if (errors?.length) {\n    const errorMessages = await formatMessages(errors, { kind: 'error', color: true });\n    context.logger.error(errorMessages.join('\\n'));\n  }\n}\n\n/**\n * Generates a syntax feature object map for Angular applications based on a list of targets.\n * A full set of feature names can be found here: https://esbuild.github.io/api/#supported\n * @param target An array of browser/engine targets in the format accepted by the esbuild `target` option.\n * @returns An object that can be used with the esbuild build `supported` option.\n */\nexport function getFeatureSupport(target: string[]): BuildOptions['supported'] {\n  const supported: Record<string, boolean> = {\n    // Native async/await is not supported with Zone.js. Disabling support here will cause\n    // esbuild to downlevel async/await, async generators, and for await...of to a Zone.js supported form.\n    'async-await': false,\n    // V8 currently has a performance defect involving object spread operations that can cause signficant\n    // degradation in runtime performance. By not supporting the language feature here, a downlevel form\n    // will be used instead which provides a workaround for the performance issue.\n    // For more details: https://bugs.chromium.org/p/v8/issues/detail?id=11536\n    'object-rest-spread': false,\n  };\n\n  // Detect Safari browser versions that have a class field behavior bug\n  // See: https://github.com/angular/angular-cli/issues/24355#issuecomment-1333477033\n  // See: https://github.com/WebKit/WebKit/commit/e8788a34b3d5f5b4edd7ff6450b80936bff396f2\n  let safariClassFieldScopeBug = false;\n  for (const browser of target) {\n    let majorVersion;\n    if (browser.startsWith('ios')) {\n      majorVersion = Number(browser.slice(3, 5));\n    } else if (browser.startsWith('safari')) {\n      majorVersion = Number(browser.slice(6, 8));\n    } else {\n      continue;\n    }\n    // Technically, 14.0 is not broken but rather does not have support. However, the behavior\n    // is identical since it would be set to false by esbuild if present as a target.\n    if (majorVersion === 14 || majorVersion === 15) {\n      safariClassFieldScopeBug = true;\n      break;\n    }\n  }\n  // If class field support cannot be used set to false; otherwise leave undefined to allow\n  // esbuild to use `target` to determine support.\n  if (safariClassFieldScopeBug) {\n    supported['class-field'] = false;\n    supported['class-static-field'] = false;\n  }\n\n  return supported;\n}\n\nexport async function writeResultFiles(\n  outputFiles: OutputFile[],\n  assetFiles: { source: string; destination: string }[] | undefined,\n  outputPath: string,\n) {\n  const directoryExists = new Set<string>();\n  await Promise.all(\n    outputFiles.map(async (file) => {\n      // Ensure output subdirectories exist\n      const basePath = path.dirname(file.path);\n      if (basePath && !directoryExists.has(basePath)) {\n        await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n        directoryExists.add(basePath);\n      }\n      // Write file contents\n      await fs.writeFile(path.join(outputPath, file.path), file.contents);\n    }),\n  );\n\n  if (assetFiles?.length) {\n    await Promise.all(\n      assetFiles.map(async ({ source, destination }) => {\n        // Ensure output subdirectories exist\n        const basePath = path.dirname(destination);\n        if (basePath && !directoryExists.has(basePath)) {\n          await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n          directoryExists.add(basePath);\n        }\n        // Copy file contents\n        await fs.copyFile(source, path.join(outputPath, destination), fsConstants.COPYFILE_FICLONE);\n      }),\n    );\n  }\n}\n\nexport function createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get hash() {\n      return createHash('sha256').update(this.text).digest('hex');\n    },\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nexport function createOutputFileFromData(path: string, data: Uint8Array): OutputFile {\n  return {\n    path,\n    get text() {\n      return Buffer.from(data.buffer, data.byteOffset, data.byteLength).toString('utf-8');\n    },\n    get hash() {\n      return createHash('sha256').update(data).digest('hex');\n    },\n    get contents() {\n      return data;\n    },\n  };\n}\n\nexport function cloneOutputFile(file: OutputFile): OutputFile {\n  return {\n    path: file.path,\n    get text() {\n      return file.text;\n    },\n    get hash() {\n      return file.hash;\n    },\n    get contents() {\n      return file.contents;\n    },\n  };\n}\n\n/**\n * Transform browserlists result to esbuild target.\n * @see https://esbuild.github.io/api/#target\n */\nexport function transformSupportedBrowsersToTargets(supportedBrowsers: string[]): string[] {\n  const transformed: string[] = [];\n\n  // https://esbuild.github.io/api/#target\n  const esBuildSupportedBrowsers = new Set([\n    'chrome',\n    'edge',\n    'firefox',\n    'ie',\n    'ios',\n    'node',\n    'opera',\n    'safari',\n  ]);\n\n  for (const browser of supportedBrowsers) {\n    let [browserName, version] = browser.toLowerCase().split(' ');\n\n    // browserslist uses the name `ios_saf` for iOS Safari whereas esbuild uses `ios`\n    if (browserName === 'ios_saf') {\n      browserName = 'ios';\n    }\n\n    // browserslist uses ranges `15.2-15.3` versions but only the lowest is required\n    // to perform minimum supported feature checks. esbuild also expects a single version.\n    [version] = version.split('-');\n\n    if (esBuildSupportedBrowsers.has(browserName)) {\n      if (browserName === 'safari' && version === 'tp') {\n        // esbuild only supports numeric versions so `TP` is converted to a high number (999) since\n        // a Technology Preview (TP) of Safari is assumed to support all currently known features.\n        version = '999';\n      } else if (!version.includes('.')) {\n        // A lone major version is considered by esbuild to include all minor versions. However,\n        // browserslist does not and is also inconsistent in its `.0` version naming. For example,\n        // Safari 15.0 is named `safari 15` but Safari 16.0 is named `safari 16.0`.\n        version += '.0';\n      }\n\n      transformed.push(browserName + version);\n    }\n  }\n\n  return transformed;\n}\n"]}
|
|
316
|
+
const SUPPORTED_NODE_VERSIONS = '>=18.13.0';
|
|
317
|
+
/**
|
|
318
|
+
* Transform supported Node.js versions to esbuild target.
|
|
319
|
+
* @see https://esbuild.github.io/api/#target
|
|
320
|
+
*/
|
|
321
|
+
function getSupportedNodeTargets() {
|
|
322
|
+
if (SUPPORTED_NODE_VERSIONS.charAt(0) === '0') {
|
|
323
|
+
// Unlike `pkg_npm`, `ts_library` which is used to run unit tests does not support substitutions.
|
|
324
|
+
return [];
|
|
325
|
+
}
|
|
326
|
+
return SUPPORTED_NODE_VERSIONS.split('||').map((v) => 'node' + (0, semver_1.coerce)(v)?.version);
|
|
327
|
+
}
|
|
328
|
+
exports.getSupportedNodeTargets = getSupportedNodeTargets;
|
|
329
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 { BuilderContext } from '@angular-devkit/architect';\nimport { BuildOptions, Metafile, OutputFile, PartialMessage, formatMessages } from 'esbuild';\nimport { createHash } from 'node:crypto';\nimport { constants as fsConstants } from 'node:fs';\nimport fs from 'node:fs/promises';\nimport path, { join } from 'node:path';\nimport { promisify } from 'node:util';\nimport { brotliCompress } from 'node:zlib';\nimport { coerce } from 'semver';\nimport { BudgetCalculatorResult } from '../../utils/bundle-calculator';\nimport { Spinner } from '../../utils/spinner';\nimport { BundleStats, generateBuildStatsTable } from '../webpack/utils/stats';\nimport { BuildOutputFile, BuildOutputFileType, InitialFileRecord } from './bundler-context';\n\nconst compressAsync = promisify(brotliCompress);\n\nexport function logBuildStats(\n  context: BuilderContext,\n  metafile: Metafile,\n  initial: Map<string, InitialFileRecord>,\n  budgetFailures: BudgetCalculatorResult[] | undefined,\n  estimatedTransferSizes?: Map<string, number>,\n): void {\n  const stats: BundleStats[] = [];\n  for (const [file, output] of Object.entries(metafile.outputs)) {\n    // Only display JavaScript and CSS files\n    if (!file.endsWith('.js') && !file.endsWith('.css')) {\n      continue;\n    }\n    // Skip internal component resources\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    if ((output as any)['ng-component']) {\n      continue;\n    }\n\n    let name = initial.get(file)?.name;\n    if (name === undefined && output.entryPoint) {\n      name = path\n        .basename(output.entryPoint)\n        .replace(/\\.[cm]?[jt]s$/, '')\n        .replace(/[\\\\/.]/g, '-');\n    }\n\n    stats.push({\n      initial: initial.has(file),\n      stats: [file, name ?? '-', output.bytes, estimatedTransferSizes?.get(file) ?? '-'],\n    });\n  }\n\n  const tableText = generateBuildStatsTable(\n    stats,\n    true,\n    true,\n    !!estimatedTransferSizes,\n    budgetFailures,\n  );\n\n  context.logger.info('\\n' + tableText + '\\n');\n}\n\nexport async function calculateEstimatedTransferSizes(\n  outputFiles: OutputFile[],\n): Promise<Map<string, number>> {\n  const sizes = new Map<string, number>();\n  const pendingCompression = [];\n\n  for (const outputFile of outputFiles) {\n    // Only calculate JavaScript and CSS files\n    if (!outputFile.path.endsWith('.js') && !outputFile.path.endsWith('.css')) {\n      continue;\n    }\n\n    // Skip compressing small files which may end being larger once compressed and will most likely not be\n    // compressed in actual transit.\n    if (outputFile.contents.byteLength < 1024) {\n      sizes.set(outputFile.path, outputFile.contents.byteLength);\n      continue;\n    }\n\n    pendingCompression.push(\n      compressAsync(outputFile.contents).then((result) =>\n        sizes.set(outputFile.path, result.byteLength),\n      ),\n    );\n  }\n\n  await Promise.all(pendingCompression);\n\n  return sizes;\n}\n\nexport async function withSpinner<T>(text: string, action: () => T | Promise<T>): Promise<T> {\n  const spinner = new Spinner(text);\n  spinner.start();\n\n  try {\n    return await action();\n  } finally {\n    spinner.stop();\n  }\n}\n\nexport async function withNoProgress<T>(text: string, action: () => T | Promise<T>): Promise<T> {\n  return action();\n}\n\nexport async function logMessages(\n  context: BuilderContext,\n  { errors, warnings }: { errors?: PartialMessage[]; warnings?: PartialMessage[] },\n): Promise<void> {\n  if (warnings?.length) {\n    const warningMessages = await formatMessages(warnings, { kind: 'warning', color: true });\n    context.logger.warn(warningMessages.join('\\n'));\n  }\n\n  if (errors?.length) {\n    const errorMessages = await formatMessages(errors, { kind: 'error', color: true });\n    context.logger.error(errorMessages.join('\\n'));\n  }\n}\n\n/**\n * Generates a syntax feature object map for Angular applications based on a list of targets.\n * A full set of feature names can be found here: https://esbuild.github.io/api/#supported\n * @param target An array of browser/engine targets in the format accepted by the esbuild `target` option.\n * @returns An object that can be used with the esbuild build `supported` option.\n */\nexport function getFeatureSupport(target: string[]): BuildOptions['supported'] {\n  const supported: Record<string, boolean> = {\n    // Native async/await is not supported with Zone.js. Disabling support here will cause\n    // esbuild to downlevel async/await, async generators, and for await...of to a Zone.js supported form.\n    'async-await': false,\n    // V8 currently has a performance defect involving object spread operations that can cause signficant\n    // degradation in runtime performance. By not supporting the language feature here, a downlevel form\n    // will be used instead which provides a workaround for the performance issue.\n    // For more details: https://bugs.chromium.org/p/v8/issues/detail?id=11536\n    'object-rest-spread': false,\n  };\n\n  // Detect Safari browser versions that have a class field behavior bug\n  // See: https://github.com/angular/angular-cli/issues/24355#issuecomment-1333477033\n  // See: https://github.com/WebKit/WebKit/commit/e8788a34b3d5f5b4edd7ff6450b80936bff396f2\n  let safariClassFieldScopeBug = false;\n  for (const browser of target) {\n    let majorVersion;\n    if (browser.startsWith('ios')) {\n      majorVersion = Number(browser.slice(3, 5));\n    } else if (browser.startsWith('safari')) {\n      majorVersion = Number(browser.slice(6, 8));\n    } else {\n      continue;\n    }\n    // Technically, 14.0 is not broken but rather does not have support. However, the behavior\n    // is identical since it would be set to false by esbuild if present as a target.\n    if (majorVersion === 14 || majorVersion === 15) {\n      safariClassFieldScopeBug = true;\n      break;\n    }\n  }\n  // If class field support cannot be used set to false; otherwise leave undefined to allow\n  // esbuild to use `target` to determine support.\n  if (safariClassFieldScopeBug) {\n    supported['class-field'] = false;\n    supported['class-static-field'] = false;\n  }\n\n  return supported;\n}\n\nconst MAX_CONCURRENT_WRITES = 64;\n\nexport async function writeResultFiles(\n  outputFiles: BuildOutputFile[],\n  assetFiles: { source: string; destination: string }[] | undefined,\n  outputPath: string,\n) {\n  const directoryExists = new Set<string>();\n\n  // Writes the output file to disk and ensures the containing directories are present\n  const writeOutputFile = async (file: BuildOutputFile) => {\n    const fullOutputPath = file.fullOutputPath;\n    // Ensure output subdirectories exist\n    const basePath = path.dirname(fullOutputPath);\n    if (basePath && !directoryExists.has(basePath)) {\n      await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n      directoryExists.add(basePath);\n    }\n    // Write file contents\n    await fs.writeFile(path.join(outputPath, fullOutputPath), file.contents);\n  };\n\n  // Write files in groups of MAX_CONCURRENT_WRITES to avoid too many open files\n  for (let fileIndex = 0; fileIndex < outputFiles.length; ) {\n    const groupMax = Math.min(fileIndex + MAX_CONCURRENT_WRITES, outputFiles.length);\n\n    const actions = [];\n    while (fileIndex < groupMax) {\n      actions.push(writeOutputFile(outputFiles[fileIndex++]));\n    }\n\n    await Promise.all(actions);\n  }\n\n  if (assetFiles?.length) {\n    const copyAssetFile = async (asset: { source: string; destination: string }) => {\n      // Ensure output subdirectories exist\n      const destPath = join('browser', asset.destination);\n      const basePath = path.dirname(destPath);\n      if (basePath && !directoryExists.has(basePath)) {\n        await fs.mkdir(path.join(outputPath, basePath), { recursive: true });\n        directoryExists.add(basePath);\n      }\n      // Copy file contents\n      await fs.copyFile(\n        asset.source,\n        path.join(outputPath, destPath),\n        fsConstants.COPYFILE_FICLONE,\n      );\n    };\n\n    for (let fileIndex = 0; fileIndex < assetFiles.length; ) {\n      const groupMax = Math.min(fileIndex + MAX_CONCURRENT_WRITES, assetFiles.length);\n\n      const actions = [];\n      while (fileIndex < groupMax) {\n        actions.push(copyAssetFile(assetFiles[fileIndex++]));\n      }\n\n      await Promise.all(actions);\n    }\n  }\n}\n\nexport function createOutputFileFromText(\n  path: string,\n  text: string,\n  type: BuildOutputFileType,\n): BuildOutputFile {\n  return {\n    path,\n    text,\n    type,\n    get hash() {\n      return createHash('sha256').update(this.text).digest('hex');\n    },\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n    get fullOutputPath(): string {\n      return getFullOutputPath(this);\n    },\n    clone(): BuildOutputFile {\n      return createOutputFileFromText(this.path, this.text, this.type);\n    },\n  };\n}\n\nexport function createOutputFileFromData(\n  path: string,\n  data: Uint8Array,\n  type: BuildOutputFileType,\n): BuildOutputFile {\n  return {\n    path,\n    type,\n    get text() {\n      return Buffer.from(data.buffer, data.byteOffset, data.byteLength).toString('utf-8');\n    },\n    get hash() {\n      return createHash('sha256').update(this.text).digest('hex');\n    },\n    get contents() {\n      return data;\n    },\n    get fullOutputPath(): string {\n      return getFullOutputPath(this);\n    },\n    clone(): BuildOutputFile {\n      return createOutputFileFromData(this.path, this.contents, this.type);\n    },\n  };\n}\n\nexport function getFullOutputPath(file: BuildOutputFile): string {\n  switch (file.type) {\n    case BuildOutputFileType.Browser:\n    case BuildOutputFileType.Media:\n      return join('browser', file.path);\n    case BuildOutputFileType.Server:\n      return join('server', file.path);\n    default:\n      return file.path;\n  }\n}\n\n/**\n * Transform browserlists result to esbuild target.\n * @see https://esbuild.github.io/api/#target\n */\nexport function transformSupportedBrowsersToTargets(supportedBrowsers: string[]): string[] {\n  const transformed: string[] = [];\n\n  // https://esbuild.github.io/api/#target\n  const esBuildSupportedBrowsers = new Set([\n    'chrome',\n    'edge',\n    'firefox',\n    'ie',\n    'ios',\n    'node',\n    'opera',\n    'safari',\n  ]);\n\n  for (const browser of supportedBrowsers) {\n    let [browserName, version] = browser.toLowerCase().split(' ');\n\n    // browserslist uses the name `ios_saf` for iOS Safari whereas esbuild uses `ios`\n    if (browserName === 'ios_saf') {\n      browserName = 'ios';\n    }\n\n    // browserslist uses ranges `15.2-15.3` versions but only the lowest is required\n    // to perform minimum supported feature checks. esbuild also expects a single version.\n    [version] = version.split('-');\n\n    if (esBuildSupportedBrowsers.has(browserName)) {\n      if (browserName === 'safari' && version === 'tp') {\n        // esbuild only supports numeric versions so `TP` is converted to a high number (999) since\n        // a Technology Preview (TP) of Safari is assumed to support all currently known features.\n        version = '999';\n      } else if (!version.includes('.')) {\n        // A lone major version is considered by esbuild to include all minor versions. However,\n        // browserslist does not and is also inconsistent in its `.0` version naming. For example,\n        // Safari 15.0 is named `safari 15` but Safari 16.0 is named `safari 16.0`.\n        version += '.0';\n      }\n\n      transformed.push(browserName + version);\n    }\n  }\n\n  return transformed;\n}\n\nconst SUPPORTED_NODE_VERSIONS = '0.0.0-ENGINES-NODE';\n\n/**\n * Transform supported Node.js versions to esbuild target.\n * @see https://esbuild.github.io/api/#target\n */\nexport function getSupportedNodeTargets(): string[] {\n  if (SUPPORTED_NODE_VERSIONS.charAt(0) === '0') {\n    // Unlike `pkg_npm`, `ts_library` which is used to run unit tests does not support substitutions.\n    return [];\n  }\n\n  return SUPPORTED_NODE_VERSIONS.split('||').map((v) => 'node' + coerce(v)?.version);\n}\n"]}
|
|
@@ -61,7 +61,7 @@ export interface BuildOptions {
|
|
|
61
61
|
codeCoverageExclude?: string[];
|
|
62
62
|
supportedBrowsers?: string[];
|
|
63
63
|
}
|
|
64
|
-
export interface WebpackDevServerOptions extends BuildOptions, Omit<DevServerSchema, 'optimization' | 'sourceMap' | 'browserTarget'> {
|
|
64
|
+
export interface WebpackDevServerOptions extends BuildOptions, Omit<DevServerSchema, 'optimization' | 'sourceMap' | 'buildTarget' | 'browserTarget'> {
|
|
65
65
|
}
|
|
66
66
|
export interface WebpackConfigOptions<T = BuildOptions> {
|
|
67
67
|
root: string;
|
|
@@ -7,4 +7,4 @@
|
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
9
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL3V0aWxzL2J1aWxkLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBhcnNlZENvbmZpZ3VyYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb21waWxlci1jbGknO1xuaW1wb3J0IHsgbG9nZ2luZyB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9jb3JlJztcbmltcG9ydCB7XG4gIEFzc2V0UGF0dGVybkNsYXNzLFxuICBCdWRnZXQsXG4gIENyb3NzT3JpZ2luLFxuICBJMThOVHJhbnNsYXRpb24sXG4gIEluZGV4VW5pb24sXG4gIElubGluZVN0eWxlTGFuZ3VhZ2UsXG4gIExvY2FsaXplLFxuICBPdXRwdXRIYXNoaW5nLFxuICBTY3JpcHRFbGVtZW50LFxuICBTb3VyY2VNYXBDbGFzcyxcbiAgU3R5bGVFbGVtZW50LFxufSBmcm9tICcuLi9idWlsZGVycy9icm93c2VyL3NjaGVtYSc7XG5pbXBvcnQgeyBTY2hlbWEgYXMgRGV2U2VydmVyU2NoZW1hIH0gZnJvbSAnLi4vYnVpbGRlcnMvZGV2LXNlcnZlci9zY2hlbWEnO1xuaW1wb3J0IHsgTm9ybWFsaXplZENhY2hlZE9wdGlvbnMgfSBmcm9tICcuL25vcm1hbGl6ZS1jYWNoZSc7XG5pbXBvcnQgeyBOb3JtYWxpemVkRmlsZVJlcGxhY2VtZW50IH0gZnJvbSAnLi9ub3JtYWxpemUtZmlsZS1yZXBsYWNlbWVudHMnO1xuaW1wb3J0IHsgTm9ybWFsaXplZE9wdGltaXphdGlvbk9wdGlvbnMgfSBmcm9tICcuL25vcm1hbGl6ZS1vcHRpbWl6YXRpb24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkT3B0aW9ucyB7XG4gIG9wdGltaXphdGlvbjogTm9ybWFsaXplZE9wdGltaXphdGlvbk9wdGlvbnM7XG4gIGVudmlyb25tZW50Pzogc3RyaW5nO1xuICBvdXRwdXRQYXRoOiBzdHJpbmc7XG4gIHJlc291cmNlc091dHB1dFBhdGg/OiBzdHJpbmc7XG4gIGFvdD86IGJvb2xlYW47XG4gIHNvdXJjZU1hcDogU291cmNlTWFwQ2xhc3M7XG4gIHZlbmRvckNodW5rPzogYm9vbGVhbjtcbiAgY29tbW9uQ2h1bms/OiBib29sZWFuO1xuICBiYXNlSHJlZj86IHN0cmluZztcbiAgZGVwbG95VXJsPzogc3RyaW5nO1xuICB2ZXJib3NlPzogYm9vbGVhbjtcbiAgcHJvZ3Jlc3M/OiBib29sZWFuO1xuICBsb2NhbGl6ZT86IExvY2FsaXplO1xuICBpMThuTWlzc2luZ1RyYW5zbGF0aW9uPzogSTE4TlRyYW5zbGF0aW9uO1xuICBleHRlcm5hbERlcGVuZGVuY2llcz86IHN0cmluZ1tdO1xuICB3YXRjaD86IGJvb2xlYW47XG4gIG91dHB1dEhhc2hpbmc/OiBPdXRwdXRIYXNoaW5nO1xuICBwb2xsPzogbnVtYmVyO1xuICBpbmRleD86IEluZGV4VW5pb247XG4gIGRlbGV0ZU91dHB1dFBhdGg/OiBib29sZWFuO1xuICBwcmVzZXJ2ZVN5bWxpbmtzPzogYm9vbGVhbjtcbiAgZXh0cmFjdExpY2Vuc2VzPzogYm9vbGVhbjtcbiAgYnVpbGRPcHRpbWl6ZXI/OiBib29sZWFuO1xuICBuYW1lZENodW5rcz86IGJvb2xlYW47XG4gIGNyb3NzT3JpZ2luPzogQ3Jvc3NPcmlnaW47XG4gIHN1YnJlc291cmNlSW50ZWdyaXR5PzogYm9vbGVhbjtcbiAgc2VydmljZVdvcmtlcj86IGJvb2xlYW47XG4gIHdlYldvcmtlclRzQ29uZmlnPzogc3RyaW5nO1xuICBzdGF0c0pzb246IGJvb2xlYW47XG4gIGhtcj86IGJvb2xlYW47XG4gIG1haW46IHN0cmluZztcbiAgcG9seWZpbGxzOiBzdHJpbmdbXTtcbiAgYnVkZ2V0czogQnVkZ2V0W107XG4gIGFzc2V0czogQXNzZXRQYXR0ZXJuQ2xhc3NbXTtcbiAgc2NyaXB0czogU2NyaXB0RWxlbWVudFtdO1xuICBzdHlsZXM6IFN0eWxlRWxlbWVudFtdO1xuICBzdHlsZVByZXByb2Nlc3Nvck9wdGlvbnM/OiB7IGluY2x1ZGVQYXRoczogc3RyaW5nW10gfTtcbiAgcGxhdGZvcm0/
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnVpbGQtb3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL3V0aWxzL2J1aWxkLW9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgdHlwZSB7IFBhcnNlZENvbmZpZ3VyYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb21waWxlci1jbGknO1xuaW1wb3J0IHsgbG9nZ2luZyB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9jb3JlJztcbmltcG9ydCB7XG4gIEFzc2V0UGF0dGVybkNsYXNzLFxuICBCdWRnZXQsXG4gIENyb3NzT3JpZ2luLFxuICBJMThOVHJhbnNsYXRpb24sXG4gIEluZGV4VW5pb24sXG4gIElubGluZVN0eWxlTGFuZ3VhZ2UsXG4gIExvY2FsaXplLFxuICBPdXRwdXRIYXNoaW5nLFxuICBTY3JpcHRFbGVtZW50LFxuICBTb3VyY2VNYXBDbGFzcyxcbiAgU3R5bGVFbGVtZW50LFxufSBmcm9tICcuLi9idWlsZGVycy9icm93c2VyL3NjaGVtYSc7XG5pbXBvcnQgeyBTY2hlbWEgYXMgRGV2U2VydmVyU2NoZW1hIH0gZnJvbSAnLi4vYnVpbGRlcnMvZGV2LXNlcnZlci9zY2hlbWEnO1xuaW1wb3J0IHsgTm9ybWFsaXplZENhY2hlZE9wdGlvbnMgfSBmcm9tICcuL25vcm1hbGl6ZS1jYWNoZSc7XG5pbXBvcnQgeyBOb3JtYWxpemVkRmlsZVJlcGxhY2VtZW50IH0gZnJvbSAnLi9ub3JtYWxpemUtZmlsZS1yZXBsYWNlbWVudHMnO1xuaW1wb3J0IHsgTm9ybWFsaXplZE9wdGltaXphdGlvbk9wdGlvbnMgfSBmcm9tICcuL25vcm1hbGl6ZS1vcHRpbWl6YXRpb24nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJ1aWxkT3B0aW9ucyB7XG4gIG9wdGltaXphdGlvbjogTm9ybWFsaXplZE9wdGltaXphdGlvbk9wdGlvbnM7XG4gIGVudmlyb25tZW50Pzogc3RyaW5nO1xuICBvdXRwdXRQYXRoOiBzdHJpbmc7XG4gIHJlc291cmNlc091dHB1dFBhdGg/OiBzdHJpbmc7XG4gIGFvdD86IGJvb2xlYW47XG4gIHNvdXJjZU1hcDogU291cmNlTWFwQ2xhc3M7XG4gIHZlbmRvckNodW5rPzogYm9vbGVhbjtcbiAgY29tbW9uQ2h1bms/OiBib29sZWFuO1xuICBiYXNlSHJlZj86IHN0cmluZztcbiAgZGVwbG95VXJsPzogc3RyaW5nO1xuICB2ZXJib3NlPzogYm9vbGVhbjtcbiAgcHJvZ3Jlc3M/OiBib29sZWFuO1xuICBsb2NhbGl6ZT86IExvY2FsaXplO1xuICBpMThuTWlzc2luZ1RyYW5zbGF0aW9uPzogSTE4TlRyYW5zbGF0aW9uO1xuICBleHRlcm5hbERlcGVuZGVuY2llcz86IHN0cmluZ1tdO1xuICB3YXRjaD86IGJvb2xlYW47XG4gIG91dHB1dEhhc2hpbmc/OiBPdXRwdXRIYXNoaW5nO1xuICBwb2xsPzogbnVtYmVyO1xuICBpbmRleD86IEluZGV4VW5pb247XG4gIGRlbGV0ZU91dHB1dFBhdGg/OiBib29sZWFuO1xuICBwcmVzZXJ2ZVN5bWxpbmtzPzogYm9vbGVhbjtcbiAgZXh0cmFjdExpY2Vuc2VzPzogYm9vbGVhbjtcbiAgYnVpbGRPcHRpbWl6ZXI/OiBib29sZWFuO1xuICBuYW1lZENodW5rcz86IGJvb2xlYW47XG4gIGNyb3NzT3JpZ2luPzogQ3Jvc3NPcmlnaW47XG4gIHN1YnJlc291cmNlSW50ZWdyaXR5PzogYm9vbGVhbjtcbiAgc2VydmljZVdvcmtlcj86IGJvb2xlYW47XG4gIHdlYldvcmtlclRzQ29uZmlnPzogc3RyaW5nO1xuICBzdGF0c0pzb246IGJvb2xlYW47XG4gIGhtcj86IGJvb2xlYW47XG4gIG1haW46IHN0cmluZztcbiAgcG9seWZpbGxzOiBzdHJpbmdbXTtcbiAgYnVkZ2V0czogQnVkZ2V0W107XG4gIGFzc2V0czogQXNzZXRQYXR0ZXJuQ2xhc3NbXTtcbiAgc2NyaXB0czogU2NyaXB0RWxlbWVudFtdO1xuICBzdHlsZXM6IFN0eWxlRWxlbWVudFtdO1xuICBzdHlsZVByZXByb2Nlc3Nvck9wdGlvbnM/OiB7IGluY2x1ZGVQYXRoczogc3RyaW5nW10gfTtcbiAgcGxhdGZvcm0/OiAnYnJvd3NlcicgfCAnc2VydmVyJztcbiAgZmlsZVJlcGxhY2VtZW50czogTm9ybWFsaXplZEZpbGVSZXBsYWNlbWVudFtdO1xuICBpbmxpbmVTdHlsZUxhbmd1YWdlPzogSW5saW5lU3R5bGVMYW5ndWFnZTtcbiAgYWxsb3dlZENvbW1vbkpzRGVwZW5kZW5jaWVzPzogc3RyaW5nW107XG4gIGNhY2hlOiBOb3JtYWxpemVkQ2FjaGVkT3B0aW9ucztcbiAgY29kZUNvdmVyYWdlPzogYm9vbGVhbjtcbiAgY29kZUNvdmVyYWdlRXhjbHVkZT86IHN0cmluZ1tdO1xuICBzdXBwb3J0ZWRCcm93c2Vycz86IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFdlYnBhY2tEZXZTZXJ2ZXJPcHRpb25zXG4gIGV4dGVuZHMgQnVpbGRPcHRpb25zLFxuICAgIE9taXQ8RGV2U2VydmVyU2NoZW1hLCAnb3B0aW1pemF0aW9uJyB8ICdzb3VyY2VNYXAnIHwgJ2J1aWxkVGFyZ2V0JyB8ICdicm93c2VyVGFyZ2V0Jz4ge31cblxuZXhwb3J0IGludGVyZmFjZSBXZWJwYWNrQ29uZmlnT3B0aW9uczxUID0gQnVpbGRPcHRpb25zPiB7XG4gIHJvb3Q6IHN0cmluZztcbiAgbG9nZ2VyOiBsb2dnaW5nLkxvZ2dlcjtcbiAgcHJvamVjdFJvb3Q6IHN0cmluZztcbiAgc291cmNlUm9vdD86IHN0cmluZztcbiAgYnVpbGRPcHRpb25zOiBUO1xuICB0c0NvbmZpZzogUGFyc2VkQ29uZmlndXJhdGlvbjtcbiAgdHNDb25maWdQYXRoOiBzdHJpbmc7XG4gIHByb2plY3ROYW1lOiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -5,9 +5,8 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import { StatsCompilation } from 'webpack';
|
|
9
8
|
import { Budget } from '../builders/browser/schema';
|
|
10
|
-
interface Threshold {
|
|
9
|
+
export interface Threshold {
|
|
11
10
|
limit: number;
|
|
12
11
|
type: ThresholdType;
|
|
13
12
|
severity: ThresholdSeverity;
|
|
@@ -25,7 +24,21 @@ export interface BudgetCalculatorResult {
|
|
|
25
24
|
message: string;
|
|
26
25
|
label?: string;
|
|
27
26
|
}
|
|
27
|
+
export interface BudgetChunk {
|
|
28
|
+
files?: string[];
|
|
29
|
+
names?: string[];
|
|
30
|
+
initial?: boolean;
|
|
31
|
+
}
|
|
32
|
+
export interface BudgetAsset {
|
|
33
|
+
name: string;
|
|
34
|
+
size: number;
|
|
35
|
+
componentStyle?: boolean;
|
|
36
|
+
}
|
|
37
|
+
export interface BudgetStats {
|
|
38
|
+
chunks?: BudgetChunk[];
|
|
39
|
+
assets?: BudgetAsset[];
|
|
40
|
+
}
|
|
28
41
|
export declare function calculateThresholds(budget: Budget): IterableIterator<Threshold>;
|
|
29
|
-
export declare function checkBudgets(budgets: Budget[],
|
|
42
|
+
export declare function checkBudgets(budgets: Budget[], stats: BudgetStats, checkComponentStyles?: boolean): IterableIterator<BudgetCalculatorResult>;
|
|
30
43
|
export declare function checkThresholds(thresholds: IterableIterator<Threshold>, size: number, label?: string): IterableIterator<BudgetCalculatorResult>;
|
|
31
44
|
export {};
|
|
@@ -79,16 +79,12 @@ exports.calculateThresholds = calculateThresholds;
|
|
|
79
79
|
* Calculates the sizes for bundles in the budget type provided.
|
|
80
80
|
*/
|
|
81
81
|
function calculateSizes(budget, stats) {
|
|
82
|
-
if (budget.type === schema_1.Type.AnyComponentStyle) {
|
|
83
|
-
// Component style size information is not available post-build, this must
|
|
84
|
-
// be checked mid-build via the `AnyComponentStyleBudgetChecker` plugin.
|
|
85
|
-
throw new Error('Can not calculate size of AnyComponentStyle. Use `AnyComponentStyleBudgetChecker` instead.');
|
|
86
|
-
}
|
|
87
82
|
const calculatorMap = {
|
|
88
83
|
all: AllCalculator,
|
|
89
84
|
allScript: AllScriptCalculator,
|
|
90
85
|
any: AnyCalculator,
|
|
91
86
|
anyScript: AnyScriptCalculator,
|
|
87
|
+
anyComponentStyle: AnyComponentStyleCalculator,
|
|
92
88
|
bundle: BundleCalculator,
|
|
93
89
|
initial: InitialCalculator,
|
|
94
90
|
};
|
|
@@ -215,6 +211,19 @@ class AnyCalculator extends Calculator {
|
|
|
215
211
|
}));
|
|
216
212
|
}
|
|
217
213
|
}
|
|
214
|
+
/**
|
|
215
|
+
* Any compoonent stylesheet
|
|
216
|
+
*/
|
|
217
|
+
class AnyComponentStyleCalculator extends Calculator {
|
|
218
|
+
calculate() {
|
|
219
|
+
return this.assets
|
|
220
|
+
.filter((asset) => asset.componentStyle)
|
|
221
|
+
.map((asset) => ({
|
|
222
|
+
size: this.getAssetSize(asset),
|
|
223
|
+
label: asset.name,
|
|
224
|
+
}));
|
|
225
|
+
}
|
|
226
|
+
}
|
|
218
227
|
/**
|
|
219
228
|
* Calculate the bytes given a string value.
|
|
220
229
|
*/
|
|
@@ -244,11 +253,13 @@ function calculateBytes(input, baseline, factor = 1) {
|
|
|
244
253
|
}
|
|
245
254
|
return baselineBytes + value * factor;
|
|
246
255
|
}
|
|
247
|
-
function* checkBudgets(budgets,
|
|
248
|
-
// Ignore AnyComponentStyle budgets as these are handled in `AnyComponentStyleBudgetChecker
|
|
249
|
-
const computableBudgets =
|
|
256
|
+
function* checkBudgets(budgets, stats, checkComponentStyles) {
|
|
257
|
+
// Ignore AnyComponentStyle budgets as these are handled in `AnyComponentStyleBudgetChecker` unless requested
|
|
258
|
+
const computableBudgets = checkComponentStyles
|
|
259
|
+
? budgets
|
|
260
|
+
: budgets.filter((budget) => budget.type !== schema_1.Type.AnyComponentStyle);
|
|
250
261
|
for (const budget of computableBudgets) {
|
|
251
|
-
const sizes = calculateSizes(budget,
|
|
262
|
+
const sizes = calculateSizes(budget, stats);
|
|
252
263
|
for (const { size, label } of sizes) {
|
|
253
264
|
yield* checkThresholds(calculateThresholds(budget), size, label);
|
|
254
265
|
}
|
|
@@ -289,4 +300,4 @@ function* checkThresholds(thresholds, size, label) {
|
|
|
289
300
|
}
|
|
290
301
|
}
|
|
291
302
|
exports.checkThresholds = checkThresholds;
|
|
292
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle-calculator.js","sourceRoot":"","sources":["../../../../../../../../packages/angular_devkit/build_angular/src/utils/bundle-calculator.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 { StatsAsset, StatsChunk, StatsCompilation } from 'webpack';\nimport { Budget, Type } from '../builders/browser/schema';\nimport { formatSize } from '../tools/webpack/utils/stats';\n\ninterface Size {\n  size: number;\n  label?: string;\n}\n\ninterface Threshold {\n  limit: number;\n  type: ThresholdType;\n  severity: ThresholdSeverity;\n}\n\nenum ThresholdType {\n  Max = 'maximum',\n  Min = 'minimum',\n}\n\nexport enum ThresholdSeverity {\n  Warning = 'warning',\n  Error = 'error',\n}\n\nexport interface BudgetCalculatorResult {\n  severity: ThresholdSeverity;\n  message: string;\n  label?: string;\n}\n\nexport function* calculateThresholds(budget: Budget): IterableIterator<Threshold> {\n  if (budget.maximumWarning) {\n    yield {\n      limit: calculateBytes(budget.maximumWarning, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Warning,\n    };\n  }\n\n  if (budget.maximumError) {\n    yield {\n      limit: calculateBytes(budget.maximumError, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Error,\n    };\n  }\n\n  if (budget.minimumWarning) {\n    yield {\n      limit: calculateBytes(budget.minimumWarning, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Warning,\n    };\n  }\n\n  if (budget.minimumError) {\n    yield {\n      limit: calculateBytes(budget.minimumError, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Error,\n    };\n  }\n\n  if (budget.warning) {\n    yield {\n      limit: calculateBytes(budget.warning, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Warning,\n    };\n\n    yield {\n      limit: calculateBytes(budget.warning, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Warning,\n    };\n  }\n\n  if (budget.error) {\n    yield {\n      limit: calculateBytes(budget.error, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Error,\n    };\n\n    yield {\n      limit: calculateBytes(budget.error, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Error,\n    };\n  }\n}\n\n/**\n * Calculates the sizes for bundles in the budget type provided.\n */\nfunction calculateSizes(budget: Budget, stats: StatsCompilation): Size[] {\n  if (budget.type === Type.AnyComponentStyle) {\n    // Component style size information is not available post-build, this must\n    // be checked mid-build via the `AnyComponentStyleBudgetChecker` plugin.\n    throw new Error(\n      'Can not calculate size of AnyComponentStyle. Use `AnyComponentStyleBudgetChecker` instead.',\n    );\n  }\n\n  type NonComponentStyleBudgetTypes = Exclude<Budget['type'], Type.AnyComponentStyle>;\n  type CalculatorTypes = {\n    new (budget: Budget, chunks: StatsChunk[], assets: StatsAsset[]): Calculator;\n  };\n  const calculatorMap: Record<NonComponentStyleBudgetTypes, CalculatorTypes> = {\n    all: AllCalculator,\n    allScript: AllScriptCalculator,\n    any: AnyCalculator,\n    anyScript: AnyScriptCalculator,\n    bundle: BundleCalculator,\n    initial: InitialCalculator,\n  };\n\n  const ctor = calculatorMap[budget.type];\n  const { chunks, assets } = stats;\n  if (!chunks) {\n    throw new Error('Webpack stats output did not include chunk information.');\n  }\n  if (!assets) {\n    throw new Error('Webpack stats output did not include asset information.');\n  }\n\n  const calculator = new ctor(budget, chunks, assets);\n\n  return calculator.calculate();\n}\n\nabstract class Calculator {\n  constructor(\n    protected budget: Budget,\n    protected chunks: StatsChunk[],\n    protected assets: StatsAsset[],\n  ) {}\n\n  abstract calculate(): Size[];\n\n  /** Calculates the size of the given chunk for the provided build type. */\n  protected calculateChunkSize(chunk: StatsChunk): number {\n    // No differential builds, get the chunk size by summing its assets.\n    if (!chunk.files) {\n      return 0;\n    }\n\n    return chunk.files\n      .filter((file) => !file.endsWith('.map'))\n      .map((file) => {\n        const asset = this.assets.find((asset) => asset.name === file);\n        if (!asset) {\n          throw new Error(`Could not find asset for file: ${file}`);\n        }\n\n        return asset.size;\n      })\n      .reduce((l, r) => l + r, 0);\n  }\n\n  protected getAssetSize(asset: StatsAsset): number {\n    return asset.size;\n  }\n}\n\n/**\n * A named bundle.\n */\nclass BundleCalculator extends Calculator {\n  calculate() {\n    const budgetName = this.budget.name;\n    if (!budgetName) {\n      return [];\n    }\n\n    const size = this.chunks\n      .filter((chunk) => chunk?.names?.includes(budgetName))\n      .map((chunk) => this.calculateChunkSize(chunk))\n      .reduce((l, r) => l + r, 0);\n\n    return [{ size, label: this.budget.name }];\n  }\n}\n\n/**\n * The sum of all initial chunks (marked as initial).\n */\nclass InitialCalculator extends Calculator {\n  calculate() {\n    return [\n      {\n        label: `bundle initial`,\n        size: this.chunks\n          .filter((chunk) => chunk.initial)\n          .map((chunk) => this.calculateChunkSize(chunk))\n          .reduce((l, r) => l + r, 0),\n      },\n    ];\n  }\n}\n\n/**\n * The sum of all the scripts portions.\n */\nclass AllScriptCalculator extends Calculator {\n  calculate() {\n    const size = this.assets\n      .filter((asset) => asset.name.endsWith('.js'))\n      .map((asset) => this.getAssetSize(asset))\n      .reduce((total: number, size: number) => total + size, 0);\n\n    return [{ size, label: 'total scripts' }];\n  }\n}\n\n/**\n * All scripts and assets added together.\n */\nclass AllCalculator extends Calculator {\n  calculate() {\n    const size = this.assets\n      .filter((asset) => !asset.name.endsWith('.map'))\n      .map((asset) => this.getAssetSize(asset))\n      .reduce((total: number, size: number) => total + size, 0);\n\n    return [{ size, label: 'total' }];\n  }\n}\n\n/**\n * Any script, individually.\n */\nclass AnyScriptCalculator extends Calculator {\n  calculate() {\n    return this.assets\n      .filter((asset) => asset.name.endsWith('.js'))\n      .map((asset) => ({\n        size: this.getAssetSize(asset),\n        label: asset.name,\n      }));\n  }\n}\n\n/**\n * Any script or asset (images, css, etc).\n */\nclass AnyCalculator extends Calculator {\n  calculate() {\n    return this.assets\n      .filter((asset) => !asset.name.endsWith('.map'))\n      .map((asset) => ({\n        size: this.getAssetSize(asset),\n        label: asset.name,\n      }));\n  }\n}\n\n/**\n * Calculate the bytes given a string value.\n */\nfunction calculateBytes(input: string, baseline?: string, factor: 1 | -1 = 1): number {\n  const matches = input.match(/^\\s*(\\d+(?:\\.\\d+)?)\\s*(%|(?:[mM]|[kK]|[gG])?[bB])?\\s*$/);\n  if (!matches) {\n    return NaN;\n  }\n\n  const baselineBytes = (baseline && calculateBytes(baseline)) || 0;\n\n  let value = Number(matches[1]);\n  switch (matches[2] && matches[2].toLowerCase()) {\n    case '%':\n      value = (baselineBytes * value) / 100;\n      break;\n    case 'kb':\n      value *= 1024;\n      break;\n    case 'mb':\n      value *= 1024 * 1024;\n      break;\n    case 'gb':\n      value *= 1024 * 1024 * 1024;\n      break;\n  }\n\n  if (baselineBytes === 0) {\n    return value;\n  }\n\n  return baselineBytes + value * factor;\n}\n\nexport function* checkBudgets(\n  budgets: Budget[],\n  webpackStats: StatsCompilation,\n): IterableIterator<BudgetCalculatorResult> {\n  // Ignore AnyComponentStyle budgets as these are handled in `AnyComponentStyleBudgetChecker`.\n  const computableBudgets = budgets.filter((budget) => budget.type !== Type.AnyComponentStyle);\n\n  for (const budget of computableBudgets) {\n    const sizes = calculateSizes(budget, webpackStats);\n    for (const { size, label } of sizes) {\n      yield* checkThresholds(calculateThresholds(budget), size, label);\n    }\n  }\n}\n\nexport function* checkThresholds(\n  thresholds: IterableIterator<Threshold>,\n  size: number,\n  label?: string,\n): IterableIterator<BudgetCalculatorResult> {\n  for (const threshold of thresholds) {\n    switch (threshold.type) {\n      case ThresholdType.Max: {\n        if (size <= threshold.limit) {\n          continue;\n        }\n\n        const sizeDifference = formatSize(size - threshold.limit);\n        yield {\n          severity: threshold.severity,\n          label,\n          message: `${label} exceeded maximum budget. Budget ${formatSize(\n            threshold.limit,\n          )} was not met by ${sizeDifference} with a total of ${formatSize(size)}.`,\n        };\n        break;\n      }\n      case ThresholdType.Min: {\n        if (size >= threshold.limit) {\n          continue;\n        }\n\n        const sizeDifference = formatSize(threshold.limit - size);\n        yield {\n          severity: threshold.severity,\n          label,\n          message: `${label} failed to meet minimum budget. Budget ${formatSize(\n            threshold.limit,\n          )} was not met by ${sizeDifference} with a total of ${formatSize(size)}.`,\n        };\n        break;\n      }\n      default: {\n        throw new Error(`Unexpected threshold type: ${ThresholdType[threshold.type]}`);\n      }\n    }\n  }\n}\n"]}
|
|
303
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle-calculator.js","sourceRoot":"","sources":["../../../../../../../../packages/angular_devkit/build_angular/src/utils/bundle-calculator.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,uDAA0D;AAC1D,wDAA0D;AAa1D,IAAK,aAGJ;AAHD,WAAK,aAAa;IAChB,gCAAe,CAAA;IACf,gCAAe,CAAA;AACjB,CAAC,EAHI,aAAa,KAAb,aAAa,QAGjB;AAED,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IAC3B,wCAAmB,CAAA;IACnB,oCAAe,CAAA;AACjB,CAAC,EAHW,iBAAiB,iCAAjB,iBAAiB,QAG5B;AAyBD,QAAe,CAAC,CAAC,mBAAmB,CAAC,MAAc;IACjD,IAAI,MAAM,CAAC,cAAc,EAAE;QACzB,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;YAChE,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,OAAO;SACpC,CAAC;KACH;IAED,IAAI,MAAM,CAAC,YAAY,EAAE;QACvB,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC9D,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,KAAK;SAClC,CAAC;KACH;IAED,IAAI,MAAM,CAAC,cAAc,EAAE;QACzB,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,cAAc,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YACjE,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,OAAO;SACpC,CAAC;KACH;IAED,IAAI,MAAM,CAAC,YAAY,EAAE;QACvB,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAC/D,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,KAAK;SAClC,CAAC;KACH;IAED,IAAI,MAAM,CAAC,OAAO,EAAE;QAClB,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YAC1D,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,OAAO;SACpC,CAAC;QAEF,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;YACzD,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,OAAO;SACpC,CAAC;KACH;IAED,IAAI,MAAM,CAAC,KAAK,EAAE;QAChB,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;YACxD,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,KAAK;SAClC,CAAC;QAEF,MAAM;YACJ,KAAK,EAAE,cAAc,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;YACvD,IAAI,EAAE,aAAa,CAAC,GAAG;YACvB,QAAQ,EAAE,iBAAiB,CAAC,KAAK;SAClC,CAAC;KACH;AACH,CAAC;AA5DD,kDA4DC;AAED;;GAEG;AACH,SAAS,cAAc,CAAC,MAAc,EAAE,KAAkB;IAIxD,MAAM,aAAa,GAA4C;QAC7D,GAAG,EAAE,aAAa;QAClB,SAAS,EAAE,mBAAmB;QAC9B,GAAG,EAAE,aAAa;QAClB,SAAS,EAAE,mBAAmB;QAC9B,iBAAiB,EAAE,2BAA2B;QAC9C,MAAM,EAAE,gBAAgB;QACxB,OAAO,EAAE,iBAAiB;KAC3B,CAAC;IAEF,MAAM,IAAI,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;IACjC,IAAI,CAAC,MAAM,EAAE;QACX,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;KAC5E;IACD,IAAI,CAAC,MAAM,EAAE;QACX,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;KAC5E;IAED,MAAM,UAAU,GAAG,IAAI,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IAEpD,OAAO,UAAU,CAAC,SAAS,EAAE,CAAC;AAChC,CAAC;AAED,MAAe,UAAU;IAEX;IACA;IACA;IAHZ,YACY,MAAc,EACd,MAAqB,EACrB,MAAqB;QAFrB,WAAM,GAAN,MAAM,CAAQ;QACd,WAAM,GAAN,MAAM,CAAe;QACrB,WAAM,GAAN,MAAM,CAAe;IAC9B,CAAC;IAIJ,0EAA0E;IAChE,kBAAkB,CAAC,KAAkB;QAC7C,oEAAoE;QACpE,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;YAChB,OAAO,CAAC,CAAC;SACV;QAED,OAAO,KAAK,CAAC,KAAK;aACf,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;aACxC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC;YAC/D,IAAI,CAAC,KAAK,EAAE;gBACV,MAAM,IAAI,KAAK,CAAC,kCAAkC,IAAI,EAAE,CAAC,CAAC;aAC3D;YAED,OAAO,KAAK,CAAC,IAAI,CAAC;QACpB,CAAC,CAAC;aACD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;IAChC,CAAC;IAES,YAAY,CAAC,KAAkB;QACvC,OAAO,KAAK,CAAC,IAAI,CAAC;IACpB,CAAC;CACF;AAED;;GAEG;AACH,MAAM,gBAAiB,SAAQ,UAAU;IACvC,SAAS;QACP,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,UAAU,EAAE;YACf,OAAO,EAAE,CAAC;SACX;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM;aACrB,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAC,UAAU,CAAC,CAAC;aACrD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;aAC9C,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAE9B,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;CACF;AAED;;GAEG;AACH,MAAM,iBAAkB,SAAQ,UAAU;IACxC,SAAS;QACP,OAAO;YACL;gBACE,KAAK,EAAE,gBAAgB;gBACvB,IAAI,EAAE,IAAI,CAAC,MAAM;qBACd,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC;qBAChC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;qBAC9C,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aAC9B;SACF,CAAC;IACJ,CAAC;CACF;AAED;;GAEG;AACH,MAAM,mBAAoB,SAAQ,UAAU;IAC1C,SAAS;QACP,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM;aACrB,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAC7C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aACxC,MAAM,CAAC,CAAC,KAAa,EAAE,IAAY,EAAE,EAAE,CAAC,KAAK,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;QAE5D,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,CAAC,CAAC;IAC5C,CAAC;CACF;AAED;;GAEG;AACH,MAAM,aAAc,SAAQ,UAAU;IACpC,SAAS;QACP,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM;aACrB,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;aAC/C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;aACxC,MAAM,CAAC,CAAC,KAAa,EAAE,IAAY,EAAE,EAAE,CAAC,KAAK,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;QAE5D,OAAO,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;IACpC,CAAC;CACF;AAED;;GAEG;AACH,MAAM,mBAAoB,SAAQ,UAAU;IAC1C,SAAS;QACP,OAAO,IAAI,CAAC,MAAM;aACf,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAC7C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACf,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YAC9B,KAAK,EAAE,KAAK,CAAC,IAAI;SAClB,CAAC,CAAC,CAAC;IACR,CAAC;CACF;AAED;;GAEG;AACH,MAAM,aAAc,SAAQ,UAAU;IACpC,SAAS;QACP,OAAO,IAAI,CAAC,MAAM;aACf,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;aAC/C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACf,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YAC9B,KAAK,EAAE,KAAK,CAAC,IAAI;SAClB,CAAC,CAAC,CAAC;IACR,CAAC;CACF;AAED;;GAEG;AACH,MAAM,2BAA4B,SAAQ,UAAU;IAClD,SAAS;QACP,OAAO,IAAI,CAAC,MAAM;aACf,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC;aACvC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YACf,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YAC9B,KAAK,EAAE,KAAK,CAAC,IAAI;SAClB,CAAC,CAAC,CAAC;IACR,CAAC;CACF;AAED;;GAEG;AACH,SAAS,cAAc,CAAC,KAAa,EAAE,QAAiB,EAAE,SAAiB,CAAC;IAC1E,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,wDAAwD,CAAC,CAAC;IACtF,IAAI,CAAC,OAAO,EAAE;QACZ,OAAO,GAAG,CAAC;KACZ;IAED,MAAM,aAAa,GAAG,CAAC,QAAQ,IAAI,cAAc,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC;IAElE,IAAI,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/B,QAAQ,OAAO,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,EAAE;QAC9C,KAAK,GAAG;YACN,KAAK,GAAG,CAAC,aAAa,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC;YACtC,MAAM;QACR,KAAK,IAAI;YACP,KAAK,IAAI,IAAI,CAAC;YACd,MAAM;QACR,KAAK,IAAI;YACP,KAAK,IAAI,IAAI,GAAG,IAAI,CAAC;YACrB,MAAM;QACR,KAAK,IAAI;YACP,KAAK,IAAI,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;YAC5B,MAAM;KACT;IAED,IAAI,aAAa,KAAK,CAAC,EAAE;QACvB,OAAO,KAAK,CAAC;KACd;IAED,OAAO,aAAa,GAAG,KAAK,GAAG,MAAM,CAAC;AACxC,CAAC;AAED,QAAe,CAAC,CAAC,YAAY,CAC3B,OAAiB,EACjB,KAAkB,EAClB,oBAA8B;IAE9B,6GAA6G;IAC7G,MAAM,iBAAiB,GAAG,oBAAoB;QAC5C,CAAC,CAAC,OAAO;QACT,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,aAAI,CAAC,iBAAiB,CAAC,CAAC;IAEvE,KAAK,MAAM,MAAM,IAAI,iBAAiB,EAAE;QACtC,MAAM,KAAK,GAAG,cAAc,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC5C,KAAK,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,KAAK,EAAE;YACnC,KAAK,CAAC,CAAC,eAAe,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;SAClE;KACF;AACH,CAAC;AAhBD,oCAgBC;AAED,QAAe,CAAC,CAAC,eAAe,CAC9B,UAAuC,EACvC,IAAY,EACZ,KAAc;IAEd,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE;QAClC,QAAQ,SAAS,CAAC,IAAI,EAAE;YACtB,KAAK,aAAa,CAAC,GAAG,CAAC,CAAC;gBACtB,IAAI,IAAI,IAAI,SAAS,CAAC,KAAK,EAAE;oBAC3B,SAAS;iBACV;gBAED,MAAM,cAAc,GAAG,IAAA,kBAAU,EAAC,IAAI,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC;gBAC1D,MAAM;oBACJ,QAAQ,EAAE,SAAS,CAAC,QAAQ;oBAC5B,KAAK;oBACL,OAAO,EAAE,GAAG,KAAK,oCAAoC,IAAA,kBAAU,EAC7D,SAAS,CAAC,KAAK,CAChB,mBAAmB,cAAc,oBAAoB,IAAA,kBAAU,EAAC,IAAI,CAAC,GAAG;iBAC1E,CAAC;gBACF,MAAM;aACP;YACD,KAAK,aAAa,CAAC,GAAG,CAAC,CAAC;gBACtB,IAAI,IAAI,IAAI,SAAS,CAAC,KAAK,EAAE;oBAC3B,SAAS;iBACV;gBAED,MAAM,cAAc,GAAG,IAAA,kBAAU,EAAC,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC;gBAC1D,MAAM;oBACJ,QAAQ,EAAE,SAAS,CAAC,QAAQ;oBAC5B,KAAK;oBACL,OAAO,EAAE,GAAG,KAAK,0CAA0C,IAAA,kBAAU,EACnE,SAAS,CAAC,KAAK,CAChB,mBAAmB,cAAc,oBAAoB,IAAA,kBAAU,EAAC,IAAI,CAAC,GAAG;iBAC1E,CAAC;gBACF,MAAM;aACP;YACD,OAAO,CAAC,CAAC;gBACP,MAAM,IAAI,KAAK,CAAC,8BAA8B,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;aAChF;SACF;KACF;AACH,CAAC;AA1CD,0CA0CC","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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 { Budget, Type } from '../builders/browser/schema';\nimport { formatSize } from '../tools/webpack/utils/stats';\n\ninterface Size {\n  size: number;\n  label?: string;\n}\n\nexport interface Threshold {\n  limit: number;\n  type: ThresholdType;\n  severity: ThresholdSeverity;\n}\n\nenum ThresholdType {\n  Max = 'maximum',\n  Min = 'minimum',\n}\n\nexport enum ThresholdSeverity {\n  Warning = 'warning',\n  Error = 'error',\n}\n\nexport interface BudgetCalculatorResult {\n  severity: ThresholdSeverity;\n  message: string;\n  label?: string;\n}\n\nexport interface BudgetChunk {\n  files?: string[];\n  names?: string[];\n  initial?: boolean;\n}\n\nexport interface BudgetAsset {\n  name: string;\n  size: number;\n  componentStyle?: boolean;\n}\n\nexport interface BudgetStats {\n  chunks?: BudgetChunk[];\n  assets?: BudgetAsset[];\n}\n\nexport function* calculateThresholds(budget: Budget): IterableIterator<Threshold> {\n  if (budget.maximumWarning) {\n    yield {\n      limit: calculateBytes(budget.maximumWarning, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Warning,\n    };\n  }\n\n  if (budget.maximumError) {\n    yield {\n      limit: calculateBytes(budget.maximumError, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Error,\n    };\n  }\n\n  if (budget.minimumWarning) {\n    yield {\n      limit: calculateBytes(budget.minimumWarning, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Warning,\n    };\n  }\n\n  if (budget.minimumError) {\n    yield {\n      limit: calculateBytes(budget.minimumError, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Error,\n    };\n  }\n\n  if (budget.warning) {\n    yield {\n      limit: calculateBytes(budget.warning, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Warning,\n    };\n\n    yield {\n      limit: calculateBytes(budget.warning, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Warning,\n    };\n  }\n\n  if (budget.error) {\n    yield {\n      limit: calculateBytes(budget.error, budget.baseline, -1),\n      type: ThresholdType.Min,\n      severity: ThresholdSeverity.Error,\n    };\n\n    yield {\n      limit: calculateBytes(budget.error, budget.baseline, 1),\n      type: ThresholdType.Max,\n      severity: ThresholdSeverity.Error,\n    };\n  }\n}\n\n/**\n * Calculates the sizes for bundles in the budget type provided.\n */\nfunction calculateSizes(budget: Budget, stats: BudgetStats): Size[] {\n  type CalculatorTypes = {\n    new (budget: Budget, chunks: BudgetChunk[], assets: BudgetAsset[]): Calculator;\n  };\n  const calculatorMap: Record<Budget['type'], CalculatorTypes> = {\n    all: AllCalculator,\n    allScript: AllScriptCalculator,\n    any: AnyCalculator,\n    anyScript: AnyScriptCalculator,\n    anyComponentStyle: AnyComponentStyleCalculator,\n    bundle: BundleCalculator,\n    initial: InitialCalculator,\n  };\n\n  const ctor = calculatorMap[budget.type];\n  const { chunks, assets } = stats;\n  if (!chunks) {\n    throw new Error('Webpack stats output did not include chunk information.');\n  }\n  if (!assets) {\n    throw new Error('Webpack stats output did not include asset information.');\n  }\n\n  const calculator = new ctor(budget, chunks, assets);\n\n  return calculator.calculate();\n}\n\nabstract class Calculator {\n  constructor(\n    protected budget: Budget,\n    protected chunks: BudgetChunk[],\n    protected assets: BudgetAsset[],\n  ) {}\n\n  abstract calculate(): Size[];\n\n  /** Calculates the size of the given chunk for the provided build type. */\n  protected calculateChunkSize(chunk: BudgetChunk): number {\n    // No differential builds, get the chunk size by summing its assets.\n    if (!chunk.files) {\n      return 0;\n    }\n\n    return chunk.files\n      .filter((file) => !file.endsWith('.map'))\n      .map((file) => {\n        const asset = this.assets.find((asset) => asset.name === file);\n        if (!asset) {\n          throw new Error(`Could not find asset for file: ${file}`);\n        }\n\n        return asset.size;\n      })\n      .reduce((l, r) => l + r, 0);\n  }\n\n  protected getAssetSize(asset: BudgetAsset): number {\n    return asset.size;\n  }\n}\n\n/**\n * A named bundle.\n */\nclass BundleCalculator extends Calculator {\n  calculate() {\n    const budgetName = this.budget.name;\n    if (!budgetName) {\n      return [];\n    }\n\n    const size = this.chunks\n      .filter((chunk) => chunk?.names?.includes(budgetName))\n      .map((chunk) => this.calculateChunkSize(chunk))\n      .reduce((l, r) => l + r, 0);\n\n    return [{ size, label: this.budget.name }];\n  }\n}\n\n/**\n * The sum of all initial chunks (marked as initial).\n */\nclass InitialCalculator extends Calculator {\n  calculate() {\n    return [\n      {\n        label: `bundle initial`,\n        size: this.chunks\n          .filter((chunk) => chunk.initial)\n          .map((chunk) => this.calculateChunkSize(chunk))\n          .reduce((l, r) => l + r, 0),\n      },\n    ];\n  }\n}\n\n/**\n * The sum of all the scripts portions.\n */\nclass AllScriptCalculator extends Calculator {\n  calculate() {\n    const size = this.assets\n      .filter((asset) => asset.name.endsWith('.js'))\n      .map((asset) => this.getAssetSize(asset))\n      .reduce((total: number, size: number) => total + size, 0);\n\n    return [{ size, label: 'total scripts' }];\n  }\n}\n\n/**\n * All scripts and assets added together.\n */\nclass AllCalculator extends Calculator {\n  calculate() {\n    const size = this.assets\n      .filter((asset) => !asset.name.endsWith('.map'))\n      .map((asset) => this.getAssetSize(asset))\n      .reduce((total: number, size: number) => total + size, 0);\n\n    return [{ size, label: 'total' }];\n  }\n}\n\n/**\n * Any script, individually.\n */\nclass AnyScriptCalculator extends Calculator {\n  calculate() {\n    return this.assets\n      .filter((asset) => asset.name.endsWith('.js'))\n      .map((asset) => ({\n        size: this.getAssetSize(asset),\n        label: asset.name,\n      }));\n  }\n}\n\n/**\n * Any script or asset (images, css, etc).\n */\nclass AnyCalculator extends Calculator {\n  calculate() {\n    return this.assets\n      .filter((asset) => !asset.name.endsWith('.map'))\n      .map((asset) => ({\n        size: this.getAssetSize(asset),\n        label: asset.name,\n      }));\n  }\n}\n\n/**\n * Any compoonent stylesheet\n */\nclass AnyComponentStyleCalculator extends Calculator {\n  calculate() {\n    return this.assets\n      .filter((asset) => asset.componentStyle)\n      .map((asset) => ({\n        size: this.getAssetSize(asset),\n        label: asset.name,\n      }));\n  }\n}\n\n/**\n * Calculate the bytes given a string value.\n */\nfunction calculateBytes(input: string, baseline?: string, factor: 1 | -1 = 1): number {\n  const matches = input.match(/^\\s*(\\d+(?:\\.\\d+)?)\\s*(%|(?:[mM]|[kK]|[gG])?[bB])?\\s*$/);\n  if (!matches) {\n    return NaN;\n  }\n\n  const baselineBytes = (baseline && calculateBytes(baseline)) || 0;\n\n  let value = Number(matches[1]);\n  switch (matches[2] && matches[2].toLowerCase()) {\n    case '%':\n      value = (baselineBytes * value) / 100;\n      break;\n    case 'kb':\n      value *= 1024;\n      break;\n    case 'mb':\n      value *= 1024 * 1024;\n      break;\n    case 'gb':\n      value *= 1024 * 1024 * 1024;\n      break;\n  }\n\n  if (baselineBytes === 0) {\n    return value;\n  }\n\n  return baselineBytes + value * factor;\n}\n\nexport function* checkBudgets(\n  budgets: Budget[],\n  stats: BudgetStats,\n  checkComponentStyles?: boolean,\n): IterableIterator<BudgetCalculatorResult> {\n  // Ignore AnyComponentStyle budgets as these are handled in `AnyComponentStyleBudgetChecker` unless requested\n  const computableBudgets = checkComponentStyles\n    ? budgets\n    : budgets.filter((budget) => budget.type !== Type.AnyComponentStyle);\n\n  for (const budget of computableBudgets) {\n    const sizes = calculateSizes(budget, stats);\n    for (const { size, label } of sizes) {\n      yield* checkThresholds(calculateThresholds(budget), size, label);\n    }\n  }\n}\n\nexport function* checkThresholds(\n  thresholds: IterableIterator<Threshold>,\n  size: number,\n  label?: string,\n): IterableIterator<BudgetCalculatorResult> {\n  for (const threshold of thresholds) {\n    switch (threshold.type) {\n      case ThresholdType.Max: {\n        if (size <= threshold.limit) {\n          continue;\n        }\n\n        const sizeDifference = formatSize(size - threshold.limit);\n        yield {\n          severity: threshold.severity,\n          label,\n          message: `${label} exceeded maximum budget. Budget ${formatSize(\n            threshold.limit,\n          )} was not met by ${sizeDifference} with a total of ${formatSize(size)}.`,\n        };\n        break;\n      }\n      case ThresholdType.Min: {\n        if (size >= threshold.limit) {\n          continue;\n        }\n\n        const sizeDifference = formatSize(threshold.limit - size);\n        yield {\n          severity: threshold.severity,\n          label,\n          message: `${label} failed to meet minimum budget. Budget ${formatSize(\n            threshold.limit,\n          )} was not met by ${sizeDifference} with a total of ${formatSize(size)}.`,\n        };\n        break;\n      }\n      default: {\n        throw new Error(`Unexpected threshold type: ${ThresholdType[threshold.type]}`);\n      }\n    }\n  }\n}\n"]}
|
|
@@ -13,6 +13,7 @@ export interface ESMInMemoryFileLoaderWorkerData {
|
|
|
13
13
|
outputFiles: Record<string, string>;
|
|
14
14
|
workspaceRoot: string;
|
|
15
15
|
}
|
|
16
|
+
export declare function initialize(data: ESMInMemoryFileLoaderWorkerData): void;
|
|
16
17
|
export declare function resolve(specifier: string, context: {
|
|
17
18
|
parentURL: undefined | string;
|
|
18
19
|
}, nextResolve: Function): any;
|