@angular-devkit/build-angular 16.1.4 → 16.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.
Files changed (65) hide show
  1. package/builders.json +5 -0
  2. package/package.json +21 -22
  3. package/src/builders/application/build-action.d.ts +24 -0
  4. package/src/builders/application/build-action.js +159 -0
  5. package/src/builders/application/execute-build.d.ts +11 -0
  6. package/src/builders/application/execute-build.js +126 -0
  7. package/src/builders/application/index.d.ts +29 -0
  8. package/src/builders/application/index.js +50 -0
  9. package/src/builders/{browser-esbuild → application}/options.d.ts +11 -9
  10. package/src/builders/application/options.js +230 -0
  11. package/src/builders/application/schema.d.ts +390 -0
  12. package/src/builders/application/schema.js +59 -0
  13. package/src/builders/application/schema.json +520 -0
  14. package/src/builders/browser-esbuild/builder-status-warnings.d.ts +2 -2
  15. package/src/builders/browser-esbuild/builder-status-warnings.js +2 -1
  16. package/src/builders/browser-esbuild/index.d.ts +0 -17
  17. package/src/builders/browser-esbuild/index.js +14 -279
  18. package/src/builders/dev-server/vite-server.js +2 -2
  19. package/src/builders/jest/index.js +3 -5
  20. package/src/tools/esbuild/angular/{angular-compilation.d.ts → compilation/angular-compilation.d.ts} +1 -1
  21. package/src/tools/esbuild/angular/compilation/angular-compilation.js +52 -0
  22. package/src/tools/esbuild/angular/{aot-compilation.d.ts → compilation/aot-compilation.d.ts} +1 -1
  23. package/src/tools/esbuild/angular/compilation/aot-compilation.js +211 -0
  24. package/src/tools/esbuild/angular/compilation/index.d.ts +11 -0
  25. package/src/tools/esbuild/angular/compilation/index.js +19 -0
  26. package/src/tools/esbuild/angular/{jit-compilation.d.ts → compilation/jit-compilation.d.ts} +1 -1
  27. package/src/tools/esbuild/angular/compilation/jit-compilation.js +106 -0
  28. package/src/tools/esbuild/angular/compilation/noop-compilation.d.ts +20 -0
  29. package/src/tools/esbuild/angular/compilation/noop-compilation.js +27 -0
  30. package/src/tools/esbuild/angular/compiler-plugin.d.ts +2 -0
  31. package/src/tools/esbuild/angular/compiler-plugin.js +22 -8
  32. package/src/tools/esbuild/application-code-bundle.d.ts +9 -3
  33. package/src/tools/esbuild/application-code-bundle.js +131 -69
  34. package/src/tools/esbuild/compiler-plugin-options.d.ts +15 -0
  35. package/src/tools/esbuild/compiler-plugin-options.js +45 -0
  36. package/src/tools/esbuild/global-scripts.d.ts +2 -2
  37. package/src/tools/esbuild/global-scripts.js +1 -1
  38. package/src/tools/esbuild/global-styles.d.ts +2 -2
  39. package/src/tools/esbuild/global-styles.js +2 -3
  40. package/src/tools/esbuild/index-html-generator.d.ts +2 -2
  41. package/src/tools/esbuild/index-html-generator.js +4 -2
  42. package/src/tools/esbuild/javascript-transformer-worker.d.ts +0 -1
  43. package/src/tools/esbuild/javascript-transformer-worker.js +2 -5
  44. package/src/tools/esbuild/javascript-transformer.js +5 -13
  45. package/src/tools/esbuild/rxjs-esm-resolution-plugin.d.ts +18 -0
  46. package/src/tools/esbuild/rxjs-esm-resolution-plugin.js +45 -0
  47. package/src/tools/esbuild/stylesheets/bundle-options.d.ts +3 -4
  48. package/src/tools/esbuild/stylesheets/bundle-options.js +3 -4
  49. package/src/tools/esbuild/stylesheets/stylesheet-plugin-factory.d.ts +0 -7
  50. package/src/tools/esbuild/stylesheets/stylesheet-plugin-factory.js +6 -24
  51. package/src/tools/esbuild/utils.d.ts +5 -0
  52. package/src/tools/esbuild/utils.js +47 -16
  53. package/src/tools/webpack/plugins/css-optimizer-plugin.js +3 -3
  54. package/src/tools/webpack/plugins/javascript-optimizer-plugin.js +3 -3
  55. package/src/utils/index-file/augment-index-html.d.ts +1 -0
  56. package/src/utils/index-file/augment-index-html.js +6 -1
  57. package/src/utils/index-file/index-html-generator.d.ts +1 -0
  58. package/src/utils/index-file/index-html-generator.js +1 -1
  59. package/src/utils/index-file/inline-fonts.js +44 -14
  60. package/src/builders/browser-esbuild/options.js +0 -230
  61. package/src/tools/esbuild/angular/angular-compilation.js +0 -51
  62. package/src/tools/esbuild/angular/aot-compilation.js +0 -211
  63. package/src/tools/esbuild/angular/jit-compilation.js +0 -106
  64. package/src/utils/esbuild-targets.d.ts +0 -12
  65. package/src/utils/esbuild-targets.js +0 -55
@@ -35,7 +35,7 @@ const child_process_1 = require("child_process");
35
35
  const path = __importStar(require("path"));
36
36
  const util_1 = require("util");
37
37
  const color_1 = require("../../utils/color");
38
- const browser_esbuild_1 = require("../browser-esbuild");
38
+ const application_1 = require("../application");
39
39
  const schema_1 = require("../browser-esbuild/schema");
40
40
  const options_1 = require("./options");
41
41
  const test_files_1 = require("./test-files");
