@angular/compiler-cli 9.0.3 → 9.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (71) hide show
  1. package/ngcc/index.d.ts +2 -2
  2. package/ngcc/index.js +4 -3
  3. package/ngcc/main-ngcc.js +4 -3
  4. package/ngcc/src/dependencies/dependency_resolver.d.ts +7 -1
  5. package/ngcc/src/dependencies/dependency_resolver.js +20 -6
  6. package/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.d.ts +3 -2
  7. package/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.js +36 -21
  8. package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +15 -10
  9. package/ngcc/src/execution/api.d.ts +2 -4
  10. package/ngcc/src/execution/api.js +1 -1
  11. package/ngcc/src/execution/cluster/executor.d.ts +2 -2
  12. package/ngcc/src/execution/cluster/executor.js +1 -1
  13. package/ngcc/src/execution/cluster/master.js +15 -8
  14. package/ngcc/src/execution/single_process_executor.d.ts +13 -7
  15. package/ngcc/src/execution/single_process_executor.js +55 -38
  16. package/ngcc/src/execution/utils.js +1 -1
  17. package/ngcc/src/host/commonjs_host.js +2 -7
  18. package/ngcc/src/host/delegating_host.d.ts +44 -0
  19. package/ngcc/src/host/delegating_host.js +146 -0
  20. package/ngcc/src/host/esm5_host.js +1 -7
  21. package/ngcc/src/host/umd_host.js +2 -7
  22. package/ngcc/src/locking/lock_file.d.ts +29 -0
  23. package/ngcc/src/locking/lock_file.js +17 -0
  24. package/ngcc/src/locking/lock_file_with_child_process/index.d.ts +41 -0
  25. package/ngcc/src/locking/lock_file_with_child_process/index.js +91 -0
  26. package/ngcc/src/locking/lock_file_with_child_process/unlocker.d.ts +2 -0
  27. package/ngcc/src/locking/lock_file_with_child_process/unlocker.js +44 -0
  28. package/ngcc/src/locking/lock_file_with_child_process/util.d.ts +17 -0
  29. package/ngcc/src/locking/lock_file_with_child_process/util.js +42 -0
  30. package/ngcc/src/locking/sync_locker.d.ts +36 -0
  31. package/ngcc/src/locking/sync_locker.js +67 -0
  32. package/ngcc/src/logging/console_logger.d.ts +3 -9
  33. package/ngcc/src/logging/console_logger.js +16 -15
  34. package/ngcc/src/logging/logger.d.ts +7 -0
  35. package/ngcc/src/logging/logger.js +8 -1
  36. package/ngcc/src/main.js +32 -24
  37. package/ngcc/src/packages/build_marker.d.ts +1 -1
  38. package/ngcc/src/packages/build_marker.js +1 -1
  39. package/ngcc/src/packages/configuration.d.ts +8 -0
  40. package/ngcc/src/packages/configuration.js +2 -2
  41. package/ngcc/src/packages/entry_point.d.ts +26 -2
  42. package/ngcc/src/packages/entry_point.js +34 -24
  43. package/ngcc/src/packages/transformer.js +8 -4
  44. package/ngcc/src/rendering/dts_renderer.js +2 -2
  45. package/ngcc/src/rendering/renderer.js +2 -2
  46. package/ngcc/src/rendering/source_maps.d.ts +2 -1
  47. package/ngcc/src/rendering/source_maps.js +24 -13
  48. package/ngcc/src/sourcemaps/segment_marker.d.ts +7 -15
  49. package/ngcc/src/sourcemaps/segment_marker.js +12 -41
  50. package/ngcc/src/sourcemaps/source_file.d.ts +31 -4
  51. package/ngcc/src/sourcemaps/source_file.js +130 -37
  52. package/package.json +2 -2
  53. package/src/ngtsc/annotations/src/directive.js +3 -2
  54. package/src/ngtsc/core/api/index.d.ts +11 -0
  55. package/src/ngtsc/core/api/index.js +20 -0
  56. package/src/ngtsc/core/api/src/interfaces.d.ts +65 -0
  57. package/src/ngtsc/core/api/src/interfaces.js +20 -0
  58. package/src/ngtsc/core/api/src/options.d.ts +32 -0
  59. package/src/ngtsc/core/api/src/options.js +20 -0
  60. package/src/ngtsc/core/{api.d.ts → api/src/public_options.d.ts} +14 -81
  61. package/src/ngtsc/core/api/src/public_options.js +20 -0
  62. package/src/ngtsc/diagnostics/src/error_code.d.ts +9 -0
  63. package/src/ngtsc/diagnostics/src/error_code.js +10 -1
  64. package/src/ngtsc/scope/src/local.js +50 -47
  65. package/src/ngtsc/typecheck/src/oob.d.ts +10 -0
  66. package/src/ngtsc/typecheck/src/oob.js +14 -1
  67. package/src/ngtsc/typecheck/src/type_check_block.js +11 -2
  68. package/src/version.js +1 -1
  69. package/ngcc/src/execution/lock_file.d.ts +0 -43
  70. package/ngcc/src/execution/lock_file.js +0 -129
  71. package/src/ngtsc/core/api.js +0 -20
package/ngcc/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  /// <amd-module name="@angular/compiler-cli/ngcc" />
2
2
  import { AsyncNgccOptions, SyncNgccOptions } from './src/main';
3
- export { ConsoleLogger, LogLevel } from './src/logging/console_logger';
4
- export { Logger } from './src/logging/logger';
3
+ export { ConsoleLogger } from './src/logging/console_logger';
4
+ export { LogLevel, Logger } from './src/logging/logger';
5
5
  export { AsyncNgccOptions, NgccOptions, SyncNgccOptions } from './src/main';
6
6
  export { PathMappings } from './src/utils';
7
7
  export declare function process(options: AsyncNgccOptions): Promise<void>;
