@angular/compiler-cli 10.0.3 → 10.0.4

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.
@@ -40,6 +40,7 @@
40
40
  // targetEntryPointPath forces us to error if an entry-point fails.
41
41
  errorOnFailedEntryPoint = true;
42
42
  }
43
+ checkForSolutionStyleTsConfig(fileSystem, logger, projectPath, options.tsConfigPath, tsConfig);
43
44
  return {
44
45
  basePath: basePath,
45
46
  targetEntryPointPath: targetEntryPointPath,
@@ -86,5 +87,20 @@
86
87
  tsConfigCache = null;
87
88
  }
88
89
  exports.clearTsConfigCache = clearTsConfigCache;
90
+ function checkForSolutionStyleTsConfig(fileSystem, logger, projectPath, tsConfigPath, tsConfig) {
91
+ if (tsConfigPath !== null && !tsConfigPath && tsConfig !== null &&
92
+ tsConfig.rootNames.length === 0 && tsConfig.projectReferences !== undefined &&
93
+ tsConfig.projectReferences.length > 0) {
94
+ logger.warn("The inferred tsconfig file \"" + tsConfig.project + "\" appears to be \"solution-style\" " +
95
+ "since it contains no root files but does contain project references.\n" +
96
+ "This is probably not wanted, since ngcc is unable to infer settings like \"paths\" mappings from such a file.\n" +
97
+ "Perhaps you should have explicitly specified one of the referenced projects using the --tsconfig option. For example:\n\n" +
98
+ tsConfig.projectReferences.map(function (ref) { return " ngcc ... --tsconfig \"" + ref.originalPath + "\"\n"; })
99
+ .join('') +
100
+ "\nFind out more about solution-style tsconfig at https://devblogs.microsoft.com/typescript/announcing-typescript-3-9/#solution-style-tsconfig.\n" +
101
+ "If you did intend to use this file, then you can hide this warning by providing it explicitly:\n\n" +
102
+ (" ngcc ... --tsconfig \"" + fileSystem.relative(projectPath, tsConfig.project) + "\""));
103
+ }
104
+ }
89
105
  });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngcc_options.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/ngcc/src/ngcc_options.ts"],"names":[],"mappings":";;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,2EAAoG;IACpG,6EAAiF;IAEjF,wFAAuD;IACvD,wEAAkD;IAClD,mFAAmE;IACnE,8EAA0E;IAE1E,oGAAiE;IACjE,kHAA8E;IA4I9E;;;;OAIG;IACH,SAAgB,cAAc,CAAC,OAAoB;QAEjD,IAAM,UAAU,GAAG,2BAAa,EAAE,CAAC;QACnC,IAAM,WAAW,GAAG,0BAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAM,WAAW,GAAG,UAAU,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACpD,IAAM,QAAQ,GACV,OAAO,CAAC,YAAY,KAAK,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,YAAY,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAG1F,IAAA,QAAQ,GAYN,OAAO,SAZD,EACR,oBAAoB,GAWlB,OAAO,qBAXW,EACpB,KAUE,OAAO,qBAVyC,EAAlD,oBAAoB,mBAAG,yCAA2B,KAAA,EAClD,KASE,OAAO,kBATe,EAAxB,iBAAiB,mBAAG,IAAI,KAAA,EACxB,KAQE,OAAO,2BARyB,EAAlC,0BAA0B,mBAAG,KAAK,KAAA,EAClC,KAOE,OAAO,OAPgC,EAAzC,MAAM,mBAAG,IAAI,8BAAa,CAAC,iBAAQ,CAAC,IAAI,CAAC,KAAA,EACzC,KAME,OAAO,aANwD,EAAjE,YAAY,mBAAG,2CAA2B,CAAC,QAAQ,EAAE,WAAW,CAAC,KAAA,EACjE,KAKE,OAAO,MALI,EAAb,KAAK,mBAAG,KAAK,KAAA,EACb,KAIE,OAAO,wBAJsB,EAA/B,uBAAuB,mBAAG,KAAK,KAAA,EAC/B,KAGE,OAAO,gCAH6B,EAAtC,+BAA+B,mBAAG,IAAI,KAAA,EACtC,KAEE,OAAO,6BAF2B,EAApC,4BAA4B,mBAAG,KAAK,KAAA,EACpC,YAAY,GACV,OAAO,aADG,CACF;QAEZ,IAAI,CAAC,CAAC,oBAAoB,EAAE;YAC1B,mEAAmE;YACnE,uBAAuB,GAAG,IAAI,CAAC;SAChC;QAED,OAAO;YACL,QAAQ,UAAA;YACR,oBAAoB,sBAAA;YACpB,oBAAoB,sBAAA;YACpB,iBAAiB,mBAAA;YACjB,0BAA0B,4BAAA;YAC1B,MAAM,QAAA;YACN,YAAY,cAAA;YACZ,KAAK,OAAA;YACL,uBAAuB,yBAAA;YACvB,+BAA+B,iCAAA;YAC/B,4BAA4B,8BAAA;YAC5B,YAAY,cAAA;YACZ,UAAU,YAAA;YACV,WAAW,aAAA;YACX,WAAW,aAAA;YACX,QAAQ,UAAA;YACR,aAAa,EAAE,UAAC,cAAkC,IAAK,OAAA,0BAA0B,CAAC,CAAC;gBAC/E,IAAI,qDAAuB,CAAC,UAAU,EAAE,MAAM,EAAE,uBAAuB,EAAE,cAAc,CAAC,CAAC,CAAC;gBAC1F,IAAI,wCAAiB,CAAC,UAAU,EAAE,MAAM,EAAE,uBAAuB,CAAC,EAFf,CAEe;SACvE,CAAC;IACJ,CAAC;IAjDD,wCAiDC;IAED,IAAI,aAAa,GAA6B,IAAI,CAAC;IACnD,IAAI,iBAAiB,GAAgB,IAAI,CAAC;IAE1C;;;;;;;;OAQG;IACH,SAAS,WAAW,CAAC,YAAoB;QACvC,IAAI,YAAY,KAAK,iBAAiB,EAAE;YACtC,iBAAiB,GAAG,YAAY,CAAC;YACjC,aAAa,GAAG,mCAAiB,CAAC,YAAY,CAAC,CAAC;SACjD;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;IAED,SAAgB,kBAAkB;QAChC,iBAAiB,GAAG,IAAI,CAAC;QACzB,aAAa,GAAG,IAAI,CAAC;IACvB,CAAC;IAHD,gDAGC","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 */\nimport {absoluteFrom, AbsoluteFsPath, FileSystem, getFileSystem} from '../../src/ngtsc/file_system';\nimport {ParsedConfiguration, readConfiguration} from '../../src/perform_compile';\n\nimport {ConsoleLogger} from './logging/console_logger';\nimport {Logger, LogLevel} from './logging/logger';\nimport {SUPPORTED_FORMAT_PROPERTIES} from './packages/entry_point';\nimport {getPathMappingsFromTsConfig, PathMappings} from './path_mappings';\nimport {FileWriter} from './writing/file_writer';\nimport {InPlaceFileWriter} from './writing/in_place_file_writer';\nimport {NewEntryPointFileWriter} from './writing/new_entry_point_file_writer';\nimport {PackageJsonUpdater} from './writing/package_json_updater';\n\n/**\n * The options to configure the ngcc compiler for synchronous execution.\n */\nexport interface SyncNgccOptions {\n  /** The absolute path to the `node_modules` folder that contains the packages to process. */\n  basePath: string;\n\n  /**\n   * The path to the primary package to be processed. If not absolute then it must be relative to\n   * `basePath`.\n   *\n   * All its dependencies will need to be processed too.\n   *\n   * If this property is provided then `errorOnFailedEntryPoint` is forced to true.\n   */\n  targetEntryPointPath?: string;\n\n  /**\n   * Which entry-point properties in the package.json to consider when processing an entry-point.\n   * Each property should hold a path to the particular bundle format for the entry-point.\n   * Defaults to all the properties in the package.json.\n   */\n  propertiesToConsider?: string[];\n\n  /**\n   * Whether to process all formats specified by (`propertiesToConsider`)  or to stop processing\n   * this entry-point at the first matching format. Defaults to `true`.\n   */\n  compileAllFormats?: boolean;\n\n  /**\n   * Whether to create new entry-points bundles rather than overwriting the original files.\n   */\n  createNewEntryPointFormats?: boolean;\n\n  /**\n   * Provide a logger that will be called with log messages.\n   */\n  logger?: Logger;\n\n  /**\n   * Paths mapping configuration (`paths` and `baseUrl`), as found in `ts.CompilerOptions`.\n   * These are used to resolve paths to locally built Angular libraries.\n   *\n   * Note that `pathMappings` specified here take precedence over any `pathMappings` loaded from a\n   * TS config file.\n   */\n  pathMappings?: PathMappings;\n\n  /**\n   * Provide a file-system service that will be used by ngcc for all file interactions.\n   */\n  fileSystem?: FileSystem;\n\n  /**\n   * Whether the compilation should run and return asynchronously. Allowing asynchronous execution\n   * may speed up the compilation by utilizing multiple CPU cores (if available).\n   *\n   * Default: `false` (i.e. run synchronously)\n   */\n  async?: false;\n\n  /**\n   * Set to true in order to terminate immediately with an error code if an entry-point fails to be\n   * processed.\n   *\n   * If `targetEntryPointPath` is provided then this property is always true and cannot be\n   * changed. Otherwise the default is false.\n   *\n   * When set to false, ngcc will continue to process entry-points after a failure. In which case it\n   * will log an error and resume processing other entry-points.\n   */\n  errorOnFailedEntryPoint?: boolean;\n\n  /**\n   * Render `$localize` messages with legacy format ids.\n   *\n   * The default value is `true`. Only set this to `false` if you do not want legacy message ids to\n   * be rendered. For example, if you are not using legacy message ids in your translation files\n   * AND are not doing compile-time inlining of translations, in which case the extra message ids\n   * would add unwanted size to the final source bundle.\n   *\n   * It is safe to leave this set to true if you are doing compile-time inlining because the extra\n   * legacy message ids will all be stripped during translation.\n   */\n  enableI18nLegacyMessageIdFormat?: boolean;\n\n  /**\n   * Whether to invalidate any entry-point manifest file that is on disk. Instead, walk the\n   * directory tree looking for entry-points, and then write a new entry-point manifest, if\n   * possible.\n   *\n   * Default: `false` (i.e. the manifest will be used if available)\n   */\n  invalidateEntryPointManifest?: boolean;\n\n  /**\n   * An absolute path to a TS config file (e.g. `tsconfig.json`) or a directory containing one, that\n   * will be used to configure module resolution with things like path mappings, if not specified\n   * explicitly via the `pathMappings` property to `mainNgcc`.\n   *\n   * If `undefined`, ngcc will attempt to load a `tsconfig.json` file from the directory above the\n   * `basePath`.\n   *\n   * If `null`, ngcc will not attempt to load any TS config file at all.\n   */\n  tsConfigPath?: string|null;\n\n  /**\n   * Use the program defined in the loaded tsconfig.json (if available - see\n   * `tsConfigPath` option) to identify the entry-points that should be processed.\n   * If this is set to `true` then only the entry-points reachable from the given\n   * program (and their dependencies) will be processed.\n   */\n  findEntryPointsFromTsConfigProgram?: boolean;\n}\n\n/**\n * The options to configure the ngcc compiler for asynchronous execution.\n */\nexport type AsyncNgccOptions = Omit<SyncNgccOptions, 'async'>&{async: true};\n\n/**\n * The options to configure the ngcc compiler.\n */\nexport type NgccOptions = AsyncNgccOptions|SyncNgccOptions;\n\nexport type OptionalNgccOptionKeys =\n    'targetEntryPointPath'|'tsConfigPath'|'pathMappings'|'findEntryPointsFromTsConfigProgram';\nexport type RequiredNgccOptions = Required<Omit<NgccOptions, OptionalNgccOptionKeys>>;\nexport type OptionalNgccOptions = Pick<NgccOptions, OptionalNgccOptionKeys>;\nexport type SharedSetup = {\n  fileSystem: FileSystem; absBasePath: AbsoluteFsPath; projectPath: AbsoluteFsPath;\n  tsConfig: ParsedConfiguration | null;\n  getFileWriter(pkgJsonUpdater: PackageJsonUpdater): FileWriter;\n};\n\n/**\n * Instantiate common utilities that are always used and fix up options with defaults, as necessary.\n *\n * NOTE: Avoid eagerly instantiating anything that might not be used when running sync/async.\n */\nexport function getSharedSetup(options: NgccOptions): SharedSetup&RequiredNgccOptions&\n    OptionalNgccOptions {\n  const fileSystem = getFileSystem();\n  const absBasePath = absoluteFrom(options.basePath);\n  const projectPath = fileSystem.dirname(absBasePath);\n  const tsConfig =\n      options.tsConfigPath !== null ? getTsConfig(options.tsConfigPath || projectPath) : null;\n\n  let {\n    basePath,\n    targetEntryPointPath,\n    propertiesToConsider = SUPPORTED_FORMAT_PROPERTIES,\n    compileAllFormats = true,\n    createNewEntryPointFormats = false,\n    logger = new ConsoleLogger(LogLevel.info),\n    pathMappings = getPathMappingsFromTsConfig(tsConfig, projectPath),\n    async = false,\n    errorOnFailedEntryPoint = false,\n    enableI18nLegacyMessageIdFormat = true,\n    invalidateEntryPointManifest = false,\n    tsConfigPath,\n  } = options;\n\n  if (!!targetEntryPointPath) {\n    // targetEntryPointPath forces us to error if an entry-point fails.\n    errorOnFailedEntryPoint = true;\n  }\n\n  return {\n    basePath,\n    targetEntryPointPath,\n    propertiesToConsider,\n    compileAllFormats,\n    createNewEntryPointFormats,\n    logger,\n    pathMappings,\n    async,\n    errorOnFailedEntryPoint,\n    enableI18nLegacyMessageIdFormat,\n    invalidateEntryPointManifest,\n    tsConfigPath,\n    fileSystem,\n    absBasePath,\n    projectPath,\n    tsConfig,\n    getFileWriter: (pkgJsonUpdater: PackageJsonUpdater) => createNewEntryPointFormats ?\n        new NewEntryPointFileWriter(fileSystem, logger, errorOnFailedEntryPoint, pkgJsonUpdater) :\n        new InPlaceFileWriter(fileSystem, logger, errorOnFailedEntryPoint),\n  };\n}\n\nlet tsConfigCache: ParsedConfiguration|null = null;\nlet tsConfigPathCache: string|null = null;\n\n/**\n * Get the parsed configuration object for the given `tsConfigPath`.\n *\n * This function will cache the previous parsed configuration object to avoid unnecessary processing\n * of the tsconfig.json in the case that it is requested repeatedly.\n *\n * This makes the assumption, which is true as of writing, that the contents of tsconfig.json and\n * its dependencies will not change during the life of the process running ngcc.\n */\nfunction getTsConfig(tsConfigPath: string): ParsedConfiguration|null {\n  if (tsConfigPath !== tsConfigPathCache) {\n    tsConfigPathCache = tsConfigPath;\n    tsConfigCache = readConfiguration(tsConfigPath);\n  }\n  return tsConfigCache;\n}\n\nexport function clearTsConfigCache() {\n  tsConfigPathCache = null;\n  tsConfigCache = null;\n}\n"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngcc_options.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/ngcc/src/ngcc_options.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 */\nimport {absoluteFrom, AbsoluteFsPath, FileSystem, getFileSystem} from '../../src/ngtsc/file_system';\nimport {ParsedConfiguration, readConfiguration} from '../../src/perform_compile';\n\nimport {ConsoleLogger} from './logging/console_logger';\nimport {Logger, LogLevel} from './logging/logger';\nimport {SUPPORTED_FORMAT_PROPERTIES} from './packages/entry_point';\nimport {getPathMappingsFromTsConfig, PathMappings} from './path_mappings';\nimport {FileWriter} from './writing/file_writer';\nimport {InPlaceFileWriter} from './writing/in_place_file_writer';\nimport {NewEntryPointFileWriter} from './writing/new_entry_point_file_writer';\nimport {PackageJsonUpdater} from './writing/package_json_updater';\n\n/**\n * The options to configure the ngcc compiler for synchronous execution.\n */\nexport interface SyncNgccOptions {\n  /** The absolute path to the `node_modules` folder that contains the packages to process. */\n  basePath: string;\n\n  /**\n   * The path to the primary package to be processed. If not absolute then it must be relative to\n   * `basePath`.\n   *\n   * All its dependencies will need to be processed too.\n   *\n   * If this property is provided then `errorOnFailedEntryPoint` is forced to true.\n   */\n  targetEntryPointPath?: string;\n\n  /**\n   * Which entry-point properties in the package.json to consider when processing an entry-point.\n   * Each property should hold a path to the particular bundle format for the entry-point.\n   * Defaults to all the properties in the package.json.\n   */\n  propertiesToConsider?: string[];\n\n  /**\n   * Whether to process all formats specified by (`propertiesToConsider`)  or to stop processing\n   * this entry-point at the first matching format. Defaults to `true`.\n   */\n  compileAllFormats?: boolean;\n\n  /**\n   * Whether to create new entry-points bundles rather than overwriting the original files.\n   */\n  createNewEntryPointFormats?: boolean;\n\n  /**\n   * Provide a logger that will be called with log messages.\n   */\n  logger?: Logger;\n\n  /**\n   * Paths mapping configuration (`paths` and `baseUrl`), as found in `ts.CompilerOptions`.\n   * These are used to resolve paths to locally built Angular libraries.\n   *\n   * Note that `pathMappings` specified here take precedence over any `pathMappings` loaded from a\n   * TS config file.\n   */\n  pathMappings?: PathMappings;\n\n  /**\n   * Provide a file-system service that will be used by ngcc for all file interactions.\n   */\n  fileSystem?: FileSystem;\n\n  /**\n   * Whether the compilation should run and return asynchronously. Allowing asynchronous execution\n   * may speed up the compilation by utilizing multiple CPU cores (if available).\n   *\n   * Default: `false` (i.e. run synchronously)\n   */\n  async?: false;\n\n  /**\n   * Set to true in order to terminate immediately with an error code if an entry-point fails to be\n   * processed.\n   *\n   * If `targetEntryPointPath` is provided then this property is always true and cannot be\n   * changed. Otherwise the default is false.\n   *\n   * When set to false, ngcc will continue to process entry-points after a failure. In which case it\n   * will log an error and resume processing other entry-points.\n   */\n  errorOnFailedEntryPoint?: boolean;\n\n  /**\n   * Render `$localize` messages with legacy format ids.\n   *\n   * The default value is `true`. Only set this to `false` if you do not want legacy message ids to\n   * be rendered. For example, if you are not using legacy message ids in your translation files\n   * AND are not doing compile-time inlining of translations, in which case the extra message ids\n   * would add unwanted size to the final source bundle.\n   *\n   * It is safe to leave this set to true if you are doing compile-time inlining because the extra\n   * legacy message ids will all be stripped during translation.\n   */\n  enableI18nLegacyMessageIdFormat?: boolean;\n\n  /**\n   * Whether to invalidate any entry-point manifest file that is on disk. Instead, walk the\n   * directory tree looking for entry-points, and then write a new entry-point manifest, if\n   * possible.\n   *\n   * Default: `false` (i.e. the manifest will be used if available)\n   */\n  invalidateEntryPointManifest?: boolean;\n\n  /**\n   * An absolute path to a TS config file (e.g. `tsconfig.json`) or a directory containing one, that\n   * will be used to configure module resolution with things like path mappings, if not specified\n   * explicitly via the `pathMappings` property to `mainNgcc`.\n   *\n   * If `undefined`, ngcc will attempt to load a `tsconfig.json` file from the directory above the\n   * `basePath`.\n   *\n   * If `null`, ngcc will not attempt to load any TS config file at all.\n   */\n  tsConfigPath?: string|null;\n\n  /**\n   * Use the program defined in the loaded tsconfig.json (if available - see\n   * `tsConfigPath` option) to identify the entry-points that should be processed.\n   * If this is set to `true` then only the entry-points reachable from the given\n   * program (and their dependencies) will be processed.\n   */\n  findEntryPointsFromTsConfigProgram?: boolean;\n}\n\n/**\n * The options to configure the ngcc compiler for asynchronous execution.\n */\nexport type AsyncNgccOptions = Omit<SyncNgccOptions, 'async'>&{async: true};\n\n/**\n * The options to configure the ngcc compiler.\n */\nexport type NgccOptions = AsyncNgccOptions|SyncNgccOptions;\n\nexport type OptionalNgccOptionKeys =\n    'targetEntryPointPath'|'tsConfigPath'|'pathMappings'|'findEntryPointsFromTsConfigProgram';\nexport type RequiredNgccOptions = Required<Omit<NgccOptions, OptionalNgccOptionKeys>>;\nexport type OptionalNgccOptions = Pick<NgccOptions, OptionalNgccOptionKeys>;\nexport type SharedSetup = {\n  fileSystem: FileSystem; absBasePath: AbsoluteFsPath; projectPath: AbsoluteFsPath;\n  tsConfig: ParsedConfiguration | null;\n  getFileWriter(pkgJsonUpdater: PackageJsonUpdater): FileWriter;\n};\n\n/**\n * Instantiate common utilities that are always used and fix up options with defaults, as necessary.\n *\n * NOTE: Avoid eagerly instantiating anything that might not be used when running sync/async.\n */\nexport function getSharedSetup(options: NgccOptions): SharedSetup&RequiredNgccOptions&\n    OptionalNgccOptions {\n  const fileSystem = getFileSystem();\n  const absBasePath = absoluteFrom(options.basePath);\n  const projectPath = fileSystem.dirname(absBasePath);\n  const tsConfig =\n      options.tsConfigPath !== null ? getTsConfig(options.tsConfigPath || projectPath) : null;\n\n  let {\n    basePath,\n    targetEntryPointPath,\n    propertiesToConsider = SUPPORTED_FORMAT_PROPERTIES,\n    compileAllFormats = true,\n    createNewEntryPointFormats = false,\n    logger = new ConsoleLogger(LogLevel.info),\n    pathMappings = getPathMappingsFromTsConfig(tsConfig, projectPath),\n    async = false,\n    errorOnFailedEntryPoint = false,\n    enableI18nLegacyMessageIdFormat = true,\n    invalidateEntryPointManifest = false,\n    tsConfigPath,\n  } = options;\n\n  if (!!targetEntryPointPath) {\n    // targetEntryPointPath forces us to error if an entry-point fails.\n    errorOnFailedEntryPoint = true;\n  }\n\n  checkForSolutionStyleTsConfig(fileSystem, logger, projectPath, options.tsConfigPath, tsConfig);\n\n  return {\n    basePath,\n    targetEntryPointPath,\n    propertiesToConsider,\n    compileAllFormats,\n    createNewEntryPointFormats,\n    logger,\n    pathMappings,\n    async,\n    errorOnFailedEntryPoint,\n    enableI18nLegacyMessageIdFormat,\n    invalidateEntryPointManifest,\n    tsConfigPath,\n    fileSystem,\n    absBasePath,\n    projectPath,\n    tsConfig,\n    getFileWriter: (pkgJsonUpdater: PackageJsonUpdater) => createNewEntryPointFormats ?\n        new NewEntryPointFileWriter(fileSystem, logger, errorOnFailedEntryPoint, pkgJsonUpdater) :\n        new InPlaceFileWriter(fileSystem, logger, errorOnFailedEntryPoint),\n  };\n}\n\nlet tsConfigCache: ParsedConfiguration|null = null;\nlet tsConfigPathCache: string|null = null;\n\n/**\n * Get the parsed configuration object for the given `tsConfigPath`.\n *\n * This function will cache the previous parsed configuration object to avoid unnecessary processing\n * of the tsconfig.json in the case that it is requested repeatedly.\n *\n * This makes the assumption, which is true as of writing, that the contents of tsconfig.json and\n * its dependencies will not change during the life of the process running ngcc.\n */\nfunction getTsConfig(tsConfigPath: string): ParsedConfiguration|null {\n  if (tsConfigPath !== tsConfigPathCache) {\n    tsConfigPathCache = tsConfigPath;\n    tsConfigCache = readConfiguration(tsConfigPath);\n  }\n  return tsConfigCache;\n}\n\nexport function clearTsConfigCache() {\n  tsConfigPathCache = null;\n  tsConfigCache = null;\n}\n\nfunction checkForSolutionStyleTsConfig(\n    fileSystem: FileSystem, logger: Logger, projectPath: AbsoluteFsPath,\n    tsConfigPath: string|null|undefined, tsConfig: ParsedConfiguration|null): void {\n  if (tsConfigPath !== null && !tsConfigPath && tsConfig !== null &&\n      tsConfig.rootNames.length === 0 && tsConfig.projectReferences !== undefined &&\n      tsConfig.projectReferences.length > 0) {\n    logger.warn(\n        `The inferred tsconfig file \"${tsConfig.project}\" appears to be \"solution-style\" ` +\n        `since it contains no root files but does contain project references.\\n` +\n        `This is probably not wanted, since ngcc is unable to infer settings like \"paths\" mappings from such a file.\\n` +\n        `Perhaps you should have explicitly specified one of the referenced projects using the --tsconfig option. For example:\\n\\n` +\n        tsConfig.projectReferences.map(ref => `  ngcc ... --tsconfig \"${ref.originalPath}\"\\n`)\n            .join('') +\n        `\\nFind out more about solution-style tsconfig at https://devblogs.microsoft.com/typescript/announcing-typescript-3-9/#solution-style-tsconfig.\\n` +\n        `If you did intend to use this file, then you can hide this warning by providing it explicitly:\\n\\n` +\n        `  ngcc ... --tsconfig \"${fileSystem.relative(projectPath, tsConfig.project)}\"`);\n  }\n}\n"]}
@@ -9,7 +9,7 @@
9
9
  import { AbsoluteFsPath } from '../../../src/ngtsc/file_system';
10
10
  import { PackageJsonUpdater } from '../writing/package_json_updater';
11
11
  import { EntryPointPackageJson, PackageJsonFormatProperties } from './entry_point';
12
- export declare const NGCC_VERSION = "10.0.3";
12
+ export declare const NGCC_VERSION = "10.0.4";
13
13
  /**
14
14
  * Returns true if there is a format in this entry-point that was compiled with an outdated version
15
15
  * of ngcc.
@@ -12,7 +12,7 @@
12
12
  exports.markAsProcessed = exports.hasBeenProcessed = exports.cleanPackageJson = exports.needsCleaning = exports.NGCC_VERSION = void 0;
13
13
  var tslib_1 = require("tslib");
14
14
  var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer");
15
- exports.NGCC_VERSION = '10.0.3';
15
+ exports.NGCC_VERSION = '10.0.4';
16
16
  /**
17
17
  * Returns true if there is a format in this entry-point that was compiled with an outdated version
18
18
  * of ngcc.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/compiler-cli",
3
- "version": "10.0.3",
3
+ "version": "10.0.4",
4
4
  "description": "Angular - the compiler CLI for Node.js",
5
5
  "main": "index.js",
6
6
  "typings": "index.d.ts",
@@ -26,7 +26,7 @@
26
26
  "yargs": "15.3.0"
27
27
  },
28
28
  "peerDependencies": {
29
- "@angular/compiler": "10.0.3",
29
+ "@angular/compiler": "10.0.4",
30
30
  "typescript": ">=3.9 <4.0"
31
31
  },
32
32
  "engines": {
@@ -20,6 +20,7 @@ export interface ParsedConfiguration {
20
20
  project: string;
21
21
  options: api.CompilerOptions;
22
22
  rootNames: string[];
23
+ projectReferences?: readonly ts.ProjectReference[] | undefined;
23
24
  emitFlags: api.EmitFlags;
24
25
  errors: Diagnostics;
25
26
  }
@@ -185,6 +185,7 @@
185
185
  var configFileName = fs_1.resolve(fs_1.pwd(), projectFile);
186
186
  var parsed = ts.parseJsonConfigFileContent(config, parseConfigHost, basePath, existingOptions, configFileName);
187
187
  var rootNames = parsed.fileNames;
188
+ var projectReferences = parsed.projectReferences;
188
189
  var options = createNgCompilerOptions(basePath, config, parsed.options);
189
190
  var emitFlags = api.EmitFlags.Default;
190
191
  if (!(options.skipMetadataEmit || options.flatModuleOutFile)) {
@@ -193,7 +194,14 @@
193
194
  if (options.skipTemplateCodegen) {
194
195
  emitFlags = emitFlags & ~api.EmitFlags.Codegen;
195
196
  }
196
- return { project: projectFile, rootNames: rootNames, options: options, errors: parsed.errors, emitFlags: emitFlags };
197
+ return {
198
+ project: projectFile,
199
+ rootNames: rootNames,
200
+ projectReferences: projectReferences,
201
+ options: options,
202
+ errors: parsed.errors,
203
+ emitFlags: emitFlags
204
+ };
197
205
  }
198
206
  catch (e) {
199
207
  var errors = [{
@@ -291,4 +299,4 @@
291
299
  return diags.some(function (d) { return d.category === ts.DiagnosticCategory.Error; });
292
300
  }
293
301
  });
294
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"perform_compile.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/src/perform_compile.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 {isSyntaxError, Position} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, AbsoluteFsPath, getFileSystem, relative, resolve} from '../src/ngtsc/file_system';\n\nimport {replaceTsWithNgInErrors} from './ngtsc/diagnostics';\nimport * as api from './transformers/api';\nimport * as ng from './transformers/entry_points';\nimport {createMessageDiagnostic} from './transformers/util';\n\nexport type Diagnostics = ReadonlyArray<ts.Diagnostic|api.Diagnostic>;\n\nexport function filterErrorsAndWarnings(diagnostics: Diagnostics): Diagnostics {\n  return diagnostics.filter(d => d.category !== ts.DiagnosticCategory.Message);\n}\n\nconst defaultFormatHost: ts.FormatDiagnosticsHost = {\n  getCurrentDirectory: () => ts.sys.getCurrentDirectory(),\n  getCanonicalFileName: fileName => fileName,\n  getNewLine: () => ts.sys.newLine\n};\n\nfunction displayFileName(fileName: string, host: ts.FormatDiagnosticsHost): string {\n  return relative(\n      resolve(host.getCurrentDirectory()), resolve(host.getCanonicalFileName(fileName)));\n}\n\nexport function formatDiagnosticPosition(\n    position: Position, host: ts.FormatDiagnosticsHost = defaultFormatHost): string {\n  return `${displayFileName(position.fileName, host)}(${position.line + 1},${position.column + 1})`;\n}\n\nexport function flattenDiagnosticMessageChain(\n    chain: api.DiagnosticMessageChain, host: ts.FormatDiagnosticsHost = defaultFormatHost,\n    indent = 0): string {\n  const newLine = host.getNewLine();\n  let result = '';\n  if (indent) {\n    result += newLine;\n\n    for (let i = 0; i < indent; i++) {\n      result += '  ';\n    }\n  }\n  result += chain.messageText;\n\n  const position = chain.position;\n  // add position if available, and we are not at the depest frame\n  if (position && indent !== 0) {\n    result += ` at ${formatDiagnosticPosition(position, host)}`;\n  }\n\n  indent++;\n  if (chain.next) {\n    for (const kid of chain.next) {\n      result += flattenDiagnosticMessageChain(kid, host, indent);\n    }\n  }\n  return result;\n}\n\nexport function formatDiagnostic(\n    diagnostic: api.Diagnostic, host: ts.FormatDiagnosticsHost = defaultFormatHost) {\n  let result = '';\n  const newLine = host.getNewLine();\n  const span = diagnostic.span;\n  if (span) {\n    result += `${\n        formatDiagnosticPosition(\n            {fileName: span.start.file.url, line: span.start.line, column: span.start.col},\n            host)}: `;\n  } else if (diagnostic.position) {\n    result += `${formatDiagnosticPosition(diagnostic.position, host)}: `;\n  }\n  if (diagnostic.span && diagnostic.span.details) {\n    result += `${diagnostic.span.details}, ${diagnostic.messageText}${newLine}`;\n  } else if (diagnostic.chain) {\n    result += `${flattenDiagnosticMessageChain(diagnostic.chain, host)}.${newLine}`;\n  } else {\n    result += `${diagnostic.messageText}${newLine}`;\n  }\n  return result;\n}\n\nexport function formatDiagnostics(\n    diags: Diagnostics, host: ts.FormatDiagnosticsHost = defaultFormatHost): string {\n  if (diags && diags.length) {\n    return diags\n        .map(diagnostic => {\n          if (api.isTsDiagnostic(diagnostic)) {\n            return replaceTsWithNgInErrors(\n                ts.formatDiagnosticsWithColorAndContext([diagnostic], host));\n          } else {\n            return formatDiagnostic(diagnostic, host);\n          }\n        })\n        .join('');\n  } else {\n    return '';\n  }\n}\n\nexport interface ParsedConfiguration {\n  project: string;\n  options: api.CompilerOptions;\n  rootNames: string[];\n  emitFlags: api.EmitFlags;\n  errors: Diagnostics;\n}\n\nexport function calcProjectFileAndBasePath(project: string):\n    {projectFile: AbsoluteFsPath, basePath: AbsoluteFsPath} {\n  const fs = getFileSystem();\n  const absProject = fs.resolve(project);\n  const projectIsDir = fs.lstat(absProject).isDirectory();\n  const projectFile = projectIsDir ? fs.join(absProject, 'tsconfig.json') : absProject;\n  const projectDir = projectIsDir ? absProject : fs.dirname(absProject);\n  const basePath = fs.resolve(projectDir);\n  return {projectFile, basePath};\n}\n\nexport function createNgCompilerOptions(\n    basePath: string, config: any, tsOptions: ts.CompilerOptions): api.CompilerOptions {\n  // enableIvy `ngtsc` is an alias for `true`.\n  const {angularCompilerOptions = {}} = config;\n  const {enableIvy} = angularCompilerOptions;\n  angularCompilerOptions.enableIvy = enableIvy !== false && enableIvy !== 'tsc';\n\n  return {...tsOptions, ...angularCompilerOptions, genDir: basePath, basePath};\n}\n\nexport function readConfiguration(\n    project: string, existingOptions?: ts.CompilerOptions): ParsedConfiguration {\n  try {\n    const fs = getFileSystem();\n    const {projectFile, basePath} = calcProjectFileAndBasePath(project);\n\n    const readExtendedConfigFile =\n        (configFile: string, existingConfig?: any): {config?: any, error?: ts.Diagnostic} => {\n          const {config, error} = ts.readConfigFile(configFile, ts.sys.readFile);\n\n          if (error) {\n            return {error};\n          }\n\n          // we are only interested into merging 'angularCompilerOptions' as\n          // other options like 'compilerOptions' are merged by TS\n          const baseConfig = existingConfig || config;\n          if (existingConfig) {\n            baseConfig.angularCompilerOptions = {\n              ...config.angularCompilerOptions,\n              ...baseConfig.angularCompilerOptions\n            };\n          }\n\n          if (config.extends) {\n            let extendedConfigPath = fs.resolve(fs.dirname(configFile), config.extends);\n            extendedConfigPath = fs.extname(extendedConfigPath) ?\n                extendedConfigPath :\n                absoluteFrom(`${extendedConfigPath}.json`);\n\n            if (fs.exists(extendedConfigPath)) {\n              // Call read config recursively as TypeScript only merges CompilerOptions\n              return readExtendedConfigFile(extendedConfigPath, baseConfig);\n            }\n          }\n\n          return {config: baseConfig};\n        };\n\n    const {config, error} = readExtendedConfigFile(projectFile);\n\n    if (error) {\n      return {\n        project,\n        errors: [error],\n        rootNames: [],\n        options: {},\n        emitFlags: api.EmitFlags.Default\n      };\n    }\n    const parseConfigHost = {\n      useCaseSensitiveFileNames: true,\n      fileExists: fs.exists.bind(fs),\n      readDirectory: ts.sys.readDirectory,\n      readFile: ts.sys.readFile\n    };\n    const configFileName = fs.resolve(fs.pwd(), projectFile);\n    const parsed = ts.parseJsonConfigFileContent(\n        config, parseConfigHost, basePath, existingOptions, configFileName);\n    const rootNames = parsed.fileNames;\n\n    const options = createNgCompilerOptions(basePath, config, parsed.options);\n    let emitFlags = api.EmitFlags.Default;\n    if (!(options.skipMetadataEmit || options.flatModuleOutFile)) {\n      emitFlags |= api.EmitFlags.Metadata;\n    }\n    if (options.skipTemplateCodegen) {\n      emitFlags = emitFlags & ~api.EmitFlags.Codegen;\n    }\n    return {project: projectFile, rootNames, options, errors: parsed.errors, emitFlags};\n  } catch (e) {\n    const errors: Diagnostics = [{\n      category: ts.DiagnosticCategory.Error,\n      messageText: e.stack,\n      source: api.SOURCE,\n      code: api.UNKNOWN_ERROR_CODE\n    }];\n    return {project: '', errors, rootNames: [], options: {}, emitFlags: api.EmitFlags.Default};\n  }\n}\n\nexport interface PerformCompilationResult {\n  diagnostics: Diagnostics;\n  program?: api.Program;\n  emitResult?: ts.EmitResult;\n}\n\nexport function exitCodeFromResult(diags: Diagnostics|undefined): number {\n  if (!diags || filterErrorsAndWarnings(diags).length === 0) {\n    // If we have a result and didn't get any errors, we succeeded.\n    return 0;\n  }\n\n  // Return 2 if any of the errors were unknown.\n  return diags.some(d => d.source === 'angular' && d.code === api.UNKNOWN_ERROR_CODE) ? 2 : 1;\n}\n\nexport function performCompilation({\n  rootNames,\n  options,\n  host,\n  oldProgram,\n  emitCallback,\n  mergeEmitResultsCallback,\n  gatherDiagnostics = defaultGatherDiagnostics,\n  customTransformers,\n  emitFlags = api.EmitFlags.Default,\n  modifiedResourceFiles = null\n}: {\n  rootNames: string[],\n  options: api.CompilerOptions,\n  host?: api.CompilerHost,\n  oldProgram?: api.Program,\n  emitCallback?: api.TsEmitCallback,\n  mergeEmitResultsCallback?: api.TsMergeEmitResultsCallback,\n  gatherDiagnostics?: (program: api.Program) => Diagnostics,\n  customTransformers?: api.CustomTransformers,\n  emitFlags?: api.EmitFlags,\n  modifiedResourceFiles?: Set<string>| null,\n}): PerformCompilationResult {\n  let program: api.Program|undefined;\n  let emitResult: ts.EmitResult|undefined;\n  let allDiagnostics: Array<ts.Diagnostic|api.Diagnostic> = [];\n  try {\n    if (!host) {\n      host = ng.createCompilerHost({options});\n    }\n    if (modifiedResourceFiles) {\n      host.getModifiedResourceFiles = () => modifiedResourceFiles;\n    }\n\n    program = ng.createProgram({rootNames, host, options, oldProgram});\n\n    const beforeDiags = Date.now();\n    allDiagnostics.push(...gatherDiagnostics(program!));\n    if (options.diagnostics) {\n      const afterDiags = Date.now();\n      allDiagnostics.push(\n          createMessageDiagnostic(`Time for diagnostics: ${afterDiags - beforeDiags}ms.`));\n    }\n\n    if (!hasErrors(allDiagnostics)) {\n      emitResult =\n          program!.emit({emitCallback, mergeEmitResultsCallback, customTransformers, emitFlags});\n      allDiagnostics.push(...emitResult.diagnostics);\n      return {diagnostics: allDiagnostics, program, emitResult};\n    }\n    return {diagnostics: allDiagnostics, program};\n  } catch (e) {\n    let errMsg: string;\n    let code: number;\n    if (isSyntaxError(e)) {\n      // don't report the stack for syntax errors as they are well known errors.\n      errMsg = e.message;\n      code = api.DEFAULT_ERROR_CODE;\n    } else {\n      errMsg = e.stack;\n      // It is not a syntax error we might have a program with unknown state, discard it.\n      program = undefined;\n      code = api.UNKNOWN_ERROR_CODE;\n    }\n    allDiagnostics.push(\n        {category: ts.DiagnosticCategory.Error, messageText: errMsg, code, source: api.SOURCE});\n    return {diagnostics: allDiagnostics, program};\n  }\n}\nexport function defaultGatherDiagnostics(program: api.Program): Diagnostics {\n  const allDiagnostics: Array<ts.Diagnostic|api.Diagnostic> = [];\n\n  function checkDiagnostics(diags: Diagnostics|undefined) {\n    if (diags) {\n      allDiagnostics.push(...diags);\n      return !hasErrors(diags);\n    }\n    return true;\n  }\n\n  let checkOtherDiagnostics = true;\n  // Check parameter diagnostics\n  checkOtherDiagnostics = checkOtherDiagnostics &&\n      checkDiagnostics([...program.getTsOptionDiagnostics(), ...program.getNgOptionDiagnostics()]);\n\n  // Check syntactic diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics && checkDiagnostics(program.getTsSyntacticDiagnostics() as Diagnostics);\n\n  // Check TypeScript semantic and Angular structure diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics &&\n      checkDiagnostics(\n          [...program.getTsSemanticDiagnostics(), ...program.getNgStructuralDiagnostics()]);\n\n  // Check Angular semantic diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics && checkDiagnostics(program.getNgSemanticDiagnostics() as Diagnostics);\n\n  return allDiagnostics;\n}\n\nfunction hasErrors(diags: Diagnostics) {\n  return diags.some(d => d.category === ts.DiagnosticCategory.Error);\n}\n"]}
302
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"perform_compile.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/src/perform_compile.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 {isSyntaxError, Position} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, AbsoluteFsPath, getFileSystem, relative, resolve} from '../src/ngtsc/file_system';\n\nimport {replaceTsWithNgInErrors} from './ngtsc/diagnostics';\nimport * as api from './transformers/api';\nimport * as ng from './transformers/entry_points';\nimport {createMessageDiagnostic} from './transformers/util';\n\nexport type Diagnostics = ReadonlyArray<ts.Diagnostic|api.Diagnostic>;\n\nexport function filterErrorsAndWarnings(diagnostics: Diagnostics): Diagnostics {\n  return diagnostics.filter(d => d.category !== ts.DiagnosticCategory.Message);\n}\n\nconst defaultFormatHost: ts.FormatDiagnosticsHost = {\n  getCurrentDirectory: () => ts.sys.getCurrentDirectory(),\n  getCanonicalFileName: fileName => fileName,\n  getNewLine: () => ts.sys.newLine\n};\n\nfunction displayFileName(fileName: string, host: ts.FormatDiagnosticsHost): string {\n  return relative(\n      resolve(host.getCurrentDirectory()), resolve(host.getCanonicalFileName(fileName)));\n}\n\nexport function formatDiagnosticPosition(\n    position: Position, host: ts.FormatDiagnosticsHost = defaultFormatHost): string {\n  return `${displayFileName(position.fileName, host)}(${position.line + 1},${position.column + 1})`;\n}\n\nexport function flattenDiagnosticMessageChain(\n    chain: api.DiagnosticMessageChain, host: ts.FormatDiagnosticsHost = defaultFormatHost,\n    indent = 0): string {\n  const newLine = host.getNewLine();\n  let result = '';\n  if (indent) {\n    result += newLine;\n\n    for (let i = 0; i < indent; i++) {\n      result += '  ';\n    }\n  }\n  result += chain.messageText;\n\n  const position = chain.position;\n  // add position if available, and we are not at the depest frame\n  if (position && indent !== 0) {\n    result += ` at ${formatDiagnosticPosition(position, host)}`;\n  }\n\n  indent++;\n  if (chain.next) {\n    for (const kid of chain.next) {\n      result += flattenDiagnosticMessageChain(kid, host, indent);\n    }\n  }\n  return result;\n}\n\nexport function formatDiagnostic(\n    diagnostic: api.Diagnostic, host: ts.FormatDiagnosticsHost = defaultFormatHost) {\n  let result = '';\n  const newLine = host.getNewLine();\n  const span = diagnostic.span;\n  if (span) {\n    result += `${\n        formatDiagnosticPosition(\n            {fileName: span.start.file.url, line: span.start.line, column: span.start.col},\n            host)}: `;\n  } else if (diagnostic.position) {\n    result += `${formatDiagnosticPosition(diagnostic.position, host)}: `;\n  }\n  if (diagnostic.span && diagnostic.span.details) {\n    result += `${diagnostic.span.details}, ${diagnostic.messageText}${newLine}`;\n  } else if (diagnostic.chain) {\n    result += `${flattenDiagnosticMessageChain(diagnostic.chain, host)}.${newLine}`;\n  } else {\n    result += `${diagnostic.messageText}${newLine}`;\n  }\n  return result;\n}\n\nexport function formatDiagnostics(\n    diags: Diagnostics, host: ts.FormatDiagnosticsHost = defaultFormatHost): string {\n  if (diags && diags.length) {\n    return diags\n        .map(diagnostic => {\n          if (api.isTsDiagnostic(diagnostic)) {\n            return replaceTsWithNgInErrors(\n                ts.formatDiagnosticsWithColorAndContext([diagnostic], host));\n          } else {\n            return formatDiagnostic(diagnostic, host);\n          }\n        })\n        .join('');\n  } else {\n    return '';\n  }\n}\n\nexport interface ParsedConfiguration {\n  project: string;\n  options: api.CompilerOptions;\n  rootNames: string[];\n  projectReferences?: readonly ts.ProjectReference[]|undefined;\n  emitFlags: api.EmitFlags;\n  errors: Diagnostics;\n}\n\nexport function calcProjectFileAndBasePath(project: string):\n    {projectFile: AbsoluteFsPath, basePath: AbsoluteFsPath} {\n  const fs = getFileSystem();\n  const absProject = fs.resolve(project);\n  const projectIsDir = fs.lstat(absProject).isDirectory();\n  const projectFile = projectIsDir ? fs.join(absProject, 'tsconfig.json') : absProject;\n  const projectDir = projectIsDir ? absProject : fs.dirname(absProject);\n  const basePath = fs.resolve(projectDir);\n  return {projectFile, basePath};\n}\n\nexport function createNgCompilerOptions(\n    basePath: string, config: any, tsOptions: ts.CompilerOptions): api.CompilerOptions {\n  // enableIvy `ngtsc` is an alias for `true`.\n  const {angularCompilerOptions = {}} = config;\n  const {enableIvy} = angularCompilerOptions;\n  angularCompilerOptions.enableIvy = enableIvy !== false && enableIvy !== 'tsc';\n\n  return {...tsOptions, ...angularCompilerOptions, genDir: basePath, basePath};\n}\n\nexport function readConfiguration(\n    project: string, existingOptions?: ts.CompilerOptions): ParsedConfiguration {\n  try {\n    const fs = getFileSystem();\n    const {projectFile, basePath} = calcProjectFileAndBasePath(project);\n\n    const readExtendedConfigFile =\n        (configFile: string, existingConfig?: any): {config?: any, error?: ts.Diagnostic} => {\n          const {config, error} = ts.readConfigFile(configFile, ts.sys.readFile);\n\n          if (error) {\n            return {error};\n          }\n\n          // we are only interested into merging 'angularCompilerOptions' as\n          // other options like 'compilerOptions' are merged by TS\n          const baseConfig = existingConfig || config;\n          if (existingConfig) {\n            baseConfig.angularCompilerOptions = {\n              ...config.angularCompilerOptions,\n              ...baseConfig.angularCompilerOptions\n            };\n          }\n\n          if (config.extends) {\n            let extendedConfigPath = fs.resolve(fs.dirname(configFile), config.extends);\n            extendedConfigPath = fs.extname(extendedConfigPath) ?\n                extendedConfigPath :\n                absoluteFrom(`${extendedConfigPath}.json`);\n\n            if (fs.exists(extendedConfigPath)) {\n              // Call read config recursively as TypeScript only merges CompilerOptions\n              return readExtendedConfigFile(extendedConfigPath, baseConfig);\n            }\n          }\n\n          return {config: baseConfig};\n        };\n\n    const {config, error} = readExtendedConfigFile(projectFile);\n\n    if (error) {\n      return {\n        project,\n        errors: [error],\n        rootNames: [],\n        options: {},\n        emitFlags: api.EmitFlags.Default\n      };\n    }\n    const parseConfigHost = {\n      useCaseSensitiveFileNames: true,\n      fileExists: fs.exists.bind(fs),\n      readDirectory: ts.sys.readDirectory,\n      readFile: ts.sys.readFile\n    };\n    const configFileName = fs.resolve(fs.pwd(), projectFile);\n    const parsed = ts.parseJsonConfigFileContent(\n        config, parseConfigHost, basePath, existingOptions, configFileName);\n    const rootNames = parsed.fileNames;\n    const projectReferences = parsed.projectReferences;\n\n    const options = createNgCompilerOptions(basePath, config, parsed.options);\n    let emitFlags = api.EmitFlags.Default;\n    if (!(options.skipMetadataEmit || options.flatModuleOutFile)) {\n      emitFlags |= api.EmitFlags.Metadata;\n    }\n    if (options.skipTemplateCodegen) {\n      emitFlags = emitFlags & ~api.EmitFlags.Codegen;\n    }\n    return {\n      project: projectFile,\n      rootNames,\n      projectReferences,\n      options,\n      errors: parsed.errors,\n      emitFlags\n    };\n  } catch (e) {\n    const errors: Diagnostics = [{\n      category: ts.DiagnosticCategory.Error,\n      messageText: e.stack,\n      source: api.SOURCE,\n      code: api.UNKNOWN_ERROR_CODE\n    }];\n    return {project: '', errors, rootNames: [], options: {}, emitFlags: api.EmitFlags.Default};\n  }\n}\n\nexport interface PerformCompilationResult {\n  diagnostics: Diagnostics;\n  program?: api.Program;\n  emitResult?: ts.EmitResult;\n}\n\nexport function exitCodeFromResult(diags: Diagnostics|undefined): number {\n  if (!diags || filterErrorsAndWarnings(diags).length === 0) {\n    // If we have a result and didn't get any errors, we succeeded.\n    return 0;\n  }\n\n  // Return 2 if any of the errors were unknown.\n  return diags.some(d => d.source === 'angular' && d.code === api.UNKNOWN_ERROR_CODE) ? 2 : 1;\n}\n\nexport function performCompilation({\n  rootNames,\n  options,\n  host,\n  oldProgram,\n  emitCallback,\n  mergeEmitResultsCallback,\n  gatherDiagnostics = defaultGatherDiagnostics,\n  customTransformers,\n  emitFlags = api.EmitFlags.Default,\n  modifiedResourceFiles = null\n}: {\n  rootNames: string[],\n  options: api.CompilerOptions,\n  host?: api.CompilerHost,\n  oldProgram?: api.Program,\n  emitCallback?: api.TsEmitCallback,\n  mergeEmitResultsCallback?: api.TsMergeEmitResultsCallback,\n  gatherDiagnostics?: (program: api.Program) => Diagnostics,\n  customTransformers?: api.CustomTransformers,\n  emitFlags?: api.EmitFlags,\n  modifiedResourceFiles?: Set<string>| null,\n}): PerformCompilationResult {\n  let program: api.Program|undefined;\n  let emitResult: ts.EmitResult|undefined;\n  let allDiagnostics: Array<ts.Diagnostic|api.Diagnostic> = [];\n  try {\n    if (!host) {\n      host = ng.createCompilerHost({options});\n    }\n    if (modifiedResourceFiles) {\n      host.getModifiedResourceFiles = () => modifiedResourceFiles;\n    }\n\n    program = ng.createProgram({rootNames, host, options, oldProgram});\n\n    const beforeDiags = Date.now();\n    allDiagnostics.push(...gatherDiagnostics(program!));\n    if (options.diagnostics) {\n      const afterDiags = Date.now();\n      allDiagnostics.push(\n          createMessageDiagnostic(`Time for diagnostics: ${afterDiags - beforeDiags}ms.`));\n    }\n\n    if (!hasErrors(allDiagnostics)) {\n      emitResult =\n          program!.emit({emitCallback, mergeEmitResultsCallback, customTransformers, emitFlags});\n      allDiagnostics.push(...emitResult.diagnostics);\n      return {diagnostics: allDiagnostics, program, emitResult};\n    }\n    return {diagnostics: allDiagnostics, program};\n  } catch (e) {\n    let errMsg: string;\n    let code: number;\n    if (isSyntaxError(e)) {\n      // don't report the stack for syntax errors as they are well known errors.\n      errMsg = e.message;\n      code = api.DEFAULT_ERROR_CODE;\n    } else {\n      errMsg = e.stack;\n      // It is not a syntax error we might have a program with unknown state, discard it.\n      program = undefined;\n      code = api.UNKNOWN_ERROR_CODE;\n    }\n    allDiagnostics.push(\n        {category: ts.DiagnosticCategory.Error, messageText: errMsg, code, source: api.SOURCE});\n    return {diagnostics: allDiagnostics, program};\n  }\n}\nexport function defaultGatherDiagnostics(program: api.Program): Diagnostics {\n  const allDiagnostics: Array<ts.Diagnostic|api.Diagnostic> = [];\n\n  function checkDiagnostics(diags: Diagnostics|undefined) {\n    if (diags) {\n      allDiagnostics.push(...diags);\n      return !hasErrors(diags);\n    }\n    return true;\n  }\n\n  let checkOtherDiagnostics = true;\n  // Check parameter diagnostics\n  checkOtherDiagnostics = checkOtherDiagnostics &&\n      checkDiagnostics([...program.getTsOptionDiagnostics(), ...program.getNgOptionDiagnostics()]);\n\n  // Check syntactic diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics && checkDiagnostics(program.getTsSyntacticDiagnostics() as Diagnostics);\n\n  // Check TypeScript semantic and Angular structure diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics &&\n      checkDiagnostics(\n          [...program.getTsSemanticDiagnostics(), ...program.getNgStructuralDiagnostics()]);\n\n  // Check Angular semantic diagnostics\n  checkOtherDiagnostics =\n      checkOtherDiagnostics && checkDiagnostics(program.getNgSemanticDiagnostics() as Diagnostics);\n\n  return allDiagnostics;\n}\n\nfunction hasErrors(diags: Diagnostics) {\n  return diags.some(d => d.category === ts.DiagnosticCategory.Error);\n}\n"]}
package/src/version.js CHANGED
@@ -23,6 +23,6 @@
23
23
  * Entry point for all public APIs of the common package.
24
24
  */
25
25
  var compiler_1 = require("@angular/compiler");
26
- exports.VERSION = new compiler_1.Version('10.0.3');
26
+ exports.VERSION = new compiler_1.Version('10.0.4');
27
27
  });
28
28
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9zcmMvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7Ozs7Ozs7Ozs7Ozs7SUFFSDs7OztPQUlHO0lBRUgsOENBQTBDO0lBRTdCLFFBQUEsT0FBTyxHQUFHLElBQUksa0JBQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSBjb21tb24gcGFja2FnZS5cbiAqL1xuXG5pbXBvcnQge1ZlcnNpb259IGZyb20gJ0Bhbmd1bGFyL2NvbXBpbGVyJztcblxuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==