@angular-devkit/build-angular 17.0.0-next.6 → 17.0.0-next.7

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 CHANGED
@@ -1,29 +1,29 @@
1
1
  {
2
2
  "name": "@angular-devkit/build-angular",
3
- "version": "17.0.0-next.6",
3
+ "version": "17.0.0-next.7",
4
4
  "description": "Angular Webpack Build Facade",
5
5
  "main": "src/index.js",
6
6
  "typings": "src/index.d.ts",
7
7
  "builders": "builders.json",
8
8
  "dependencies": {
9
9
  "@ampproject/remapping": "2.2.1",
10
- "@angular-devkit/architect": "0.1700.0-next.6",
11
- "@angular-devkit/build-webpack": "0.1700.0-next.6",
12
- "@angular-devkit/core": "17.0.0-next.6",
13
- "@babel/core": "7.22.17",
14
- "@babel/generator": "7.22.15",
10
+ "@angular-devkit/architect": "0.1700.0-next.7",
11
+ "@angular-devkit/build-webpack": "0.1700.0-next.7",
12
+ "@angular-devkit/core": "17.0.0-next.7",
13
+ "@babel/core": "7.23.0",
14
+ "@babel/generator": "7.23.0",
15
15
  "@babel/helper-annotate-as-pure": "7.22.5",
16
16
  "@babel/helper-split-export-declaration": "7.22.6",
17
17
  "@babel/plugin-transform-async-generator-functions": "7.22.15",
18
18
  "@babel/plugin-transform-async-to-generator": "7.22.5",
19
19
  "@babel/plugin-transform-runtime": "7.22.15",
20
- "@babel/preset-env": "7.22.15",
21
- "@babel/runtime": "7.22.15",
20
+ "@babel/preset-env": "7.22.20",
21
+ "@babel/runtime": "7.23.1",
22
22
  "@discoveryjs/json-ext": "0.5.7",
23
- "@ngtools/webpack": "17.0.0-next.6",
23
+ "@ngtools/webpack": "17.0.0-next.7",
24
24
  "@vitejs/plugin-basic-ssl": "1.0.1",
25
25
  "ansi-colors": "4.1.3",
26
- "autoprefixer": "10.4.15",
26
+ "autoprefixer": "10.4.16",
27
27
  "babel-loader": "9.1.3",
28
28
  "babel-plugin-istanbul": "6.1.1",
29
29
  "browserslist": "^4.21.5",
@@ -32,7 +32,7 @@
32
32
  "copy-webpack-plugin": "11.0.0",
33
33
  "critters": "0.0.20",
34
34
  "css-loader": "6.8.1",
35
- "esbuild-wasm": "0.19.3",
35
+ "esbuild-wasm": "0.19.4",
36
36
  "fast-glob": "3.3.1",
37
37
  "https-proxy-agent": "7.0.2",
38
38
  "http-proxy-middleware": "2.0.6",
@@ -43,7 +43,7 @@
43
43
  "less-loader": "11.1.0",
44
44
  "license-webpack-plugin": "4.0.2",
45
45
  "loader-utils": "3.2.1",
46
- "magic-string": "0.30.3",
46
+ "magic-string": "0.30.4",
47
47
  "mini-css-extract-plugin": "2.7.6",
48
48
  "mrmime": "1.0.1",
49
49
  "open": "8.4.2",
@@ -51,7 +51,7 @@
51
51
  "parse5-html-rewriting-stream": "7.0.0",
52
52
  "picomatch": "2.3.1",
53
53
  "piscina": "4.1.0",
54
- "postcss": "8.4.29",
54
+ "postcss": "8.4.31",
55
55
  "postcss-loader": "7.3.3",
56
56
  "resolve-url-loader": "5.0.0",
57
57
  "rxjs": "7.8.1",
@@ -60,11 +60,11 @@
60
60
  "semver": "7.5.4",
61
61
  "source-map-loader": "4.0.1",
62
62
  "source-map-support": "0.5.21",
63
- "terser": "5.19.4",
63
+ "terser": "5.21.0",
64
64
  "text-table": "0.2.0",
65
65
  "tree-kill": "1.2.2",
66
66
  "tslib": "2.6.2",
67
- "vite": "4.4.9",
67
+ "vite": "4.4.10",
68
68
  "webpack": "5.88.2",
69
69
  "webpack-dev-middleware": "6.1.1",
70
70
  "webpack-dev-server": "4.15.1",
@@ -72,7 +72,7 @@
72
72
  "webpack-subresource-integrity": "5.1.0"
73
73
  },
74
74
  "optionalDependencies": {
75
- "esbuild": "0.19.3"
75
+ "esbuild": "0.19.4"
76
76
  },
77
77
  "peerDependencies": {
78
78
  "@angular/compiler-cli": "^17.0.0 || ^17.0.0-next.0",
@@ -21,4 +21,5 @@ export declare function runEsBuildBuildAction(action: (rebuildState?: RebuildSta
21
21
  progress?: boolean;
22
22
  deleteOutputPath?: boolean;
23
23
  poll?: number;
24
+ signal?: AbortSignal;
24
25
  }): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput>;
@@ -65,20 +65,6 @@ async function* runEsBuildBuildAction(action, options) {
65
65
  let result;
66
66
  try {
67
67
  result = await withProgress('Building...', () => action());
68
- if (writeToFileSystem) {
69
- // Write output files
70
- await (0, utils_1.writeResultFiles)(result.outputFiles, result.assetFiles, outputPath);
71
- yield result.output;
72
- }
73
- else {
74
- // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.
75
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
76
- yield result.outputWithFiles;
77
- }
78
- // Finish if watch mode is not enabled
79
- if (!watch) {
80
- return;
81
- }
82
68
  }
83
69
  finally {
84
70
  // Ensure Sass workers are shutdown if not watching
@@ -86,46 +72,72 @@ async function* runEsBuildBuildAction(action, options) {
86
72
  (0, sass_language_1.shutdownSassWorkerPool)();
87
73
  }
88
74
  }
89
- if (progress) {
90
- logger.info('Watch mode enabled. Watching for file changes...');
75
+ // Setup watcher if watch mode enabled
76
+ let watcher;
77
+ if (watch) {
78
+ if (progress) {
79
+ logger.info('Watch mode enabled. Watching for file changes...');
80
+ }
81
+ // Setup a watcher
82
+ const { createWatcher } = await Promise.resolve().then(() => __importStar(require('../../tools/esbuild/watcher')));
83
+ watcher = createWatcher({
84
+ polling: typeof poll === 'number',
85
+ interval: poll,
86
+ ignored: [
87
+ // Ignore the output and cache paths to avoid infinite rebuild cycles
88
+ outputPath,
89
+ cacheOptions.basePath,
90
+ // Ignore all node modules directories to avoid excessive file watchers.
91
+ // Package changes are handled below by watching manifest and lock files.
92
+ '**/node_modules/**',
93
+ '**/.*/**',
94
+ ],
95
+ });
96
+ // Setup abort support
97
+ options.signal?.addEventListener('abort', () => void watcher?.close());
98
+ // Temporarily watch the entire project
99
+ watcher.add(projectRoot);
100
+ // Watch workspace for package manager changes
101
+ const packageWatchFiles = [
102
+ // manifest can affect module resolution
103
+ 'package.json',
104
+ // npm lock file
105
+ 'package-lock.json',
106
+ // pnpm lock file
107
+ 'pnpm-lock.yaml',
108
+ // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
109
+ 'yarn.lock',
110
+ '.pnp.cjs',
111
+ '.pnp.data.json',
112
+ ];
113
+ watcher.add(packageWatchFiles.map((file) => node_path_1.default.join(workspaceRoot, file)));
114
+ // Watch locations provided by the initial build result
115
+ watcher.add(result.watchFiles);
116
+ }
117
+ // Output the first build results after setting up the watcher to ensure that any code executed
118
+ // higher in the iterator call stack will trigger the watcher. This is particularly relevant for
119
+ // unit tests which execute the builder and modify the file system programmatically.
120
+ if (writeToFileSystem) {
121
+ // Write output files
122
+ await (0, utils_1.writeResultFiles)(result.outputFiles, result.assetFiles, outputPath);
123
+ yield result.output;
124
+ }
125
+ else {
126
+ // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.
127
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
128
+ yield result.outputWithFiles;
129
+ }
130
+ // Finish if watch mode is not enabled
131
+ if (!watcher) {
132
+ return;
91
133
  }
92
- // Setup a watcher
93
- const { createWatcher } = await Promise.resolve().then(() => __importStar(require('../../tools/esbuild/watcher')));
94
- const watcher = createWatcher({
95
- polling: typeof poll === 'number',
96
- interval: poll,
97
- ignored: [
98
- // Ignore the output and cache paths to avoid infinite rebuild cycles
99
- outputPath,
100
- cacheOptions.basePath,
101
- // Ignore all node modules directories to avoid excessive file watchers.
102
- // Package changes are handled below by watching manifest and lock files.
103
- '**/node_modules/**',
104
- '**/.*/**',
105
- ],
106
- });
107
- // Temporarily watch the entire project
108
- watcher.add(projectRoot);
109
- // Watch workspace for package manager changes
110
- const packageWatchFiles = [
111
- // manifest can affect module resolution
112
- 'package.json',
113
- // npm lock file
114
- 'package-lock.json',
115
- // pnpm lock file
116
- 'pnpm-lock.yaml',
117
- // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)
118
- 'yarn.lock',
119
- '.pnp.cjs',
120
- '.pnp.data.json',
121
- ];
122
- watcher.add(packageWatchFiles.map((file) => node_path_1.default.join(workspaceRoot, file)));
123
- // Watch locations provided by the initial build result
124
- let previousWatchFiles = new Set(result.watchFiles);
125
- watcher.add(result.watchFiles);
126
134
  // Wait for changes and rebuild as needed
135
+ let previousWatchFiles = new Set(result.watchFiles);
127
136
  try {
128
137
  for await (const changes of watcher) {
138
+ if (options.signal?.aborted) {
139
+ break;
140
+ }
129
141
  if (verbose) {
130
142
  logger.info(changes.toDebugString());
131
143
  }
@@ -156,4 +168,4 @@ async function* runEsBuildBuildAction(action, options) {
156
168
  }
157
169
  }
158
170
  exports.runEsBuildBuildAction = runEsBuildBuildAction;
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-action.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/build-action.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 { BuilderOutput } from '@angular-devkit/architect';\nimport type { logging } from '@angular-devkit/core';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { shutdownSassWorkerPool } from '../../tools/esbuild/stylesheets/sass-language';\nimport { withNoProgress, withSpinner, writeResultFiles } from '../../tools/esbuild/utils';\nimport { assertIsError } from '../../utils/error';\nimport { NormalizedCachedOptions } from '../../utils/normalize-cache';\n\nexport async function* runEsBuildBuildAction(\n  action: (rebuildState?: RebuildState) => ExecutionResult | Promise<ExecutionResult>,\n  options: {\n    workspaceRoot: string;\n    projectRoot: string;\n    outputPath: string;\n    logger: logging.LoggerApi;\n    cacheOptions: NormalizedCachedOptions;\n    writeToFileSystem?: boolean;\n    watch?: boolean;\n    verbose?: boolean;\n    progress?: boolean;\n    deleteOutputPath?: boolean;\n    poll?: number;\n  },\n): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput> {\n  const {\n    writeToFileSystem = true,\n    watch,\n    poll,\n    logger,\n    deleteOutputPath,\n    cacheOptions,\n    outputPath,\n    verbose,\n    projectRoot,\n    workspaceRoot,\n    progress,\n  } = options;\n\n  if (writeToFileSystem) {\n    // Clean output path if enabled\n    if (deleteOutputPath) {\n      if (outputPath === workspaceRoot) {\n        logger.error('Output path MUST not be workspace root directory!');\n\n        return;\n      }\n\n      await fs.rm(outputPath, { force: true, recursive: true, maxRetries: 3 });\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  const withProgress: typeof withSpinner = progress ? withSpinner : withNoProgress;\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await withProgress('Building...', () => action());\n\n    if (writeToFileSystem) {\n      // Write output files\n      await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n      yield result.output;\n    } else {\n      // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      yield result.outputWithFiles as any;\n    }\n\n    // Finish if watch mode is not enabled\n    if (!watch) {\n      return;\n    }\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  if (progress) {\n    logger.info('Watch mode enabled. Watching for file changes...');\n  }\n\n  // Setup a watcher\n  const { createWatcher } = await import('../../tools/esbuild/watcher');\n  const watcher = createWatcher({\n    polling: typeof poll === 'number',\n    interval: poll,\n    ignored: [\n      // Ignore the output and cache paths to avoid infinite rebuild cycles\n      outputPath,\n      cacheOptions.basePath,\n      // Ignore all node modules directories to avoid excessive file watchers.\n      // Package changes are handled below by watching manifest and lock files.\n      '**/node_modules/**',\n      '**/.*/**',\n    ],\n  });\n\n  // Temporarily watch the entire project\n  watcher.add(projectRoot);\n\n  // Watch workspace for package manager changes\n  const packageWatchFiles = [\n    // manifest can affect module resolution\n    'package.json',\n    // npm lock file\n    'package-lock.json',\n    // pnpm lock file\n    'pnpm-lock.yaml',\n    // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n    'yarn.lock',\n    '.pnp.cjs',\n    '.pnp.data.json',\n  ];\n\n  watcher.add(packageWatchFiles.map((file) => path.join(workspaceRoot, file)));\n\n  // Watch locations provided by the initial build result\n  let previousWatchFiles = new Set(result.watchFiles);\n  watcher.add(result.watchFiles);\n\n  // Wait for changes and rebuild as needed\n  try {\n    for await (const changes of watcher) {\n      if (verbose) {\n        logger.info(changes.toDebugString());\n      }\n\n      result = await withProgress('Changes detected. Rebuilding...', () =>\n        action(result.createRebuildState(changes)),\n      );\n\n      // Update watched locations provided by the new build result.\n      // Add any new locations\n      watcher.add(result.watchFiles.filter((watchFile) => !previousWatchFiles.has(watchFile)));\n      const newWatchFiles = new Set(result.watchFiles);\n      // Remove any old locations\n      watcher.remove([...previousWatchFiles].filter((watchFile) => !newWatchFiles.has(watchFile)));\n      previousWatchFiles = newWatchFiles;\n\n      if (writeToFileSystem) {\n        // Write output files\n        await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n        yield result.output;\n      } else {\n        // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        yield result.outputWithFiles as any;\n      }\n    }\n  } finally {\n    // Stop the watcher and cleanup incremental rebuild state\n    await Promise.allSettled([watcher.close(), result.dispose()]);\n\n    shutdownSassWorkerPool();\n  }\n}\n"]}
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-action.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/build-action.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIH,gEAAkC;AAClC,0DAA6B;AAE7B,iFAAuF;AACvF,qDAA0F;AAC1F,6CAAkD;AAG3C,KAAK,SAAS,CAAC,CAAC,qBAAqB,CAC1C,MAAmF,EACnF,OAaC;IAED,MAAM,EACJ,iBAAiB,GAAG,IAAI,EACxB,KAAK,EACL,IAAI,EACJ,MAAM,EACN,gBAAgB,EAChB,YAAY,EACZ,UAAU,EACV,OAAO,EACP,WAAW,EACX,aAAa,EACb,QAAQ,GACT,GAAG,OAAO,CAAC;IAEZ,IAAI,iBAAiB,EAAE;QACrB,+BAA+B;QAC/B,IAAI,gBAAgB,EAAE;YACpB,IAAI,UAAU,KAAK,aAAa,EAAE;gBAChC,MAAM,CAAC,KAAK,CAAC,mDAAmD,CAAC,CAAC;gBAElE,OAAO;aACR;YAED,MAAM,kBAAE,CAAC,EAAE,CAAC,UAAU,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;SAC1E;QAED,oCAAoC;QACpC,IAAI;YACF,MAAM,kBAAE,CAAC,KAAK,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;SACjD;QAAC,OAAO,CAAC,EAAE;YACV,IAAA,qBAAa,EAAC,CAAC,CAAC,CAAC;YACjB,MAAM,CAAC,KAAK,CAAC,qCAAqC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC;YAEhE,OAAO;SACR;KACF;IAED,MAAM,YAAY,GAAuB,QAAQ,CAAC,CAAC,CAAC,mBAAW,CAAC,CAAC,CAAC,sBAAc,CAAC;IAEjF,gBAAgB;IAChB,IAAI,MAAuB,CAAC;IAC5B,IAAI;QACF,MAAM,GAAG,MAAM,YAAY,CAAC,aAAa,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC;KAC5D;YAAS;QACR,mDAAmD;QACnD,IAAI,CAAC,KAAK,EAAE;YACV,IAAA,sCAAsB,GAAE,CAAC;SAC1B;KACF;IAED,sCAAsC;IACtC,IAAI,OAAuE,CAAC;IAC5E,IAAI,KAAK,EAAE;QACT,IAAI,QAAQ,EAAE;YACZ,MAAM,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAC;SACjE;QAED,kBAAkB;QAClB,MAAM,EAAE,aAAa,EAAE,GAAG,wDAAa,6BAA6B,GAAC,CAAC;QACtE,OAAO,GAAG,aAAa,CAAC;YACtB,OAAO,EAAE,OAAO,IAAI,KAAK,QAAQ;YACjC,QAAQ,EAAE,IAAI;YACd,OAAO,EAAE;gBACP,qEAAqE;gBACrE,UAAU;gBACV,YAAY,CAAC,QAAQ;gBACrB,wEAAwE;gBACxE,yEAAyE;gBACzE,oBAAoB;gBACpB,UAAU;aACX;SACF,CAAC,CAAC;QAEH,sBAAsB;QACtB,OAAO,CAAC,MAAM,EAAE,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,KAAK,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QAEvE,uCAAuC;QACvC,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QAEzB,8CAA8C;QAC9C,MAAM,iBAAiB,GAAG;YACxB,wCAAwC;YACxC,cAAc;YACd,gBAAgB;YAChB,mBAAmB;YACnB,iBAAiB;YACjB,gBAAgB;YAChB,4FAA4F;YAC5F,WAAW;YACX,UAAU;YACV,gBAAgB;SACjB,CAAC;QAEF,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,mBAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;QAE7E,uDAAuD;QACvD,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;KAChC;IAED,+FAA+F;IAC/F,gGAAgG;IAChG,oFAAoF;IACpF,IAAI,iBAAiB,EAAE;QACrB,qBAAqB;QACrB,MAAM,IAAA,wBAAgB,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAE1E,MAAM,MAAM,CAAC,MAAM,CAAC;KACrB;SAAM;QACL,gFAAgF;QAChF,8DAA8D;QAC9D,MAAM,MAAM,CAAC,eAAsB,CAAC;KACrC;IAED,sCAAsC;IACtC,IAAI,CAAC,OAAO,EAAE;QACZ,OAAO;KACR;IAED,yCAAyC;IACzC,IAAI,kBAAkB,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACpD,IAAI;QACF,IAAI,KAAK,EAAE,MAAM,OAAO,IAAI,OAAO,EAAE;YACnC,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE;gBAC3B,MAAM;aACP;YAED,IAAI,OAAO,EAAE;gBACX,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;aACtC;YAED,MAAM,GAAG,MAAM,YAAY,CAAC,iCAAiC,EAAE,GAAG,EAAE,CAClE,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAC3C,CAAC;YAEF,6DAA6D;YAC7D,wBAAwB;YACxB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YACzF,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YACjD,2BAA2B;YAC3B,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,kBAAkB,CAAC,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAC7F,kBAAkB,GAAG,aAAa,CAAC;YAEnC,IAAI,iBAAiB,EAAE;gBACrB,qBAAqB;gBACrB,MAAM,IAAA,wBAAgB,EAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;gBAE1E,MAAM,MAAM,CAAC,MAAM,CAAC;aACrB;iBAAM;gBACL,gFAAgF;gBAChF,8DAA8D;gBAC9D,MAAM,MAAM,CAAC,eAAsB,CAAC;aACrC;SACF;KACF;YAAS;QACR,yDAAyD;QACzD,MAAM,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;QAE9D,IAAA,sCAAsB,GAAE,CAAC;KAC1B;AACH,CAAC;AAhLD,sDAgLC","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 { BuilderOutput } from '@angular-devkit/architect';\nimport type { logging } from '@angular-devkit/core';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { shutdownSassWorkerPool } from '../../tools/esbuild/stylesheets/sass-language';\nimport { withNoProgress, withSpinner, writeResultFiles } from '../../tools/esbuild/utils';\nimport { assertIsError } from '../../utils/error';\nimport { NormalizedCachedOptions } from '../../utils/normalize-cache';\n\nexport async function* runEsBuildBuildAction(\n  action: (rebuildState?: RebuildState) => ExecutionResult | Promise<ExecutionResult>,\n  options: {\n    workspaceRoot: string;\n    projectRoot: string;\n    outputPath: string;\n    logger: logging.LoggerApi;\n    cacheOptions: NormalizedCachedOptions;\n    writeToFileSystem?: boolean;\n    watch?: boolean;\n    verbose?: boolean;\n    progress?: boolean;\n    deleteOutputPath?: boolean;\n    poll?: number;\n    signal?: AbortSignal;\n  },\n): AsyncIterable<(ExecutionResult['outputWithFiles'] | ExecutionResult['output']) & BuilderOutput> {\n  const {\n    writeToFileSystem = true,\n    watch,\n    poll,\n    logger,\n    deleteOutputPath,\n    cacheOptions,\n    outputPath,\n    verbose,\n    projectRoot,\n    workspaceRoot,\n    progress,\n  } = options;\n\n  if (writeToFileSystem) {\n    // Clean output path if enabled\n    if (deleteOutputPath) {\n      if (outputPath === workspaceRoot) {\n        logger.error('Output path MUST not be workspace root directory!');\n\n        return;\n      }\n\n      await fs.rm(outputPath, { force: true, recursive: true, maxRetries: 3 });\n    }\n\n    // Create output directory if needed\n    try {\n      await fs.mkdir(outputPath, { recursive: true });\n    } catch (e) {\n      assertIsError(e);\n      logger.error('Unable to create output directory: ' + e.message);\n\n      return;\n    }\n  }\n\n  const withProgress: typeof withSpinner = progress ? withSpinner : withNoProgress;\n\n  // Initial build\n  let result: ExecutionResult;\n  try {\n    result = await withProgress('Building...', () => action());\n  } finally {\n    // Ensure Sass workers are shutdown if not watching\n    if (!watch) {\n      shutdownSassWorkerPool();\n    }\n  }\n\n  // Setup watcher if watch mode enabled\n  let watcher: import('../../tools/esbuild/watcher').BuildWatcher | undefined;\n  if (watch) {\n    if (progress) {\n      logger.info('Watch mode enabled. Watching for file changes...');\n    }\n\n    // Setup a watcher\n    const { createWatcher } = await import('../../tools/esbuild/watcher');\n    watcher = createWatcher({\n      polling: typeof poll === 'number',\n      interval: poll,\n      ignored: [\n        // Ignore the output and cache paths to avoid infinite rebuild cycles\n        outputPath,\n        cacheOptions.basePath,\n        // Ignore all node modules directories to avoid excessive file watchers.\n        // Package changes are handled below by watching manifest and lock files.\n        '**/node_modules/**',\n        '**/.*/**',\n      ],\n    });\n\n    // Setup abort support\n    options.signal?.addEventListener('abort', () => void watcher?.close());\n\n    // Temporarily watch the entire project\n    watcher.add(projectRoot);\n\n    // Watch workspace for package manager changes\n    const packageWatchFiles = [\n      // manifest can affect module resolution\n      'package.json',\n      // npm lock file\n      'package-lock.json',\n      // pnpm lock file\n      'pnpm-lock.yaml',\n      // yarn lock file including Yarn PnP manifest files (https://yarnpkg.com/advanced/pnp-spec/)\n      'yarn.lock',\n      '.pnp.cjs',\n      '.pnp.data.json',\n    ];\n\n    watcher.add(packageWatchFiles.map((file) => path.join(workspaceRoot, file)));\n\n    // Watch locations provided by the initial build result\n    watcher.add(result.watchFiles);\n  }\n\n  // Output the first build results after setting up the watcher to ensure that any code executed\n  // higher in the iterator call stack will trigger the watcher. This is particularly relevant for\n  // unit tests which execute the builder and modify the file system programmatically.\n  if (writeToFileSystem) {\n    // Write output files\n    await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n    yield result.output;\n  } else {\n    // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    yield result.outputWithFiles as any;\n  }\n\n  // Finish if watch mode is not enabled\n  if (!watcher) {\n    return;\n  }\n\n  // Wait for changes and rebuild as needed\n  let previousWatchFiles = new Set(result.watchFiles);\n  try {\n    for await (const changes of watcher) {\n      if (options.signal?.aborted) {\n        break;\n      }\n\n      if (verbose) {\n        logger.info(changes.toDebugString());\n      }\n\n      result = await withProgress('Changes detected. Rebuilding...', () =>\n        action(result.createRebuildState(changes)),\n      );\n\n      // Update watched locations provided by the new build result.\n      // Add any new locations\n      watcher.add(result.watchFiles.filter((watchFile) => !previousWatchFiles.has(watchFile)));\n      const newWatchFiles = new Set(result.watchFiles);\n      // Remove any old locations\n      watcher.remove([...previousWatchFiles].filter((watchFile) => !newWatchFiles.has(watchFile)));\n      previousWatchFiles = newWatchFiles;\n\n      if (writeToFileSystem) {\n        // Write output files\n        await writeResultFiles(result.outputFiles, result.assetFiles, outputPath);\n\n        yield result.output;\n      } else {\n        // Requires casting due to unneeded `JsonObject` requirement. Remove once fixed.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        yield result.outputWithFiles as any;\n      }\n    }\n  } finally {\n    // Stop the watcher and cleanup incremental rebuild state\n    await Promise.allSettled([watcher.close(), result.dispose()]);\n\n    shutdownSassWorkerPool();\n  }\n}\n"]}
@@ -112,7 +112,8 @@ async function executeBuild(options, context, rebuildState) {
112
112
  }
113
113
  }
114
114
  // Pre-render (SSG) and App-shell
115
- if (prerenderOptions || appShellOptions) {
115
+ // If localization is enabled, prerendering is handled in the inlining process.
116
+ if ((prerenderOptions || appShellOptions) && !options.i18nOptions.shouldInline) {
116
117
  (0, node_assert_1.default)(indexContentOutputNoCssInlining, 'The "index" option is required when using the "ssg" or "appShell" options.');
117
118
  const { output, warnings, errors } = await (0, prerender_1.prerenderPages)(workspaceRoot, appShellOptions, prerenderOptions, executionResult.outputFiles, indexContentOutputNoCssInlining, optimizationOptions.styles.inlineCritical, environment_options_1.maxWorkers, verbose);
118
119
  printWarningsAndErrorsToConsole(context, warnings, errors);
@@ -126,16 +127,13 @@ async function executeBuild(options, context, rebuildState) {
126
127
  // from directly writing to disk. This should eventually be replaced with a more optimized helper.
127
128
  executionResult.assetFiles.push(...(await (0, copy_assets_1.copyAssets)(assets, [], workspaceRoot)));
128
129
  }
129
- // Write metafile if stats option is enabled
130
- if (options.stats) {
131
- executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));
132
- }
133
130
  // Extract and write licenses for used packages
134
131
  if (options.extractLicenses) {
135
132
  executionResult.addOutputFile('3rdpartylicenses.txt', await (0, license_extractor_1.extractLicenses)(metafile, workspaceRoot));
136
133
  }
137
134
  // Augment the application with service worker support
138
- if (serviceWorker) {
135
+ // If localization is enabled, service worker is handled in the inlining process.
136
+ if (serviceWorker && !options.i18nOptions.shouldInline) {
139
137
  try {
140
138
  const serviceWorkerResult = await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(workspaceRoot, serviceWorker, options.baseHref || '/', executionResult.outputFiles, executionResult.assetFiles);
141
139
  executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);
@@ -156,7 +154,12 @@ async function executeBuild(options, context, rebuildState) {
156
154
  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);
157
155
  // Perform i18n translation inlining if enabled
158
156
  if (options.i18nOptions.shouldInline) {
159
- await (0, i18n_1.inlineI18n)(options, executionResult, initialFiles);
157
+ const { errors, warnings } = await (0, i18n_1.inlineI18n)(options, executionResult, initialFiles);
158
+ printWarningsAndErrorsToConsole(context, warnings, errors);
159
+ }
160
+ // Write metafile if stats option is enabled
161
+ if (options.stats) {
162
+ executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));
160
163
  }
161
164
  return executionResult;
162
165
  }
@@ -169,4 +172,4 @@ function printWarningsAndErrorsToConsole(context, warnings, errors) {
169
172
  context.logger.warn(warning);
170
173
  }
171
174
  }
172
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execute-build.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/execute-build.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 assert from 'node:assert';\nimport { SourceFileCache } from '../../tools/esbuild/angular/compiler-plugin';\nimport {\n  createBrowserCodeBundleOptions,\n  createServerCodeBundleOptions,\n} from '../../tools/esbuild/application-code-bundle';\nimport { BundlerContext } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { checkCommonJSModules } from '../../tools/esbuild/commonjs-checker';\nimport { createGlobalScriptsBundleOptions } from '../../tools/esbuild/global-scripts';\nimport { createGlobalStylesBundleOptions } from '../../tools/esbuild/global-styles';\nimport { generateIndexHtml } from '../../tools/esbuild/index-html-generator';\nimport { extractLicenses } from '../../tools/esbuild/license-extractor';\nimport {\n  calculateEstimatedTransferSizes,\n  logBuildStats,\n  logMessages,\n  transformSupportedBrowsersToTargets,\n} from '../../tools/esbuild/utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { maxWorkers } from '../../utils/environment-options';\nimport { prerenderPages } from '../../utils/server-rendering/prerender';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { inlineI18n, loadActiveTranslations } from './i18n';\nimport { NormalizedApplicationBuildOptions } from './options';\n\n// eslint-disable-next-line max-lines-per-function\nexport async function executeBuild(\n  options: NormalizedApplicationBuildOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    serviceWorker,\n    optimizationOptions,\n    serverEntryPoint,\n    assets,\n    indexHtmlOptions,\n    cacheOptions,\n    prerenderOptions,\n    appShellOptions,\n    ssrOptions,\n    verbose,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Load active translations if inlining\n  // TODO: Integrate into watch mode and only load changed translations\n  if (options.i18nOptions.shouldInline) {\n    await loadActiveTranslations(context, options.i18nOptions);\n  }\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  let bundlerContexts = rebuildState?.rebuildContexts;\n  const codeBundleCache =\n    rebuildState?.codeBundleCache ??\n    new SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);\n  if (bundlerContexts === undefined) {\n    bundlerContexts = [];\n\n    // Browser application code\n    bundlerContexts.push(\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createBrowserCodeBundleOptions(options, target, codeBundleCache),\n      ),\n    );\n\n    // Global Stylesheets\n    if (options.globalStyles.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalStylesBundleOptions(\n          options,\n          target,\n          initial,\n          codeBundleCache?.loadResultCache,\n        );\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Global Scripts\n    if (options.globalScripts.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalScriptsBundleOptions(options, initial);\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Server application code\n    if (serverEntryPoint) {\n      bundlerContexts.push(\n        new BundlerContext(\n          workspaceRoot,\n          !!options.watch,\n          createServerCodeBundleOptions(\n            options,\n            // NOTE: earlier versions of Node.js are not supported due to unsafe promise patching.\n            // See: https://github.com/angular/angular/pull/50552#issue-1737967592\n            [...target, 'node18.13'],\n            codeBundleCache,\n          ),\n          () => false,\n        ),\n      );\n    }\n  }\n\n  const bundlingResult = await BundlerContext.bundleAll(bundlerContexts);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, bundlingResult);\n\n  const executionResult = new ExecutionResult(bundlerContexts, codeBundleCache);\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  const { metafile, initialFiles, outputFiles } = bundlingResult;\n\n  executionResult.outputFiles.push(...outputFiles);\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  /**\n   * Index HTML content without CSS inlining to be used for server rendering (AppShell, SSG and SSR).\n   *\n   * NOTE: we don't perform critical CSS inlining as this will be done during server rendering.\n   */\n  let indexContentOutputNoCssInlining: string | undefined;\n\n  // Generate index HTML file\n  // If localization is enabled, index generation is handled in the inlining process.\n  // NOTE: Localization with SSR is not currently supported.\n  if (indexHtmlOptions && !options.i18nOptions.shouldInline) {\n    const { content, contentWithoutCriticalCssInlined, errors, warnings } = await generateIndexHtml(\n      initialFiles,\n      executionResult.outputFiles,\n      {\n        ...options,\n        optimizationOptions,\n      },\n      // Set lang attribute to the defined source locale if present\n      options.i18nOptions.hasDefinedSourceLocale ? options.i18nOptions.sourceLocale : undefined,\n    );\n\n    indexContentOutputNoCssInlining = contentWithoutCriticalCssInlined;\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    executionResult.addOutputFile(indexHtmlOptions.output, content);\n\n    if (ssrOptions) {\n      executionResult.addOutputFile('index.server.html', contentWithoutCriticalCssInlined);\n    }\n  }\n\n  // Pre-render (SSG) and App-shell\n  if (prerenderOptions || appShellOptions) {\n    assert(\n      indexContentOutputNoCssInlining,\n      'The \"index\" option is required when using the \"ssg\" or \"appShell\" options.',\n    );\n\n    const { output, warnings, errors } = await prerenderPages(\n      workspaceRoot,\n      appShellOptions,\n      prerenderOptions,\n      executionResult.outputFiles,\n      indexContentOutputNoCssInlining,\n      optimizationOptions.styles.inlineCritical,\n      maxWorkers,\n      verbose,\n    );\n\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    for (const [path, content] of Object.entries(output)) {\n      executionResult.addOutputFile(path, content);\n    }\n  }\n\n  // Copy assets\n  if (assets) {\n    // The webpack copy assets helper is used with no base paths defined. This prevents the helper\n    // from directly writing to disk. This should eventually be replaced with a more optimized helper.\n    executionResult.assetFiles.push(...(await copyAssets(assets, [], workspaceRoot)));\n  }\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    executionResult.addOutputFile(\n      '3rdpartylicenses.txt',\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  if (serviceWorker) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorker,\n        options.baseHref || '/',\n        executionResult.outputFiles,\n        executionResult.assetFiles,\n      );\n      executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);\n      executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return executionResult;\n    }\n  }\n\n  // Calculate estimated transfer size if scripts are optimized\n  let estimatedTransferSizes;\n  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {\n    estimatedTransferSizes = await calculateEstimatedTransferSizes(executionResult.outputFiles);\n  }\n\n  logBuildStats(context, metafile, initialFiles, estimatedTransferSizes);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);\n\n  // Perform i18n translation inlining if enabled\n  if (options.i18nOptions.shouldInline) {\n    await inlineI18n(options, executionResult, initialFiles);\n  }\n\n  return executionResult;\n}\n\nfunction printWarningsAndErrorsToConsole(\n  context: BuilderContext,\n  warnings: string[],\n  errors: string[],\n): void {\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"]}
175
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execute-build.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/execute-build.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 assert from 'node:assert';\nimport { SourceFileCache } from '../../tools/esbuild/angular/compiler-plugin';\nimport {\n  createBrowserCodeBundleOptions,\n  createServerCodeBundleOptions,\n} from '../../tools/esbuild/application-code-bundle';\nimport { BundlerContext } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult, RebuildState } from '../../tools/esbuild/bundler-execution-result';\nimport { checkCommonJSModules } from '../../tools/esbuild/commonjs-checker';\nimport { createGlobalScriptsBundleOptions } from '../../tools/esbuild/global-scripts';\nimport { createGlobalStylesBundleOptions } from '../../tools/esbuild/global-styles';\nimport { generateIndexHtml } from '../../tools/esbuild/index-html-generator';\nimport { extractLicenses } from '../../tools/esbuild/license-extractor';\nimport {\n  calculateEstimatedTransferSizes,\n  logBuildStats,\n  logMessages,\n  transformSupportedBrowsersToTargets,\n} from '../../tools/esbuild/utils';\nimport { copyAssets } from '../../utils/copy-assets';\nimport { maxWorkers } from '../../utils/environment-options';\nimport { prerenderPages } from '../../utils/server-rendering/prerender';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { getSupportedBrowsers } from '../../utils/supported-browsers';\nimport { inlineI18n, loadActiveTranslations } from './i18n';\nimport { NormalizedApplicationBuildOptions } from './options';\n\n// eslint-disable-next-line max-lines-per-function\nexport async function executeBuild(\n  options: NormalizedApplicationBuildOptions,\n  context: BuilderContext,\n  rebuildState?: RebuildState,\n): Promise<ExecutionResult> {\n  const startTime = process.hrtime.bigint();\n\n  const {\n    projectRoot,\n    workspaceRoot,\n    serviceWorker,\n    optimizationOptions,\n    serverEntryPoint,\n    assets,\n    indexHtmlOptions,\n    cacheOptions,\n    prerenderOptions,\n    appShellOptions,\n    ssrOptions,\n    verbose,\n  } = options;\n\n  const browsers = getSupportedBrowsers(projectRoot, context.logger);\n  const target = transformSupportedBrowsersToTargets(browsers);\n\n  // Load active translations if inlining\n  // TODO: Integrate into watch mode and only load changed translations\n  if (options.i18nOptions.shouldInline) {\n    await loadActiveTranslations(context, options.i18nOptions);\n  }\n\n  // Reuse rebuild state or create new bundle contexts for code and global stylesheets\n  let bundlerContexts = rebuildState?.rebuildContexts;\n  const codeBundleCache =\n    rebuildState?.codeBundleCache ??\n    new SourceFileCache(cacheOptions.enabled ? cacheOptions.path : undefined);\n  if (bundlerContexts === undefined) {\n    bundlerContexts = [];\n\n    // Browser application code\n    bundlerContexts.push(\n      new BundlerContext(\n        workspaceRoot,\n        !!options.watch,\n        createBrowserCodeBundleOptions(options, target, codeBundleCache),\n      ),\n    );\n\n    // Global Stylesheets\n    if (options.globalStyles.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalStylesBundleOptions(\n          options,\n          target,\n          initial,\n          codeBundleCache?.loadResultCache,\n        );\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Global Scripts\n    if (options.globalScripts.length > 0) {\n      for (const initial of [true, false]) {\n        const bundleOptions = createGlobalScriptsBundleOptions(options, initial);\n        if (bundleOptions) {\n          bundlerContexts.push(\n            new BundlerContext(workspaceRoot, !!options.watch, bundleOptions, () => initial),\n          );\n        }\n      }\n    }\n\n    // Server application code\n    if (serverEntryPoint) {\n      bundlerContexts.push(\n        new BundlerContext(\n          workspaceRoot,\n          !!options.watch,\n          createServerCodeBundleOptions(\n            options,\n            // NOTE: earlier versions of Node.js are not supported due to unsafe promise patching.\n            // See: https://github.com/angular/angular/pull/50552#issue-1737967592\n            [...target, 'node18.13'],\n            codeBundleCache,\n          ),\n          () => false,\n        ),\n      );\n    }\n  }\n\n  const bundlingResult = await BundlerContext.bundleAll(bundlerContexts);\n\n  // Log all warnings and errors generated during bundling\n  await logMessages(context, bundlingResult);\n\n  const executionResult = new ExecutionResult(bundlerContexts, codeBundleCache);\n\n  // Return if the bundling has errors\n  if (bundlingResult.errors) {\n    return executionResult;\n  }\n\n  const { metafile, initialFiles, outputFiles } = bundlingResult;\n\n  executionResult.outputFiles.push(...outputFiles);\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  /**\n   * Index HTML content without CSS inlining to be used for server rendering (AppShell, SSG and SSR).\n   *\n   * NOTE: we don't perform critical CSS inlining as this will be done during server rendering.\n   */\n  let indexContentOutputNoCssInlining: string | undefined;\n\n  // Generate index HTML file\n  // If localization is enabled, index generation is handled in the inlining process.\n  // NOTE: Localization with SSR is not currently supported.\n  if (indexHtmlOptions && !options.i18nOptions.shouldInline) {\n    const { content, contentWithoutCriticalCssInlined, errors, warnings } = await generateIndexHtml(\n      initialFiles,\n      executionResult.outputFiles,\n      {\n        ...options,\n        optimizationOptions,\n      },\n      // Set lang attribute to the defined source locale if present\n      options.i18nOptions.hasDefinedSourceLocale ? options.i18nOptions.sourceLocale : undefined,\n    );\n\n    indexContentOutputNoCssInlining = contentWithoutCriticalCssInlined;\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    executionResult.addOutputFile(indexHtmlOptions.output, content);\n\n    if (ssrOptions) {\n      executionResult.addOutputFile('index.server.html', contentWithoutCriticalCssInlined);\n    }\n  }\n\n  // Pre-render (SSG) and App-shell\n  // If localization is enabled, prerendering is handled in the inlining process.\n  if ((prerenderOptions || appShellOptions) && !options.i18nOptions.shouldInline) {\n    assert(\n      indexContentOutputNoCssInlining,\n      'The \"index\" option is required when using the \"ssg\" or \"appShell\" options.',\n    );\n\n    const { output, warnings, errors } = await prerenderPages(\n      workspaceRoot,\n      appShellOptions,\n      prerenderOptions,\n      executionResult.outputFiles,\n      indexContentOutputNoCssInlining,\n      optimizationOptions.styles.inlineCritical,\n      maxWorkers,\n      verbose,\n    );\n\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n\n    for (const [path, content] of Object.entries(output)) {\n      executionResult.addOutputFile(path, content);\n    }\n  }\n\n  // Copy assets\n  if (assets) {\n    // The webpack copy assets helper is used with no base paths defined. This prevents the helper\n    // from directly writing to disk. This should eventually be replaced with a more optimized helper.\n    executionResult.assetFiles.push(...(await copyAssets(assets, [], workspaceRoot)));\n  }\n\n  // Extract and write licenses for used packages\n  if (options.extractLicenses) {\n    executionResult.addOutputFile(\n      '3rdpartylicenses.txt',\n      await extractLicenses(metafile, workspaceRoot),\n    );\n  }\n\n  // Augment the application with service worker support\n  // If localization is enabled, service worker is handled in the inlining process.\n  if (serviceWorker && !options.i18nOptions.shouldInline) {\n    try {\n      const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n        workspaceRoot,\n        serviceWorker,\n        options.baseHref || '/',\n        executionResult.outputFiles,\n        executionResult.assetFiles,\n      );\n      executionResult.addOutputFile('ngsw.json', serviceWorkerResult.manifest);\n      executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);\n    } catch (error) {\n      context.logger.error(error instanceof Error ? error.message : `${error}`);\n\n      return executionResult;\n    }\n  }\n\n  // Calculate estimated transfer size if scripts are optimized\n  let estimatedTransferSizes;\n  if (optimizationOptions.scripts || optimizationOptions.styles.minify) {\n    estimatedTransferSizes = await calculateEstimatedTransferSizes(executionResult.outputFiles);\n  }\n\n  logBuildStats(context, metafile, initialFiles, estimatedTransferSizes);\n\n  const buildTime = Number(process.hrtime.bigint() - startTime) / 10 ** 9;\n  context.logger.info(`Application bundle generation complete. [${buildTime.toFixed(3)} seconds]`);\n\n  // Perform i18n translation inlining if enabled\n  if (options.i18nOptions.shouldInline) {\n    const { errors, warnings } = await inlineI18n(options, executionResult, initialFiles);\n    printWarningsAndErrorsToConsole(context, warnings, errors);\n  }\n\n  // Write metafile if stats option is enabled\n  if (options.stats) {\n    executionResult.addOutputFile('stats.json', JSON.stringify(metafile, null, 2));\n  }\n\n  return executionResult;\n}\n\nfunction printWarningsAndErrorsToConsole(\n  context: BuilderContext,\n  warnings: string[],\n  errors: string[],\n): void {\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"]}
@@ -16,7 +16,10 @@ import { NormalizedApplicationBuildOptions } from './options';
16
16
  * @param executionResult The result of an executed build.
17
17
  * @param initialFiles A map containing initial file information for the executed build.
18
18
  */
19
- export declare function inlineI18n(options: NormalizedApplicationBuildOptions, executionResult: ExecutionResult, initialFiles: Map<string, InitialFileRecord>): Promise<void>;
19
+ export declare function inlineI18n(options: NormalizedApplicationBuildOptions, executionResult: ExecutionResult, initialFiles: Map<string, InitialFileRecord>): Promise<{
20
+ errors: string[];
21
+ warnings: string[];
22
+ }>;
20
23
  /**
21
24
  * Loads all active translations using the translation loaders from the `@angular/localize` package.
22
25
  * @param context The architect builder context for the current build.
@@ -15,6 +15,8 @@ const utils_1 = require("../../tools/esbuild/utils");
15
15
  const environment_options_1 = require("../../utils/environment-options");
16
16
  const i18n_options_1 = require("../../utils/i18n-options");
17
17
  const load_translations_1 = require("../../utils/load-translations");
18
+ const prerender_1 = require("../../utils/server-rendering/prerender");
19
+ const service_worker_1 = require("../../utils/service-worker");
18
20
  const url_1 = require("../../utils/url");
19
21
  /**
20
22
  * Inlines all active locales as specified by the application build options into all
@@ -30,6 +32,10 @@ async function inlineI18n(options, executionResult, initialFiles) {
30
32
  outputFiles: executionResult.outputFiles,
31
33
  shouldOptimize: options.optimizationOptions.scripts,
32
34
  }, environment_options_1.maxWorkers);
35
+ const inlineResult = {
36
+ errors: [],
37
+ warnings: [],
38
+ };
33
39
  // For each active locale, use the inliner to process the output files of the build.
34
40
  const updatedOutputFiles = [];
35
41
  const updatedAssetFiles = [];
@@ -37,13 +43,35 @@ async function inlineI18n(options, executionResult, initialFiles) {
37
43
  for (const locale of options.i18nOptions.inlineLocales) {
38
44
  // A locale specific set of files is returned from the inliner.
39
45
  const localeOutputFiles = await inliner.inlineForLocale(locale, options.i18nOptions.locales[locale].translation);
46
+ const baseHref = getLocaleBaseHref(options.baseHref, options.i18nOptions, locale) ?? options.baseHref;
40
47
  // Generate locale specific index HTML files
41
48
  if (options.indexHtmlOptions) {
42
- const { content, errors, warnings } = await (0, index_html_generator_1.generateIndexHtml)(initialFiles, localeOutputFiles, {
49
+ const { content, contentWithoutCriticalCssInlined, errors, warnings } = await (0, index_html_generator_1.generateIndexHtml)(initialFiles, localeOutputFiles, {
43
50
  ...options,
44
- baseHref: getLocaleBaseHref(options.baseHref, options.i18nOptions, locale) ?? options.baseHref,
51
+ baseHref,
45
52
  }, locale);
46
53
  localeOutputFiles.push((0, utils_1.createOutputFileFromText)(options.indexHtmlOptions.output, content));
54
+ inlineResult.errors.push(...errors);
55
+ inlineResult.warnings.push(...warnings);
56
+ // Pre-render (SSG) and App-shell
57
+ if (options.prerenderOptions || options.appShellOptions) {
58
+ const { output, warnings, errors } = await (0, prerender_1.prerenderPages)(options.workspaceRoot, options.appShellOptions, options.prerenderOptions, localeOutputFiles, contentWithoutCriticalCssInlined, options.optimizationOptions.styles.inlineCritical, environment_options_1.maxWorkers, options.verbose);
59
+ inlineResult.errors.push(...errors);
60
+ inlineResult.warnings.push(...warnings);
61
+ for (const [path, content] of Object.entries(output)) {
62
+ localeOutputFiles.push((0, utils_1.createOutputFileFromText)(path, content));
63
+ }
64
+ }
65
+ }
66
+ if (options.serviceWorker) {
67
+ try {
68
+ const serviceWorkerResult = await (0, service_worker_1.augmentAppWithServiceWorkerEsbuild)(options.workspaceRoot, options.serviceWorker, baseHref || '/', localeOutputFiles, executionResult.assetFiles);
69
+ localeOutputFiles.push((0, utils_1.createOutputFileFromText)('ngsw.json', serviceWorkerResult.manifest));
70
+ executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);
71
+ }
72
+ catch (error) {
73
+ inlineResult.errors.push(error instanceof Error ? error.message : `${error}`);
74
+ }
47
75
  }
48
76
  // Update directory with locale base
49
77
  if (options.i18nOptions.flatOutput !== true) {
@@ -69,6 +97,7 @@ async function inlineI18n(options, executionResult, initialFiles) {
69
97
  if (options.i18nOptions.flatOutput !== true) {
70
98
  executionResult.assetFiles = updatedAssetFiles;
71
99
  }
100
+ return inlineResult;
72
101
  }
73
102
  exports.inlineI18n = inlineI18n;
74
103
  function getLocaleBaseHref(baseHref, i18n, locale) {
@@ -107,4 +136,4 @@ async function loadActiveTranslations(context, i18n) {
107
136
  }
108
137
  }
109
138
  exports.loadActiveTranslations = loadActiveTranslations;
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/i18n.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 { join } from 'node:path';\nimport { InitialFileRecord } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult } from '../../tools/esbuild/bundler-execution-result';\nimport { I18nInliner } from '../../tools/esbuild/i18n-inliner';\nimport { generateIndexHtml } from '../../tools/esbuild/index-html-generator';\nimport { createOutputFileFromText } from '../../tools/esbuild/utils';\nimport { maxWorkers } from '../../utils/environment-options';\nimport { loadTranslations } from '../../utils/i18n-options';\nimport { createTranslationLoader } from '../../utils/load-translations';\nimport { urlJoin } from '../../utils/url';\nimport { NormalizedApplicationBuildOptions } from './options';\n\n/**\n * Inlines all active locales as specified by the application build options into all\n * application JavaScript files created during the build.\n * @param options The normalized application builder options used to create the build.\n * @param executionResult The result of an executed build.\n * @param initialFiles A map containing initial file information for the executed build.\n */\nexport async function inlineI18n(\n  options: NormalizedApplicationBuildOptions,\n  executionResult: ExecutionResult,\n  initialFiles: Map<string, InitialFileRecord>,\n): Promise<void> {\n  // Create the multi-threaded inliner with common options and the files generated from the build.\n  const inliner = new I18nInliner(\n    {\n      missingTranslation: options.i18nOptions.missingTranslationBehavior ?? 'warning',\n      outputFiles: executionResult.outputFiles,\n      shouldOptimize: options.optimizationOptions.scripts,\n    },\n    maxWorkers,\n  );\n\n  // For each active locale, use the inliner to process the output files of the build.\n  const updatedOutputFiles = [];\n  const updatedAssetFiles = [];\n  try {\n    for (const locale of options.i18nOptions.inlineLocales) {\n      // A locale specific set of files is returned from the inliner.\n      const localeOutputFiles = await inliner.inlineForLocale(\n        locale,\n        options.i18nOptions.locales[locale].translation,\n      );\n\n      // Generate locale specific index HTML files\n      if (options.indexHtmlOptions) {\n        const { content, errors, warnings } = await generateIndexHtml(\n          initialFiles,\n          localeOutputFiles,\n          {\n            ...options,\n            baseHref:\n              getLocaleBaseHref(options.baseHref, options.i18nOptions, locale) ?? options.baseHref,\n          },\n          locale,\n        );\n\n        localeOutputFiles.push(createOutputFileFromText(options.indexHtmlOptions.output, content));\n      }\n\n      // Update directory with locale base\n      if (options.i18nOptions.flatOutput !== true) {\n        localeOutputFiles.forEach((file) => {\n          file.path = join(locale, file.path);\n        });\n\n        for (const assetFile of executionResult.assetFiles) {\n          updatedAssetFiles.push({\n            source: assetFile.source,\n            destination: join(locale, assetFile.destination),\n          });\n        }\n      }\n\n      updatedOutputFiles.push(...localeOutputFiles);\n    }\n  } finally {\n    await inliner.close();\n  }\n\n  // Update the result with all localized files\n  executionResult.outputFiles = updatedOutputFiles;\n\n  // Assets are only changed if not using the flat output option\n  if (options.i18nOptions.flatOutput !== true) {\n    executionResult.assetFiles = updatedAssetFiles;\n  }\n}\n\nfunction getLocaleBaseHref(\n  baseHref: string | undefined,\n  i18n: NormalizedApplicationBuildOptions['i18nOptions'],\n  locale: string,\n): string | undefined {\n  if (i18n.flatOutput) {\n    return undefined;\n  }\n\n  if (i18n.locales[locale] && i18n.locales[locale].baseHref !== '') {\n    return urlJoin(baseHref || '', i18n.locales[locale].baseHref ?? `/${locale}/`);\n  }\n\n  return undefined;\n}\n\n/**\n * Loads all active translations using the translation loaders from the `@angular/localize` package.\n * @param context The architect builder context for the current build.\n * @param i18n The normalized i18n options to use.\n */\nexport async function loadActiveTranslations(\n  context: BuilderContext,\n  i18n: NormalizedApplicationBuildOptions['i18nOptions'],\n) {\n  // Load locale data and translations (if present)\n  let loader;\n  for (const [locale, desc] of Object.entries(i18n.locales)) {\n    if (!i18n.inlineLocales.has(locale) && locale !== i18n.sourceLocale) {\n      continue;\n    }\n\n    if (!desc.files.length) {\n      continue;\n    }\n\n    loader ??= await createTranslationLoader();\n\n    loadTranslations(\n      locale,\n      desc,\n      context.workspaceRoot,\n      loader,\n      {\n        warn(message) {\n          context.logger.warn(message);\n        },\n        error(message) {\n          throw new Error(message);\n        },\n      },\n      undefined,\n      i18n.duplicateTranslationBehavior,\n    );\n  }\n}\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"i18n.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/application/i18n.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 { join } from 'node:path';\nimport { InitialFileRecord } from '../../tools/esbuild/bundler-context';\nimport { ExecutionResult } from '../../tools/esbuild/bundler-execution-result';\nimport { I18nInliner } from '../../tools/esbuild/i18n-inliner';\nimport { generateIndexHtml } from '../../tools/esbuild/index-html-generator';\nimport { createOutputFileFromText } from '../../tools/esbuild/utils';\nimport { maxWorkers } from '../../utils/environment-options';\nimport { loadTranslations } from '../../utils/i18n-options';\nimport { createTranslationLoader } from '../../utils/load-translations';\nimport { prerenderPages } from '../../utils/server-rendering/prerender';\nimport { augmentAppWithServiceWorkerEsbuild } from '../../utils/service-worker';\nimport { urlJoin } from '../../utils/url';\nimport { NormalizedApplicationBuildOptions } from './options';\n\n/**\n * Inlines all active locales as specified by the application build options into all\n * application JavaScript files created during the build.\n * @param options The normalized application builder options used to create the build.\n * @param executionResult The result of an executed build.\n * @param initialFiles A map containing initial file information for the executed build.\n */\nexport async function inlineI18n(\n  options: NormalizedApplicationBuildOptions,\n  executionResult: ExecutionResult,\n  initialFiles: Map<string, InitialFileRecord>,\n): Promise<{ errors: string[]; warnings: string[] }> {\n  // Create the multi-threaded inliner with common options and the files generated from the build.\n  const inliner = new I18nInliner(\n    {\n      missingTranslation: options.i18nOptions.missingTranslationBehavior ?? 'warning',\n      outputFiles: executionResult.outputFiles,\n      shouldOptimize: options.optimizationOptions.scripts,\n    },\n    maxWorkers,\n  );\n\n  const inlineResult: { errors: string[]; warnings: string[] } = {\n    errors: [],\n    warnings: [],\n  };\n\n  // For each active locale, use the inliner to process the output files of the build.\n  const updatedOutputFiles = [];\n  const updatedAssetFiles = [];\n  try {\n    for (const locale of options.i18nOptions.inlineLocales) {\n      // A locale specific set of files is returned from the inliner.\n      const localeOutputFiles = await inliner.inlineForLocale(\n        locale,\n        options.i18nOptions.locales[locale].translation,\n      );\n\n      const baseHref =\n        getLocaleBaseHref(options.baseHref, options.i18nOptions, locale) ?? options.baseHref;\n\n      // Generate locale specific index HTML files\n      if (options.indexHtmlOptions) {\n        const { content, contentWithoutCriticalCssInlined, errors, warnings } =\n          await generateIndexHtml(\n            initialFiles,\n            localeOutputFiles,\n            {\n              ...options,\n              baseHref,\n            },\n            locale,\n          );\n\n        localeOutputFiles.push(createOutputFileFromText(options.indexHtmlOptions.output, content));\n        inlineResult.errors.push(...errors);\n        inlineResult.warnings.push(...warnings);\n\n        // Pre-render (SSG) and App-shell\n        if (options.prerenderOptions || options.appShellOptions) {\n          const { output, warnings, errors } = await prerenderPages(\n            options.workspaceRoot,\n            options.appShellOptions,\n            options.prerenderOptions,\n            localeOutputFiles,\n            contentWithoutCriticalCssInlined,\n            options.optimizationOptions.styles.inlineCritical,\n            maxWorkers,\n            options.verbose,\n          );\n\n          inlineResult.errors.push(...errors);\n          inlineResult.warnings.push(...warnings);\n\n          for (const [path, content] of Object.entries(output)) {\n            localeOutputFiles.push(createOutputFileFromText(path, content));\n          }\n        }\n      }\n\n      if (options.serviceWorker) {\n        try {\n          const serviceWorkerResult = await augmentAppWithServiceWorkerEsbuild(\n            options.workspaceRoot,\n            options.serviceWorker,\n            baseHref || '/',\n            localeOutputFiles,\n            executionResult.assetFiles,\n          );\n          localeOutputFiles.push(\n            createOutputFileFromText('ngsw.json', serviceWorkerResult.manifest),\n          );\n          executionResult.assetFiles.push(...serviceWorkerResult.assetFiles);\n        } catch (error) {\n          inlineResult.errors.push(error instanceof Error ? error.message : `${error}`);\n        }\n      }\n\n      // Update directory with locale base\n      if (options.i18nOptions.flatOutput !== true) {\n        localeOutputFiles.forEach((file) => {\n          file.path = join(locale, file.path);\n        });\n\n        for (const assetFile of executionResult.assetFiles) {\n          updatedAssetFiles.push({\n            source: assetFile.source,\n            destination: join(locale, assetFile.destination),\n          });\n        }\n      }\n\n      updatedOutputFiles.push(...localeOutputFiles);\n    }\n  } finally {\n    await inliner.close();\n  }\n\n  // Update the result with all localized files\n  executionResult.outputFiles = updatedOutputFiles;\n\n  // Assets are only changed if not using the flat output option\n  if (options.i18nOptions.flatOutput !== true) {\n    executionResult.assetFiles = updatedAssetFiles;\n  }\n\n  return inlineResult;\n}\n\nfunction getLocaleBaseHref(\n  baseHref: string | undefined,\n  i18n: NormalizedApplicationBuildOptions['i18nOptions'],\n  locale: string,\n): string | undefined {\n  if (i18n.flatOutput) {\n    return undefined;\n  }\n\n  if (i18n.locales[locale] && i18n.locales[locale].baseHref !== '') {\n    return urlJoin(baseHref || '', i18n.locales[locale].baseHref ?? `/${locale}/`);\n  }\n\n  return undefined;\n}\n\n/**\n * Loads all active translations using the translation loaders from the `@angular/localize` package.\n * @param context The architect builder context for the current build.\n * @param i18n The normalized i18n options to use.\n */\nexport async function loadActiveTranslations(\n  context: BuilderContext,\n  i18n: NormalizedApplicationBuildOptions['i18nOptions'],\n) {\n  // Load locale data and translations (if present)\n  let loader;\n  for (const [locale, desc] of Object.entries(i18n.locales)) {\n    if (!i18n.inlineLocales.has(locale) && locale !== i18n.sourceLocale) {\n      continue;\n    }\n\n    if (!desc.files.length) {\n      continue;\n    }\n\n    loader ??= await createTranslationLoader();\n\n    loadTranslations(\n      locale,\n      desc,\n      context.workspaceRoot,\n      loader,\n      {\n        warn(message) {\n          context.logger.warn(message);\n        },\n        error(message) {\n          throw new Error(message);\n        },\n      },\n      undefined,\n      i18n.duplicateTranslationBehavior,\n    );\n  }\n}\n"]}
@@ -9,7 +9,9 @@ import { BuilderContext, BuilderOutput } from '@angular-devkit/architect';
9
9
  import type { OutputFile } from 'esbuild';
10
10
  import { ApplicationBuilderInternalOptions } from './options';
11
11
  import { Schema as ApplicationBuilderOptions } from './schema';
12
- export declare function buildApplicationInternal(options: ApplicationBuilderInternalOptions, context: BuilderContext, infrastructureSettings?: {
12
+ export declare function buildApplicationInternal(options: ApplicationBuilderInternalOptions, context: BuilderContext & {
13
+ signal?: AbortSignal;
14
+ }, infrastructureSettings?: {
13
15
  write?: boolean;
14
16
  }): AsyncIterable<BuilderOutput & {
15
17
  outputFiles?: OutputFile[];