package/ngcc/index.js CHANGED
@@ -4,7 +4,7 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/compiler-cli/ngcc", ["require", "exports", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/main", "@angular/compiler-cli/ngcc/src/logging/console_logger"], factory);
7
+ define("@angular/compiler-cli/ngcc", ["require", "exports", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/main", "@angular/compiler-cli/ngcc/src/logging/console_logger", "@angular/compiler-cli/ngcc/src/logging/logger"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
@@ -20,7 +20,8 @@
20
20
  var main_1 = require("@angular/compiler-cli/ngcc/src/main");
21
21
  var console_logger_1 = require("@angular/compiler-cli/ngcc/src/logging/console_logger");
22
22
  exports.ConsoleLogger = console_logger_1.ConsoleLogger;
23
- exports.LogLevel = console_logger_1.LogLevel;
23
+ var logger_1 = require("@angular/compiler-cli/ngcc/src/logging/logger");
24
+ exports.LogLevel = logger_1.LogLevel;
24
25
  function process(options) {
25
26
  // Recreate the file system on each call to reset the cache
26
27
  file_system_1.setFileSystem(new file_system_1.CachedFileSystem(new file_system_1.NodeJSFileSystem()));
@@ -28,4 +29,4 @@
28
29
  }
29
30
  exports.process = process;
30
31
  });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILDJFQUEyRjtJQUUzRiw0REFBb0Y7SUFDcEYsd0ZBQXFFO0lBQTdELHlDQUFBLGFBQWEsQ0FBQTtJQUFFLG9DQUFBLFFBQVEsQ0FBQTtJQU8vQixTQUFnQixPQUFPLENBQUMsT0FBb0I7UUFDMUMsMkRBQTJEO1FBQzNELDJCQUFhLENBQUMsSUFBSSw4QkFBZ0IsQ0FBQyxJQUFJLDhCQUFnQixFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQzVELE9BQU8sZUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzNCLENBQUM7SUFKRCwwQkFJQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCB7Q2FjaGVkRmlsZVN5c3RlbSwgTm9kZUpTRmlsZVN5c3RlbSwgc2V0RmlsZVN5c3RlbX0gZnJvbSAnLi4vc3JjL25ndHNjL2ZpbGVfc3lzdGVtJztcblxuaW1wb3J0IHtBc3luY05nY2NPcHRpb25zLCBOZ2NjT3B0aW9ucywgU3luY05nY2NPcHRpb25zLCBtYWluTmdjY30gZnJvbSAnLi9zcmMvbWFpbic7XG5leHBvcnQge0NvbnNvbGVMb2dnZXIsIExvZ0xldmVsfSBmcm9tICcuL3NyYy9sb2dnaW5nL2NvbnNvbGVfbG9nZ2VyJztcbmV4cG9ydCB7TG9nZ2VyfSBmcm9tICcuL3NyYy9sb2dnaW5nL2xvZ2dlcic7XG5leHBvcnQge0FzeW5jTmdjY09wdGlvbnMsIE5nY2NPcHRpb25zLCBTeW5jTmdjY09wdGlvbnN9IGZyb20gJy4vc3JjL21haW4nO1xuZXhwb3J0IHtQYXRoTWFwcGluZ3N9IGZyb20gJy4vc3JjL3V0aWxzJztcblxuZXhwb3J0IGZ1bmN0aW9uIHByb2Nlc3Mob3B0aW9uczogQXN5bmNOZ2NjT3B0aW9ucyk6IFByb21pc2U8dm9pZD47XG5leHBvcnQgZnVuY3Rpb24gcHJvY2VzcyhvcHRpb25zOiBTeW5jTmdjY09wdGlvbnMpOiB2b2lkO1xuZXhwb3J0IGZ1bmN0aW9uIHByb2Nlc3Mob3B0aW9uczogTmdjY09wdGlvbnMpOiB2b2lkfFByb21pc2U8dm9pZD4ge1xuICAvLyBSZWNyZWF0ZSB0aGUgZmlsZSBzeXN0ZW0gb24gZWFjaCBjYWxsIHRvIHJlc2V0IHRoZSBjYWNoZVxuICBzZXRGaWxlU3lzdGVtKG5ldyBDYWNoZWRGaWxlU3lzdGVtKG5ldyBOb2RlSlNGaWxlU3lzdGVtKCkpKTtcbiAgcmV0dXJuIG1haW5OZ2NjKG9wdGlvbnMpO1xufVxuIl19
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILDJFQUEyRjtJQUUzRiw0REFBb0Y7SUFDcEYsd0ZBQTJEO0lBQW5ELHlDQUFBLGFBQWEsQ0FBQTtJQUNyQix3RUFBc0Q7SUFBOUMsNEJBQUEsUUFBUSxDQUFBO0lBTWhCLFNBQWdCLE9BQU8sQ0FBQyxPQUFvQjtRQUMxQywyREFBMkQ7UUFDM0QsMkJBQWEsQ0FBQyxJQUFJLDhCQUFnQixDQUFDLElBQUksOEJBQWdCLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDNUQsT0FBTyxlQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUpELDBCQUlDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtDYWNoZWRGaWxlU3lzdGVtLCBOb2RlSlNGaWxlU3lzdGVtLCBzZXRGaWxlU3lzdGVtfSBmcm9tICcuLi9zcmMvbmd0c2MvZmlsZV9zeXN0ZW0nO1xuXG5pbXBvcnQge0FzeW5jTmdjY09wdGlvbnMsIE5nY2NPcHRpb25zLCBTeW5jTmdjY09wdGlvbnMsIG1haW5OZ2NjfSBmcm9tICcuL3NyYy9tYWluJztcbmV4cG9ydCB7Q29uc29sZUxvZ2dlcn0gZnJvbSAnLi9zcmMvbG9nZ2luZy9jb25zb2xlX2xvZ2dlcic7XG5leHBvcnQge0xvZ0xldmVsLCBMb2dnZXJ9IGZyb20gJy4vc3JjL2xvZ2dpbmcvbG9nZ2VyJztcbmV4cG9ydCB7QXN5bmNOZ2NjT3B0aW9ucywgTmdjY09wdGlvbnMsIFN5bmNOZ2NjT3B0aW9uc30gZnJvbSAnLi9zcmMvbWFpbic7XG5leHBvcnQge1BhdGhNYXBwaW5nc30gZnJvbSAnLi9zcmMvdXRpbHMnO1xuXG5leHBvcnQgZnVuY3Rpb24gcHJvY2VzcyhvcHRpb25zOiBBc3luY05nY2NPcHRpb25zKTogUHJvbWlzZTx2b2lkPjtcbmV4cG9ydCBmdW5jdGlvbiBwcm9jZXNzKG9wdGlvbnM6IFN5bmNOZ2NjT3B0aW9ucyk6IHZvaWQ7XG5leHBvcnQgZnVuY3Rpb24gcHJvY2VzcyhvcHRpb25zOiBOZ2NjT3B0aW9ucyk6IHZvaWR8UHJvbWlzZTx2b2lkPiB7XG4gIC8vIFJlY3JlYXRlIHRoZSBmaWxlIHN5c3RlbSBvbiBlYWNoIGNhbGwgdG8gcmVzZXQgdGhlIGNhY2hlXG4gIHNldEZpbGVTeXN0ZW0obmV3IENhY2hlZEZpbGVTeXN0ZW0obmV3IE5vZGVKU0ZpbGVTeXN0ZW0oKSkpO1xuICByZXR1cm4gbWFpbk5nY2Mob3B0aW9ucyk7XG59XG4iXX0=
package/ngcc/main-ngcc.js CHANGED
@@ -5,7 +5,7 @@
5
5
  if (v !== undefined) module.exports = v;
6
6
  }