@@ -79,9 +79,7 @@ exports.default = (0, architect_1.createBuilder)(async (schema, context) => {
79
79
  index: null,
80
80
  outputHashing: schema_1.OutputHashing.None,
81
81
  outExtension: 'mjs',
82
- commonChunk: false,
83
82
  optimization: false,
84
- buildOptimizer: false,
85
83
  sourceMap: {
86
84
  scripts: true,
87
85
  styles: false,
@@ -139,7 +137,7 @@ exports.default = (0, architect_1.createBuilder)(async (schema, context) => {
139
137
  });
140
138
  async function build(context, options) {
141
139
  try {
142
- for await (const _ of (0, browser_esbuild_1.buildEsbuildBrowserInternal)(options, context)) {
140
+ for await (const _ of (0, application_1.buildApplicationInternal)(options, context)) {
143
141
  // Nothing to do for each event, just wait for the whole build.
144
142
  }
145
143
  return { success: true };
@@ -160,4 +158,4 @@ function resolveModule(module) {
160
158
  return undefined;
161
159
  }
162
160
  }
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/jest/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 { execFile as execFileCb } from 'child_process';\nimport * as path from 'path';\nimport { promisify } from 'util';\nimport { colors } from '../../utils/color';\nimport { buildEsbuildBrowserInternal } from '../browser-esbuild';\nimport { BrowserEsbuildOptions } from '../browser-esbuild/options';\nimport { OutputHashing } from '../browser-esbuild/schema';\nimport { normalizeOptions } from './options';\nimport { Schema as JestBuilderSchema } from './schema';\nimport { findTestFiles } from './test-files';\n\nconst execFile = promisify(execFileCb);\n\n/** Main execution function for the Jest builder. */\nexport default createBuilder(\n  async (schema: JestBuilderSchema, context: BuilderContext): Promise<BuilderOutput> => {\n    context.logger.warn(\n      'NOTE: The Jest builder is currently EXPERIMENTAL and not ready for production use.',\n    );\n\n    const options = normalizeOptions(schema);\n    const testOut = 'dist/test-out'; // TODO(dgp1130): Hide in temp directory.\n\n    // Verify Jest installation and get the path to it's binary.\n    // We need to `node_modules/.bin/jest`, but there is no means to resolve that directly. Fortunately Jest's `package.json` exports the\n    // same file at `bin/jest`, so we can just resolve that instead.\n    const jest = resolveModule('jest/bin/jest');\n    if (!jest) {\n      return {\n        success: false,\n        // TODO(dgp1130): Display a more accurate message for non-NPM users.\n        error:\n          'Jest is not installed, most likely you need to run `npm install jest --save-dev` in your project.',\n      };\n    }\n\n    // Verify that JSDom is installed in the project.\n    const environment = resolveModule('jest-environment-jsdom');\n    if (!environment) {\n      return {\n        success: false,\n        // TODO(dgp1130): Display a more accurate message for non-NPM users.\n        error:\n          '`jest-environment-jsdom` is not installed. Install it with `npm install jest-environment-jsdom --save-dev`.',\n      };\n    }\n\n    // Build all the test files.\n    const testFiles = await findTestFiles(options, context.workspaceRoot);\n    const jestGlobal = path.join(__dirname, 'jest-global.mjs');\n    const initTestBed = path.join(__dirname, 'init-test-bed.mjs');\n    const buildResult = await build(context, {\n      // Build all the test files and also the `jest-global` and `init-test-bed` scripts.\n      entryPoints: new Set([...testFiles, jestGlobal, initTestBed]),\n      tsConfig: options.tsConfig,\n      polyfills: options.polyfills ?? ['zone.js', 'zone.js/testing'],\n      outputPath: testOut,\n      aot: false,\n      index: null,\n      outputHashing: OutputHashing.None,\n      outExtension: 'mjs', // Force native ESM.\n      commonChunk: false,\n      optimization: false,\n      buildOptimizer: false,\n      sourceMap: {\n        scripts: true,\n        styles: false,\n        vendor: false,\n      },\n    });\n    if (!buildResult.success) {\n      return buildResult;\n    }\n\n    // Execute Jest on the built output directory.\n    const jestProc = execFile(process.execPath, [\n      '--experimental-vm-modules',\n      jest,\n\n      `--rootDir=\"${testOut}\"`,\n      '--testEnvironment=jsdom',\n\n      // TODO(dgp1130): Enable cache once we have a mechanism for properly clearing / disabling it.\n      '--no-cache',\n\n      // Run basically all files in the output directory, any excluded files were already dropped by the build.\n      `--testMatch=\"<rootDir>/**/*.mjs\"`,\n\n      // Load polyfills and initialize the environment before executing each test file.\n      // IMPORTANT: Order matters here.\n      // First, we execute `jest-global.mjs` to initialize the `jest` global variable.\n      // Second, we execute user polyfills, including `zone.js` and `zone.js/testing`. This is dependent on the Jest global so it can patch\n      // the environment for fake async to work correctly.\n      // Third, we initialize `TestBed`. This is dependent on fake async being set up correctly beforehand.\n      `--setupFilesAfterEnv=\"<rootDir>/jest-global.mjs\"`,\n      ...(options.polyfills ? [`--setupFilesAfterEnv=\"<rootDir>/polyfills.mjs\"`] : []),\n      `--setupFilesAfterEnv=\"<rootDir>/init-test-bed.mjs\"`,\n\n      // Don't run any infrastructure files as tests, they are manually loaded where needed.\n      `--testPathIgnorePatterns=\"<rootDir>/jest-global\\\\.mjs\"`,\n      ...(options.polyfills ? [`--testPathIgnorePatterns=\"<rootDir>/polyfills\\\\.mjs\"`] : []),\n      `--testPathIgnorePatterns=\"<rootDir>/init-test-bed\\\\.mjs\"`,\n\n      // Skip shared chunks, as they are not entry points to tests.\n      `--testPathIgnorePatterns=\"<rootDir>/chunk-.*\\\\.mjs\"`,\n\n      // Optionally enable color.\n      ...(colors.enabled ? ['--colors'] : []),\n    ]);\n\n    // Stream test output to the terminal.\n    jestProc.child.stdout?.on('data', (chunk) => {\n      context.logger.info(chunk);\n    });\n    jestProc.child.stderr?.on('data', (chunk) => {\n      // Write to stderr directly instead of `context.logger.error(chunk)` because the logger will overwrite Jest's coloring information.\n      process.stderr.write(chunk);\n    });\n\n    try {\n      await jestProc;\n    } catch (error) {\n      // No need to propagate error message, already piped to terminal output.\n      // TODO(dgp1130): Handle process spawning failures.\n      return { success: false };\n    }\n\n    return { success: true };\n  },\n);\n\nasync function build(\n  context: BuilderContext,\n  options: BrowserEsbuildOptions,\n): Promise<BuilderOutput> {\n  try {\n    for await (const _ of buildEsbuildBrowserInternal(options, context)) {\n      // Nothing to do for each event, just wait for the whole build.\n    }\n\n    return { success: true };\n  } catch (err) {\n    return {\n      success: false,\n      error: (err as Error).message,\n    };\n  }\n}\n\n/** Safely resolves the given Node module string. */\nfunction resolveModule(module: string): string | undefined {\n  try {\n    return require.resolve(module);\n  } catch {\n    return undefined;\n  }\n}\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/angular_devkit/build_angular/src/builders/jest/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 { execFile as execFileCb } from 'child_process';\nimport * as path from 'path';\nimport { promisify } from 'util';\nimport { colors } from '../../utils/color';\nimport { buildApplicationInternal } from '../application';\nimport { ApplicationBuilderInternalOptions } from '../application/options';\nimport { OutputHashing } from '../browser-esbuild/schema';\nimport { normalizeOptions } from './options';\nimport { Schema as JestBuilderSchema } from './schema';\nimport { findTestFiles } from './test-files';\n\nconst execFile = promisify(execFileCb);\n\n/** Main execution function for the Jest builder. */\nexport default createBuilder(\n  async (schema: JestBuilderSchema, context: BuilderContext): Promise<BuilderOutput> => {\n    context.logger.warn(\n      'NOTE: The Jest builder is currently EXPERIMENTAL and not ready for production use.',\n    );\n\n    const options = normalizeOptions(schema);\n    const testOut = 'dist/test-out'; // TODO(dgp1130): Hide in temp directory.\n\n    // Verify Jest installation and get the path to it's binary.\n    // We need to `node_modules/.bin/jest`, but there is no means to resolve that directly. Fortunately Jest's `package.json` exports the\n    // same file at `bin/jest`, so we can just resolve that instead.\n    const jest = resolveModule('jest/bin/jest');\n    if (!jest) {\n      return {\n        success: false,\n        // TODO(dgp1130): Display a more accurate message for non-NPM users.\n        error:\n          'Jest is not installed, most likely you need to run `npm install jest --save-dev` in your project.',\n      };\n    }\n\n    // Verify that JSDom is installed in the project.\n    const environment = resolveModule('jest-environment-jsdom');\n    if (!environment) {\n      return {\n        success: false,\n        // TODO(dgp1130): Display a more accurate message for non-NPM users.\n        error:\n          '`jest-environment-jsdom` is not installed. Install it with `npm install jest-environment-jsdom --save-dev`.',\n      };\n    }\n\n    // Build all the test files.\n    const testFiles = await findTestFiles(options, context.workspaceRoot);\n    const jestGlobal = path.join(__dirname, 'jest-global.mjs');\n    const initTestBed = path.join(__dirname, 'init-test-bed.mjs');\n    const buildResult = await build(context, {\n      // Build all the test files and also the `jest-global` and `init-test-bed` scripts.\n      entryPoints: new Set([...testFiles, jestGlobal, initTestBed]),\n      tsConfig: options.tsConfig,\n      polyfills: options.polyfills ?? ['zone.js', 'zone.js/testing'],\n      outputPath: testOut,\n      aot: false,\n      index: null,\n      outputHashing: OutputHashing.None,\n      outExtension: 'mjs', // Force native ESM.\n      optimization: false,\n      sourceMap: {\n        scripts: true,\n        styles: false,\n        vendor: false,\n      },\n    });\n    if (!buildResult.success) {\n      return buildResult;\n    }\n\n    // Execute Jest on the built output directory.\n    const jestProc = execFile(process.execPath, [\n      '--experimental-vm-modules',\n      jest,\n\n      `--rootDir=\"${testOut}\"`,\n      '--testEnvironment=jsdom',\n\n      // TODO(dgp1130): Enable cache once we have a mechanism for properly clearing / disabling it.\n      '--no-cache',\n\n      // Run basically all files in the output directory, any excluded files were already dropped by the build.\n      `--testMatch=\"<rootDir>/**/*.mjs\"`,\n\n      // Load polyfills and initialize the environment before executing each test file.\n      // IMPORTANT: Order matters here.\n      // First, we execute `jest-global.mjs` to initialize the `jest` global variable.\n      // Second, we execute user polyfills, including `zone.js` and `zone.js/testing`. This is dependent on the Jest global so it can patch\n      // the environment for fake async to work correctly.\n      // Third, we initialize `TestBed`. This is dependent on fake async being set up correctly beforehand.\n      `--setupFilesAfterEnv=\"<rootDir>/jest-global.mjs\"`,\n      ...(options.polyfills ? [`--setupFilesAfterEnv=\"<rootDir>/polyfills.mjs\"`] : []),\n      `--setupFilesAfterEnv=\"<rootDir>/init-test-bed.mjs\"`,\n\n      // Don't run any infrastructure files as tests, they are manually loaded where needed.\n      `--testPathIgnorePatterns=\"<rootDir>/jest-global\\\\.mjs\"`,\n      ...(options.polyfills ? [`--testPathIgnorePatterns=\"<rootDir>/polyfills\\\\.mjs\"`] : []),\n      `--testPathIgnorePatterns=\"<rootDir>/init-test-bed\\\\.mjs\"`,\n\n      // Skip shared chunks, as they are not entry points to tests.\n      `--testPathIgnorePatterns=\"<rootDir>/chunk-.*\\\\.mjs\"`,\n\n      // Optionally enable color.\n      ...(colors.enabled ? ['--colors'] : []),\n    ]);\n\n    // Stream test output to the terminal.\n    jestProc.child.stdout?.on('data', (chunk) => {\n      context.logger.info(chunk);\n    });\n    jestProc.child.stderr?.on('data', (chunk) => {\n      // Write to stderr directly instead of `context.logger.error(chunk)` because the logger will overwrite Jest's coloring information.\n      process.stderr.write(chunk);\n    });\n\n    try {\n      await jestProc;\n    } catch (error) {\n      // No need to propagate error message, already piped to terminal output.\n      // TODO(dgp1130): Handle process spawning failures.\n      return { success: false };\n    }\n\n    return { success: true };\n  },\n);\n\nasync function build(\n  context: BuilderContext,\n  options: ApplicationBuilderInternalOptions,\n): Promise<BuilderOutput> {\n  try {\n    for await (const _ of buildApplicationInternal(options, context)) {\n      // Nothing to do for each event, just wait for the whole build.\n    }\n\n    return { success: true };\n  } catch (err) {\n    return {\n      success: false,\n      error: (err as Error).message,\n    };\n  }\n}\n\n/** Safely resolves the given Node module string. */\nfunction resolveModule(module: string): string | undefined {\n  try {\n    return require.resolve(module);\n  } catch {\n    return undefined;\n  }\n}\n"]}
@@ -7,7 +7,7 @@
7
7
  */
8
8
  import type ng from '@angular/compiler-cli';
9
9
  import type ts from 'typescript';
10
- import type { AngularHostOptions } from './angular-host';
10
+ import type { AngularHostOptions } from '../angular-host';
11
11
  export interface EmitFileResult {
12
12
  filename: string;
13
13
  contents: string;
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
10
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
11
+ 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");
12
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
13
+ };
14
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
15
+ if (kind === "m") throw new TypeError("Private method is not writable");
16
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
17
+ 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");
18
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
19
+ };
20
+ var _a, _AngularCompilation_angularCompilerCliModule;
21
+ Object.defineProperty(exports, "__esModule", { value: true });
22
+ exports.AngularCompilation = void 0;
23
+ const load_esm_1 = require("../../../../utils/load-esm");
24
+ const profiling_1 = require("../../profiling");
25
+ class AngularCompilation {
26
+ static async loadCompilerCli() {
27
+ var _b;
28
+ // This uses a wrapped dynamic import to load `@angular/compiler-cli` which is ESM.
29
+ // Once TypeScript provides support for retaining dynamic imports this workaround can be dropped.
30
+ __classPrivateFieldSet(_b = AngularCompilation, _a, __classPrivateFieldGet(_b, _a, "f", _AngularCompilation_angularCompilerCliModule) ?? await (0, load_esm_1.loadEsmModule)('@angular/compiler-cli'), "f", _AngularCompilation_angularCompilerCliModule);
31
+ return __classPrivateFieldGet(AngularCompilation, _a, "f", _AngularCompilation_angularCompilerCliModule);
32
+ }
33
+ async loadConfiguration(tsconfig) {
34
+ const { readConfiguration } = await AngularCompilation.loadCompilerCli();
35
+ return (0, profiling_1.profileSync)('NG_READ_CONFIG', () => readConfiguration(tsconfig, {
36
+ // Angular specific configuration defaults and overrides to ensure a functioning compilation.
37
+ suppressOutputPathCheck: true,
38
+ outDir: undefined,
39
+ sourceMap: false,
40
+ declaration: false,
41
+ declarationMap: false,
42
+ allowEmptyCodegenFiles: false,
43
+ annotationsAs: 'decorators',
44
+ enableResourceInlining: false,
45
+ supportTestBed: false,
46
+ }));
47
+ }
48
+ }
49
+ exports.AngularCompilation = AngularCompilation;
50
+ _a = AngularCompilation;
51
+ _AngularCompilation_angularCompilerCliModule = { value: void 0 };
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1jb21waWxhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2FuZ3VsYXJfZGV2a2l0L2J1aWxkX2FuZ3VsYXIvc3JjL3Rvb2xzL2VzYnVpbGQvYW5ndWxhci9jb21waWxhdGlvbi9hbmd1bGFyLWNvbXBpbGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7Ozs7OztBQUlILHlEQUEyRDtBQUMzRCwrQ0FBOEM7QUFTOUMsTUFBc0Isa0JBQWtCO0lBR3RDLE1BQU0sQ0FBQyxLQUFLLENBQUMsZUFBZTs7UUFDMUIsbUZBQW1GO1FBQ25GLGlHQUFpRztRQUNqRyx5SUFBaUQsTUFBTSxJQUFBLHdCQUFhLEVBQ2xFLHVCQUF1QixDQUN4QixvREFBQSxDQUFDO1FBRUYsT0FBTyx1QkFBQSxrQkFBa0Isd0RBQTBCLENBQUM7SUFDdEQsQ0FBQztJQUVTLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxRQUFnQjtRQUNoRCxNQUFNLEVBQUUsaUJBQWlCLEVBQUUsR0FBRyxNQUFNLGtCQUFrQixDQUFDLGVBQWUsRUFBRSxDQUFDO1FBRXpFLE9BQU8sSUFBQSx1QkFBVyxFQUFDLGdCQUFnQixFQUFFLEdBQUcsRUFBRSxDQUN4QyxpQkFBaUIsQ0FBQyxRQUFRLEVBQUU7WUFDMUIsNkZBQTZGO1lBQzdGLHVCQUF1QixFQUFFLElBQUk7WUFDN0IsTUFBTSxFQUFFLFNBQVM7WUFDakIsU0FBUyxFQUFFLEtBQUs7WUFDaEIsV0FBVyxFQUFFLEtBQUs7WUFDbEIsY0FBYyxFQUFFLEtBQUs7WUFDckIsc0JBQXNCLEVBQUUsS0FBSztZQUM3QixhQUFhLEVBQUUsWUFBWTtZQUMzQixzQkFBc0IsRUFBRSxLQUFLO1lBQzdCLGNBQWMsRUFBRSxLQUFLO1NBQ3RCLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQztDQWVGO0FBN0NELGdEQTZDQzs7QUE1Q1EsZ0VBQXlCLENBQWEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHR5cGUgbmcgZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXItY2xpJztcbmltcG9ydCB0eXBlIHRzIGZyb20gJ3R5cGVzY3JpcHQnO1xuaW1wb3J0IHsgbG9hZEVzbU1vZHVsZSB9IGZyb20gJy4uLy4uLy4uLy4uL3V0aWxzL2xvYWQtZXNtJztcbmltcG9ydCB7IHByb2ZpbGVTeW5jIH0gZnJvbSAnLi4vLi4vcHJvZmlsaW5nJztcbmltcG9ydCB0eXBlIHsgQW5ndWxhckhvc3RPcHRpb25zIH0gZnJvbSAnLi4vYW5ndWxhci1ob3N0JztcblxuZXhwb3J0IGludGVyZmFjZSBFbWl0RmlsZVJlc3VsdCB7XG4gIGZpbGVuYW1lOiBzdHJpbmc7XG4gIGNvbnRlbnRzOiBzdHJpbmc7XG4gIGRlcGVuZGVuY2llcz86IHJlYWRvbmx5IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQW5ndWxhckNvbXBpbGF0aW9uIHtcbiAgc3RhdGljICNhbmd1bGFyQ29tcGlsZXJDbGlNb2R1bGU/OiB0eXBlb2Ygbmc7XG5cbiAgc3RhdGljIGFzeW5jIGxvYWRDb21waWxlckNsaSgpOiBQcm9taXNlPHR5cGVvZiBuZz4ge1xuICAgIC8vIFRoaXMgdXNlcyBhIHdyYXBwZWQgZHluYW1pYyBpbXBvcnQgdG8gbG9hZCBgQGFuZ3VsYXIvY29tcGlsZXItY2xpYCB3aGljaCBpcyBFU00uXG4gICAgLy8gT25jZSBUeXBlU2NyaXB0IHByb3ZpZGVzIHN1cHBvcnQgZm9yIHJldGFpbmluZyBkeW5hbWljIGltcG9ydHMgdGhpcyB3b3JrYXJvdW5kIGNhbiBiZSBkcm9wcGVkLlxuICAgIEFuZ3VsYXJDb21waWxhdGlvbi4jYW5ndWxhckNvbXBpbGVyQ2xpTW9kdWxlID8/PSBhd2FpdCBsb2FkRXNtTW9kdWxlPHR5cGVvZiBuZz4oXG4gICAgICAnQGFuZ3VsYXIvY29tcGlsZXItY2xpJyxcbiAgICApO1xuXG4gICAgcmV0dXJuIEFuZ3VsYXJDb21waWxhdGlvbi4jYW5ndWxhckNvbXBpbGVyQ2xpTW9kdWxlO1xuICB9XG5cbiAgcHJvdGVjdGVkIGFzeW5jIGxvYWRDb25maWd1cmF0aW9uKHRzY29uZmlnOiBzdHJpbmcpOiBQcm9taXNlPG5nLkNvbXBpbGVyT3B0aW9ucz4ge1xuICAgIGNvbnN0IHsgcmVhZENvbmZpZ3VyYXRpb24gfSA9IGF3YWl0IEFuZ3VsYXJDb21waWxhdGlvbi5sb2FkQ29tcGlsZXJDbGkoKTtcblxuICAgIHJldHVybiBwcm9maWxlU3luYygnTkdfUkVBRF9DT05GSUcnLCAoKSA9PlxuICAgICAgcmVhZENvbmZpZ3VyYXRpb24odHNjb25maWcsIHtcbiAgICAgICAgLy8gQW5ndWxhciBzcGVjaWZpYyBjb25maWd1cmF0aW9uIGRlZmF1bHRzIGFuZCBvdmVycmlkZXMgdG8gZW5zdXJlIGEgZnVuY3Rpb25pbmcgY29tcGlsYXRpb24uXG4gICAgICAgIHN1cHByZXNzT3V0cHV0UGF0aENoZWNrOiB0cnVlLFxuICAgICAgICBvdXREaXI6IHVuZGVmaW5lZCxcbiAgICAgICAgc291cmNlTWFwOiBmYWxzZSxcbiAgICAgICAgZGVjbGFyYXRpb246IGZhbHNlLFxuICAgICAgICBkZWNsYXJhdGlvbk1hcDogZmFsc2UsXG4gICAgICAgIGFsbG93RW1wdHlDb2RlZ2VuRmlsZXM6IGZhbHNlLFxuICAgICAgICBhbm5vdGF0aW9uc0FzOiAnZGVjb3JhdG9ycycsXG4gICAgICAgIGVuYWJsZVJlc291cmNlSW5saW5pbmc6IGZhbHNlLFxuICAgICAgICBzdXBwb3J0VGVzdEJlZDogZmFsc2UsXG4gICAgICB9KSxcbiAgICApO1xuICB9XG5cbiAgYWJzdHJhY3QgaW5pdGlhbGl6ZShcbiAgICB0c2NvbmZpZzogc3RyaW5nLFxuICAgIGhvc3RPcHRpb25zOiBBbmd1bGFySG9zdE9wdGlvbnMsXG4gICAgY29tcGlsZXJPcHRpb25zVHJhbnNmb3JtZXI/OiAoY29tcGlsZXJPcHRpb25zOiBuZy5Db21waWxlck9wdGlvbnMpID0+IG5nLkNvbXBpbGVyT3B0aW9ucyxcbiAgKTogUHJvbWlzZTx7XG4gICAgYWZmZWN0ZWRGaWxlczogUmVhZG9ubHlTZXQ8dHMuU291cmNlRmlsZT47XG4gICAgY29tcGlsZXJPcHRpb25zOiBuZy5Db21waWxlck9wdGlvbnM7XG4gICAgcmVmZXJlbmNlZEZpbGVzOiByZWFkb25seSBzdHJpbmdbXTtcbiAgfT47XG5cbiAgYWJzdHJhY3QgY29sbGVjdERpYWdub3N0aWNzKCk6IEl0ZXJhYmxlPHRzLkRpYWdub3N0aWM+O1xuXG4gIGFic3RyYWN0IGVtaXRBZmZlY3RlZEZpbGVzKCk6IEl0ZXJhYmxlPEVtaXRGaWxlUmVzdWx0Pjtcbn1cbiJdfQ==
@@ -7,8 +7,8 @@
7
7
  */
8
8
  import type ng from '@angular/compiler-cli';
9
9
  import ts from 'typescript';
10
+ import { AngularHostOptions } from '../angular-host';
10
11
  import { AngularCompilation, EmitFileResult } from './angular-compilation';
11
- import { AngularHostOptions } from './angular-host';
12
12
  export declare class AotCompilation extends AngularCompilation {
13
13
  #private;
14
14
  initialize(tsconfig: string, hostOptions: AngularHostOptions, compilerOptionsTransformer?: (compilerOptions: ng.CompilerOptions) => ng.CompilerOptions): Promise<{
@@ -0,0 +1,211 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
10
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
11
+ 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");
12
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
13
+ };
14
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
15
+ if (kind === "m") throw new TypeError("Private method is not writable");
16
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
17
+ 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");
18
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
19
+ };
20
+ var __importDefault = (this && this.__importDefault) || function (mod) {
21
+ return (mod && mod.__esModule) ? mod : { "default": mod };
22
+ };
23
+ var _AotCompilation_state;
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.AotCompilation = void 0;
26
+ const node_assert_1 = __importDefault(require("node:assert"));
27
+ const typescript_1 = __importDefault(require("typescript"));
28
+ const profiling_1 = require("../../profiling");
29
+ const angular_host_1 = require("../angular-host");
30
+ const angular_compilation_1 = require("./angular-compilation");
31
+ // Temporary deep import for transformer support
32
+ // TODO: Move these to a private exports location or move the implementation into this package.
33
+ const { mergeTransformers, replaceBootstrap } = require('@ngtools/webpack/src/ivy/transformation');
34
+ class AngularCompilationState {
35
+ constructor(angularProgram, compilerHost, typeScriptProgram, affectedFiles, templateDiagnosticsOptimization, diagnosticCache = new WeakMap()) {
36
+ this.angularProgram = angularProgram;
37
+ this.compilerHost = compilerHost;
38
+ this.typeScriptProgram = typeScriptProgram;
39
+ this.affectedFiles = affectedFiles;
40
+ this.templateDiagnosticsOptimization = templateDiagnosticsOptimization;
41
+ this.diagnosticCache = diagnosticCache;
42
+ }
43
+ get angularCompiler() {
44
+ return this.angularProgram.compiler;
45
+ }
46
+ }
47
+ class AotCompilation extends angular_compilation_1.AngularCompilation {
48
+ constructor() {
49
+ super(...arguments);
50
+ _AotCompilation_state.set(this, void 0);
51
+ }
52
+ async initialize(tsconfig, hostOptions, compilerOptionsTransformer) {
53
+ // Dynamically load the Angular compiler CLI package
54
+ const { NgtscProgram, OptimizeFor } = await angular_compilation_1.AngularCompilation.loadCompilerCli();
55
+ // Load the compiler configuration and transform as needed
56
+ const { options: originalCompilerOptions, rootNames, errors: configurationDiagnostics, } = await this.loadConfiguration(tsconfig);
57
+ const compilerOptions = compilerOptionsTransformer?.(originalCompilerOptions) ?? originalCompilerOptions;
58
+ // Create Angular compiler host
59
+ const host = (0, angular_host_1.createAngularCompilerHost)(compilerOptions, hostOptions);
60
+ // Create the Angular specific program that contains the Angular compiler
61
+ const angularProgram = (0, profiling_1.profileSync)('NG_CREATE_PROGRAM', () => new NgtscProgram(rootNames, compilerOptions, host, __classPrivateFieldGet(this, _AotCompilation_state, "f")?.angularProgram));
62
+ const angularCompiler = angularProgram.compiler;
63
+ const angularTypeScriptProgram = angularProgram.getTsProgram();
64
+ (0, angular_host_1.ensureSourceFileVersions)(angularTypeScriptProgram);
65
+ let oldProgram = __classPrivateFieldGet(this, _AotCompilation_state, "f")?.typeScriptProgram;
66
+ let usingBuildInfo = false;
67
+ if (!oldProgram) {
68
+ oldProgram = typescript_1.default.readBuilderProgram(compilerOptions, host);
69
+ usingBuildInfo = true;
70
+ }
71
+ const typeScriptProgram = typescript_1.default.createEmitAndSemanticDiagnosticsBuilderProgram(angularTypeScriptProgram, host, oldProgram, configurationDiagnostics);
72
+ await (0, profiling_1.profileAsync)('NG_ANALYZE_PROGRAM', () => angularCompiler.analyzeAsync());
73
+ const affectedFiles = (0, profiling_1.profileSync)('NG_FIND_AFFECTED', () => findAffectedFiles(typeScriptProgram, angularCompiler, usingBuildInfo));
74
+ __classPrivateFieldSet(this, _AotCompilation_state, new AngularCompilationState(angularProgram, host, typeScriptProgram, affectedFiles, affectedFiles.size === 1 ? OptimizeFor.SingleFile : OptimizeFor.WholeProgram, __classPrivateFieldGet(this, _AotCompilation_state, "f")?.diagnosticCache), "f");
75
+ const referencedFiles = typeScriptProgram
76
+ .getSourceFiles()
77
+ .filter((sourceFile) => !angularCompiler.ignoreForEmit.has(sourceFile))
78
+ .flatMap((sourceFile) => [
79
+ sourceFile.fileName,
80
+ ...angularCompiler.getResourceDependencies(sourceFile),
81
+ ]);
82
+ return { affectedFiles, compilerOptions, referencedFiles };
83
+ }
84
+ *collectDiagnostics() {
85
+ (0, node_assert_1.default)(__classPrivateFieldGet(this, _AotCompilation_state, "f"), 'Angular compilation must be initialized prior to collecting diagnostics.');
86
+ const { affectedFiles, angularCompiler, diagnosticCache, templateDiagnosticsOptimization, typeScriptProgram, } = __classPrivateFieldGet(this, _AotCompilation_state, "f");
87
+ // Collect program level diagnostics
88
+ yield* typeScriptProgram.getConfigFileParsingDiagnostics();
89
+ yield* angularCompiler.getOptionDiagnostics();
90
+ yield* typeScriptProgram.getOptionsDiagnostics();
91
+ yield* typeScriptProgram.getGlobalDiagnostics();
92
+ // Collect source file specific diagnostics
93
+ for (const sourceFile of typeScriptProgram.getSourceFiles()) {
94
+ if (angularCompiler.ignoreForDiagnostics.has(sourceFile)) {
95
+ continue;
96
+ }
97
+ // TypeScript will use cached diagnostics for files that have not been
98
+ // changed or affected for this build when using incremental building.
99
+ yield* (0, profiling_1.profileSync)('NG_DIAGNOSTICS_SYNTACTIC', () => typeScriptProgram.getSyntacticDiagnostics(sourceFile), true);
100
+ yield* (0, profiling_1.profileSync)('NG_DIAGNOSTICS_SEMANTIC', () => typeScriptProgram.getSemanticDiagnostics(sourceFile), true);
101
+ // Declaration files cannot have template diagnostics
102
+ if (sourceFile.isDeclarationFile) {
103
+ continue;
104
+ }
105
+ // Only request Angular template diagnostics for affected files to avoid
106
+ // overhead of template diagnostics for unchanged files.
107
+ if (affectedFiles.has(sourceFile)) {
108
+ const angularDiagnostics = (0, profiling_1.profileSync)('NG_DIAGNOSTICS_TEMPLATE', () => angularCompiler.getDiagnosticsForFile(sourceFile, templateDiagnosticsOptimization), true);
109
+ diagnosticCache.set(sourceFile, angularDiagnostics);
110
+ yield* angularDiagnostics;
111
+ }
112
+ else {
113
+ const angularDiagnostics = diagnosticCache.get(sourceFile);
114
+ if (angularDiagnostics) {
115
+ yield* angularDiagnostics;
116
+ }
117
+ }
118
+ }
119
+ }
120
+ emitAffectedFiles() {
121
+ (0, node_assert_1.default)(__classPrivateFieldGet(this, _AotCompilation_state, "f"), 'Angular compilation must be initialized prior to emitting files.');
122
+ const { angularCompiler, compilerHost, typeScriptProgram } = __classPrivateFieldGet(this, _AotCompilation_state, "f");
123
+ const buildInfoFilename = typeScriptProgram.getCompilerOptions().tsBuildInfoFile ?? '.tsbuildinfo';
124
+ const emittedFiles = new Map();
125
+ const writeFileCallback = (filename, contents, _a, _b, sourceFiles) => {
126
+ if (!sourceFiles?.length && filename.endsWith(buildInfoFilename)) {
127
+ // Save builder info contents to specified location
128
+ compilerHost.writeFile(filename, contents, false);
129
+ return;
130
+ }
131
+ (0, node_assert_1.default)(sourceFiles?.length === 1, 'Invalid TypeScript program emit for ' + filename);
132
+ const sourceFile = sourceFiles[0];
133
+ if (angularCompiler.ignoreForEmit.has(sourceFile)) {
134
+ return;
135
+ }
136
+ angularCompiler.incrementalCompilation.recordSuccessfulEmit(sourceFile);
137
+ emittedFiles.set(sourceFile, { filename: sourceFile.fileName, contents });
138
+ };
139
+ const transformers = mergeTransformers(angularCompiler.prepareEmit().transformers, {
140
+ before: [replaceBootstrap(() => typeScriptProgram.getProgram().getTypeChecker())],
141
+ });
142
+ // TypeScript will loop until there are no more affected files in the program
143
+ while (typeScriptProgram.emitNextAffectedFile(writeFileCallback, undefined, undefined, transformers)) {
144
+ /* empty */
145
+ }
146
+ // Angular may have files that must be emitted but TypeScript does not consider affected
147
+ for (const sourceFile of typeScriptProgram.getSourceFiles()) {
148
+ if (emittedFiles.has(sourceFile) || angularCompiler.ignoreForEmit.has(sourceFile)) {
149
+ continue;
150
+ }
151
+ if (sourceFile.isDeclarationFile) {
152
+ continue;
153
+ }
154
+ if (angularCompiler.incrementalCompilation.safeToSkipEmit(sourceFile)) {
155
+ continue;
156
+ }
157
+ typeScriptProgram.emit(sourceFile, writeFileCallback, undefined, undefined, transformers);
158
+ }
159
+ return emittedFiles.values();
160
+ }
161
+ }
162
+ exports.AotCompilation = AotCompilation;
163
+ _AotCompilation_state = new WeakMap();
164
+ function findAffectedFiles(builder, { ignoreForDiagnostics }, includeTTC) {
165
+ const affectedFiles = new Set();
166
+ // eslint-disable-next-line no-constant-condition
167
+ while (true) {
168
+ const result = builder.getSemanticDiagnosticsOfNextAffectedFile(undefined, (sourceFile) => {
169
+ // If the affected file is a TTC shim, add the shim's original source file.
170
+ // This ensures that changes that affect TTC are typechecked even when the changes
171
+ // are otherwise unrelated from a TS perspective and do not result in Ivy codegen changes.
172
+ // For example, changing @Input property types of a directive used in another component's
173
+ // template.
174
+ // A TTC shim is a file that has been ignored for diagnostics and has a filename ending in `.ngtypecheck.ts`.
175
+ if (ignoreForDiagnostics.has(sourceFile) && sourceFile.fileName.endsWith('.ngtypecheck.ts')) {
176
+ // This file name conversion relies on internal compiler logic and should be converted
177
+ // to an official method when available. 15 is length of `.ngtypecheck.ts`
178
+ const originalFilename = sourceFile.fileName.slice(0, -15) + '.ts';
179
+ const originalSourceFile = builder.getSourceFile(originalFilename);
180
+ if (originalSourceFile) {
181
+ affectedFiles.add(originalSourceFile);
182
+ }
183
+ return true;
184
+ }
185
+ return false;
186
+ });
187
+ if (!result) {
188
+ break;
189
+ }
190
+ affectedFiles.add(result.affected);
191
+ }
192
+ // Add all files with associated template type checking files.
193
+ // Stored TS build info does not have knowledge of the AOT compiler or the typechecking state of the templates.
194
+ // To ensure that errors are reported correctly, all AOT component diagnostics need to be analyzed even if build
195
+ // info is present.
196
+ if (includeTTC) {
197
+ for (const sourceFile of builder.getSourceFiles()) {
198
+ if (ignoreForDiagnostics.has(sourceFile) && sourceFile.fileName.endsWith('.ngtypecheck.ts')) {
199
+ // This file name conversion relies on internal compiler logic and should be converted
200
+ // to an official method when available. 15 is length of `.ngtypecheck.ts`
201
+ const originalFilename = sourceFile.fileName.slice(0, -15) + '.ts';
202
+ const originalSourceFile = builder.getSourceFile(originalFilename);
203
+ if (originalSourceFile) {
204
+ affectedFiles.add(originalSourceFile);
205
+ }
206
+ }
207
+ }
208
+ }
209
+ return affectedFiles;
210
+ }
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"aot-compilation.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/angular/compilation/aot-compilation.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 type ng from '@angular/compiler-cli';\nimport assert from 'node:assert';\nimport ts from 'typescript';\nimport { profileAsync, profileSync } from '../../profiling';\nimport {\n  AngularHostOptions,\n  createAngularCompilerHost,\n  ensureSourceFileVersions,\n} from '../angular-host';\nimport { AngularCompilation, EmitFileResult } from './angular-compilation';\n\n// Temporary deep import for transformer support\n// TODO: Move these to a private exports location or move the implementation into this package.\nconst { mergeTransformers, replaceBootstrap } = require('@ngtools/webpack/src/ivy/transformation');\n\nclass AngularCompilationState {\n  constructor(\n    public readonly angularProgram: ng.NgtscProgram,\n    public readonly compilerHost: ng.CompilerHost,\n    public readonly typeScriptProgram: ts.EmitAndSemanticDiagnosticsBuilderProgram,\n    public readonly affectedFiles: ReadonlySet<ts.SourceFile>,\n    public readonly templateDiagnosticsOptimization: ng.OptimizeFor,\n    public readonly diagnosticCache = new WeakMap<ts.SourceFile, ts.Diagnostic[]>(),\n  ) {}\n\n  get angularCompiler() {\n    return this.angularProgram.compiler;\n  }\n}\n\nexport class AotCompilation extends AngularCompilation {\n  #state?: AngularCompilationState;\n\n  async initialize(\n    tsconfig: string,\n    hostOptions: AngularHostOptions,\n    compilerOptionsTransformer?: (compilerOptions: ng.CompilerOptions) => ng.CompilerOptions,\n  ): Promise<{\n    affectedFiles: ReadonlySet<ts.SourceFile>;\n    compilerOptions: ng.CompilerOptions;\n    referencedFiles: readonly string[];\n  }> {\n    // Dynamically load the Angular compiler CLI package\n    const { NgtscProgram, OptimizeFor } = await AngularCompilation.loadCompilerCli();\n\n    // Load the compiler configuration and transform as needed\n    const {\n      options: originalCompilerOptions,\n      rootNames,\n      errors: configurationDiagnostics,\n    } = await this.loadConfiguration(tsconfig);\n    const compilerOptions =\n      compilerOptionsTransformer?.(originalCompilerOptions) ?? originalCompilerOptions;\n\n    // Create Angular compiler host\n    const host = createAngularCompilerHost(compilerOptions, hostOptions);\n\n    // Create the Angular specific program that contains the Angular compiler\n    const angularProgram = profileSync(\n      'NG_CREATE_PROGRAM',\n      () => new NgtscProgram(rootNames, compilerOptions, host, this.#state?.angularProgram),\n    );\n    const angularCompiler = angularProgram.compiler;\n    const angularTypeScriptProgram = angularProgram.getTsProgram();\n    ensureSourceFileVersions(angularTypeScriptProgram);\n\n    let oldProgram = this.#state?.typeScriptProgram;\n    let usingBuildInfo = false;\n    if (!oldProgram) {\n      oldProgram = ts.readBuilderProgram(compilerOptions, host);\n      usingBuildInfo = true;\n    }\n\n    const typeScriptProgram = ts.createEmitAndSemanticDiagnosticsBuilderProgram(\n      angularTypeScriptProgram,\n      host,\n      oldProgram,\n      configurationDiagnostics,\n    );\n\n    await profileAsync('NG_ANALYZE_PROGRAM', () => angularCompiler.analyzeAsync());\n    const affectedFiles = profileSync('NG_FIND_AFFECTED', () =>\n      findAffectedFiles(typeScriptProgram, angularCompiler, usingBuildInfo),\n    );\n\n    this.#state = new AngularCompilationState(\n      angularProgram,\n      host,\n      typeScriptProgram,\n      affectedFiles,\n      affectedFiles.size === 1 ? OptimizeFor.SingleFile : OptimizeFor.WholeProgram,\n      this.#state?.diagnosticCache,\n    );\n\n    const referencedFiles = typeScriptProgram\n      .getSourceFiles()\n      .filter((sourceFile) => !angularCompiler.ignoreForEmit.has(sourceFile))\n      .flatMap((sourceFile) => [\n        sourceFile.fileName,\n        ...angularCompiler.getResourceDependencies(sourceFile),\n      ]);\n\n    return { affectedFiles, compilerOptions, referencedFiles };\n  }\n\n  *collectDiagnostics(): Iterable<ts.Diagnostic> {\n    assert(this.#state, 'Angular compilation must be initialized prior to collecting diagnostics.');\n    const {\n      affectedFiles,\n      angularCompiler,\n      diagnosticCache,\n      templateDiagnosticsOptimization,\n      typeScriptProgram,\n    } = this.#state;\n\n    // Collect program level diagnostics\n    yield* typeScriptProgram.getConfigFileParsingDiagnostics();\n    yield* angularCompiler.getOptionDiagnostics();\n    yield* typeScriptProgram.getOptionsDiagnostics();\n    yield* typeScriptProgram.getGlobalDiagnostics();\n\n    // Collect source file specific diagnostics\n    for (const sourceFile of typeScriptProgram.getSourceFiles()) {\n      if (angularCompiler.ignoreForDiagnostics.has(sourceFile)) {\n        continue;\n      }\n\n      // TypeScript will use cached diagnostics for files that have not been\n      // changed or affected for this build when using incremental building.\n      yield* profileSync(\n        'NG_DIAGNOSTICS_SYNTACTIC',\n        () => typeScriptProgram.getSyntacticDiagnostics(sourceFile),\n        true,\n      );\n      yield* profileSync(\n        'NG_DIAGNOSTICS_SEMANTIC',\n        () => typeScriptProgram.getSemanticDiagnostics(sourceFile),\n        true,\n      );\n\n      // Declaration files cannot have template diagnostics\n      if (sourceFile.isDeclarationFile) {\n        continue;\n      }\n\n      // Only request Angular template diagnostics for affected files to avoid\n      // overhead of template diagnostics for unchanged files.\n      if (affectedFiles.has(sourceFile)) {\n        const angularDiagnostics = profileSync(\n          'NG_DIAGNOSTICS_TEMPLATE',\n          () => angularCompiler.getDiagnosticsForFile(sourceFile, templateDiagnosticsOptimization),\n          true,\n        );\n        diagnosticCache.set(sourceFile, angularDiagnostics);\n        yield* angularDiagnostics;\n      } else {\n        const angularDiagnostics = diagnosticCache.get(sourceFile);\n        if (angularDiagnostics) {\n          yield* angularDiagnostics;\n        }\n      }\n    }\n  }\n\n  emitAffectedFiles(): Iterable<EmitFileResult> {\n    assert(this.#state, 'Angular compilation must be initialized prior to emitting files.');\n    const { angularCompiler, compilerHost, typeScriptProgram } = this.#state;\n    const buildInfoFilename =\n      typeScriptProgram.getCompilerOptions().tsBuildInfoFile ?? '.tsbuildinfo';\n\n    const emittedFiles = new Map<ts.SourceFile, EmitFileResult>();\n    const writeFileCallback: ts.WriteFileCallback = (filename, contents, _a, _b, sourceFiles) => {\n      if (!sourceFiles?.length && filename.endsWith(buildInfoFilename)) {\n        // Save builder info contents to specified location\n        compilerHost.writeFile(filename, contents, false);\n\n        return;\n      }\n\n      assert(sourceFiles?.length === 1, 'Invalid TypeScript program emit for ' + filename);\n      const sourceFile = sourceFiles[0];\n      if (angularCompiler.ignoreForEmit.has(sourceFile)) {\n        return;\n      }\n\n      angularCompiler.incrementalCompilation.recordSuccessfulEmit(sourceFile);\n      emittedFiles.set(sourceFile, { filename: sourceFile.fileName, contents });\n    };\n    const transformers = mergeTransformers(angularCompiler.prepareEmit().transformers, {\n      before: [replaceBootstrap(() => typeScriptProgram.getProgram().getTypeChecker())],\n    });\n\n    // TypeScript will loop until there are no more affected files in the program\n    while (\n      typeScriptProgram.emitNextAffectedFile(writeFileCallback, undefined, undefined, transformers)\n    ) {\n      /* empty */\n    }\n\n    // Angular may have files that must be emitted but TypeScript does not consider affected\n    for (const sourceFile of typeScriptProgram.getSourceFiles()) {\n      if (emittedFiles.has(sourceFile) || angularCompiler.ignoreForEmit.has(sourceFile)) {\n        continue;\n      }\n\n      if (sourceFile.isDeclarationFile) {\n        continue;\n      }\n\n      if (angularCompiler.incrementalCompilation.safeToSkipEmit(sourceFile)) {\n        continue;\n      }\n\n      typeScriptProgram.emit(sourceFile, writeFileCallback, undefined, undefined, transformers);\n    }\n\n    return emittedFiles.values();\n  }\n}\n\nfunction findAffectedFiles(\n  builder: ts.EmitAndSemanticDiagnosticsBuilderProgram,\n  { ignoreForDiagnostics }: ng.NgtscProgram['compiler'],\n  includeTTC: boolean,\n): Set<ts.SourceFile> {\n  const affectedFiles = new Set<ts.SourceFile>();\n\n  // eslint-disable-next-line no-constant-condition\n  while (true) {\n    const result = builder.getSemanticDiagnosticsOfNextAffectedFile(undefined, (sourceFile) => {\n      // If the affected file is a TTC shim, add the shim's original source file.\n      // This ensures that changes that affect TTC are typechecked even when the changes\n      // are otherwise unrelated from a TS perspective and do not result in Ivy codegen changes.\n      // For example, changing @Input property types of a directive used in another component's\n      // template.\n      // A TTC shim is a file that has been ignored for diagnostics and has a filename ending in `.ngtypecheck.ts`.\n      if (ignoreForDiagnostics.has(sourceFile) && sourceFile.fileName.endsWith('.ngtypecheck.ts')) {\n        // This file name conversion relies on internal compiler logic and should be converted\n        // to an official method when available. 15 is length of `.ngtypecheck.ts`\n        const originalFilename = sourceFile.fileName.slice(0, -15) + '.ts';\n        const originalSourceFile = builder.getSourceFile(originalFilename);\n        if (originalSourceFile) {\n          affectedFiles.add(originalSourceFile);\n        }\n\n        return true;\n      }\n\n      return false;\n    });\n\n    if (!result) {\n      break;\n    }\n\n    affectedFiles.add(result.affected as ts.SourceFile);\n  }\n\n  // Add all files with associated template type checking files.\n  // Stored TS build info does not have knowledge of the AOT compiler or the typechecking state of the templates.\n  // To ensure that errors are reported correctly, all AOT component diagnostics need to be analyzed even if build\n  // info is present.\n  if (includeTTC) {\n    for (const sourceFile of builder.getSourceFiles()) {\n      if (ignoreForDiagnostics.has(sourceFile) && sourceFile.fileName.endsWith('.ngtypecheck.ts')) {\n        // This file name conversion relies on internal compiler logic and should be converted\n        // to an official method when available. 15 is length of `.ngtypecheck.ts`\n        const originalFilename = sourceFile.fileName.slice(0, -15) + '.ts';\n        const originalSourceFile = builder.getSourceFile(originalFilename);\n        if (originalSourceFile) {\n          affectedFiles.add(originalSourceFile);\n        }\n      }\n    }\n  }\n\n  return affectedFiles;\n}\n"]}
@@ -0,0 +1,11 @@
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
+ export { AngularCompilation } from './angular-compilation';
9
+ export { AotCompilation } from './aot-compilation';
10
+ export { JitCompilation } from './jit-compilation';
11
+ export { NoopCompilation } from './noop-compilation';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.NoopCompilation = exports.JitCompilation = exports.AotCompilation = exports.AngularCompilation = void 0;
11
+ var angular_compilation_1 = require("./angular-compilation");
12
+ Object.defineProperty(exports, "AngularCompilation", { enumerable: true, get: function () { return angular_compilation_1.AngularCompilation; } });
13
+ var aot_compilation_1 = require("./aot-compilation");
14
+ Object.defineProperty(exports, "AotCompilation", { enumerable: true, get: function () { return aot_compilation_1.AotCompilation; } });
15
+ var jit_compilation_1 = require("./jit-compilation");
16
+ Object.defineProperty(exports, "JitCompilation", { enumerable: true, get: function () { return jit_compilation_1.JitCompilation; } });
17
+ var noop_compilation_1 = require("./noop-compilation");
18
+ Object.defineProperty(exports, "NoopCompilation", { enumerable: true, get: function () { return noop_compilation_1.NoopCompilation; } });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy90b29scy9lc2J1aWxkL2FuZ3VsYXIvY29tcGlsYXRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7R0FNRzs7O0FBRUgsNkRBQTJEO0FBQWxELHlIQUFBLGtCQUFrQixPQUFBO0FBQzNCLHFEQUFtRDtBQUExQyxpSEFBQSxjQUFjLE9BQUE7QUFDdkIscURBQW1EO0FBQTFDLGlIQUFBLGNBQWMsT0FBQTtBQUN2Qix1REFBcUQ7QUFBNUMsbUhBQUEsZUFBZSxPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCB7IEFuZ3VsYXJDb21waWxhdGlvbiB9IGZyb20gJy4vYW5ndWxhci1jb21waWxhdGlvbic7XG5leHBvcnQgeyBBb3RDb21waWxhdGlvbiB9IGZyb20gJy4vYW90LWNvbXBpbGF0aW9uJztcbmV4cG9ydCB7IEppdENvbXBpbGF0aW9uIH0gZnJvbSAnLi9qaXQtY29tcGlsYXRpb24nO1xuZXhwb3J0IHsgTm9vcENvbXBpbGF0aW9uIH0gZnJvbSAnLi9ub29wLWNvbXBpbGF0aW9uJztcbiJdfQ==
@@ -7,8 +7,8 @@
7
7
  */
8
8
  import type ng from '@angular/compiler-cli';
9
9
  import ts from 'typescript';
10
+ import { AngularHostOptions } from '../angular-host';
10
11
  import { AngularCompilation, EmitFileResult } from './angular-compilation';
11
- import { AngularHostOptions } from './angular-host';
12
12
  export declare class JitCompilation extends AngularCompilation {
13
13
  #private;
14
14
  initialize(tsconfig: string, hostOptions: AngularHostOptions, compilerOptionsTransformer?: (compilerOptions: ng.CompilerOptions) => ng.CompilerOptions): Promise<{
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ /**
3
+ * @license
4
+ * Copyright Google LLC All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
10
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
11
+ 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");
12
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
13
+ };
14
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
15
+ if (kind === "m") throw new TypeError("Private method is not writable");
16
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
17
+ 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");
18
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
19
+ };
20
+ var __importDefault = (this && this.__importDefault) || function (mod) {
21
+ return (mod && mod.__esModule) ? mod : { "default": mod };
22
+ };
23
+ var _JitCompilation_state;
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.JitCompilation = void 0;
26
+ const node_assert_1 = __importDefault(require("node:assert"));
27
+ const typescript_1 = __importDefault(require("typescript"));
28
+ const profiling_1 = require("../../profiling");
29
+ const angular_host_1 = require("../angular-host");
30
+ const jit_resource_transformer_1 = require("../jit-resource-transformer");
31
+ const angular_compilation_1 = require("./angular-compilation");
32
+ class JitCompilationState {
33
+ constructor(compilerHost, typeScriptProgram, constructorParametersDownlevelTransform, replaceResourcesTransform) {
34
+ this.compilerHost = compilerHost;
35
+ this.typeScriptProgram = typeScriptProgram;
36
+ this.constructorParametersDownlevelTransform = constructorParametersDownlevelTransform;
37
+ this.replaceResourcesTransform = replaceResourcesTransform;
38
+ }
39
+ }
40
+ class JitCompilation extends angular_compilation_1.AngularCompilation {
41
+ constructor() {
42
+ super(...arguments);
43
+ _JitCompilation_state.set(this, void 0);
44
+ }
45
+ async initialize(tsconfig, hostOptions, compilerOptionsTransformer) {
46
+ // Dynamically load the Angular compiler CLI package
47
+ const { constructorParametersDownlevelTransform } = await angular_compilation_1.AngularCompilation.loadCompilerCli();
48
+ // Load the compiler configuration and transform as needed
49
+ const { options: originalCompilerOptions, rootNames, errors: configurationDiagnostics, } = await this.loadConfiguration(tsconfig);
50
+ const compilerOptions = compilerOptionsTransformer?.(originalCompilerOptions) ?? originalCompilerOptions;
51
+ // Create Angular compiler host
52
+ const host = (0, angular_host_1.createAngularCompilerHost)(compilerOptions, hostOptions);
53
+ // Create the TypeScript Program
54
+ const typeScriptProgram = (0, profiling_1.profileSync)('TS_CREATE_PROGRAM', () => typescript_1.default.createEmitAndSemanticDiagnosticsBuilderProgram(rootNames, compilerOptions, host, __classPrivateFieldGet(this, _JitCompilation_state, "f")?.typeScriptProgram ?? typescript_1.default.readBuilderProgram(compilerOptions, host), configurationDiagnostics));
55
+ const affectedFiles = (0, profiling_1.profileSync)('TS_FIND_AFFECTED', () => findAffectedFiles(typeScriptProgram));
56
+ __classPrivateFieldSet(this, _JitCompilation_state, new JitCompilationState(host, typeScriptProgram, constructorParametersDownlevelTransform(typeScriptProgram.getProgram()), (0, jit_resource_transformer_1.createJitResourceTransformer)(() => typeScriptProgram.getProgram().getTypeChecker())), "f");
57
+ const referencedFiles = typeScriptProgram
58
+ .getSourceFiles()
59
+ .map((sourceFile) => sourceFile.fileName);
60
+ return { affectedFiles, compilerOptions, referencedFiles };
61
+ }
62
+ *collectDiagnostics() {
63
+ (0, node_assert_1.default)(__classPrivateFieldGet(this, _JitCompilation_state, "f"), 'Compilation must be initialized prior to collecting diagnostics.');
64
+ const { typeScriptProgram } = __classPrivateFieldGet(this, _JitCompilation_state, "f");
65
+ // Collect program level diagnostics
66
+ yield* typeScriptProgram.getConfigFileParsingDiagnostics();
67
+ yield* typeScriptProgram.getOptionsDiagnostics();
68
+ yield* typeScriptProgram.getGlobalDiagnostics();
69
+ yield* (0, profiling_1.profileSync)('NG_DIAGNOSTICS_SYNTACTIC', () => typeScriptProgram.getSyntacticDiagnostics());
70
+ yield* (0, profiling_1.profileSync)('NG_DIAGNOSTICS_SEMANTIC', () => typeScriptProgram.getSemanticDiagnostics());
71
+ }
72
+ emitAffectedFiles() {
73
+ (0, node_assert_1.default)(__classPrivateFieldGet(this, _JitCompilation_state, "f"), 'Compilation must be initialized prior to emitting files.');
74
+ const { compilerHost, typeScriptProgram, constructorParametersDownlevelTransform, replaceResourcesTransform, } = __classPrivateFieldGet(this, _JitCompilation_state, "f");
75
+ const buildInfoFilename = typeScriptProgram.getCompilerOptions().tsBuildInfoFile ?? '.tsbuildinfo';
76
+ const emittedFiles = [];
77
+ const writeFileCallback = (filename, contents, _a, _b, sourceFiles) => {
78
+ if (!sourceFiles?.length && filename.endsWith(buildInfoFilename)) {
79
+ // Save builder info contents to specified location
80
+ compilerHost.writeFile(filename, contents, false);
81
+ return;
82
+ }
83
+ (0, node_assert_1.default)(sourceFiles?.length === 1, 'Invalid TypeScript program emit for ' + filename);
84
+ emittedFiles.push({ filename: sourceFiles[0].fileName, contents });
85
+ };
86
+ const transformers = {
87
+ before: [replaceResourcesTransform, constructorParametersDownlevelTransform],
88
+ };
89
+ // TypeScript will loop until there are no more affected files in the program
90
+ while (typeScriptProgram.emitNextAffectedFile(writeFileCallback, undefined, undefined, transformers)) {
91
+ /* empty */
92
+ }
93
+ return emittedFiles;
94
+ }
95
+ }
96
+ exports.JitCompilation = JitCompilation;
97
+ _JitCompilation_state = new WeakMap();
98
+ function findAffectedFiles(builder) {
99
+ const affectedFiles = new Set();
100
+ let result;
101
+ while ((result = builder.getSemanticDiagnosticsOfNextAffectedFile())) {
102
+ affectedFiles.add(result.affected);
103
+ }
104
+ return affectedFiles;
105
+ }
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jit-compilation.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/angular_devkit/build_angular/src/tools/esbuild/angular/compilation/jit-compilation.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 type ng from '@angular/compiler-cli';\nimport assert from 'node:assert';\nimport ts from 'typescript';\nimport { profileSync } from '../../profiling';\nimport { AngularHostOptions, createAngularCompilerHost } from '../angular-host';\nimport { createJitResourceTransformer } from '../jit-resource-transformer';\nimport { AngularCompilation, EmitFileResult } from './angular-compilation';\n\nclass JitCompilationState {\n  constructor(\n    public readonly compilerHost: ng.CompilerHost,\n    public readonly typeScriptProgram: ts.EmitAndSemanticDiagnosticsBuilderProgram,\n    public readonly constructorParametersDownlevelTransform: ts.TransformerFactory<ts.SourceFile>,\n    public readonly replaceResourcesTransform: ts.TransformerFactory<ts.SourceFile>,\n  ) {}\n}\n\nexport class JitCompilation extends AngularCompilation {\n  #state?: JitCompilationState;\n\n  async initialize(\n    tsconfig: string,\n    hostOptions: AngularHostOptions,\n    compilerOptionsTransformer?: (compilerOptions: ng.CompilerOptions) => ng.CompilerOptions,\n  ): Promise<{\n    affectedFiles: ReadonlySet<ts.SourceFile>;\n    compilerOptions: ng.CompilerOptions;\n    referencedFiles: readonly string[];\n  }> {\n    // Dynamically load the Angular compiler CLI package\n    const { constructorParametersDownlevelTransform } = await AngularCompilation.loadCompilerCli();\n\n    // Load the compiler configuration and transform as needed\n    const {\n      options: originalCompilerOptions,\n      rootNames,\n      errors: configurationDiagnostics,\n    } = await this.loadConfiguration(tsconfig);\n    const compilerOptions =\n      compilerOptionsTransformer?.(originalCompilerOptions) ?? originalCompilerOptions;\n\n    // Create Angular compiler host\n    const host = createAngularCompilerHost(compilerOptions, hostOptions);\n\n    // Create the TypeScript Program\n    const typeScriptProgram = profileSync('TS_CREATE_PROGRAM', () =>\n      ts.createEmitAndSemanticDiagnosticsBuilderProgram(\n        rootNames,\n        compilerOptions,\n        host,\n        this.#state?.typeScriptProgram ?? ts.readBuilderProgram(compilerOptions, host),\n        configurationDiagnostics,\n      ),\n    );\n\n    const affectedFiles = profileSync('TS_FIND_AFFECTED', () =>\n      findAffectedFiles(typeScriptProgram),\n    );\n\n    this.#state = new JitCompilationState(\n      host,\n      typeScriptProgram,\n      constructorParametersDownlevelTransform(typeScriptProgram.getProgram()),\n      createJitResourceTransformer(() => typeScriptProgram.getProgram().getTypeChecker()),\n    );\n\n    const referencedFiles = typeScriptProgram\n      .getSourceFiles()\n      .map((sourceFile) => sourceFile.fileName);\n\n    return { affectedFiles, compilerOptions, referencedFiles };\n  }\n\n  *collectDiagnostics(): Iterable<ts.Diagnostic> {\n    assert(this.#state, 'Compilation must be initialized prior to collecting diagnostics.');\n    const { typeScriptProgram } = this.#state;\n\n    // Collect program level diagnostics\n    yield* typeScriptProgram.getConfigFileParsingDiagnostics();\n    yield* typeScriptProgram.getOptionsDiagnostics();\n    yield* typeScriptProgram.getGlobalDiagnostics();\n    yield* profileSync('NG_DIAGNOSTICS_SYNTACTIC', () =>\n      typeScriptProgram.getSyntacticDiagnostics(),\n    );\n    yield* profileSync('NG_DIAGNOSTICS_SEMANTIC', () => typeScriptProgram.getSemanticDiagnostics());\n  }\n\n  emitAffectedFiles(): Iterable<EmitFileResult> {\n    assert(this.#state, 'Compilation must be initialized prior to emitting files.');\n    const {\n      compilerHost,\n      typeScriptProgram,\n      constructorParametersDownlevelTransform,\n      replaceResourcesTransform,\n    } = this.#state;\n    const buildInfoFilename =\n      typeScriptProgram.getCompilerOptions().tsBuildInfoFile ?? '.tsbuildinfo';\n\n    const emittedFiles: EmitFileResult[] = [];\n    const writeFileCallback: ts.WriteFileCallback = (filename, contents, _a, _b, sourceFiles) => {\n      if (!sourceFiles?.length && filename.endsWith(buildInfoFilename)) {\n        // Save builder info contents to specified location\n        compilerHost.writeFile(filename, contents, false);\n\n        return;\n      }\n\n      assert(sourceFiles?.length === 1, 'Invalid TypeScript program emit for ' + filename);\n\n      emittedFiles.push({ filename: sourceFiles[0].fileName, contents });\n    };\n    const transformers = {\n      before: [replaceResourcesTransform, constructorParametersDownlevelTransform],\n    };\n\n    // TypeScript will loop until there are no more affected files in the program\n    while (\n      typeScriptProgram.emitNextAffectedFile(writeFileCallback, undefined, undefined, transformers)\n    ) {\n      /* empty */\n    }\n\n    return emittedFiles;\n  }\n}\n\nfunction findAffectedFiles(\n  builder: ts.EmitAndSemanticDiagnosticsBuilderProgram,\n): Set<ts.SourceFile> {\n  const affectedFiles = new Set<ts.SourceFile>();\n\n  let result;\n  while ((result = builder.getSemanticDiagnosticsOfNextAffectedFile())) {\n    affectedFiles.add(result.affected as ts.SourceFile);\n  }\n\n  return affectedFiles;\n}\n"]}