@angular-devkit/build-angular 15.1.2 → 15.2.0-next.1

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.
@@ -6,8 +6,20 @@
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 __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
10
+ if (kind === "m") throw new TypeError("Private method is not writable");
11
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
12
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
13
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
14
+ };
15
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
16
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
17
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
18
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
19
+ };
20
+ var _BundlerContext_esbuildContext, _BundlerContext_esbuildOptions;
9
21
  Object.defineProperty(exports, "__esModule", { value: true });
10
- exports.logMessages = exports.bundle = exports.isEsBuildFailure = void 0;
22
+ exports.logMessages = exports.BundlerContext = exports.isEsBuildFailure = void 0;
11
23
  const esbuild_1 = require("esbuild");
12
24
  const node_path_1 = require("node:path");
13
25
  /**
@@ -19,69 +31,108 @@ function isEsBuildFailure(value) {
19
31
  return !!value && typeof value === 'object' && 'errors' in value && 'warnings' in value;
20
32
  }
21
33
  exports.isEsBuildFailure = isEsBuildFailure;
22
- /**
23
- * Executes the esbuild build function and normalizes the build result in the event of a
24
- * build failure that results in no output being generated.
25
- * All builds use the `write` option with a value of `false` to allow for the output files
26
- * build result array to be populated.
27
- *
28
- * @param optionsOrInvalidate The esbuild options object to use when building or the invalidate object
29
- * returned from an incremental build to perform an additional incremental build.
30
- * @returns If output files are generated, the full esbuild BuildResult; if not, the
31
- * warnings and errors for the attempted build.
32
- */
33
- async function bundle(workspaceRoot, optionsOrInvalidate) {
34
- var _a, _b;
35
- let result;
36
- try {
37
- if (typeof optionsOrInvalidate === 'function') {
38
- result = (await optionsOrInvalidate());
34
+ class BundlerContext {
35
+ constructor(workspaceRoot, incremental, options) {
36
+ this.workspaceRoot = workspaceRoot;
37
+ this.incremental = incremental;
38
+ _BundlerContext_esbuildContext.set(this, void 0);
39
+ _BundlerContext_esbuildOptions.set(this, void 0);
40
+ __classPrivateFieldSet(this, _BundlerContext_esbuildOptions, {
41
+ ...options,
42
+ metafile: true,
43
+ write: false,
44
+ }, "f");
45
+ }
46
+ /**
47
+ * Executes the esbuild build function and normalizes the build result in the event of a
48
+ * build failure that results in no output being generated.
49
+ * All builds use the `write` option with a value of `false` to allow for the output files
50
+ * build result array to be populated.
51
+ *
52
+ * @returns If output files are generated, the full esbuild BuildResult; if not, the
53
+ * warnings and errors for the attempted build.
54
+ */
55
+ async bundle() {
56
+ var _a, _b;
57
+ let result;
58
+ try {
59
+ if (__classPrivateFieldGet(this, _BundlerContext_esbuildContext, "f")) {
60
+ // Rebuild using the existing incremental build context
61
+ result = await __classPrivateFieldGet(this, _BundlerContext_esbuildContext, "f").rebuild();
62
+ }
63
+ else if (this.incremental) {
64
+ // Create an incremental build context and perform the first build.
65
+ // Context creation does not perform a build.
66
+ __classPrivateFieldSet(this, _BundlerContext_esbuildContext, await (0, esbuild_1.context)(__classPrivateFieldGet(this, _BundlerContext_esbuildOptions, "f")), "f");
67
+ result = await __classPrivateFieldGet(this, _BundlerContext_esbuildContext, "f").rebuild();
68
+ }
69
+ else {
70
+ // For non-incremental builds, perform a single build
71
+ result = await (0, esbuild_1.build)(__classPrivateFieldGet(this, _BundlerContext_esbuildOptions, "f"));
72
+ }
39
73
  }
40
- else {
41
- result = await (0, esbuild_1.build)({
42
- ...optionsOrInvalidate,
43
- metafile: true,
44
- write: false,
45
- });
74
+ catch (failure) {
75
+ // Build failures will throw an exception which contains errors/warnings
76
+ if (isEsBuildFailure(failure)) {
77
+ return failure;
78
+ }
79
+ else {
80
+ throw failure;
81
+ }
46
82
  }
47
- }
48
- catch (failure) {
49
- // Build failures will throw an exception which contains errors/warnings
50
- if (isEsBuildFailure(failure)) {
51
- return failure;
83
+ // Return if the build encountered any errors
84
+ if (result.errors.length) {
85
+ return {
86
+ errors: result.errors,
87
+ warnings: result.warnings,
88
+ };
52
89
  }
53
- else {
54
- throw failure;
90
+ // Find all initial files
91
+ const initialFiles = [];
92
+ for (const outputFile of result.outputFiles) {
93
+ // Entries in the metafile are relative to the `absWorkingDir` option which is set to the workspaceRoot
94
+ const relativeFilePath = (0, node_path_1.relative)(this.workspaceRoot, outputFile.path);
95
+ const entryPoint = (_b = (_a = result.metafile) === null || _a === void 0 ? void 0 : _a.outputs[relativeFilePath]) === null || _b === void 0 ? void 0 : _b.entryPoint;
96
+ outputFile.path = relativeFilePath;
97
+ if (entryPoint) {
98
+ // An entryPoint value indicates an initial file
99
+ initialFiles.push({
100
+ file: outputFile.path,
101
+ // The first part of the filename is the name of file (e.g., "polyfills" for "polyfills.7S5G3MDY.js")
102
+ name: (0, node_path_1.basename)(outputFile.path).split('.')[0],
103
+ extension: (0, node_path_1.extname)(outputFile.path),
104
+ });
105
+ }
55
106
  }
107
+ // Return the successful build results
108
+ return { ...result, initialFiles, errors: undefined };
56
109
  }
57
- const initialFiles = [];
58
- for (const outputFile of result.outputFiles) {
59
- // Entries in the metafile are relative to the `absWorkingDir` option which is set to the workspaceRoot
60
- const relativeFilePath = (0, node_path_1.relative)(workspaceRoot, outputFile.path);
61
- const entryPoint = (_b = (_a = result.metafile) === null || _a === void 0 ? void 0 : _a.outputs[relativeFilePath]) === null || _b === void 0 ? void 0 : _b.entryPoint;
62
- outputFile.path = relativeFilePath;
63
- if (entryPoint) {
64
- // An entryPoint value indicates an initial file
65
- initialFiles.push({
66
- file: outputFile.path,
67
- // The first part of the filename is the name of file (e.g., "polyfills" for "polyfills.7S5G3MDY.js")
68
- name: (0, node_path_1.basename)(outputFile.path).split('.')[0],
69
- extension: (0, node_path_1.extname)(outputFile.path),
70
- });
110
+ /**
111
+ * Disposes incremental build resources present in the context.
112
+ *
113
+ * @returns A promise that resolves when disposal is complete.
114
+ */
115
+ async dispose() {
116
+ var _a;
117
+ try {
118
+ return (_a = __classPrivateFieldGet(this, _BundlerContext_esbuildContext, "f")) === null || _a === void 0 ? void 0 : _a.dispose();
119
+ }
120
+ finally {
121
+ __classPrivateFieldSet(this, _BundlerContext_esbuildContext, undefined, "f");
71
122
  }
72
123
  }
73
- return { ...result, initialFiles };
74
124
  }
75
- exports.bundle = bundle;
125
+ exports.BundlerContext = BundlerContext;
126
+ _BundlerContext_esbuildContext = new WeakMap(), _BundlerContext_esbuildOptions = new WeakMap();
76
127
  async function logMessages(context, { errors, warnings }) {
77
- if (warnings.length) {
128
+ if (warnings === null || warnings === void 0 ? void 0 : warnings.length) {
78
129
  const warningMessages = await (0, esbuild_1.formatMessages)(warnings, { kind: 'warning', color: true });
79
130
  context.logger.warn(warningMessages.join('\n'));
80
131
  }
81
- if (errors.length) {
132
+ if (errors === null || errors === void 0 ? void 0 : errors.length) {
82
133
  const errorMessages = await (0, esbuild_1.formatMessages)(errors, { kind: 'error', color: true });
83
134
  context.logger.error(errorMessages.join('\n'));
84
135
  }
85
136
  }
86
137
  exports.logMessages = logMessages;
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNidWlsZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL2J1aWxkZXJzL2Jyb3dzZXItZXNidWlsZC9lc2J1aWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7OztBQUdILHFDQVNpQjtBQUNqQix5Q0FBd0Q7QUFHeEQ7Ozs7R0FJRztBQUNILFNBQWdCLGdCQUFnQixDQUFDLEtBQWM7SUFDN0MsT0FBTyxDQUFDLENBQUMsS0FBSyxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxRQUFRLElBQUksS0FBSyxJQUFJLFVBQVUsSUFBSSxLQUFLLENBQUM7QUFDMUYsQ0FBQztBQUZELDRDQUVDO0FBRUQ7Ozs7Ozs7Ozs7R0FVRztBQUNJLEtBQUssVUFBVSxNQUFNLENBQzFCLGFBQXFCLEVBQ3JCLG1CQUFtRDs7SUFLbkQsSUFBSSxNQUFNLENBQUM7SUFDWCxJQUFJO1FBQ0YsSUFBSSxPQUFPLG1CQUFtQixLQUFLLFVBQVUsRUFBRTtZQUM3QyxNQUFNLEdBQUcsQ0FBQyxNQUFNLG1CQUFtQixFQUFFLENBQWdELENBQUM7U0FDdkY7YUFBTTtZQUNMLE1BQU0sR0FBRyxNQUFNLElBQUEsZUFBSyxFQUFDO2dCQUNuQixHQUFHLG1CQUFtQjtnQkFDdEIsUUFBUSxFQUFFLElBQUk7Z0JBQ2QsS0FBSyxFQUFFLEtBQUs7YUFDYixDQUFDLENBQUM7U0FDSjtLQUNGO0lBQUMsT0FBTyxPQUFPLEVBQUU7UUFDaEIsd0VBQXdFO1FBQ3hFLElBQUksZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDN0IsT0FBTyxPQUFPLENBQUM7U0FDaEI7YUFBTTtZQUNMLE1BQU0sT0FBTyxDQUFDO1NBQ2Y7S0FDRjtJQUVELE1BQU0sWUFBWSxHQUFlLEVBQUUsQ0FBQztJQUNwQyxLQUFLLE1BQU0sVUFBVSxJQUFJLE1BQU0sQ0FBQyxXQUFXLEVBQUU7UUFDM0MsdUdBQXVHO1FBQ3ZHLE1BQU0sZ0JBQWdCLEdBQUcsSUFBQSxvQkFBUSxFQUFDLGFBQWEsRUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDbEUsTUFBTSxVQUFVLEdBQUcsTUFBQSxNQUFBLE1BQU0sQ0FBQyxRQUFRLDBDQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQywwQ0FBRSxVQUFVLENBQUM7UUFFMUUsVUFBVSxDQUFDLElBQUksR0FBRyxnQkFBZ0IsQ0FBQztRQUVuQyxJQUFJLFVBQVUsRUFBRTtZQUNkLGdEQUFnRDtZQUNoRCxZQUFZLENBQUMsSUFBSSxDQUFDO2dCQUNoQixJQUFJLEVBQUUsVUFBVSxDQUFDLElBQUk7Z0JBQ3JCLHFHQUFxRztnQkFDckcsSUFBSSxFQUFFLElBQUEsb0JBQVEsRUFBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDN0MsU0FBUyxFQUFFLElBQUEsbUJBQU8sRUFBQyxVQUFVLENBQUMsSUFBSSxDQUFDO2FBQ3BDLENBQUMsQ0FBQztTQUNKO0tBQ0Y7SUFFRCxPQUFPLEVBQUUsR0FBRyxNQUFNLEVBQUUsWUFBWSxFQUFFLENBQUM7QUFDckMsQ0FBQztBQS9DRCx3QkErQ0M7QUFFTSxLQUFLLFVBQVUsV0FBVyxDQUMvQixPQUF1QixFQUN2QixFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQThDO0lBRWhFLElBQUksUUFBUSxDQUFDLE1BQU0sRUFBRTtRQUNuQixNQUFNLGVBQWUsR0FBRyxNQUFNLElBQUEsd0JBQWMsRUFBQyxRQUFRLEVBQUUsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3pGLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztLQUNqRDtJQUVELElBQUksTUFBTSxDQUFDLE1BQU0sRUFBRTtRQUNqQixNQUFNLGFBQWEsR0FBRyxNQUFNLElBQUEsd0JBQWMsRUFBQyxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ25GLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztLQUNoRDtBQUNILENBQUM7QUFiRCxrQ0FhQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgeyBCdWlsZGVyQ29udGV4dCB9IGZyb20gJ0Bhbmd1bGFyLWRldmtpdC9hcmNoaXRlY3QnO1xuaW1wb3J0IHtcbiAgQnVpbGRGYWlsdXJlLFxuICBCdWlsZEludmFsaWRhdGUsXG4gIEJ1aWxkT3B0aW9ucyxcbiAgQnVpbGRSZXN1bHQsXG4gIE1lc3NhZ2UsXG4gIE91dHB1dEZpbGUsXG4gIGJ1aWxkLFxuICBmb3JtYXRNZXNzYWdlcyxcbn0gZnJvbSAnZXNidWlsZCc7XG5pbXBvcnQgeyBiYXNlbmFtZSwgZXh0bmFtZSwgcmVsYXRpdmUgfSBmcm9tICdub2RlOnBhdGgnO1xuaW1wb3J0IHsgRmlsZUluZm8gfSBmcm9tICcuLi8uLi91dGlscy9pbmRleC1maWxlL2F1Z21lbnQtaW5kZXgtaHRtbCc7XG5cbi8qKlxuICogRGV0ZXJtaW5lcyBpZiBhbiB1bmtub3duIHZhbHVlIGlzIGFuIGVzYnVpbGQgQnVpbGRGYWlsdXJlIGVycm9yIG9iamVjdCB0aHJvd24gYnkgZXNidWlsZC5cbiAqIEBwYXJhbSB2YWx1ZSBBIHBvdGVudGlhbCBlc2J1aWxkIEJ1aWxkRmFpbHVyZSBlcnJvciBvYmplY3QuXG4gKiBAcmV0dXJucyBgdHJ1ZWAgaWYgdGhlIG9iamVjdCBpcyBkZXRlcm1pbmVkIHRvIGJlIGEgQnVpbGRGYWlsdXJlIG9iamVjdDsgb3RoZXJ3aXNlLCBgZmFsc2VgLlxuICovXG5leHBvcnQgZnVuY3Rpb24gaXNFc0J1aWxkRmFpbHVyZSh2YWx1ZTogdW5rbm93bik6IHZhbHVlIGlzIEJ1aWxkRmFpbHVyZSB7XG4gIHJldHVybiAhIXZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiYgJ2Vycm9ycycgaW4gdmFsdWUgJiYgJ3dhcm5pbmdzJyBpbiB2YWx1ZTtcbn1cblxuLyoqXG4gKiBFeGVjdXRlcyB0aGUgZXNidWlsZCBidWlsZCBmdW5jdGlvbiBhbmQgbm9ybWFsaXplcyB0aGUgYnVpbGQgcmVzdWx0IGluIHRoZSBldmVudCBvZiBhXG4gKiBidWlsZCBmYWlsdXJlIHRoYXQgcmVzdWx0cyBpbiBubyBvdXRwdXQgYmVpbmcgZ2VuZXJhdGVkLlxuICogQWxsIGJ1aWxkcyB1c2UgdGhlIGB3cml0ZWAgb3B0aW9uIHdpdGggYSB2YWx1ZSBvZiBgZmFsc2VgIHRvIGFsbG93IGZvciB0aGUgb3V0cHV0IGZpbGVzXG4gKiBidWlsZCByZXN1bHQgYXJyYXkgdG8gYmUgcG9wdWxhdGVkLlxuICpcbiAqIEBwYXJhbSBvcHRpb25zT3JJbnZhbGlkYXRlIFRoZSBlc2J1aWxkIG9wdGlvbnMgb2JqZWN0IHRvIHVzZSB3aGVuIGJ1aWxkaW5nIG9yIHRoZSBpbnZhbGlkYXRlIG9iamVjdFxuICogcmV0dXJuZWQgZnJvbSBhbiBpbmNyZW1lbnRhbCBidWlsZCB0byBwZXJmb3JtIGFuIGFkZGl0aW9uYWwgaW5jcmVtZW50YWwgYnVpbGQuXG4gKiBAcmV0dXJucyBJZiBvdXRwdXQgZmlsZXMgYXJlIGdlbmVyYXRlZCwgdGhlIGZ1bGwgZXNidWlsZCBCdWlsZFJlc3VsdDsgaWYgbm90LCB0aGVcbiAqIHdhcm5pbmdzIGFuZCBlcnJvcnMgZm9yIHRoZSBhdHRlbXB0ZWQgYnVpbGQuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBidW5kbGUoXG4gIHdvcmtzcGFjZVJvb3Q6IHN0cmluZyxcbiAgb3B0aW9uc09ySW52YWxpZGF0ZTogQnVpbGRPcHRpb25zIHwgQnVpbGRJbnZhbGlkYXRlLFxuKTogUHJvbWlzZTxcbiAgfCAoQnVpbGRSZXN1bHQgJiB7IG91dHB1dEZpbGVzOiBPdXRwdXRGaWxlW107IGluaXRpYWxGaWxlczogRmlsZUluZm9bXSB9KVxuICB8IChCdWlsZEZhaWx1cmUgJiB7IG91dHB1dEZpbGVzPzogbmV2ZXIgfSlcbj4ge1xuICBsZXQgcmVzdWx0O1xuICB0cnkge1xuICAgIGlmICh0eXBlb2Ygb3B0aW9uc09ySW52YWxpZGF0ZSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgcmVzdWx0ID0gKGF3YWl0IG9wdGlvbnNPckludmFsaWRhdGUoKSkgYXMgQnVpbGRSZXN1bHQgJiB7IG91dHB1dEZpbGVzOiBPdXRwdXRGaWxlW10gfTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmVzdWx0ID0gYXdhaXQgYnVpbGQoe1xuICAgICAgICAuLi5vcHRpb25zT3JJbnZhbGlkYXRlLFxuICAgICAgICBtZXRhZmlsZTogdHJ1ZSxcbiAgICAgICAgd3JpdGU6IGZhbHNlLFxuICAgICAgfSk7XG4gICAgfVxuICB9IGNhdGNoIChmYWlsdXJlKSB7XG4gICAgLy8gQnVpbGQgZmFpbHVyZXMgd2lsbCB0aHJvdyBhbiBleGNlcHRpb24gd2hpY2ggY29udGFpbnMgZXJyb3JzL3dhcm5pbmdzXG4gICAgaWYgKGlzRXNCdWlsZEZhaWx1cmUoZmFpbHVyZSkpIHtcbiAgICAgIHJldHVybiBmYWlsdXJlO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBmYWlsdXJlO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGluaXRpYWxGaWxlczogRmlsZUluZm9bXSA9IFtdO1xuICBmb3IgKGNvbnN0IG91dHB1dEZpbGUgb2YgcmVzdWx0Lm91dHB1dEZpbGVzKSB7XG4gICAgLy8gRW50cmllcyBpbiB0aGUgbWV0YWZpbGUgYXJlIHJlbGF0aXZlIHRvIHRoZSBgYWJzV29ya2luZ0RpcmAgb3B0aW9uIHdoaWNoIGlzIHNldCB0byB0aGUgd29ya3NwYWNlUm9vdFxuICAgIGNvbnN0IHJlbGF0aXZlRmlsZVBhdGggPSByZWxhdGl2ZSh3b3Jrc3BhY2VSb290LCBvdXRwdXRGaWxlLnBhdGgpO1xuICAgIGNvbnN0IGVudHJ5UG9pbnQgPSByZXN1bHQubWV0YWZpbGU/Lm91dHB1dHNbcmVsYXRpdmVGaWxlUGF0aF0/LmVudHJ5UG9pbnQ7XG5cbiAgICBvdXRwdXRGaWxlLnBhdGggPSByZWxhdGl2ZUZpbGVQYXRoO1xuXG4gICAgaWYgKGVudHJ5UG9pbnQpIHtcbiAgICAgIC8vIEFuIGVudHJ5UG9pbnQgdmFsdWUgaW5kaWNhdGVzIGFuIGluaXRpYWwgZmlsZVxuICAgICAgaW5pdGlhbEZpbGVzLnB1c2goe1xuICAgICAgICBmaWxlOiBvdXRwdXRGaWxlLnBhdGgsXG4gICAgICAgIC8vIFRoZSBmaXJzdCBwYXJ0IG9mIHRoZSBmaWxlbmFtZSBpcyB0aGUgbmFtZSBvZiBmaWxlIChlLmcuLCBcInBvbHlmaWxsc1wiIGZvciBcInBvbHlmaWxscy43UzVHM01EWS5qc1wiKVxuICAgICAgICBuYW1lOiBiYXNlbmFtZShvdXRwdXRGaWxlLnBhdGgpLnNwbGl0KCcuJylbMF0sXG4gICAgICAgIGV4dGVuc2lvbjogZXh0bmFtZShvdXRwdXRGaWxlLnBhdGgpLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgLi4ucmVzdWx0LCBpbml0aWFsRmlsZXMgfTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxvZ01lc3NhZ2VzKFxuICBjb250ZXh0OiBCdWlsZGVyQ29udGV4dCxcbiAgeyBlcnJvcnMsIHdhcm5pbmdzIH06IHsgZXJyb3JzOiBNZXNzYWdlW107IHdhcm5pbmdzOiBNZXNzYWdlW10gfSxcbik6IFByb21pc2U8dm9pZD4ge1xuICBpZiAod2FybmluZ3MubGVuZ3RoKSB7XG4gICAgY29uc3Qgd2FybmluZ01lc3NhZ2VzID0gYXdhaXQgZm9ybWF0TWVzc2FnZXMod2FybmluZ3MsIHsga2luZDogJ3dhcm5pbmcnLCBjb2xvcjogdHJ1ZSB9KTtcbiAgICBjb250ZXh0LmxvZ2dlci53YXJuKHdhcm5pbmdNZXNzYWdlcy5qb2luKCdcXG4nKSk7XG4gIH1cblxuICBpZiAoZXJyb3JzLmxlbmd0aCkge1xuICAgIGNvbnN0IGVycm9yTWVzc2FnZXMgPSBhd2FpdCBmb3JtYXRNZXNzYWdlcyhlcnJvcnMsIHsga2luZDogJ2Vycm9yJywgY29sb3I6IHRydWUgfSk7XG4gICAgY29udGV4dC5sb2dnZXIuZXJyb3IoZXJyb3JNZXNzYWdlcy5qb2luKCdcXG4nKSk7XG4gIH1cbn1cbiJdfQ==
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esbuild.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/esbuild.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 {\n  BuildContext,\n  BuildFailure,\n  BuildOptions,\n  Message,\n  Metafile,\n  OutputFile,\n  PartialMessage,\n  build,\n  context,\n  formatMessages,\n} from 'esbuild';\nimport { basename, extname, relative } from 'node:path';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\n\n/**\n * Determines if an unknown value is an esbuild BuildFailure error object thrown by esbuild.\n * @param value A potential esbuild BuildFailure error object.\n * @returns `true` if the object is determined to be a BuildFailure object; otherwise, `false`.\n */\nexport function isEsBuildFailure(value: unknown): value is BuildFailure {\n  return !!value && typeof value === 'object' && 'errors' in value && 'warnings' in value;\n}\n\nexport class BundlerContext {\n  #esbuildContext?: BuildContext<{ metafile: true; write: false }>;\n  #esbuildOptions: BuildOptions & { metafile: true; write: false };\n\n  constructor(private workspaceRoot: string, private incremental: boolean, options: BuildOptions) {\n    this.#esbuildOptions = {\n      ...options,\n      metafile: true,\n      write: false,\n    };\n  }\n\n  /**\n   * Executes the esbuild build function and normalizes the build result in the event of a\n   * build failure that results in no output being generated.\n   * All builds use the `write` option with a value of `false` to allow for the output files\n   * build result array to be populated.\n   *\n   * @returns If output files are generated, the full esbuild BuildResult; if not, the\n   * warnings and errors for the attempted build.\n   */\n  async bundle(): Promise<\n    | { errors: Message[]; warnings: Message[] }\n    | {\n        errors: undefined;\n        warnings: Message[];\n        metafile: Metafile;\n        outputFiles: OutputFile[];\n        initialFiles: FileInfo[];\n      }\n  > {\n    let result;\n    try {\n      if (this.#esbuildContext) {\n        // Rebuild using the existing incremental build context\n        result = await this.#esbuildContext.rebuild();\n      } else if (this.incremental) {\n        // Create an incremental build context and perform the first build.\n        // Context creation does not perform a build.\n        this.#esbuildContext = await context(this.#esbuildOptions);\n        result = await this.#esbuildContext.rebuild();\n      } else {\n        // For non-incremental builds, perform a single build\n        result = await build(this.#esbuildOptions);\n      }\n    } catch (failure) {\n      // Build failures will throw an exception which contains errors/warnings\n      if (isEsBuildFailure(failure)) {\n        return failure;\n      } else {\n        throw failure;\n      }\n    }\n\n    // Return if the build encountered any errors\n    if (result.errors.length) {\n      return {\n        errors: result.errors,\n        warnings: result.warnings,\n      };\n    }\n\n    // Find all initial files\n    const initialFiles: FileInfo[] = [];\n    for (const outputFile of result.outputFiles) {\n      // Entries in the metafile are relative to the `absWorkingDir` option which is set to the workspaceRoot\n      const relativeFilePath = relative(this.workspaceRoot, outputFile.path);\n      const entryPoint = result.metafile?.outputs[relativeFilePath]?.entryPoint;\n\n      outputFile.path = relativeFilePath;\n\n      if (entryPoint) {\n        // An entryPoint value indicates an initial file\n        initialFiles.push({\n          file: outputFile.path,\n          // The first part of the filename is the name of file (e.g., \"polyfills\" for \"polyfills.7S5G3MDY.js\")\n          name: basename(outputFile.path).split('.')[0],\n          extension: extname(outputFile.path),\n        });\n      }\n    }\n\n    // Return the successful build results\n    return { ...result, initialFiles, errors: undefined };\n  }\n\n  /**\n   * Disposes incremental build resources present in the context.\n   *\n   * @returns A promise that resolves when disposal is complete.\n   */\n  async dispose(): Promise<void> {\n    try {\n      return this.#esbuildContext?.dispose();\n    } finally {\n      this.#esbuildContext = undefined;\n    }\n  }\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"]}
@@ -9,9 +9,7 @@
9
9
  Object.defineProperty(exports, "__esModule", { value: true });
10
10
  exports.logExperimentalWarnings = void 0;
11
11
  const UNSUPPORTED_OPTIONS = [
12
- 'allowedCommonJsDependencies',
13
12
  'budgets',
14
- 'extractLicenses',
15
13
  'progress',
16
14
  'scripts',
17
15
  // * i18n support
@@ -51,4 +49,4 @@ function logExperimentalWarnings(options, context) {
51
49
  }
52
50
  }
53
51
  exports.logExperimentalWarnings = logExperimentalWarnings;
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwZXJpbWVudGFsLXdhcm5pbmdzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvYnVpbGRlcnMvYnJvd3Nlci1lc2J1aWxkL2V4cGVyaW1lbnRhbC13YXJuaW5ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUFLSCxNQUFNLG1CQUFtQixHQUF1QztJQUM5RCw2QkFBNkI7SUFDN0IsU0FBUztJQUNULGlCQUFpQjtJQUNqQixVQUFVO0lBQ1YsU0FBUztJQUVULGlCQUFpQjtJQUNqQixVQUFVO0lBQ1YsZ0VBQWdFO0lBQ2hFLDhCQUE4QjtJQUM5Qiw0QkFBNEI7SUFFNUIsZUFBZTtJQUNmLFdBQVc7SUFFWCxnQ0FBZ0M7SUFDaEMsaUJBQWlCO0lBRWpCLHFDQUFxQztJQUNyQyxhQUFhO0lBQ2IsYUFBYTtJQUNiLG1CQUFtQjtDQUNwQixDQUFDO0FBRUYsU0FBZ0IsdUJBQXVCLENBQUMsT0FBOEIsRUFBRSxPQUF1QjtJQUM3RixpREFBaUQ7SUFDakQsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQ2pCLHdGQUF3RixDQUN6RixDQUFDO0lBRUYsNkJBQTZCO0lBQzdCLHNGQUFzRjtJQUN0RixLQUFLLE1BQU0saUJBQWlCLElBQUksbUJBQW1CLEVBQUU7UUFDbkQsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFFekMsSUFBSSxLQUFLLEtBQUssU0FBUyxJQUFJLEtBQUssS0FBSyxLQUFLLEVBQUU7WUFDMUMsU0FBUztTQUNWO1FBQ0QsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQzlDLFNBQVM7U0FDVjtRQUNELElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUNoRSxTQUFTO1NBQ1Y7UUFFRCxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDakIsUUFBUSxpQkFBaUIscUZBQXFGLENBQy9HLENBQUM7S0FDSDtJQUVELElBQUksT0FBTyxDQUFDLG1CQUFtQixLQUFLLE1BQU0sRUFBRTtRQUMxQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyw4REFBOEQsQ0FBQyxDQUFDO0tBQ3JGO0FBQ0gsQ0FBQztBQTdCRCwwREE2QkMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHsgQnVpbGRlckNvbnRleHQgfSBmcm9tICdAYW5ndWxhci1kZXZraXQvYXJjaGl0ZWN0JztcbmltcG9ydCB7IFNjaGVtYSBhcyBCcm93c2VyQnVpbGRlck9wdGlvbnMgfSBmcm9tICcuLi9icm93c2VyL3NjaGVtYSc7XG5cbmNvbnN0IFVOU1VQUE9SVEVEX09QVElPTlM6IEFycmF5PGtleW9mIEJyb3dzZXJCdWlsZGVyT3B0aW9ucz4gPSBbXG4gICdhbGxvd2VkQ29tbW9uSnNEZXBlbmRlbmNpZXMnLFxuICAnYnVkZ2V0cycsXG4gICdleHRyYWN0TGljZW5zZXMnLFxuICAncHJvZ3Jlc3MnLFxuICAnc2NyaXB0cycsXG5cbiAgLy8gKiBpMThuIHN1cHBvcnRcbiAgJ2xvY2FsaXplJyxcbiAgLy8gVGhlIGZvbGxvd2luZyB0d28gaGF2ZSBubyBlZmZlY3Qgd2hlbiBsb2NhbGl6ZSBpcyBub3QgZW5hYmxlZFxuICAvLyAnaTE4bkR1cGxpY2F0ZVRyYW5zbGF0aW9uJyxcbiAgLy8gJ2kxOG5NaXNzaW5nVHJhbnNsYXRpb24nLFxuXG4gIC8vICogRGVwcmVjYXRlZFxuICAnZGVwbG95VXJsJyxcblxuICAvLyAqIEFsd2F5cyBlbmFibGVkIHdpdGggZXNidWlsZFxuICAvLyAnY29tbW9uQ2h1bmsnLFxuXG4gIC8vICogQ3VycmVudGx5IHVuc3VwcG9ydGVkIGJ5IGVzYnVpbGRcbiAgJ25hbWVkQ2h1bmtzJyxcbiAgJ3ZlbmRvckNodW5rJyxcbiAgJ3dlYldvcmtlclRzQ29uZmlnJyxcbl07XG5cbmV4cG9ydCBmdW5jdGlvbiBsb2dFeHBlcmltZW50YWxXYXJuaW5ncyhvcHRpb25zOiBCcm93c2VyQnVpbGRlck9wdGlvbnMsIGNvbnRleHQ6IEJ1aWxkZXJDb250ZXh0KSB7XG4gIC8vIFdhcm4gYWJvdXQgZXhwZXJpbWVudGFsIHN0YXR1cyBvZiB0aGlzIGJ1aWxkZXJcbiAgY29udGV4dC5sb2dnZXIud2FybihcbiAgICBgVGhlIGVzYnVpbGQgYnJvd3NlciBhcHBsaWNhdGlvbiBidWlsZGVyICgnYnJvd3Nlci1lc2J1aWxkJykgaXMgY3VycmVudGx5IGV4cGVyaW1lbnRhbC5gLFxuICApO1xuXG4gIC8vIFZhbGlkYXRlIHN1cHBvcnRlZCBvcHRpb25zXG4gIC8vIEN1cnJlbnRseSBvbmx5IGEgc3Vic2V0IG9mIHRoZSBXZWJwYWNrLWJhc2VkIGJyb3dzZXIgYnVpbGRlciBvcHRpb25zIGFyZSBzdXBwb3J0ZWQuXG4gIGZvciAoY29uc3QgdW5zdXBwb3J0ZWRPcHRpb24gb2YgVU5TVVBQT1JURURfT1BUSU9OUykge1xuICAgIGNvbnN0IHZhbHVlID0gb3B0aW9uc1t1bnN1cHBvcnRlZE9wdGlvbl07XG5cbiAgICBpZiAodmFsdWUgPT09IHVuZGVmaW5lZCB8fCB2YWx1ZSA9PT0gZmFsc2UpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkgJiYgdmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcgJiYgT2JqZWN0LmtleXModmFsdWUpLmxlbmd0aCA9PT0gMCkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuXG4gICAgY29udGV4dC5sb2dnZXIud2FybihcbiAgICAgIGBUaGUgJyR7dW5zdXBwb3J0ZWRPcHRpb259JyBvcHRpb24gaXMgY3VycmVudGx5IHVuc3VwcG9ydGVkIGJ5IHRoaXMgZXhwZXJpbWVudGFsIGJ1aWxkZXIgYW5kIHdpbGwgYmUgaWdub3JlZC5gLFxuICAgICk7XG4gIH1cblxuICBpZiAob3B0aW9ucy5pbmxpbmVTdHlsZUxhbmd1YWdlID09PSAnbGVzcycpIHtcbiAgICBjb250ZXh0LmxvZ2dlci53YXJuKCdUaGUgbGVzcyBzdHlsZXNoZWV0IHByZXByb2Nlc3NvciBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZC4nKTtcbiAgfVxufVxuIl19
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwZXJpbWVudGFsLXdhcm5pbmdzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhcl9kZXZraXQvYnVpbGRfYW5ndWxhci9zcmMvYnVpbGRlcnMvYnJvd3Nlci1lc2J1aWxkL2V4cGVyaW1lbnRhbC13YXJuaW5ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7OztHQU1HOzs7QUFLSCxNQUFNLG1CQUFtQixHQUF1QztJQUM5RCxTQUFTO0lBQ1QsVUFBVTtJQUNWLFNBQVM7SUFFVCxpQkFBaUI7SUFDakIsVUFBVTtJQUNWLGdFQUFnRTtJQUNoRSw4QkFBOEI7SUFDOUIsNEJBQTRCO0lBRTVCLGVBQWU7SUFDZixXQUFXO0lBRVgsZ0NBQWdDO0lBQ2hDLGlCQUFpQjtJQUVqQixxQ0FBcUM7SUFDckMsYUFBYTtJQUNiLGFBQWE7SUFDYixtQkFBbUI7Q0FDcEIsQ0FBQztBQUVGLFNBQWdCLHVCQUF1QixDQUFDLE9BQThCLEVBQUUsT0FBdUI7SUFDN0YsaURBQWlEO0lBQ2pELE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUNqQix3RkFBd0YsQ0FDekYsQ0FBQztJQUVGLDZCQUE2QjtJQUM3QixzRkFBc0Y7SUFDdEYsS0FBSyxNQUFNLGlCQUFpQixJQUFJLG1CQUFtQixFQUFFO1FBQ25ELE1BQU0sS0FBSyxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRXpDLElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxLQUFLLEtBQUssS0FBSyxFQUFFO1lBQzFDLFNBQVM7U0FDVjtRQUNELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUM5QyxTQUFTO1NBQ1Y7UUFDRCxJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDaEUsU0FBUztTQUNWO1FBRUQsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQ2pCLFFBQVEsaUJBQWlCLHFGQUFxRixDQUMvRyxDQUFDO0tBQ0g7SUFFRCxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsS0FBSyxNQUFNLEVBQUU7UUFDMUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsOERBQThELENBQUMsQ0FBQztLQUNyRjtBQUNILENBQUM7QUE3QkQsMERBNkJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7IEJ1aWxkZXJDb250ZXh0IH0gZnJvbSAnQGFuZ3VsYXItZGV2a2l0L2FyY2hpdGVjdCc7XG5pbXBvcnQgeyBTY2hlbWEgYXMgQnJvd3NlckJ1aWxkZXJPcHRpb25zIH0gZnJvbSAnLi4vYnJvd3Nlci9zY2hlbWEnO1xuXG5jb25zdCBVTlNVUFBPUlRFRF9PUFRJT05TOiBBcnJheTxrZXlvZiBCcm93c2VyQnVpbGRlck9wdGlvbnM+ID0gW1xuICAnYnVkZ2V0cycsXG4gICdwcm9ncmVzcycsXG4gICdzY3JpcHRzJyxcblxuICAvLyAqIGkxOG4gc3VwcG9ydFxuICAnbG9jYWxpemUnLFxuICAvLyBUaGUgZm9sbG93aW5nIHR3byBoYXZlIG5vIGVmZmVjdCB3aGVuIGxvY2FsaXplIGlzIG5vdCBlbmFibGVkXG4gIC8vICdpMThuRHVwbGljYXRlVHJhbnNsYXRpb24nLFxuICAvLyAnaTE4bk1pc3NpbmdUcmFuc2xhdGlvbicsXG5cbiAgLy8gKiBEZXByZWNhdGVkXG4gICdkZXBsb3lVcmwnLFxuXG4gIC8vICogQWx3YXlzIGVuYWJsZWQgd2l0aCBlc2J1aWxkXG4gIC8vICdjb21tb25DaHVuaycsXG5cbiAgLy8gKiBDdXJyZW50bHkgdW5zdXBwb3J0ZWQgYnkgZXNidWlsZFxuICAnbmFtZWRDaHVua3MnLFxuICAndmVuZG9yQ2h1bmsnLFxuICAnd2ViV29ya2VyVHNDb25maWcnLFxuXTtcblxuZXhwb3J0IGZ1bmN0aW9uIGxvZ0V4cGVyaW1lbnRhbFdhcm5pbmdzKG9wdGlvbnM6IEJyb3dzZXJCdWlsZGVyT3B0aW9ucywgY29udGV4dDogQnVpbGRlckNvbnRleHQpIHtcbiAgLy8gV2FybiBhYm91dCBleHBlcmltZW50YWwgc3RhdHVzIG9mIHRoaXMgYnVpbGRlclxuICBjb250ZXh0LmxvZ2dlci53YXJuKFxuICAgIGBUaGUgZXNidWlsZCBicm93c2VyIGFwcGxpY2F0aW9uIGJ1aWxkZXIgKCdicm93c2VyLWVzYnVpbGQnKSBpcyBjdXJyZW50bHkgZXhwZXJpbWVudGFsLmAsXG4gICk7XG5cbiAgLy8gVmFsaWRhdGUgc3VwcG9ydGVkIG9wdGlvbnNcbiAgLy8gQ3VycmVudGx5IG9ubHkgYSBzdWJzZXQgb2YgdGhlIFdlYnBhY2stYmFzZWQgYnJvd3NlciBidWlsZGVyIG9wdGlvbnMgYXJlIHN1cHBvcnRlZC5cbiAgZm9yIChjb25zdCB1bnN1cHBvcnRlZE9wdGlvbiBvZiBVTlNVUFBPUlRFRF9PUFRJT05TKSB7XG4gICAgY29uc3QgdmFsdWUgPSBvcHRpb25zW3Vuc3VwcG9ydGVkT3B0aW9uXTtcblxuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8IHZhbHVlID09PSBmYWxzZSkge1xuICAgICAgY29udGludWU7XG4gICAgfVxuICAgIGlmIChBcnJheS5pc0FycmF5KHZhbHVlKSAmJiB2YWx1ZS5sZW5ndGggPT09IDApIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cbiAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiBPYmplY3Qua2V5cyh2YWx1ZSkubGVuZ3RoID09PSAwKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb250ZXh0LmxvZ2dlci53YXJuKFxuICAgICAgYFRoZSAnJHt1bnN1cHBvcnRlZE9wdGlvbn0nIG9wdGlvbiBpcyBjdXJyZW50bHkgdW5zdXBwb3J0ZWQgYnkgdGhpcyBleHBlcmltZW50YWwgYnVpbGRlciBhbmQgd2lsbCBiZSBpZ25vcmVkLmAsXG4gICAgKTtcbiAgfVxuXG4gIGlmIChvcHRpb25zLmlubGluZVN0eWxlTGFuZ3VhZ2UgPT09ICdsZXNzJykge1xuICAgIGNvbnRleHQubG9nZ2VyLndhcm4oJ1RoZSBsZXNzIHN0eWxlc2hlZXQgcHJlcHJvY2Vzc29yIGlzIG5vdCBjdXJyZW50bHkgc3VwcG9ydGVkLicpO1xuICB9XG59XG4iXX0=
@@ -45,9 +45,11 @@ const esbuild_targets_1 = require("../../utils/esbuild-targets");
45
45
  const index_html_generator_1 = require("../../utils/index-file/index-html-generator");
46
46
  const service_worker_1 = require("../../utils/service-worker");
47
47
  const supported_browsers_1 = require("../../utils/supported-browsers");
48
+ const commonjs_checker_1 = require("./commonjs-checker");
48
49
  const compiler_plugin_1 = require("./compiler-plugin");
49
50
  const esbuild_1 = require("./esbuild");
50
51
  const experimental_warnings_1 = require("./experimental-warnings");
52
+ const license_extractor_1 = require("./license-extractor");
51
53
  const options_1 = require("./options");
52
54
  const sass_plugin_1 = require("./sass-plugin");
53
55
  const stylesheets_1 = require("./stylesheets");
@@ -77,37 +79,40 @@ class ExecutionResult {
77
79
  fileChanges,
78
80
  };
79
81
  }
80
- dispose() {
81
- var _a;
82
- (_a = this.codeRebuild) === null || _a === void 0 ? void 0 : _a.dispose();
82
+ async dispose() {
83
+ var _a, _b;
84
+ await Promise.all([(_a = this.codeRebuild) === null || _a === void 0 ? void 0 : _a.dispose(), (_b = this.globalStylesRebuild) === null || _b === void 0 ? void 0 : _b.dispose()]);
83
85
  }
84
86
  }
85
87
  async function execute(options, context, rebuildState) {
86
- var _a, _b, _c, _d, _e, _f, _g, _h;
88
+ var _a, _b, _c, _d, _e, _f, _g;
87
89
  const startTime = process.hrtime.bigint();
88
90
  const { projectRoot, workspaceRoot, optimizationOptions, outputPath, assets, serviceWorkerOptions, indexHtmlOptions, } = options;
89
91
  const target = (0, esbuild_targets_1.transformSupportedBrowsersToTargets)((0, supported_browsers_1.getSupportedBrowsers)(projectRoot, context.logger));
92
+ // Reuse rebuild state or create new bundle contexts for code and global stylesheets
90
93
  const codeBundleCache = options.watch
91
94
  ? (_a = rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.codeBundleCache) !== null && _a !== void 0 ? _a : new compiler_plugin_1.SourceFileCache()
92
95
  : undefined;
96
+ const codeBundleContext = (_b = rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.codeRebuild) !== null && _b !== void 0 ? _b : new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createCodeBundleOptions(options, target, codeBundleCache));
97
+ const globalStylesBundleContext = (_c = rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.globalStylesRebuild) !== null && _c !== void 0 ? _c : new esbuild_1.BundlerContext(workspaceRoot, !!options.watch, createGlobalStylesBundleOptions(options, target));
93
98
  const [codeResults, styleResults] = await Promise.all([
94
99
  // Execute esbuild to bundle the application code
95
- (0, esbuild_1.bundle)(workspaceRoot, (_b = rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.codeRebuild) !== null && _b !== void 0 ? _b : createCodeBundleOptions(options, target, codeBundleCache)),
100
+ codeBundleContext.bundle(),
96
101
  // Execute esbuild to bundle the global stylesheets
97
- (0, esbuild_1.bundle)(workspaceRoot, (_c = rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.globalStylesRebuild) !== null && _c !== void 0 ? _c : createGlobalStylesBundleOptions(options, target)),
102
+ globalStylesBundleContext.bundle(),
98
103
  ]);
99
104
  // Log all warnings and errors generated during bundling
100
105
  await (0, esbuild_1.logMessages)(context, {
101
- errors: [...codeResults.errors, ...styleResults.errors],
106
+ errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],
102
107
  warnings: [...codeResults.warnings, ...styleResults.warnings],
103
108
  });
104
109
  // Return if the bundling failed to generate output files or there are errors
105
- if (!codeResults.outputFiles || codeResults.errors.length) {
106
- return new ExecutionResult(false, rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.codeRebuild, (_d = (styleResults.outputFiles && styleResults.rebuild)) !== null && _d !== void 0 ? _d : rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.globalStylesRebuild, codeBundleCache);
110
+ if (codeResults.errors) {
111
+ return new ExecutionResult(false, codeBundleContext, globalStylesBundleContext, codeBundleCache);
107
112
  }
108
113
  // Return if the global stylesheet bundling has errors
109
- if (!styleResults.outputFiles || styleResults.errors.length) {
110
- return new ExecutionResult(false, codeResults.rebuild, rebuildState === null || rebuildState === void 0 ? void 0 : rebuildState.globalStylesRebuild, codeBundleCache);
114
+ if (styleResults.errors) {
115
+ return new ExecutionResult(false, codeBundleContext, globalStylesBundleContext, codeBundleCache);
111
116
  }
112
117
  // Filter global stylesheet initial files
113
118
  styleResults.initialFiles = styleResults.initialFiles.filter(({ name }) => { var _a; return (_a = options.globalStyles.find((style) => style.name === name)) === null || _a === void 0 ? void 0 : _a.initial; });
@@ -116,9 +121,14 @@ async function execute(options, context, rebuildState) {
116
121
  const outputFiles = [...codeResults.outputFiles, ...styleResults.outputFiles];
117
122
  // Combine metafiles used for the stats option as well as bundle budgets and console output
118
123
  const metafile = {
119
- inputs: { ...(_e = codeResults.metafile) === null || _e === void 0 ? void 0 : _e.inputs, ...(_f = styleResults.metafile) === null || _f === void 0 ? void 0 : _f.inputs },
120
- outputs: { ...(_g = codeResults.metafile) === null || _g === void 0 ? void 0 : _g.outputs, ...(_h = styleResults.metafile) === null || _h === void 0 ? void 0 : _h.outputs },
124
+ inputs: { ...(_d = codeResults.metafile) === null || _d === void 0 ? void 0 : _d.inputs, ...(_e = styleResults.metafile) === null || _e === void 0 ? void 0 : _e.inputs },
125
+ outputs: { ...(_f = codeResults.metafile) === null || _f === void 0 ? void 0 : _f.outputs, ...(_g = styleResults.metafile) === null || _g === void 0 ? void 0 : _g.outputs },
121
126
  };
127
+ // Check metafile for CommonJS module usage if optimizing scripts
128
+ if (optimizationOptions.scripts) {
129
+ const messages = (0, commonjs_checker_1.checkCommonJSModules)(metafile, options.allowedCommonJsDependencies);
130
+ await (0, esbuild_1.logMessages)(context, { warnings: messages });
131
+ }
122
132
  // Generate index HTML file
123
133
  if (indexHtmlOptions) {
124
134
  // Create an index HTML generator that reads from the in-memory output files
@@ -164,6 +174,10 @@ async function execute(options, context, rebuildState) {
164
174
  if (options.stats) {
165
175
  await fs.writeFile(path.join(outputPath, 'stats.json'), JSON.stringify(metafile, null, 2));
166
176
  }
177
+ // Extract and write licenses for used packages
178
+ if (options.extractLicenses) {
179
+ await fs.writeFile(path.join(outputPath, '3rdpartylicenses.txt'), await (0, license_extractor_1.extractLicenses)(metafile, workspaceRoot));
180
+ }
167
181
  // Augment the application with service worker support
168
182
  // TODO: This should eventually operate on the in-memory files prior to writing the output files
169
183
  if (serviceWorkerOptions) {
@@ -172,12 +186,12 @@ async function execute(options, context, rebuildState) {
172
186
  }
173
187
  catch (error) {
174
188
  context.logger.error(error instanceof Error ? error.message : `${error}`);
175
- return new ExecutionResult(false, codeResults.rebuild, styleResults.rebuild, codeBundleCache);
189
+ return new ExecutionResult(false, codeBundleContext, globalStylesBundleContext, codeBundleCache);
176
190
  }
177
191
  }
178
192
  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;
179
193
  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);
180
- return new ExecutionResult(true, codeResults.rebuild, styleResults.rebuild, codeBundleCache);
194
+ return new ExecutionResult(true, codeBundleContext, globalStylesBundleContext, codeBundleCache);
181
195
  }
182
196
  function createOutputFileFromText(path, text) {
183
197
  return {
@@ -193,7 +207,6 @@ function createCodeBundleOptions(options, target, sourceFileCache) {
193
207
  return {
194
208
  absWorkingDir: workspaceRoot,
195
209
  bundle: true,
196
- incremental: options.watch,
197
210
  format: 'esm',
198
211
  entryPoints,
199
212
  entryNames: outputNames.bundles,
@@ -204,6 +217,7 @@ function createCodeBundleOptions(options, target, sourceFileCache) {
204
217
  conditions: ['es2020', 'es2015', 'module'],
205
218
  resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],
206
219
  metafile: true,
220
+ legalComments: options.extractLicenses ? 'none' : 'eof',
207
221
  logLevel: options.verbose ? 'debug' : 'silent',
208
222
  minify: optimizationOptions.scripts,
209
223
  pure: ['forwardRef'],
@@ -314,7 +328,7 @@ function createGlobalStylesBundleOptions(options, target) {
314
328
  outputNames,
315
329
  includePaths: stylePreprocessorOptions === null || stylePreprocessorOptions === void 0 ? void 0 : stylePreprocessorOptions.includePaths,
316
330
  });
317
- buildOptions.incremental = watch;
331
+ buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';
318
332
  const namespace = 'angular:styles/global';
319
333
  buildOptions.entryPoints = {};
320
334
  for (const { name } of globalStyles) {
@@ -428,10 +442,10 @@ async function* buildEsbuildBrowser(initialOptions, context) {
428
442
  // Stop the watcher
429
443
  await watcher.close();
430
444
  // Cleanup incremental rebuild state
431
- result.dispose();
445
+ await result.dispose();
432
446
  (0, sass_plugin_1.shutdownSassWorkerPool)();
433
447
  }
434
448
  }
435
449
  exports.buildEsbuildBrowser = buildEsbuildBrowser;
436
450
  exports.default = (0, architect_1.createBuilder)(buildEsbuildBrowser);
437
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/index.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, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport type { BuildInvalidate, BuildOptions, Metafile, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { deleteOutputDir } from '../../utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { SourceFileCache, createCompilerPlugin } from './compiler-plugin';\nimport { bundle, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\nimport { NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { shutdownSassWorkerPool } from './sass-plugin';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createStylesheetBundleOptions } from './stylesheets';\nimport { ChangedFiles, createWatcher } from './watcher';\n\ninterface RebuildState {\n  codeRebuild?: BuildInvalidate;\n  globalStylesRebuild?: BuildInvalidate;\n  codeBundleCache?: SourceFileCache;\n  fileChanges: ChangedFiles;\n}\n\n/**\n * Represents the result of a single builder execute call.\n */\nclass ExecutionResult {\n  constructor(\n    private success: boolean,\n    private codeRebuild?: BuildInvalidate,\n    private globalStylesRebuild?: BuildInvalidate,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  get output() {\n    return {\n      success: this.success,\n    };\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      codeRebuild: this.codeRebuild,\n      globalStylesRebuild: this.globalStylesRebuild,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  dispose(): void {\n    this.codeRebuild?.dispose();\n  }\n}\n\nasync function execute(\n  options: NormalizedBrowserOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    optimizationOptions,\n    outputPath,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const target = transformSupportedBrowsersToTargets(\n    getSupportedBrowsers(projectRoot, context.logger),\n  );\n\n  const codeBundleCache = options.watch\n    ? rebuildState?.codeBundleCache ?? new SourceFileCache()\n    : undefined;\n\n  const [codeResults, styleResults] = await Promise.all([\n    // Execute esbuild to bundle the application code\n    bundle(\n      workspaceRoot,\n      rebuildState?.codeRebuild ?? createCodeBundleOptions(options, target, codeBundleCache),\n    ),\n    // Execute esbuild to bundle the global stylesheets\n    bundle(\n      workspaceRoot,\n      rebuildState?.globalStylesRebuild ?? createGlobalStylesBundleOptions(options, target),\n    ),\n  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [...codeResults.errors, ...styleResults.errors],\n    warnings: [...codeResults.warnings, ...styleResults.warnings],\n  });\n\n  // Return if the bundling failed to generate output files or there are errors\n  if (!codeResults.outputFiles || codeResults.errors.length) {\n    return new ExecutionResult(\n      false,\n      rebuildState?.codeRebuild,\n      (styleResults.outputFiles && styleResults.rebuild) ?? rebuildState?.globalStylesRebuild,\n      codeBundleCache,\n    );\n  }\n\n  // Return if the global stylesheet bundling has errors\n  if (!styleResults.outputFiles || styleResults.errors.length) {\n    return new ExecutionResult(\n      false,\n      codeResults.rebuild,\n      rebuildState?.globalStylesRebuild,\n      codeBundleCache,\n    );\n  }\n\n  // Filter global stylesheet initial files\n  styleResults.initialFiles = styleResults.initialFiles.filter(\n    ({ name }) => options.globalStyles.find((style) => style.name === name)?.initial,\n  );\n\n  // Combine the bundling output files\n  const initialFiles: FileInfo[] = [...codeResults.initialFiles, ...styleResults.initialFiles];\n  const outputFiles: OutputFile[] = [...codeResults.outputFiles, ...styleResults.outputFiles];\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },\n    outputs: { ...codeResults.metafile?.outputs, ...styleResults.metafile?.outputs },\n  };\n\n  // Generate index HTML file\n  if (indexHtmlOptions) {\n    // Create an index HTML generator that reads from the in-memory output files\n    const indexHtmlGenerator = new IndexHtmlGenerator({\n      indexPath: indexHtmlOptions.input,\n      entrypoints: indexHtmlOptions.insertionOrder,\n      sri: options.subresourceIntegrity,\n      optimization: optimizationOptions,\n      crossOrigin: options.crossOrigin,\n    });\n\n    /** Virtual output path to support reading in-memory files. */\n    const virtualOutputPath = '/';\n    indexHtmlGenerator.readAsset = async function (filePath: string): Promise<string> {\n      // Remove leading directory separator\n      const relativefilePath = path.relative(virtualOutputPath, filePath);\n      const file = outputFiles.find((file) => file.path === relativefilePath);\n      if (file) {\n        return file.text;\n      }\n\n      throw new Error(`Output file does not exist: ${path}`);\n    };\n\n    const { content, warnings, errors } = await indexHtmlGenerator.process({\n      baseHref: options.baseHref,\n      lang: undefined,\n      outputPath: virtualOutputPath,\n      files: initialFiles,\n    });\n\n    for (const error of errors) {\n      context.logger.error(error);\n    }\n    for (const warning of warnings) {\n      context.logger.warn(warning);\n    }\n\n    outputFiles.push(createOutputFileFromText(indexHtmlOptions.output, content));\n  }\n\n  // Copy assets\n  if (assets) {\n    await copyAssets(assets, [outputPath], workspaceRoot);\n  }\n\n  // Write output files\n  await Promise.all(\n    outputFiles.map((file) => fs.writeFile(path.join(outputPath, file.path), file.contents)),\n  );\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    await fs.writeFile(path.join(outputPath, 'stats.json'), JSON.stringify(metafile, null, 2));\n  }\n\n  // Augment the application with service worker support\n  // TODO: This should eventually operate on the in-memory files prior to writing the output files\n  if (serviceWorkerOptions) {\n    try {\n      await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\n        outputPath,\n        options.baseHref || '/',\n      );\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return new ExecutionResult(false, codeResults.rebuild, styleResults.rebuild, codeBundleCache);\n    }\n  }\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return new ExecutionResult(true, codeResults.rebuild, styleResults.rebuild, codeBundleCache);\n}\n\nfunction createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nfunction createCodeBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n  } = options;\n\n  return {\n    absWorkingDir: workspaceRoot,\n    bundle: true,\n    incremental: options.watch,\n    format: 'esm',\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    target,\n    supported: getFeatureSupport(target),\n    mainFields: ['es2020', 'browser', 'module', 'main'],\n    conditions: ['es2020', 'es2015', 'module'],\n    resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],\n    metafile: true,\n    logLevel: options.verbose ? 'debug' : 'silent',\n    minify: optimizationOptions.scripts,\n    pure: ['forwardRef'],\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    splitting: true,\n    tsconfig,\n    external: externalDependencies,\n    write: false,\n    platform: 'browser',\n    preserveSymlinks,\n    plugins: [\n      createCompilerPlugin(\n        // JS/TS options\n        {\n          sourcemap: !!sourcemapOptions.scripts,\n          thirdPartySourcemaps: sourcemapOptions.vendor,\n          tsconfig,\n          advancedOptimizations,\n          fileReplacements,\n          sourceFileCache,\n        },\n        // Component stylesheet options\n        {\n          workspaceRoot,\n          optimization: !!optimizationOptions.styles.minify,\n          sourcemap:\n            // Hidden component stylesheet sourcemaps are inaccessible which is effectively\n            // the same as being disabled. Disabling has the advantage of avoiding the overhead\n            // of sourcemap processing.\n            !!sourcemapOptions.styles && (sourcemapOptions.hidden ? false : 'inline'),\n          outputNames,\n          includePaths: stylePreprocessorOptions?.includePaths,\n          externalDependencies,\n          target,\n          inlineStyleLanguage,\n        },\n      ),\n    ],\n    define: {\n      // Only set to false when script optimizations are enabled. It should not be set to true because\n      // Angular turns `ngDevMode` into an object for development debugging purposes when not defined\n      // which a constant true value would break.\n      ...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),\n      // Only AOT mode is supported currently\n      'ngJitMode': 'false',\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 */\nfunction 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 and for await...of to a Zone.js supported form. However, esbuild\n    // does not currently support downleveling async generators. Instead babel is used within the JS/TS\n    // loader to perform the downlevel transformation.\n    // NOTE: If esbuild adds support in the future, the babel support for async generators can be disabled.\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\nfunction createGlobalStylesBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n    watch,\n  } = options;\n\n  const buildOptions = createStylesheetBundleOptions({\n    workspaceRoot,\n    optimization: !!optimizationOptions.styles.minify,\n    sourcemap: !!sourcemapOptions.styles,\n    preserveSymlinks,\n    target,\n    externalDependencies,\n    outputNames,\n    includePaths: stylePreprocessorOptions?.includePaths,\n  });\n  buildOptions.incremental = watch;\n\n  const namespace = 'angular:styles/global';\n  buildOptions.entryPoints = {};\n  for (const { name } of globalStyles) {\n    buildOptions.entryPoints[name] = `${namespace};${name}`;\n  }\n\n  buildOptions.plugins.unshift({\n    name: 'angular-global-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/global;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        return {\n          path: args.path.split(';', 2)[1],\n          namespace,\n        };\n      });\n      build.onLoad({ filter: /./, namespace }, (args) => {\n        const files = globalStyles.find(({ name }) => name === args.path)?.files;\n        assert(files, `global style name should always be found [${args.path}]`);\n\n        return {\n          contents: files.map((file) => `@import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'css',\n          resolveDir: workspaceRoot,\n        };\n      });\n    },\n  });\n\n  return buildOptions;\n}\n\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param initialOptions The browser builder options to use when setting up the application build\n * @param context The Architect builder context object\n * @returns An async iterable with the builder result output\n */\nexport async function* buildEsbuildBrowser(\n  initialOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n): AsyncIterable<BuilderOutput> {\n  // Only AOT is currently supported\n  if (initialOptions.aot !== true) {\n    context.logger.error(\n      'JIT mode is currently not supported by this experimental builder. AOT mode must be used.',\n    );\n\n    return;\n  }\n\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(initialOptions, context);\n\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);\n\n    return;\n  }\n\n  const normalizedOptions = await normalizeOptions(context, projectName, initialOptions);\n\n  // Clean output path if enabled\n  if (initialOptions.deleteOutputPath) {\n    deleteOutputDir(normalizedOptions.workspaceRoot, initialOptions.outputPath);\n  }\n\n  // Create output directory if needed\n  try {\n    await fs.mkdir(normalizedOptions.outputPath, { recursive: true });\n  } catch (e) {\n    assertIsError(e);\n    context.logger.error('Unable to create output directory: ' + e.message);\n\n    return;\n  }\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await execute(normalizedOptions, context);\n    yield result.output;\n\n    // Finish if watch mode is not enabled\n    if (!initialOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!initialOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  context.logger.info('Watch mode enabled. Watching for file changes...');\n\n  // Setup a watcher\n  const watcher = createWatcher({\n    polling: typeof initialOptions.poll === 'number',\n    interval: initialOptions.poll,\n    // Ignore the output and cache paths to avoid infinite rebuild cycles\n    ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.projectRoot);\n\n  // Watch workspace root node modules\n  // Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n  watcher.add(path.join(normalizedOptions.workspaceRoot, 'node_modules'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      context.logger.info('Changes detected. Rebuilding...');\n\n      if (initialOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await execute(normalizedOptions, context, result.createRebuildState(changes));\n      yield result.output;\n    }\n  } finally {\n    // Stop the watcher\n    await watcher.close();\n    // Cleanup incremental rebuild state\n    result.dispose();\n    shutdownSassWorkerPool();\n  }\n}\n\nexport default createBuilder(buildEsbuildBrowser);\n"]}
451
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/browser-esbuild/index.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, BuilderOutput, createBuilder } from '@angular-devkit/architect';\nimport type { BuildOptions, OutputFile } from 'esbuild';\nimport assert from 'node:assert';\nimport * as fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { deleteOutputDir } from '../../utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { assertIsError } from '../../utils/error';\nimport { transformSupportedBrowsersToTargets } from '../../utils/esbuild-targets';\nimport { FileInfo } from '../../utils/index-file/augment-index-html';\nimport { IndexHtmlGenerator } from '../../utils/index-file/index-html-generator';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { checkCommonJSModules } from './commonjs-checker';\nimport { SourceFileCache, createCompilerPlugin } from './compiler-plugin';\nimport { BundlerContext, logMessages } from './esbuild';\nimport { logExperimentalWarnings } from './experimental-warnings';\nimport { extractLicenses } from './license-extractor';\nimport { NormalizedBrowserOptions, normalizeOptions } from './options';\nimport { shutdownSassWorkerPool } from './sass-plugin';\nimport { Schema as BrowserBuilderOptions } from './schema';\nimport { createStylesheetBundleOptions } from './stylesheets';\nimport { ChangedFiles, createWatcher } from './watcher';\n\ninterface RebuildState {\n  codeRebuild?: BundlerContext;\n  globalStylesRebuild?: BundlerContext;\n  codeBundleCache?: SourceFileCache;\n  fileChanges: ChangedFiles;\n}\n\n/**\n * Represents the result of a single builder execute call.\n */\nclass ExecutionResult {\n  constructor(\n    private success: boolean,\n    private codeRebuild?: BundlerContext,\n    private globalStylesRebuild?: BundlerContext,\n    private codeBundleCache?: SourceFileCache,\n  ) {}\n\n  get output() {\n    return {\n      success: this.success,\n    };\n  }\n\n  createRebuildState(fileChanges: ChangedFiles): RebuildState {\n    this.codeBundleCache?.invalidate([...fileChanges.modified, ...fileChanges.removed]);\n\n    return {\n      codeRebuild: this.codeRebuild,\n      globalStylesRebuild: this.globalStylesRebuild,\n      codeBundleCache: this.codeBundleCache,\n      fileChanges,\n    };\n  }\n\n  async dispose(): Promise<void> {\n    await Promise.all([this.codeRebuild?.dispose(), this.globalStylesRebuild?.dispose()]);\n  }\n}\n\nasync function execute(\n  options: NormalizedBrowserOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    optimizationOptions,\n    outputPath,\n    assets,\n    serviceWorkerOptions,\n    indexHtmlOptions,\n  } = options;\n\n  const target = transformSupportedBrowsersToTargets(\n    getSupportedBrowsers(projectRoot, context.logger),\n  );\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  const codeBundleCache = options.watch\n    ? rebuildState?.codeBundleCache ?? new SourceFileCache()\n    : undefined;\n  const codeBundleContext =\n    rebuildState?.codeRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createCodeBundleOptions(options, target, codeBundleCache),\n    );\n  const globalStylesBundleContext =\n    rebuildState?.globalStylesRebuild ??\n    new BundlerContext(\n      workspaceRoot,\n      !!options.watch,\n      createGlobalStylesBundleOptions(options, target),\n    );\n\n  const [codeResults, styleResults] = await Promise.all([\n    // Execute esbuild to bundle the application code\n    codeBundleContext.bundle(),\n    // Execute esbuild to bundle the global stylesheets\n    globalStylesBundleContext.bundle(),\n  ]);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, {\n    errors: [...(codeResults.errors || []), ...(styleResults.errors || [])],\n    warnings: [...codeResults.warnings, ...styleResults.warnings],\n  });\n\n  // Return if the bundling failed to generate output files or there are errors\n  if (codeResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\n  }\n\n  // Return if the global stylesheet bundling has errors\n  if (styleResults.errors) {\n    return new ExecutionResult(\n      false,\n      codeBundleContext,\n      globalStylesBundleContext,\n      codeBundleCache,\n    );\n  }\n\n  // Filter global stylesheet initial files\n  styleResults.initialFiles = styleResults.initialFiles.filter(\n    ({ name }) => options.globalStyles.find((style) => style.name === name)?.initial,\n  );\n\n  // Combine the bundling output files\n  const initialFiles: FileInfo[] = [...codeResults.initialFiles, ...styleResults.initialFiles];\n  const outputFiles: OutputFile[] = [...codeResults.outputFiles, ...styleResults.outputFiles];\n\n  // Combine metafiles used for the stats option as well as bundle budgets and console output\n  const metafile = {\n    inputs: { ...codeResults.metafile?.inputs, ...styleResults.metafile?.inputs },\n    outputs: { ...codeResults.metafile?.outputs, ...styleResults.metafile?.outputs },\n  };\n\n  // Check metafile for CommonJS module usage if optimizing scripts\n  if (optimizationOptions.scripts) {\n    const messages = checkCommonJSModules(metafile, options.allowedCommonJsDependencies);\n    await logMessages(context, { warnings: messages });\n  }\n\n  // Generate index HTML file\n  if (indexHtmlOptions) {\n    // Create an index HTML generator that reads from the in-memory output files\n    const indexHtmlGenerator = new IndexHtmlGenerator({\n      indexPath: indexHtmlOptions.input,\n      entrypoints: indexHtmlOptions.insertionOrder,\n      sri: options.subresourceIntegrity,\n      optimization: optimizationOptions,\n      crossOrigin: options.crossOrigin,\n    });\n\n    /** Virtual output path to support reading in-memory files. */\n    const virtualOutputPath = '/';\n    indexHtmlGenerator.readAsset = async function (filePath: string): Promise<string> {\n      // Remove leading directory separator\n      const relativefilePath = path.relative(virtualOutputPath, filePath);\n      const file = outputFiles.find((file) => file.path === relativefilePath);\n      if (file) {\n        return file.text;\n      }\n\n      throw new Error(`Output file does not exist: ${path}`);\n    };\n\n    const { content, warnings, errors } = await indexHtmlGenerator.process({\n      baseHref: options.baseHref,\n      lang: undefined,\n      outputPath: virtualOutputPath,\n      files: initialFiles,\n    });\n\n    for (const error of errors) {\n      context.logger.error(error);\n    }\n    for (const warning of warnings) {\n      context.logger.warn(warning);\n    }\n\n    outputFiles.push(createOutputFileFromText(indexHtmlOptions.output, content));\n  }\n\n  // Copy assets\n  if (assets) {\n    await copyAssets(assets, [outputPath], workspaceRoot);\n  }\n\n  // Write output files\n  await Promise.all(\n    outputFiles.map((file) => fs.writeFile(path.join(outputPath, file.path), file.contents)),\n  );\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    await fs.writeFile(path.join(outputPath, 'stats.json'), JSON.stringify(metafile, null, 2));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    await fs.writeFile(\n      path.join(outputPath, '3rdpartylicenses.txt'),\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  // TODO: This should eventually operate on the in-memory files prior to writing the output files\n  if (serviceWorkerOptions) {\n    try {\n      await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorkerOptions,\n        outputPath,\n        options.baseHref || '/',\n      );\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return new ExecutionResult(\n        false,\n        codeBundleContext,\n        globalStylesBundleContext,\n        codeBundleCache,\n      );\n    }\n  }\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Complete. [${buildTime.toFixed(3)} seconds]`);\n\n  return new ExecutionResult(true, codeBundleContext, globalStylesBundleContext, codeBundleCache);\n}\n\nfunction createOutputFileFromText(path: string, text: string): OutputFile {\n  return {\n    path,\n    text,\n    get contents() {\n      return Buffer.from(this.text, 'utf-8');\n    },\n  };\n}\n\nfunction createCodeBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n  sourceFileCache?: SourceFileCache,\n): BuildOptions {\n  const {\n    workspaceRoot,\n    entryPoints,\n    optimizationOptions,\n    sourcemapOptions,\n    tsconfig,\n    outputNames,\n    fileReplacements,\n    externalDependencies,\n    preserveSymlinks,\n    stylePreprocessorOptions,\n    advancedOptimizations,\n    inlineStyleLanguage,\n  } = options;\n\n  return {\n    absWorkingDir: workspaceRoot,\n    bundle: true,\n    format: 'esm',\n    entryPoints,\n    entryNames: outputNames.bundles,\n    assetNames: outputNames.media,\n    target,\n    supported: getFeatureSupport(target),\n    mainFields: ['es2020', 'browser', 'module', 'main'],\n    conditions: ['es2020', 'es2015', 'module'],\n    resolveExtensions: ['.ts', '.tsx', '.mjs', '.js'],\n    metafile: true,\n    legalComments: options.extractLicenses ? 'none' : 'eof',\n    logLevel: options.verbose ? 'debug' : 'silent',\n    minify: optimizationOptions.scripts,\n    pure: ['forwardRef'],\n    outdir: workspaceRoot,\n    sourcemap: sourcemapOptions.scripts && (sourcemapOptions.hidden ? 'external' : true),\n    splitting: true,\n    tsconfig,\n    external: externalDependencies,\n    write: false,\n    platform: 'browser',\n    preserveSymlinks,\n    plugins: [\n      createCompilerPlugin(\n        // JS/TS options\n        {\n          sourcemap: !!sourcemapOptions.scripts,\n          thirdPartySourcemaps: sourcemapOptions.vendor,\n          tsconfig,\n          advancedOptimizations,\n          fileReplacements,\n          sourceFileCache,\n        },\n        // Component stylesheet options\n        {\n          workspaceRoot,\n          optimization: !!optimizationOptions.styles.minify,\n          sourcemap:\n            // Hidden component stylesheet sourcemaps are inaccessible which is effectively\n            // the same as being disabled. Disabling has the advantage of avoiding the overhead\n            // of sourcemap processing.\n            !!sourcemapOptions.styles && (sourcemapOptions.hidden ? false : 'inline'),\n          outputNames,\n          includePaths: stylePreprocessorOptions?.includePaths,\n          externalDependencies,\n          target,\n          inlineStyleLanguage,\n        },\n      ),\n    ],\n    define: {\n      // Only set to false when script optimizations are enabled. It should not be set to true because\n      // Angular turns `ngDevMode` into an object for development debugging purposes when not defined\n      // which a constant true value would break.\n      ...(optimizationOptions.scripts ? { 'ngDevMode': 'false' } : undefined),\n      // Only AOT mode is supported currently\n      'ngJitMode': 'false',\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 */\nfunction 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 and for await...of to a Zone.js supported form. However, esbuild\n    // does not currently support downleveling async generators. Instead babel is used within the JS/TS\n    // loader to perform the downlevel transformation.\n    // NOTE: If esbuild adds support in the future, the babel support for async generators can be disabled.\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\nfunction createGlobalStylesBundleOptions(\n  options: NormalizedBrowserOptions,\n  target: string[],\n): BuildOptions {\n  const {\n    workspaceRoot,\n    optimizationOptions,\n    sourcemapOptions,\n    outputNames,\n    globalStyles,\n    preserveSymlinks,\n    externalDependencies,\n    stylePreprocessorOptions,\n    watch,\n  } = options;\n\n  const buildOptions = createStylesheetBundleOptions({\n    workspaceRoot,\n    optimization: !!optimizationOptions.styles.minify,\n    sourcemap: !!sourcemapOptions.styles,\n    preserveSymlinks,\n    target,\n    externalDependencies,\n    outputNames,\n    includePaths: stylePreprocessorOptions?.includePaths,\n  });\n  buildOptions.legalComments = options.extractLicenses ? 'none' : 'eof';\n\n  const namespace = 'angular:styles/global';\n  buildOptions.entryPoints = {};\n  for (const { name } of globalStyles) {\n    buildOptions.entryPoints[name] = `${namespace};${name}`;\n  }\n\n  buildOptions.plugins.unshift({\n    name: 'angular-global-styles',\n    setup(build) {\n      build.onResolve({ filter: /^angular:styles\\/global;/ }, (args) => {\n        if (args.kind !== 'entry-point') {\n          return null;\n        }\n\n        return {\n          path: args.path.split(';', 2)[1],\n          namespace,\n        };\n      });\n      build.onLoad({ filter: /./, namespace }, (args) => {\n        const files = globalStyles.find(({ name }) => name === args.path)?.files;\n        assert(files, `global style name should always be found [${args.path}]`);\n\n        return {\n          contents: files.map((file) => `@import '${file.replace(/\\\\/g, '/')}';`).join('\\n'),\n          loader: 'css',\n          resolveDir: workspaceRoot,\n        };\n      });\n    },\n  });\n\n  return buildOptions;\n}\n\n/**\n * Main execution function for the esbuild-based application builder.\n * The options are compatible with the Webpack-based builder.\n * @param initialOptions The browser builder options to use when setting up the application build\n * @param context The Architect builder context object\n * @returns An async iterable with the builder result output\n */\nexport async function* buildEsbuildBrowser(\n  initialOptions: BrowserBuilderOptions,\n  context: BuilderContext,\n): AsyncIterable<BuilderOutput> {\n  // Only AOT is currently supported\n  if (initialOptions.aot !== true) {\n    context.logger.error(\n      'JIT mode is currently not supported by this experimental builder. AOT mode must be used.',\n    );\n\n    return;\n  }\n\n  // Inform user of experimental status of builder and options\n  logExperimentalWarnings(initialOptions, context);\n\n  // Determine project name from builder context target\n  const projectName = context.target?.project;\n  if (!projectName) {\n    context.logger.error(`The 'browser-esbuild' builder requires a target to be specified.`);\n\n    return;\n  }\n\n  const normalizedOptions = await normalizeOptions(context, projectName, initialOptions);\n\n  // Clean output path if enabled\n  if (initialOptions.deleteOutputPath) {\n    deleteOutputDir(normalizedOptions.workspaceRoot, initialOptions.outputPath);\n  }\n\n  // Create output directory if needed\n  try {\n    await fs.mkdir(normalizedOptions.outputPath, { recursive: true });\n  } catch (e) {\n    assertIsError(e);\n    context.logger.error('Unable to create output directory: ' + e.message);\n\n    return;\n  }\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await execute(normalizedOptions, context);\n    yield result.output;\n\n    // Finish if watch mode is not enabled\n    if (!initialOptions.watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!initialOptions.watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  context.logger.info('Watch mode enabled. Watching for file changes...');\n\n  // Setup a watcher\n  const watcher = createWatcher({\n    polling: typeof initialOptions.poll === 'number',\n    interval: initialOptions.poll,\n    // Ignore the output and cache paths to avoid infinite rebuild cycles\n    ignored: [normalizedOptions.outputPath, normalizedOptions.cacheOptions.basePath],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(normalizedOptions.projectRoot);\n\n  // Watch workspace root node modules\n  // Includes Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n  watcher.add(path.join(normalizedOptions.workspaceRoot, 'node_modules'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.cjs'));\n  watcher.add(path.join(normalizedOptions.workspaceRoot, '.pnp.data.json'));\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      context.logger.info('Changes detected. Rebuilding...');\n\n      if (initialOptions.verbose) {\n        context.logger.info(changes.toDebugString());\n      }\n\n      result = await execute(normalizedOptions, context, result.createRebuildState(changes));\n      yield result.output;\n    }\n  } finally {\n    // Stop the watcher\n    await watcher.close();\n    // Cleanup incremental rebuild state\n    await result.dispose();\n    shutdownSassWorkerPool();\n  }\n}\n\nexport default createBuilder(buildEsbuildBrowser);\n"]}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google LLC 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 type { Metafile } from 'esbuild';
9
+ /**
10
+ * Extracts license information for each node module package included in the output
11
+ * files of the built code. This includes JavaScript and CSS output files. The esbuild
12
+ * metafile generated during the bundling steps is used as the source of information
13
+ * regarding what input files where included and where they are located. A path segment
14
+ * of `node_modules` is used to indicate that a file belongs to a package and its license
15
+ * should be include in the output licenses file.
16
+ *
17
+ * The package name and license field are extracted from the `package.json` file for the
18
+ * package. If a license file (e.g., `LICENSE`) is present in the root of the package, it
19
+ * will also be included in the output licenses file.
20
+ *
21
+ * @param metafile An esbuild metafile object.
22
+ * @param rootDirectory The root directory of the workspace.
23
+ * @returns A string containing the content of the output licenses file.
24
+ */
25
+ export declare function extractLicenses(metafile: Metafile, rootDirectory: string): Promise<string>;