7
7
  else if (typeof define === "function" && define.amd) {
8
- define("@angular/compiler-cli/ngcc/main-ngcc", ["require", "exports", "tslib", "yargs", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/main", "@angular/compiler-cli/ngcc/src/logging/console_logger"], factory);
8
+ define("@angular/compiler-cli/ngcc/main-ngcc", ["require", "exports", "tslib", "yargs", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/main", "@angular/compiler-cli/ngcc/src/logging/console_logger", "@angular/compiler-cli/ngcc/src/logging/logger"], factory);
9
9
  }
10
10
  })(function (require, exports) {
11
11
  "use strict";
@@ -22,6 +22,7 @@
22
22
  var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
23
23
  var main_1 = require("@angular/compiler-cli/ngcc/src/main");
24
24
  var console_logger_1 = require("@angular/compiler-cli/ngcc/src/logging/console_logger");
25
+ var logger_1 = require("@angular/compiler-cli/ngcc/src/logging/logger");
25
26
  // CLI entry point
26
27
  if (require.main === module) {
27
28
  var startTime_1 = Date.now();
@@ -97,7 +98,7 @@
97
98
  switch (_a.label) {
98
99
  case 0:
99
100
  _a.trys.push([0, 2, , 3]);
100
- logger = logLevel_1 && new console_logger_1.ConsoleLogger(console_logger_1.LogLevel[logLevel_1]);
101
+ logger = logLevel_1 && new console_logger_1.ConsoleLogger(logger_1.LogLevel[logLevel_1]);
101
102
  return [4 /*yield*/, main_1.mainNgcc({
102
103
  basePath: baseSourcePath_1,
103
104
  propertiesToConsider: propertiesToConsider_1,
@@ -127,4 +128,4 @@
127
128
  }); })();
128
129
  }
129
130
  });
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main-ngcc.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/ngcc/main-ngcc.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. 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 * as yargs from 'yargs';\n\nimport {resolve, setFileSystem, CachedFileSystem, NodeJSFileSystem} from '../src/ngtsc/file_system';\nimport {mainNgcc} from './src/main';\nimport {ConsoleLogger, LogLevel} from './src/logging/console_logger';\n\n// CLI entry point\nif (require.main === module) {\n  const startTime = Date.now();\n\n  const args = process.argv.slice(2);\n  const options =\n      yargs\n          .option('s', {\n            alias: 'source',\n            describe:\n                'A path (relative to the working directory) of the `node_modules` folder to process.',\n            default: './node_modules'\n          })\n          .option('f', {alias: 'formats', hidden: true, array: true})\n          .option('p', {\n            alias: 'properties',\n            array: true,\n            describe:\n                'An array of names of properties in package.json to compile (e.g. `module` or `es2015`)\\n' +\n                'Each of these properties should hold the path to a bundle-format.\\n' +\n                'If provided, only the specified properties are considered for processing.\\n' +\n                'If not provided, all the supported format properties (e.g. fesm2015, fesm5, es2015, esm2015, esm5, main, module) in the package.json are considered.'\n          })\n          .option('t', {\n            alias: 'target',\n            describe:\n                'A relative path (from the `source` path) to a single entry-point to process (plus its dependencies).',\n          })\n          .option('first-only', {\n            describe:\n                'If specified then only the first matching package.json property will be compiled.',\n            type: 'boolean'\n          })\n          .option('create-ivy-entry-points', {\n            describe:\n                'If specified then new `*_ivy_ngcc` entry-points will be added to package.json rather than modifying the ones in-place.\\n' +\n                'For this to work you need to have custom resolution set up (e.g. in webpack) to look for these new entry-points.\\n' +\n                'The Angular CLI does this already, so it is safe to use this option if the project is being built via the CLI.',\n            type: 'boolean',\n          })\n          .option('legacy-message-ids', {\n            describe: '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' +\n                'be rendered. For example, if you are not using legacy message ids in your translation files\\n' +\n                'AND are not doing compile-time inlining of translations, in which case the extra message ids\\n' +\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' +\n                'legacy message ids will all be stripped during translation.',\n            type: 'boolean',\n            default: true,\n          })\n          .option('async', {\n            describe:\n                'Whether to compile asynchronously. This is enabled by default as it allows compilations to be parallelized.\\n' +\n                'Disabling asynchronous compilation may be useful for debugging.',\n            type: 'boolean',\n            default: true,\n          })\n          .option('l', {\n            alias: 'loglevel',\n            describe: 'The lowest severity logging message that should be output.',\n            choices: ['debug', 'info', 'warn', 'error'],\n          })\n          .help()\n          .parse(args);\n\n  if (options['f'] && options['f'].length) {\n    console.error(\n        'The formats option (-f/--formats) has been removed. Consider the properties option (-p/--properties) instead.');\n    process.exit(1);\n  }\n\n  setFileSystem(new CachedFileSystem(new NodeJSFileSystem()));\n\n  const baseSourcePath = resolve(options['s'] || './node_modules');\n  const propertiesToConsider: string[] = options['p'];\n  const targetEntryPointPath = options['t'] ? options['t'] : undefined;\n  const compileAllFormats = !options['first-only'];\n  const createNewEntryPointFormats = options['create-ivy-entry-points'];\n  const logLevel = options['l'] as keyof typeof LogLevel | undefined;\n  const enableI18nLegacyMessageIdFormat = options['legacy-message-ids'];\n\n  (async() => {\n    try {\n      const logger = logLevel && new ConsoleLogger(LogLevel[logLevel]);\n\n      await mainNgcc({\n        basePath: baseSourcePath,\n        propertiesToConsider,\n        targetEntryPointPath,\n        compileAllFormats,\n        createNewEntryPointFormats,\n        logger,\n        enableI18nLegacyMessageIdFormat,\n        async: options['async'],\n      });\n\n      if (logger) {\n        const duration = Math.round((Date.now() - startTime) / 1000);\n        logger.debug(`Run ngcc in ${duration}s.`);\n      }\n\n      process.exitCode = 0;\n    } catch (e) {\n      console.error(e.stack || e.message);\n      process.exitCode = 1;\n    }\n  })();\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main-ngcc.js","sourceRoot":"","sources":["../../../../../../packages/compiler-cli/ngcc/main-ngcc.ts"],"names":[],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n/**\n * @license\n * Copyright Google Inc. 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 * as yargs from 'yargs';\n\nimport {resolve, setFileSystem, CachedFileSystem, NodeJSFileSystem} from '../src/ngtsc/file_system';\nimport {mainNgcc} from './src/main';\nimport {ConsoleLogger} from './src/logging/console_logger';\nimport {LogLevel} from './src/logging/logger';\n\n// CLI entry point\nif (require.main === module) {\n  const startTime = Date.now();\n\n  const args = process.argv.slice(2);\n  const options =\n      yargs\n          .option('s', {\n            alias: 'source',\n            describe:\n                'A path (relative to the working directory) of the `node_modules` folder to process.',\n            default: './node_modules'\n          })\n          .option('f', {alias: 'formats', hidden: true, array: true})\n          .option('p', {\n            alias: 'properties',\n            array: true,\n            describe:\n                'An array of names of properties in package.json to compile (e.g. `module` or `es2015`)\\n' +\n                'Each of these properties should hold the path to a bundle-format.\\n' +\n                'If provided, only the specified properties are considered for processing.\\n' +\n                'If not provided, all the supported format properties (e.g. fesm2015, fesm5, es2015, esm2015, esm5, main, module) in the package.json are considered.'\n          })\n          .option('t', {\n            alias: 'target',\n            describe:\n                'A relative path (from the `source` path) to a single entry-point to process (plus its dependencies).',\n          })\n          .option('first-only', {\n            describe:\n                'If specified then only the first matching package.json property will be compiled.',\n            type: 'boolean'\n          })\n          .option('create-ivy-entry-points', {\n            describe:\n                'If specified then new `*_ivy_ngcc` entry-points will be added to package.json rather than modifying the ones in-place.\\n' +\n                'For this to work you need to have custom resolution set up (e.g. in webpack) to look for these new entry-points.\\n' +\n                'The Angular CLI does this already, so it is safe to use this option if the project is being built via the CLI.',\n            type: 'boolean',\n          })\n          .option('legacy-message-ids', {\n            describe: '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' +\n                'be rendered. For example, if you are not using legacy message ids in your translation files\\n' +\n                'AND are not doing compile-time inlining of translations, in which case the extra message ids\\n' +\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' +\n                'legacy message ids will all be stripped during translation.',\n            type: 'boolean',\n            default: true,\n          })\n          .option('async', {\n            describe:\n                'Whether to compile asynchronously. This is enabled by default as it allows compilations to be parallelized.\\n' +\n                'Disabling asynchronous compilation may be useful for debugging.',\n            type: 'boolean',\n            default: true,\n          })\n          .option('l', {\n            alias: 'loglevel',\n            describe: 'The lowest severity logging message that should be output.',\n            choices: ['debug', 'info', 'warn', 'error'],\n          })\n          .help()\n          .parse(args);\n\n  if (options['f'] && options['f'].length) {\n    console.error(\n        'The formats option (-f/--formats) has been removed. Consider the properties option (-p/--properties) instead.');\n    process.exit(1);\n  }\n\n  setFileSystem(new CachedFileSystem(new NodeJSFileSystem()));\n\n  const baseSourcePath = resolve(options['s'] || './node_modules');\n  const propertiesToConsider: string[] = options['p'];\n  const targetEntryPointPath = options['t'] ? options['t'] : undefined;\n  const compileAllFormats = !options['first-only'];\n  const createNewEntryPointFormats = options['create-ivy-entry-points'];\n  const logLevel = options['l'] as keyof typeof LogLevel | undefined;\n  const enableI18nLegacyMessageIdFormat = options['legacy-message-ids'];\n\n  (async() => {\n    try {\n      const logger = logLevel && new ConsoleLogger(LogLevel[logLevel]);\n\n      await mainNgcc({\n        basePath: baseSourcePath,\n        propertiesToConsider,\n        targetEntryPointPath,\n        compileAllFormats,\n        createNewEntryPointFormats,\n        logger,\n        enableI18nLegacyMessageIdFormat,\n        async: options['async'],\n      });\n\n      if (logger) {\n        const duration = Math.round((Date.now() - startTime) / 1000);\n        logger.debug(`Run ngcc in ${duration}s.`);\n      }\n\n      process.exitCode = 0;\n    } catch (e) {\n      console.error(e.stack || e.message);\n      process.exitCode = 1;\n    }\n  })();\n}\n"]}
@@ -9,6 +9,7 @@
9
9
  import { DepGraph } from 'dependency-graph';
10
10
  import { FileSystem } from '../../../src/ngtsc/file_system';
11
11
  import { Logger } from '../logging/logger';
12
+ import { NgccConfiguration } from '../packages/configuration';
12
13
  import { EntryPoint, EntryPointFormat } from '../packages/entry_point';
13
14
  import { PartiallyOrderedList } from '../utils';
14
15
  import { DependencyHost, DependencyInfo } from './dependency_host';
@@ -74,9 +75,10 @@ export interface SortedEntryPointsInfo extends DependencyDiagnostics {
74
75
  export declare class DependencyResolver {
75
76
  private fs;
76
77
  private logger;
78
+ private config;
77
79
  private hosts;
78
80
  private typingsHost;
79
- constructor(fs: FileSystem, logger: Logger, hosts: Partial<Record<EntryPointFormat, DependencyHost>>, typingsHost: DependencyHost);
81
+ constructor(fs: FileSystem, logger: Logger, config: NgccConfiguration, hosts: Partial<Record<EntryPointFormat, DependencyHost>>, typingsHost: DependencyHost);
80
82
  /**
81
83
  * Sort the array of entry points so that the dependant entry points always come later than
82
84
  * their dependencies in the array.
@@ -94,4 +96,8 @@ export declare class DependencyResolver {
94
96
  */
95
97
  private computeDependencyGraph;
96
98
  private getEntryPointFormatInfo;
99
+ /**
100
+ * Filter out the deepImports that can be ignored, according to this entryPoint's config.
101
+ */
102
+ private filterIgnorableDeepImports;
97
103
  }
@@ -26,9 +26,10 @@
26
26
  * A class that resolves dependencies between entry-points.
27
27
  */
28
28
  var DependencyResolver = /** @class */ (function () {
29
- function DependencyResolver(fs, logger, hosts, typingsHost) {
29
+ function DependencyResolver(fs, logger, config, hosts, typingsHost) {
30
30
  this.fs = fs;
31
31
  this.logger = logger;
32
+ this.config = config;
32
33
  this.hosts = hosts;
33
34
  this.typingsHost = typingsHost;
34
35
  }
@@ -118,10 +119,13 @@
118
119
  }
119
120
  });
120
121
  }
121
- if (deepImports.size) {
122
- var imports = Array.from(deepImports).map(function (i) { return "'" + i + "'"; }).join(', ');
123
- _this.logger.warn("Entry point '" + entryPoint.name + "' contains deep imports into " + imports + ". " +
124
- "This is probably not a problem, but may cause the compilation of entry points to be out of order.");
122
+ if (deepImports.size > 0) {
123
+ var notableDeepImports = _this.filterIgnorableDeepImports(entryPoint, deepImports);
124
+ if (notableDeepImports.length > 0) {
125
+ var imports = notableDeepImports.map(function (i) { return "'" + i + "'"; }).join(', ');
126
+ _this.logger.warn("Entry point '" + entryPoint.name + "' contains deep imports into " + imports + ". " +
127
+ "This is probably not a problem, but may cause the compilation of entry points to be out of order.");
128
+ }
125
129
  }
126
130
  });
127
131
  return { invalidEntryPoints: invalidEntryPoints, ignoredDependencies: ignoredDependencies, graph: graph };
@@ -156,8 +160,18 @@
156
160
  }
157
161
  throw new Error("There is no appropriate source code format in '" + entryPoint.path + "' entry-point.");
158
162
  };
163
+ /**
164
+ * Filter out the deepImports that can be ignored, according to this entryPoint's config.
165
+ */
166
+ DependencyResolver.prototype.filterIgnorableDeepImports = function (entryPoint, deepImports) {
167
+ var version = (entryPoint.packageJson.version || null);
168
+ var packageConfig = this.config.getConfig(entryPoint.package, version);
169
+ var matchers = packageConfig.ignorableDeepImportMatchers || [];
170
+ return Array.from(deepImports)
171
+ .filter(function (deepImport) { return !matchers.some(function (matcher) { return matcher.test(deepImport); }); });
172
+ };
159
173
  return DependencyResolver;
160
174
  }());
161
175
  exports.DependencyResolver = DependencyResolver;
162
176
  });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_resolver.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/dependencies/dependency_resolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {DepGraph} from 'dependency-graph';\nimport {AbsoluteFsPath, FileSystem, resolve} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../logging/logger';\nimport {EntryPoint, EntryPointFormat, SUPPORTED_FORMAT_PROPERTIES, getEntryPointFormat} from '../packages/entry_point';\nimport {PartiallyOrderedList} from '../utils';\nimport {DependencyHost, DependencyInfo, createDependencyInfo} from './dependency_host';\n\nconst builtinNodeJsModules = new Set<string>(require('module').builtinModules);\n\n/**\n * Holds information about entry points that are removed because\n * they have dependencies that are missing (directly or transitively).\n *\n * This might not be an error, because such an entry point might not actually be used\n * in the application. If it is used then the `ngc` application compilation would\n * fail also, so we don't need ngcc to catch this.\n *\n * For example, consider an application that uses the `@angular/router` package.\n * This package includes an entry-point called `@angular/router/upgrade`, which has a dependency\n * on the `@angular/upgrade` package.\n * If the application never uses code from `@angular/router/upgrade` then there is no need for\n * `@angular/upgrade` to be installed.\n * In this case the ngcc tool should just ignore the `@angular/router/upgrade` end-point.\n */\nexport interface InvalidEntryPoint {\n  entryPoint: EntryPoint;\n  missingDependencies: string[];\n}\n\n/**\n * Holds information about dependencies of an entry-point that do not need to be processed\n * by the ngcc tool.\n *\n * For example, the `rxjs` package does not contain any Angular decorators that need to be\n * compiled and so this can be safely ignored by ngcc.\n */\nexport interface IgnoredDependency {\n  entryPoint: EntryPoint;\n  dependencyPath: string;\n}\n\nexport interface DependencyDiagnostics {\n  invalidEntryPoints: InvalidEntryPoint[];\n  ignoredDependencies: IgnoredDependency[];\n}\n\n/**\n * Represents a partially ordered list of entry-points.\n *\n * The entry-points' order/precedence is such that dependent entry-points always come later than\n * their dependencies in the list.\n *\n * See `DependencyResolver#sortEntryPointsByDependency()`.\n */\nexport type PartiallyOrderedEntryPoints = PartiallyOrderedList<EntryPoint>;\n\n/**\n * A list of entry-points, sorted by their dependencies, and the dependency graph.\n *\n * The `entryPoints` array will be ordered so that no entry point depends upon an entry point that\n * appears later in the array.\n *\n * Some entry points or their dependencies may have been ignored. These are captured for\n * diagnostic purposes in `invalidEntryPoints` and `ignoredDependencies` respectively.\n */\nexport interface SortedEntryPointsInfo extends DependencyDiagnostics {\n  entryPoints: PartiallyOrderedEntryPoints;\n  graph: DepGraph<EntryPoint>;\n}\n\n/**\n * A class that resolves dependencies between entry-points.\n */\nexport class DependencyResolver {\n  constructor(\n      private fs: FileSystem, private logger: Logger,\n      private hosts: Partial<Record<EntryPointFormat, DependencyHost>>,\n      private typingsHost: DependencyHost) {}\n  /**\n   * Sort the array of entry points so that the dependant entry points always come later than\n   * their dependencies in the array.\n   * @param entryPoints An array entry points to sort.\n   * @param target If provided, only return entry-points depended on by this entry-point.\n   * @returns the result of sorting the entry points by dependency.\n   */\n  sortEntryPointsByDependency(entryPoints: EntryPoint[], target?: EntryPoint):\n      SortedEntryPointsInfo {\n    const {invalidEntryPoints, ignoredDependencies, graph} =\n        this.computeDependencyGraph(entryPoints);\n\n    let sortedEntryPointNodes: string[];\n    if (target) {\n      if (target.compiledByAngular && graph.hasNode(target.path)) {\n        sortedEntryPointNodes = graph.dependenciesOf(target.path);\n        sortedEntryPointNodes.push(target.path);\n      } else {\n        sortedEntryPointNodes = [];\n      }\n    } else {\n      sortedEntryPointNodes = graph.overallOrder();\n    }\n\n    return {\n      entryPoints: (sortedEntryPointNodes as PartiallyOrderedList<string>)\n                       .map(path => graph.getNodeData(path)),\n      graph,\n      invalidEntryPoints,\n      ignoredDependencies,\n    };\n  }\n\n  getEntryPointDependencies(entryPoint: EntryPoint): DependencyInfo {\n    const formatInfo = this.getEntryPointFormatInfo(entryPoint);\n    const host = this.hosts[formatInfo.format];\n    if (!host) {\n      throw new Error(\n          `Could not find a suitable format for computing dependencies of entry-point: '${entryPoint.path}'.`);\n    }\n    const depInfo = createDependencyInfo();\n    host.collectDependencies(formatInfo.path, depInfo);\n    this.typingsHost.collectDependencies(entryPoint.typings, depInfo);\n    return depInfo;\n  }\n\n  /**\n   * Computes a dependency graph of the given entry-points.\n   *\n   * The graph only holds entry-points that ngcc cares about and whose dependencies\n   * (direct and transitive) all exist.\n   */\n  private computeDependencyGraph(entryPoints: EntryPoint[]): DependencyGraph {\n    const invalidEntryPoints: InvalidEntryPoint[] = [];\n    const ignoredDependencies: IgnoredDependency[] = [];\n    const graph = new DepGraph<EntryPoint>();\n\n    const angularEntryPoints = entryPoints.filter(entryPoint => entryPoint.compiledByAngular);\n\n    // Add the Angular compiled entry points to the graph as nodes\n    angularEntryPoints.forEach(entryPoint => graph.addNode(entryPoint.path, entryPoint));\n\n    // Now add the dependencies between them\n    angularEntryPoints.forEach(entryPoint => {\n      const {dependencies, missing, deepImports} = this.getEntryPointDependencies(entryPoint);\n\n      const missingDependencies = Array.from(missing).filter(dep => !builtinNodeJsModules.has(dep));\n\n      if (missingDependencies.length > 0 && !entryPoint.ignoreMissingDependencies) {\n        // This entry point has dependencies that are missing\n        // so remove it from the graph.\n        removeNodes(entryPoint, missingDependencies);\n      } else {\n        dependencies.forEach(dependencyPath => {\n          if (!graph.hasNode(entryPoint.path)) {\n            // The entry-point has already been identified as invalid so we don't need\n            // to do any further work on it.\n          } else if (graph.hasNode(dependencyPath)) {\n            // The entry-point is still valid (i.e. has no missing dependencies) and\n            // the dependency maps to an entry point that exists in the graph so add it\n            graph.addDependency(entryPoint.path, dependencyPath);\n          } else if (invalidEntryPoints.some(i => i.entryPoint.path === dependencyPath)) {\n            // The dependency path maps to an entry-point that was previously removed\n            // from the graph, so remove this entry-point as well.\n            removeNodes(entryPoint, [dependencyPath]);\n          } else {\n            // The dependency path points to a package that ngcc does not care about.\n            ignoredDependencies.push({entryPoint, dependencyPath});\n          }\n        });\n      }\n\n      if (deepImports.size) {\n        const imports = Array.from(deepImports).map(i => `'${i}'`).join(', ');\n        this.logger.warn(\n            `Entry point '${entryPoint.name}' contains deep imports into ${imports}. ` +\n            `This is probably not a problem, but may cause the compilation of entry points to be out of order.`);\n      }\n    });\n\n    return {invalidEntryPoints, ignoredDependencies, graph};\n\n    function removeNodes(entryPoint: EntryPoint, missingDependencies: string[]) {\n      const nodesToRemove = [entryPoint.path, ...graph.dependantsOf(entryPoint.path)];\n      nodesToRemove.forEach(node => {\n        invalidEntryPoints.push({entryPoint: graph.getNodeData(node), missingDependencies});\n        graph.removeNode(node);\n      });\n    }\n  }\n\n  private getEntryPointFormatInfo(entryPoint: EntryPoint):\n      {format: EntryPointFormat, path: AbsoluteFsPath} {\n    for (const property of SUPPORTED_FORMAT_PROPERTIES) {\n      const formatPath = entryPoint.packageJson[property];\n      if (formatPath === undefined) continue;\n\n      const format = getEntryPointFormat(this.fs, entryPoint, property);\n      if (format === undefined) continue;\n\n      return {format, path: resolve(entryPoint.path, formatPath)};\n    }\n\n    throw new Error(\n        `There is no appropriate source code format in '${entryPoint.path}' entry-point.`);\n  }\n}\n\ninterface DependencyGraph extends DependencyDiagnostics {\n  graph: DepGraph<EntryPoint>;\n}\n"]}
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_resolver.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/dependencies/dependency_resolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {DepGraph} from 'dependency-graph';\nimport {AbsoluteFsPath, FileSystem, resolve} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../logging/logger';\nimport {NgccConfiguration} from '../packages/configuration';\nimport {EntryPoint, EntryPointFormat, SUPPORTED_FORMAT_PROPERTIES, getEntryPointFormat} from '../packages/entry_point';\nimport {PartiallyOrderedList} from '../utils';\nimport {DependencyHost, DependencyInfo, createDependencyInfo} from './dependency_host';\n\nconst builtinNodeJsModules = new Set<string>(require('module').builtinModules);\n\n/**\n * Holds information about entry points that are removed because\n * they have dependencies that are missing (directly or transitively).\n *\n * This might not be an error, because such an entry point might not actually be used\n * in the application. If it is used then the `ngc` application compilation would\n * fail also, so we don't need ngcc to catch this.\n *\n * For example, consider an application that uses the `@angular/router` package.\n * This package includes an entry-point called `@angular/router/upgrade`, which has a dependency\n * on the `@angular/upgrade` package.\n * If the application never uses code from `@angular/router/upgrade` then there is no need for\n * `@angular/upgrade` to be installed.\n * In this case the ngcc tool should just ignore the `@angular/router/upgrade` end-point.\n */\nexport interface InvalidEntryPoint {\n  entryPoint: EntryPoint;\n  missingDependencies: string[];\n}\n\n/**\n * Holds information about dependencies of an entry-point that do not need to be processed\n * by the ngcc tool.\n *\n * For example, the `rxjs` package does not contain any Angular decorators that need to be\n * compiled and so this can be safely ignored by ngcc.\n */\nexport interface IgnoredDependency {\n  entryPoint: EntryPoint;\n  dependencyPath: string;\n}\n\nexport interface DependencyDiagnostics {\n  invalidEntryPoints: InvalidEntryPoint[];\n  ignoredDependencies: IgnoredDependency[];\n}\n\n/**\n * Represents a partially ordered list of entry-points.\n *\n * The entry-points' order/precedence is such that dependent entry-points always come later than\n * their dependencies in the list.\n *\n * See `DependencyResolver#sortEntryPointsByDependency()`.\n */\nexport type PartiallyOrderedEntryPoints = PartiallyOrderedList<EntryPoint>;\n\n/**\n * A list of entry-points, sorted by their dependencies, and the dependency graph.\n *\n * The `entryPoints` array will be ordered so that no entry point depends upon an entry point that\n * appears later in the array.\n *\n * Some entry points or their dependencies may have been ignored. These are captured for\n * diagnostic purposes in `invalidEntryPoints` and `ignoredDependencies` respectively.\n */\nexport interface SortedEntryPointsInfo extends DependencyDiagnostics {\n  entryPoints: PartiallyOrderedEntryPoints;\n  graph: DepGraph<EntryPoint>;\n}\n\n/**\n * A class that resolves dependencies between entry-points.\n */\nexport class DependencyResolver {\n  constructor(\n      private fs: FileSystem, private logger: Logger, private config: NgccConfiguration,\n      private hosts: Partial<Record<EntryPointFormat, DependencyHost>>,\n      private typingsHost: DependencyHost) {}\n  /**\n   * Sort the array of entry points so that the dependant entry points always come later than\n   * their dependencies in the array.\n   * @param entryPoints An array entry points to sort.\n   * @param target If provided, only return entry-points depended on by this entry-point.\n   * @returns the result of sorting the entry points by dependency.\n   */\n  sortEntryPointsByDependency(entryPoints: EntryPoint[], target?: EntryPoint):\n      SortedEntryPointsInfo {\n    const {invalidEntryPoints, ignoredDependencies, graph} =\n        this.computeDependencyGraph(entryPoints);\n\n    let sortedEntryPointNodes: string[];\n    if (target) {\n      if (target.compiledByAngular && graph.hasNode(target.path)) {\n        sortedEntryPointNodes = graph.dependenciesOf(target.path);\n        sortedEntryPointNodes.push(target.path);\n      } else {\n        sortedEntryPointNodes = [];\n      }\n    } else {\n      sortedEntryPointNodes = graph.overallOrder();\n    }\n\n    return {\n      entryPoints: (sortedEntryPointNodes as PartiallyOrderedList<string>)\n                       .map(path => graph.getNodeData(path)),\n      graph,\n      invalidEntryPoints,\n      ignoredDependencies,\n    };\n  }\n\n  getEntryPointDependencies(entryPoint: EntryPoint): DependencyInfo {\n    const formatInfo = this.getEntryPointFormatInfo(entryPoint);\n    const host = this.hosts[formatInfo.format];\n    if (!host) {\n      throw new Error(\n          `Could not find a suitable format for computing dependencies of entry-point: '${entryPoint.path}'.`);\n    }\n    const depInfo = createDependencyInfo();\n    host.collectDependencies(formatInfo.path, depInfo);\n    this.typingsHost.collectDependencies(entryPoint.typings, depInfo);\n    return depInfo;\n  }\n\n  /**\n   * Computes a dependency graph of the given entry-points.\n   *\n   * The graph only holds entry-points that ngcc cares about and whose dependencies\n   * (direct and transitive) all exist.\n   */\n  private computeDependencyGraph(entryPoints: EntryPoint[]): DependencyGraph {\n    const invalidEntryPoints: InvalidEntryPoint[] = [];\n    const ignoredDependencies: IgnoredDependency[] = [];\n    const graph = new DepGraph<EntryPoint>();\n\n    const angularEntryPoints = entryPoints.filter(entryPoint => entryPoint.compiledByAngular);\n\n    // Add the Angular compiled entry points to the graph as nodes\n    angularEntryPoints.forEach(entryPoint => graph.addNode(entryPoint.path, entryPoint));\n\n    // Now add the dependencies between them\n    angularEntryPoints.forEach(entryPoint => {\n      const {dependencies, missing, deepImports} = this.getEntryPointDependencies(entryPoint);\n\n      const missingDependencies = Array.from(missing).filter(dep => !builtinNodeJsModules.has(dep));\n\n      if (missingDependencies.length > 0 && !entryPoint.ignoreMissingDependencies) {\n        // This entry point has dependencies that are missing\n        // so remove it from the graph.\n        removeNodes(entryPoint, missingDependencies);\n      } else {\n        dependencies.forEach(dependencyPath => {\n          if (!graph.hasNode(entryPoint.path)) {\n            // The entry-point has already been identified as invalid so we don't need\n            // to do any further work on it.\n          } else if (graph.hasNode(dependencyPath)) {\n            // The entry-point is still valid (i.e. has no missing dependencies) and\n            // the dependency maps to an entry point that exists in the graph so add it\n            graph.addDependency(entryPoint.path, dependencyPath);\n          } else if (invalidEntryPoints.some(i => i.entryPoint.path === dependencyPath)) {\n            // The dependency path maps to an entry-point that was previously removed\n            // from the graph, so remove this entry-point as well.\n            removeNodes(entryPoint, [dependencyPath]);\n          } else {\n            // The dependency path points to a package that ngcc does not care about.\n            ignoredDependencies.push({entryPoint, dependencyPath});\n          }\n        });\n      }\n\n      if (deepImports.size > 0) {\n        const notableDeepImports = this.filterIgnorableDeepImports(entryPoint, deepImports);\n        if (notableDeepImports.length > 0) {\n          const imports = notableDeepImports.map(i => `'${i}'`).join(', ');\n          this.logger.warn(\n              `Entry point '${entryPoint.name}' contains deep imports into ${imports}. ` +\n              `This is probably not a problem, but may cause the compilation of entry points to be out of order.`);\n        }\n      }\n    });\n\n    return {invalidEntryPoints, ignoredDependencies, graph};\n\n    function removeNodes(entryPoint: EntryPoint, missingDependencies: string[]) {\n      const nodesToRemove = [entryPoint.path, ...graph.dependantsOf(entryPoint.path)];\n      nodesToRemove.forEach(node => {\n        invalidEntryPoints.push({entryPoint: graph.getNodeData(node), missingDependencies});\n        graph.removeNode(node);\n      });\n    }\n  }\n\n  private getEntryPointFormatInfo(entryPoint: EntryPoint):\n      {format: EntryPointFormat, path: AbsoluteFsPath} {\n    for (const property of SUPPORTED_FORMAT_PROPERTIES) {\n      const formatPath = entryPoint.packageJson[property];\n      if (formatPath === undefined) continue;\n\n      const format = getEntryPointFormat(this.fs, entryPoint, property);\n      if (format === undefined) continue;\n\n      return {format, path: resolve(entryPoint.path, formatPath)};\n    }\n\n    throw new Error(\n        `There is no appropriate source code format in '${entryPoint.path}' entry-point.`);\n  }\n\n  /**\n   * Filter out the deepImports that can be ignored, according to this entryPoint's config.\n   */\n  private filterIgnorableDeepImports(entryPoint: EntryPoint, deepImports: Set<AbsoluteFsPath>):\n      AbsoluteFsPath[] {\n    const version = (entryPoint.packageJson.version || null) as string | null;\n    const packageConfig = this.config.getConfig(entryPoint.package, version);\n    const matchers = packageConfig.ignorableDeepImportMatchers || [];\n    return Array.from(deepImports)\n        .filter(deepImport => !matchers.some(matcher => matcher.test(deepImport)));\n  }\n}\n\ninterface DependencyGraph extends DependencyDiagnostics {\n  graph: DepGraph<EntryPoint>;\n}\n"]}
@@ -10,6 +10,7 @@ import { AbsoluteFsPath, FileSystem } from '../../../src/ngtsc/file_system';
10
10
  import { DependencyResolver, SortedEntryPointsInfo } from '../dependencies/dependency_resolver';
11
11
  import { Logger } from '../logging/logger';
12
12
  import { NgccConfiguration } from '../packages/configuration';
13
+ import { EntryPoint } from '../packages/entry_point';
13
14
  import { PathMappings } from '../utils';
14
15
  import { EntryPointFinder } from './interface';
15
16
  /**
@@ -35,11 +36,11 @@ export declare class DirectoryWalkerEntryPointFinder implements EntryPointFinder
35
36
  * The function will recurse into directories that start with `@...`, e.g. `@angular/...`.
36
37
  * @param sourceDirectory An absolute path to the root directory where searching begins.
37
38
  */
38
- private walkDirectoryForEntryPoints;
39
+ walkDirectoryForEntryPoints(sourceDirectory: AbsoluteFsPath): EntryPoint[];
39
40
  /**
40
41
  * Recurse the folder structure looking for all the entry points
41
42
  * @param packagePath The absolute path to an npm package that may contain entry points
42
- * @returns An array of entry points that were discovered.
43
+ * @returns An array of entry points that were discovered or null when it's not a valid entrypoint
43
44
  */
44
45
  private getEntryPointsForPackage;
45
46
  /**
@@ -4,7 +4,7 @@
4
4
  if (v !== undefined) module.exports = v;
5
5
  }
6
6
  else if (typeof define === "function" && define.amd) {
7
- define("@angular/compiler-cli/ngcc/src/entry_point_finder/directory_walker_entry_point_finder", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/entry_point_finder/utils"], factory);
7
+ define("@angular/compiler-cli/ngcc/src/entry_point_finder/directory_walker_entry_point_finder", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer", "@angular/compiler-cli/ngcc/src/entry_point_finder/utils"], factory);
8
8
  }
9
9
  })(function (require, exports) {
10
10
  "use strict";
@@ -19,6 +19,7 @@
19
19
  */
20
20
  var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
21
21
  var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
22
+ var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer");
22
23
  var utils_1 = require("@angular/compiler-cli/ngcc/src/entry_point_finder/utils");
23
24
  /**
24
25
  * An EntryPointFinder that searches for all entry-points that can be found given a `basePath` and
@@ -51,8 +52,20 @@
51
52
  DirectoryWalkerEntryPointFinder.prototype.walkDirectoryForEntryPoints = function (sourceDirectory) {
52
53
  var _this = this;
53
54
  var entryPoints = this.getEntryPointsForPackage(sourceDirectory);
55
+ if (entryPoints === null) {
56
+ return [];
57
+ }
54
58
  if (entryPoints.length > 0) {
55
- // The `sourceDirectory` is an entry-point itself so no need to search its sub-directories.
59
+ // The `sourceDirectory` is an entry point itself so no need to search its sub-directories.
60
+ // Also check for any nested node_modules in this package but only if it was compiled by
61
+ // Angular.
62
+ // It is unlikely that a non Angular entry point has a dependency on an Angular library.
63
+ if (entryPoints.some(function (e) { return e.compiledByAngular; })) {
64
+ var nestedNodeModulesPath = this.fs.join(sourceDirectory, 'node_modules');
65
+ if (this.fs.exists(nestedNodeModulesPath)) {
66
+ entryPoints.push.apply(entryPoints, tslib_1.__spread(this.walkDirectoryForEntryPoints(nestedNodeModulesPath)));
67
+ }
68
+ }
56
69
  return entryPoints;
57
70
  }
58
71
  this.fs
@@ -60,29 +73,23 @@
60
73
  // Not interested in hidden files
61
74
  .filter(function (p) { return !p.startsWith('.'); })
62
75
  // Ignore node_modules
63
- .filter(function (p) { return p !== 'node_modules'; })
76
+ .filter(function (p) { return p !== 'node_modules' && p !== new_entry_point_file_writer_1.NGCC_DIRECTORY; })
64
77
  // Only interested in directories (and only those that are not symlinks)
65
78
  .filter(function (p) {
66
79
  var stat = _this.fs.lstat(file_system_1.resolve(sourceDirectory, p));
67
80
  return stat.isDirectory() && !stat.isSymbolicLink();
68
81
  })
69
82
  .forEach(function (p) {
70
- // Either the directory is a potential package or a namespace containing packages (e.g
71
- // `@angular`).
83
+ // Package is a potential namespace containing packages (e.g `@angular`).
72
84
  var packagePath = file_system_1.join(sourceDirectory, p);
73
85
  entryPoints.push.apply(entryPoints, tslib_1.__spread(_this.walkDirectoryForEntryPoints(packagePath)));
74
- // Also check for any nested node_modules in this package
75
- var nestedNodeModulesPath = file_system_1.join(packagePath, 'node_modules');
76
- if (_this.fs.exists(nestedNodeModulesPath)) {
77
- entryPoints.push.apply(entryPoints, tslib_1.__spread(_this.walkDirectoryForEntryPoints(nestedNodeModulesPath)));
78
- }
79
86
  });
80
87
  return entryPoints;
81
88
  };
82
89
  /**
83
90
  * Recurse the folder structure looking for all the entry points
84
91
  * @param packagePath The absolute path to an npm package that may contain entry points
85
- * @returns An array of entry points that were discovered.
92
+ * @returns An array of entry points that were discovered or null when it's not a valid entrypoint
86
93
  */
87
94
  DirectoryWalkerEntryPointFinder.prototype.getEntryPointsForPackage = function (packagePath) {
88
95
  var _this = this;
@@ -90,18 +97,26 @@
90
97
  // Try to get an entry point from the top level package directory
91
98
  var topLevelEntryPoint = entry_point_1.getEntryPointInfo(this.fs, this.config, this.logger, packagePath, packagePath);
92
99
  // If there is no primary entry-point then exit
93
- if (topLevelEntryPoint === null) {
100
+ if (topLevelEntryPoint === entry_point_1.NO_ENTRY_POINT) {
94
101
  return [];
95
102
  }
103
+ if (topLevelEntryPoint === entry_point_1.INVALID_ENTRY_POINT) {
104
+ return null;
105
+ }
96
106
  // Otherwise store it and search for secondary entry-points
97
107
  entryPoints.push(topLevelEntryPoint);
98
108
  this.walkDirectory(packagePath, packagePath, function (path, isDirectory) {
109
+ if (!path.endsWith('.js') && !isDirectory) {
110
+ return false;
111
+ }
99
112
  // If the path is a JS file then strip its extension and see if we can match an entry-point.
100
113
  var possibleEntryPointPath = isDirectory ? path : stripJsExtension(path);
101
114
  var subEntryPoint = entry_point_1.getEntryPointInfo(_this.fs, _this.config, _this.logger, packagePath, possibleEntryPointPath);
102
- if (subEntryPoint !== null) {
103
- entryPoints.push(subEntryPoint);
115
+ if (subEntryPoint === entry_point_1.NO_ENTRY_POINT || subEntryPoint === entry_point_1.INVALID_ENTRY_POINT) {
116
+ return false;
104
117
  }
118
+ entryPoints.push(subEntryPoint);
119
+ return true;
105
120
  });
106
121
  return entryPoints;
107
122
  };
@@ -118,17 +133,17 @@
118
133
  // Not interested in hidden files
119
134
  .filter(function (path) { return !path.startsWith('.'); })
120
135
  // Ignore node_modules
121
- .filter(function (path) { return path !== 'node_modules'; })
122
- .map(function (path) { return file_system_1.resolve(dir, path); })
136
+ .filter(function (path) { return path !== 'node_modules' && path !== new_entry_point_file_writer_1.NGCC_DIRECTORY; })
123
137
  .forEach(function (path) {
124
- var stat = _this.fs.lstat(path);
138
+ var absolutePath = file_system_1.resolve(dir, path);
139
+ var stat = _this.fs.lstat(absolutePath);
125
140
  if (stat.isSymbolicLink()) {
126
141
  // We are not interested in symbolic links
127
142
  return;
128
143
  }
129
- fn(path, stat.isDirectory());
130
- if (stat.isDirectory()) {
131
- _this.walkDirectory(packagePath, path, fn);
144
+ var containsEntryPoint = fn(absolutePath, stat.isDirectory());
145
+ if (containsEntryPoint) {
146
+ _this.walkDirectory(packagePath, absolutePath, fn);
132
147
  }
133
148
  });
134
149
  };
@@ -139,4 +154,4 @@
139
154
  return filePath.replace(/\.js$/, '');
140
155
  }
141
156
  });
142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directory_walker_entry_point_finder.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {AbsoluteFsPath, FileSystem, join, resolve} from '../../../src/ngtsc/file_system';\nimport {DependencyResolver, SortedEntryPointsInfo} from '../dependencies/dependency_resolver';\nimport {Logger} from '../logging/logger';\nimport {NgccConfiguration} from '../packages/configuration';\nimport {EntryPoint, getEntryPointInfo} from '../packages/entry_point';\nimport {PathMappings} from '../utils';\nimport {EntryPointFinder} from './interface';\nimport {getBasePaths} from './utils';\n\n/**\n * An EntryPointFinder that searches for all entry-points that can be found given a `basePath` and\n * `pathMappings`.\n */\nexport class DirectoryWalkerEntryPointFinder implements EntryPointFinder {\n  private basePaths = getBasePaths(this.sourceDirectory, this.pathMappings);\n  constructor(\n      private fs: FileSystem, private config: NgccConfiguration, private logger: Logger,\n      private resolver: DependencyResolver, private sourceDirectory: AbsoluteFsPath,\n      private pathMappings: PathMappings|undefined) {}\n  /**\n   * Search the `sourceDirectory`, and sub-directories, using `pathMappings` as necessary, to find\n   * all package entry-points.\n   */\n  findEntryPoints(): SortedEntryPointsInfo {\n    const unsortedEntryPoints = this.basePaths.reduce<EntryPoint[]>(\n        (entryPoints, basePath) => entryPoints.concat(this.walkDirectoryForEntryPoints(basePath)),\n        []);\n    return this.resolver.sortEntryPointsByDependency(unsortedEntryPoints);\n  }\n\n  /**\n   * Look for entry points that need to be compiled, starting at the source directory.\n   * The function will recurse into directories that start with `@...`, e.g. `@angular/...`.\n   * @param sourceDirectory An absolute path to the root directory where searching begins.\n   */\n  private walkDirectoryForEntryPoints(sourceDirectory: AbsoluteFsPath): EntryPoint[] {\n    const entryPoints = this.getEntryPointsForPackage(sourceDirectory);\n    if (entryPoints.length > 0) {\n      // The `sourceDirectory` is an entry-point itself so no need to search its sub-directories.\n      return entryPoints;\n    }\n\n    this.fs\n        .readdir(sourceDirectory)\n        // Not interested in hidden files\n        .filter(p => !p.startsWith('.'))\n        // Ignore node_modules\n        .filter(p => p !== 'node_modules')\n        // Only interested in directories (and only those that are not symlinks)\n        .filter(p => {\n          const stat = this.fs.lstat(resolve(sourceDirectory, p));\n          return stat.isDirectory() && !stat.isSymbolicLink();\n        })\n        .forEach(p => {\n          // Either the directory is a potential package or a namespace containing packages (e.g\n          // `@angular`).\n          const packagePath = join(sourceDirectory, p);\n          entryPoints.push(...this.walkDirectoryForEntryPoints(packagePath));\n\n          // Also check for any nested node_modules in this package\n          const nestedNodeModulesPath = join(packagePath, 'node_modules');\n          if (this.fs.exists(nestedNodeModulesPath)) {\n            entryPoints.push(...this.walkDirectoryForEntryPoints(nestedNodeModulesPath));\n          }\n        });\n    return entryPoints;\n  }\n\n  /**\n   * Recurse the folder structure looking for all the entry points\n   * @param packagePath The absolute path to an npm package that may contain entry points\n   * @returns An array of entry points that were discovered.\n   */\n  private getEntryPointsForPackage(packagePath: AbsoluteFsPath): EntryPoint[] {\n    const entryPoints: EntryPoint[] = [];\n\n    // Try to get an entry point from the top level package directory\n    const topLevelEntryPoint =\n        getEntryPointInfo(this.fs, this.config, this.logger, packagePath, packagePath);\n\n    // If there is no primary entry-point then exit\n    if (topLevelEntryPoint === null) {\n      return [];\n    }\n\n    // Otherwise store it and search for secondary entry-points\n    entryPoints.push(topLevelEntryPoint);\n    this.walkDirectory(packagePath, packagePath, (path, isDirectory) => {\n      // If the path is a JS file then strip its extension and see if we can match an entry-point.\n      const possibleEntryPointPath = isDirectory ? path : stripJsExtension(path);\n      const subEntryPoint =\n          getEntryPointInfo(this.fs, this.config, this.logger, packagePath, possibleEntryPointPath);\n      if (subEntryPoint !== null) {\n        entryPoints.push(subEntryPoint);\n      }\n    });\n\n    return entryPoints;\n  }\n\n  /**\n   * Recursively walk a directory and its sub-directories, applying a given\n   * function to each directory.\n   * @param dir the directory to recursively walk.\n   * @param fn the function to apply to each directory.\n   */\n  private walkDirectory(\n      packagePath: AbsoluteFsPath, dir: AbsoluteFsPath,\n      fn: (path: AbsoluteFsPath, isDirectory: boolean) => void) {\n    return this.fs\n        .readdir(dir)\n        // Not interested in hidden files\n        .filter(path => !path.startsWith('.'))\n        // Ignore node_modules\n        .filter(path => path !== 'node_modules')\n        .map(path => resolve(dir, path))\n        .forEach(path => {\n          const stat = this.fs.lstat(path);\n\n          if (stat.isSymbolicLink()) {\n            // We are not interested in symbolic links\n            return;\n          }\n\n          fn(path, stat.isDirectory());\n\n          if (stat.isDirectory()) {\n            this.walkDirectory(packagePath, path, fn);\n          }\n        });\n  }\n}\n\nfunction stripJsExtension<T extends string>(filePath: T): T {\n  return filePath.replace(/\\.js$/, '') as T;\n}\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directory_walker_entry_point_finder.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/entry_point_finder/directory_walker_entry_point_finder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {AbsoluteFsPath, FileSystem, join, resolve} from '../../../src/ngtsc/file_system';\nimport {DependencyResolver, SortedEntryPointsInfo} from '../dependencies/dependency_resolver';\nimport {Logger} from '../logging/logger';\nimport {NgccConfiguration} from '../packages/configuration';\nimport {EntryPoint, INVALID_ENTRY_POINT, NO_ENTRY_POINT, getEntryPointInfo} from '../packages/entry_point';\nimport {PathMappings} from '../utils';\nimport {NGCC_DIRECTORY} from '../writing/new_entry_point_file_writer';\nimport {EntryPointFinder} from './interface';\nimport {getBasePaths} from './utils';\n\n/**\n * An EntryPointFinder that searches for all entry-points that can be found given a `basePath` and\n * `pathMappings`.\n */\nexport class DirectoryWalkerEntryPointFinder implements EntryPointFinder {\n  private basePaths = getBasePaths(this.sourceDirectory, this.pathMappings);\n  constructor(\n      private fs: FileSystem, private config: NgccConfiguration, private logger: Logger,\n      private resolver: DependencyResolver, private sourceDirectory: AbsoluteFsPath,\n      private pathMappings: PathMappings|undefined) {}\n  /**\n   * Search the `sourceDirectory`, and sub-directories, using `pathMappings` as necessary, to find\n   * all package entry-points.\n   */\n  findEntryPoints(): SortedEntryPointsInfo {\n    const unsortedEntryPoints = this.basePaths.reduce<EntryPoint[]>(\n        (entryPoints, basePath) => entryPoints.concat(this.walkDirectoryForEntryPoints(basePath)),\n        []);\n    return this.resolver.sortEntryPointsByDependency(unsortedEntryPoints);\n  }\n\n  /**\n   * Look for entry points that need to be compiled, starting at the source directory.\n   * The function will recurse into directories that start with `@...`, e.g. `@angular/...`.\n   * @param sourceDirectory An absolute path to the root directory where searching begins.\n   */\n  walkDirectoryForEntryPoints(sourceDirectory: AbsoluteFsPath): EntryPoint[] {\n    const entryPoints = this.getEntryPointsForPackage(sourceDirectory);\n    if (entryPoints === null) {\n      return [];\n    }\n\n    if (entryPoints.length > 0) {\n      // The `sourceDirectory` is an entry point itself so no need to search its sub-directories.\n      // Also check for any nested node_modules in this package but only if it was compiled by\n      // Angular.\n      // It is unlikely that a non Angular entry point has a dependency on an Angular library.\n      if (entryPoints.some(e => e.compiledByAngular)) {\n        const nestedNodeModulesPath = this.fs.join(sourceDirectory, 'node_modules');\n        if (this.fs.exists(nestedNodeModulesPath)) {\n          entryPoints.push(...this.walkDirectoryForEntryPoints(nestedNodeModulesPath));\n        }\n      }\n\n      return entryPoints;\n    }\n\n    this.fs\n        .readdir(sourceDirectory)\n        // Not interested in hidden files\n        .filter(p => !p.startsWith('.'))\n        // Ignore node_modules\n        .filter(p => p !== 'node_modules' && p !== NGCC_DIRECTORY)\n        // Only interested in directories (and only those that are not symlinks)\n        .filter(p => {\n          const stat = this.fs.lstat(resolve(sourceDirectory, p));\n          return stat.isDirectory() && !stat.isSymbolicLink();\n        })\n        .forEach(p => {\n          // Package is a potential namespace containing packages (e.g `@angular`).\n          const packagePath = join(sourceDirectory, p);\n          entryPoints.push(...this.walkDirectoryForEntryPoints(packagePath));\n        });\n    return entryPoints;\n  }\n\n  /**\n   * Recurse the folder structure looking for all the entry points\n   * @param packagePath The absolute path to an npm package that may contain entry points\n   * @returns An array of entry points that were discovered or null when it's not a valid entrypoint\n   */\n  private getEntryPointsForPackage(packagePath: AbsoluteFsPath): EntryPoint[]|null {\n    const entryPoints: EntryPoint[] = [];\n\n    // Try to get an entry point from the top level package directory\n    const topLevelEntryPoint =\n        getEntryPointInfo(this.fs, this.config, this.logger, packagePath, packagePath);\n\n    // If there is no primary entry-point then exit\n    if (topLevelEntryPoint === NO_ENTRY_POINT) {\n      return [];\n    }\n\n    if (topLevelEntryPoint === INVALID_ENTRY_POINT) {\n      return null;\n    }\n\n    // Otherwise store it and search for secondary entry-points\n    entryPoints.push(topLevelEntryPoint);\n    this.walkDirectory(packagePath, packagePath, (path, isDirectory) => {\n      if (!path.endsWith('.js') && !isDirectory) {\n        return false;\n      }\n\n      // If the path is a JS file then strip its extension and see if we can match an entry-point.\n      const possibleEntryPointPath = isDirectory ? path : stripJsExtension(path);\n      const subEntryPoint =\n          getEntryPointInfo(this.fs, this.config, this.logger, packagePath, possibleEntryPointPath);\n      if (subEntryPoint === NO_ENTRY_POINT || subEntryPoint === INVALID_ENTRY_POINT) {\n        return false;\n      }\n      entryPoints.push(subEntryPoint);\n      return true;\n    });\n\n    return entryPoints;\n  }\n\n  /**\n   * Recursively walk a directory and its sub-directories, applying a given\n   * function to each directory.\n   * @param dir the directory to recursively walk.\n   * @param fn the function to apply to each directory.\n   */\n  private walkDirectory(\n      packagePath: AbsoluteFsPath, dir: AbsoluteFsPath,\n      fn: (path: AbsoluteFsPath, isDirectory: boolean) => boolean) {\n    return this.fs\n        .readdir(dir)\n        // Not interested in hidden files\n        .filter(path => !path.startsWith('.'))\n        // Ignore node_modules\n        .filter(path => path !== 'node_modules' && path !== NGCC_DIRECTORY)\n        .forEach(path => {\n          const absolutePath = resolve(dir, path);\n          const stat = this.fs.lstat(absolutePath);\n\n          if (stat.isSymbolicLink()) {\n            // We are not interested in symbolic links\n            return;\n          }\n\n          const containsEntryPoint = fn(absolutePath, stat.isDirectory());\n          if (containsEntryPoint) {\n            this.walkDirectory(packagePath, absolutePath, fn);\n          }\n        });\n  }\n}\n\nfunction stripJsExtension<T extends string>(filePath: T): T {\n  return filePath.replace(/\\.js$/, '') as T;\n}\n"]}