@angular/compiler-cli 8.0.0 → 8.1.0-beta.0

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 (131) hide show
  1. package/ngcc/index.d.ts +1 -0
  2. package/ngcc/index.js +1 -1
  3. package/ngcc/main-ngcc.js +4 -4
  4. package/ngcc/src/analysis/decoration_analyzer.d.ts +5 -1
  5. package/ngcc/src/analysis/decoration_analyzer.js +12 -12
  6. package/ngcc/src/analysis/module_with_providers_analyzer.js +2 -2
  7. package/ngcc/src/analysis/private_declarations_analyzer.d.ts +3 -2
  8. package/ngcc/src/analysis/private_declarations_analyzer.js +8 -7
  9. package/ngcc/src/dependencies/commonjs_dependency_host.d.ts +46 -0
  10. package/ngcc/src/dependencies/commonjs_dependency_host.js +133 -0
  11. package/ngcc/src/dependencies/dependency_host.d.ts +17 -0
  12. package/ngcc/src/dependencies/dependency_host.js +20 -0
  13. package/ngcc/src/{packages → dependencies}/dependency_resolver.d.ts +13 -8
  14. package/ngcc/src/dependencies/dependency_resolver.js +138 -0
  15. package/ngcc/src/dependencies/esm_dependency_host.d.ts +62 -0
  16. package/ngcc/src/dependencies/esm_dependency_host.js +122 -0
  17. package/ngcc/src/dependencies/module_resolver.d.ts +139 -0
  18. package/ngcc/src/dependencies/module_resolver.js +297 -0
  19. package/ngcc/src/dependencies/umd_dependency_host.d.ts +46 -0
  20. package/ngcc/src/dependencies/umd_dependency_host.js +114 -0
  21. package/ngcc/src/file_system/file_system.d.ts +36 -0
  22. package/ngcc/src/file_system/file_system.js +20 -0
  23. package/ngcc/src/file_system/node_js_file_system.d.ts +27 -0
  24. package/ngcc/src/file_system/node_js_file_system.js +44 -0
  25. package/ngcc/src/host/commonjs_host.d.ts +43 -0
  26. package/ngcc/src/host/commonjs_host.js +187 -0
  27. package/ngcc/src/host/esm2015_host.d.ts +8 -10
  28. package/ngcc/src/host/esm2015_host.js +70 -40
  29. package/ngcc/src/host/esm5_host.js +3 -3
  30. package/ngcc/src/host/umd_host.d.ts +51 -0
  31. package/ngcc/src/host/umd_host.js +250 -0
  32. package/ngcc/src/main.d.ts +7 -8
  33. package/ngcc/src/main.js +64 -48
  34. package/ngcc/src/packages/build_marker.d.ts +3 -2
  35. package/ngcc/src/packages/build_marker.js +5 -6
  36. package/ngcc/src/packages/bundle_program.d.ts +13 -4
  37. package/ngcc/src/packages/bundle_program.js +11 -12
  38. package/ngcc/src/packages/entry_point.d.ts +6 -10
  39. package/ngcc/src/packages/entry_point.js +28 -24
  40. package/ngcc/src/packages/entry_point_bundle.d.ts +3 -1
  41. package/ngcc/src/packages/entry_point_bundle.js +10 -21
  42. package/ngcc/src/packages/entry_point_finder.d.ts +33 -3
  43. package/ngcc/src/packages/entry_point_finder.js +80 -18
  44. package/ngcc/src/packages/ngcc_compiler_host.d.ts +31 -0
  45. package/ngcc/src/packages/ngcc_compiler_host.js +108 -0
  46. package/ngcc/src/packages/transformer.d.ts +7 -5
  47. package/ngcc/src/packages/transformer.js +36 -12
  48. package/ngcc/src/rendering/commonjs_rendering_formatter.d.ts +25 -0
  49. package/ngcc/src/rendering/commonjs_rendering_formatter.js +89 -0
  50. package/ngcc/src/rendering/dts_renderer.d.ts +51 -0
  51. package/ngcc/src/rendering/dts_renderer.js +135 -0
  52. package/ngcc/src/rendering/esm5_rendering_formatter.d.ts +21 -0
  53. package/ngcc/src/rendering/esm5_rendering_formatter.js +44 -0
  54. package/ngcc/src/rendering/esm_rendering_formatter.d.ts +63 -0
  55. package/ngcc/src/rendering/esm_rendering_formatter.js +202 -0
  56. package/ngcc/src/rendering/renderer.d.ts +16 -112
  57. package/ngcc/src/rendering/renderer.js +38 -285
  58. package/ngcc/src/rendering/rendering_formatter.d.ts +35 -0
  59. package/ngcc/src/rendering/rendering_formatter.js +14 -0
  60. package/ngcc/src/rendering/source_maps.d.ts +45 -0
  61. package/ngcc/src/rendering/source_maps.js +129 -0
  62. package/ngcc/src/rendering/umd_rendering_formatter.d.ts +28 -0
  63. package/ngcc/src/rendering/umd_rendering_formatter.js +222 -0
  64. package/ngcc/src/rendering/utils.d.ts +25 -0
  65. package/ngcc/src/rendering/utils.js +34 -0
  66. package/ngcc/src/utils.d.ts +12 -0
  67. package/ngcc/src/utils.js +10 -1
  68. package/ngcc/src/writing/file_writer.d.ts +2 -2
  69. package/ngcc/src/writing/file_writer.js +1 -1
  70. package/ngcc/src/writing/in_place_file_writer.d.ts +6 -10
  71. package/ngcc/src/writing/in_place_file_writer.js +18 -19
  72. package/ngcc/src/writing/new_entry_point_file_writer.d.ts +4 -4
  73. package/ngcc/src/writing/new_entry_point_file_writer.js +24 -25
  74. package/package.json +2 -2
  75. package/src/ngtsc/annotations/src/base_def.d.ts +5 -4
  76. package/src/ngtsc/annotations/src/base_def.js +12 -3
  77. package/src/ngtsc/annotations/src/component.d.ts +0 -1
  78. package/src/ngtsc/annotations/src/component.js +2 -5
  79. package/src/ngtsc/annotations/src/directive.d.ts +2 -1
  80. package/src/ngtsc/annotations/src/directive.js +5 -4
  81. package/src/ngtsc/annotations/src/injectable.js +1 -3
  82. package/src/ngtsc/annotations/src/ng_module.d.ts +2 -1
  83. package/src/ngtsc/annotations/src/ng_module.js +17 -10
  84. package/src/ngtsc/annotations/src/pipe.js +1 -1
  85. package/src/ngtsc/annotations/src/util.js +7 -4
  86. package/src/ngtsc/imports/src/emitter.d.ts +8 -6
  87. package/src/ngtsc/imports/src/emitter.js +10 -38
  88. package/src/ngtsc/imports/src/resolver.js +4 -5
  89. package/src/ngtsc/incremental/src/state.d.ts +15 -3
  90. package/src/ngtsc/incremental/src/state.js +72 -52
  91. package/src/ngtsc/metadata/src/api.d.ts +18 -1
  92. package/src/ngtsc/metadata/src/api.js +1 -1
  93. package/src/ngtsc/metadata/src/util.d.ts +2 -2
  94. package/src/ngtsc/metadata/src/util.js +28 -9
  95. package/src/ngtsc/partial_evaluator/index.d.ts +1 -1
  96. package/src/ngtsc/partial_evaluator/index.js +1 -1
  97. package/src/ngtsc/partial_evaluator/src/dynamic.d.ts +2 -1
  98. package/src/ngtsc/partial_evaluator/src/dynamic.js +1 -1
  99. package/src/ngtsc/partial_evaluator/src/interface.d.ts +10 -3
  100. package/src/ngtsc/partial_evaluator/src/interface.js +6 -7
  101. package/src/ngtsc/partial_evaluator/src/interpreter.d.ts +4 -3
  102. package/src/ngtsc/partial_evaluator/src/interpreter.js +11 -9
  103. package/src/ngtsc/path/src/logical.js +4 -3
  104. package/src/ngtsc/path/src/types.d.ts +19 -7
  105. package/src/ngtsc/path/src/types.js +48 -9
  106. package/src/ngtsc/program.js +13 -12
  107. package/src/ngtsc/scope/src/local.d.ts +23 -5
  108. package/src/ngtsc/scope/src/local.js +34 -11
  109. package/src/ngtsc/shims/src/factory_generator.js +4 -2
  110. package/src/ngtsc/transform/src/api.d.ts +0 -1
  111. package/src/ngtsc/transform/src/api.js +1 -1
  112. package/src/ngtsc/transform/src/compilation.d.ts +4 -2
  113. package/src/ngtsc/transform/src/compilation.js +22 -20
  114. package/src/ngtsc/translator/index.d.ts +1 -1
  115. package/src/ngtsc/translator/index.js +1 -1
  116. package/src/ngtsc/translator/src/translator.d.ts +21 -8
  117. package/src/ngtsc/translator/src/translator.js +3 -12
  118. package/src/ngtsc/typecheck/src/api.d.ts +2 -1
  119. package/src/ngtsc/typecheck/src/api.js +1 -1
  120. package/src/ngtsc/typecheck/src/expression.js +104 -88
  121. package/src/ngtsc/typecheck/src/type_check_block.js +17 -11
  122. package/src/ngtsc/util/src/typescript.d.ts +7 -0
  123. package/src/ngtsc/util/src/typescript.js +17 -1
  124. package/src/version.js +1 -1
  125. package/ngcc/src/packages/dependency_host.d.ts +0 -84
  126. package/ngcc/src/packages/dependency_host.js +0 -164
  127. package/ngcc/src/packages/dependency_resolver.js +0 -126
  128. package/ngcc/src/rendering/esm5_renderer.d.ts +0 -14
  129. package/ngcc/src/rendering/esm5_renderer.js +0 -47
  130. package/ngcc/src/rendering/esm_renderer.d.ts +0 -30
  131. package/ngcc/src/rendering/esm_renderer.js +0 -141
@@ -0,0 +1,133 @@
1
+ (function (factory) {
2
+ if (typeof module === "object" && typeof module.exports === "object") {
3
+ var v = factory(require, exports);
4
+ if (v !== undefined) module.exports = v;
5
+ }
6
+ else if (typeof define === "function" && define.amd) {
7
+ define("@angular/compiler-cli/ngcc/src/dependencies/commonjs_dependency_host", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/ngcc/src/host/commonjs_host", "@angular/compiler-cli/ngcc/src/dependencies/module_resolver"], factory);
8
+ }
9
+ })(function (require, exports) {
10
+ "use strict";
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ var tslib_1 = require("tslib");
13
+ /**
14
+ * @license
15
+ * Copyright Google Inc. All Rights Reserved.
16
+ *
17
+ * Use of this source code is governed by an MIT-style license that can be
18
+ * found in the LICENSE file at https://angular.io/license
19
+ */
20
+ var ts = require("typescript");
21
+ var commonjs_host_1 = require("@angular/compiler-cli/ngcc/src/host/commonjs_host");
22
+ var module_resolver_1 = require("@angular/compiler-cli/ngcc/src/dependencies/module_resolver");
23
+ /**
24
+ * Helper functions for computing dependencies.
25
+ */
26
+ var CommonJsDependencyHost = /** @class */ (function () {
27
+ function CommonJsDependencyHost(fs, moduleResolver) {
28
+ this.fs = fs;
29
+ this.moduleResolver = moduleResolver;
30
+ }
31
+ /**
32
+ * Find all the dependencies for the entry-point at the given path.
33
+ *
34
+ * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.
35
+ * @returns Information about the dependencies of the entry-point, including those that were
36
+ * missing or deep imports into other entry-points.
37
+ */
38
+ CommonJsDependencyHost.prototype.findDependencies = function (entryPointPath) {
39
+ var dependencies = new Set();
40
+ var missing = new Set();
41
+ var deepImports = new Set();
42
+ var alreadySeen = new Set();
43
+ this.recursivelyFindDependencies(entryPointPath, dependencies, missing, deepImports, alreadySeen);
44
+ return { dependencies: dependencies, missing: missing, deepImports: deepImports };
45
+ };
46
+ /**
47
+ * Compute the dependencies of the given file.
48
+ *
49
+ * @param file An absolute path to the file whose dependencies we want to get.
50
+ * @param dependencies A set that will have the absolute paths of resolved entry points added to
51
+ * it.
52
+ * @param missing A set that will have the dependencies that could not be found added to it.
53
+ * @param deepImports A set that will have the import paths that exist but cannot be mapped to
54
+ * entry-points, i.e. deep-imports.
55
+ * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck
56
+ * in a
57
+ * circular dependency loop.
58
+ */
59
+ CommonJsDependencyHost.prototype.recursivelyFindDependencies = function (file, dependencies, missing, deepImports, alreadySeen) {
60
+ var e_1, _a, e_2, _b;
61
+ var fromContents = this.fs.readFile(file);
62
+ if (!this.hasRequireCalls(fromContents)) {
63
+ // Avoid parsing the source file as there are no require calls.
64
+ return;
65
+ }
66
+ // Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
67
+ var sf = ts.createSourceFile(file, fromContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
68
+ try {
69
+ for (var _c = tslib_1.__values(sf.statements), _d = _c.next(); !_d.done; _d = _c.next()) {
70
+ var statement = _d.value;
71
+ var declarations = ts.isVariableStatement(statement) ? statement.declarationList.declarations : [];
72
+ try {
73
+ for (var declarations_1 = tslib_1.__values(declarations), declarations_1_1 = declarations_1.next(); !declarations_1_1.done; declarations_1_1 = declarations_1.next()) {
74
+ var declaration = declarations_1_1.value;
75
+ if (declaration.initializer && commonjs_host_1.isRequireCall(declaration.initializer)) {
76
+ var importPath = declaration.initializer.arguments[0].text;
77
+ var resolvedModule = this.moduleResolver.resolveModuleImport(importPath, file);
78
+ if (resolvedModule) {
79
+ if (resolvedModule instanceof module_resolver_1.ResolvedRelativeModule) {
80
+ var internalDependency = resolvedModule.modulePath;
81
+ if (!alreadySeen.has(internalDependency)) {
82
+ alreadySeen.add(internalDependency);
83
+ this.recursivelyFindDependencies(internalDependency, dependencies, missing, deepImports, alreadySeen);
84
+ }
85
+ }
86
+ else {
87
+ if (resolvedModule instanceof module_resolver_1.ResolvedDeepImport) {
88
+ deepImports.add(resolvedModule.importPath);
89
+ }
90
+ else {
91
+ dependencies.add(resolvedModule.entryPointPath);
92
+ }
93
+ }
94
+ }
95
+ else {
96
+ missing.add(importPath);
97
+ }
98
+ }
99
+ }
100
+ }
101
+ catch (e_2_1) { e_2 = { error: e_2_1 }; }
102
+ finally {
103
+ try {
104
+ if (declarations_1_1 && !declarations_1_1.done && (_b = declarations_1.return)) _b.call(declarations_1);
105
+ }
106
+ finally { if (e_2) throw e_2.error; }
107
+ }
108
+ }
109
+ }
110
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
111
+ finally {
112
+ try {
113
+ if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
114
+ }
115
+ finally { if (e_1) throw e_1.error; }
116
+ }
117
+ };
118
+ /**
119
+ * Check whether a source file needs to be parsed for imports.
120
+ * This is a performance short-circuit, which saves us from creating
121
+ * a TypeScript AST unnecessarily.
122
+ *
123
+ * @param source The content of the source file to check.
124
+ *
125
+ * @returns false if there are definitely no require calls
126
+ * in this file, true otherwise.
127
+ */
128
+ CommonJsDependencyHost.prototype.hasRequireCalls = function (source) { return /require\(['"]/.test(source); };
129
+ return CommonJsDependencyHost;
130
+ }());
131
+ exports.CommonJsDependencyHost = CommonJsDependencyHost;
132
+ });
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commonjs_dependency_host.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/dependencies/commonjs_dependency_host.ts"],"names":[],"mappings":";;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,+BAAiC;IAIjC,mFAAoD;IAGpD,+FAA6F;IAE7F;;OAEG;IACH;QACE,gCAAoB,EAAc,EAAU,cAA8B;YAAtD,OAAE,GAAF,EAAE,CAAY;YAAU,mBAAc,GAAd,cAAc,CAAgB;QAAG,CAAC;QAE9E;;;;;;WAMG;QACH,iDAAgB,GAAhB,UAAiB,cAA8B;YAC7C,IAAM,YAAY,GAAG,IAAI,GAAG,EAAkB,CAAC;YAC/C,IAAM,OAAO,GAAG,IAAI,GAAG,EAA8B,CAAC;YACtD,IAAM,WAAW,GAAG,IAAI,GAAG,EAAkB,CAAC;YAC9C,IAAM,WAAW,GAAG,IAAI,GAAG,EAAkB,CAAC;YAC9C,IAAI,CAAC,2BAA2B,CAC5B,cAAc,EAAE,YAAY,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;YACrE,OAAO,EAAC,YAAY,cAAA,EAAE,OAAO,SAAA,EAAE,WAAW,aAAA,EAAC,CAAC;QAC9C,CAAC;QAED;;;;;;;;;;;;WAYG;QACK,4DAA2B,GAAnC,UACI,IAAoB,EAAE,YAAiC,EAAE,OAAoB,EAC7E,WAAgC,EAAE,WAAgC;;YACpE,IAAM,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YAC5C,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,EAAE;gBACvC,+DAA+D;gBAC/D,OAAO;aACR;YAED,8FAA8F;YAC9F,IAAM,EAAE,GACJ,EAAE,CAAC,gBAAgB,CAAC,IAAI,EAAE,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;;gBAE7F,KAAwB,IAAA,KAAA,iBAAA,EAAE,CAAC,UAAU,CAAA,gBAAA,4BAAE;oBAAlC,IAAM,SAAS,WAAA;oBAClB,IAAM,YAAY,GACd,EAAE,CAAC,mBAAmB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC;;wBACpF,KAA0B,IAAA,iBAAA,iBAAA,YAAY,CAAA,0CAAA,oEAAE;4BAAnC,IAAM,WAAW,yBAAA;4BACpB,IAAI,WAAW,CAAC,WAAW,IAAI,6BAAa,CAAC,WAAW,CAAC,WAAW,CAAC,EAAE;gCACrE,IAAM,UAAU,GAAG,WAAW,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gCAC7D,IAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gCACjF,IAAI,cAAc,EAAE;oCAClB,IAAI,cAAc,YAAY,wCAAsB,EAAE;wCACpD,IAAM,kBAAkB,GAAG,cAAc,CAAC,UAAU,CAAC;wCACrD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE;4CACxC,WAAW,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;4CACpC,IAAI,CAAC,2BAA2B,CAC5B,kBAAkB,EAAE,YAAY,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;yCAC1E;qCACF;yCAAM;wCACL,IAAI,cAAc,YAAY,oCAAkB,EAAE;4CAChD,WAAW,CAAC,GAAG,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;yCAC5C;6CAAM;4CACL,YAAY,CAAC,GAAG,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;yCACjD;qCACF;iCACF;qCAAM;oCACL,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;iCACzB;6BACF;yBACF;;;;;;;;;iBACF;;;;;;;;;QACH,CAAC;QAED;;;;;;;;;WASG;QACH,gDAAe,GAAf,UAAgB,MAAc,IAAa,OAAO,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACnF,6BAAC;IAAD,CAAC,AAvFD,IAuFC;IAvFY,wDAAsB","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 * as ts from 'typescript';\n\nimport {AbsoluteFsPath, PathSegment} from '../../../src/ngtsc/path';\nimport {FileSystem} from '../file_system/file_system';\nimport {isRequireCall} from '../host/commonjs_host';\n\nimport {DependencyHost, DependencyInfo} from './dependency_host';\nimport {ModuleResolver, ResolvedDeepImport, ResolvedRelativeModule} from './module_resolver';\n\n/**\n * Helper functions for computing dependencies.\n */\nexport class CommonJsDependencyHost implements DependencyHost {\n  constructor(private fs: FileSystem, private moduleResolver: ModuleResolver) {}\n\n  /**\n   * Find all the dependencies for the entry-point at the given path.\n   *\n   * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.\n   * @returns Information about the dependencies of the entry-point, including those that were\n   * missing or deep imports into other entry-points.\n   */\n  findDependencies(entryPointPath: AbsoluteFsPath): DependencyInfo {\n    const dependencies = new Set<AbsoluteFsPath>();\n    const missing = new Set<AbsoluteFsPath|PathSegment>();\n    const deepImports = new Set<AbsoluteFsPath>();\n    const alreadySeen = new Set<AbsoluteFsPath>();\n    this.recursivelyFindDependencies(\n        entryPointPath, dependencies, missing, deepImports, alreadySeen);\n    return {dependencies, missing, deepImports};\n  }\n\n  /**\n   * Compute the dependencies of the given file.\n   *\n   * @param file An absolute path to the file whose dependencies we want to get.\n   * @param dependencies A set that will have the absolute paths of resolved entry points added to\n   * it.\n   * @param missing A set that will have the dependencies that could not be found added to it.\n   * @param deepImports A set that will have the import paths that exist but cannot be mapped to\n   * entry-points, i.e. deep-imports.\n   * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck\n   * in a\n   * circular dependency loop.\n   */\n  private recursivelyFindDependencies(\n      file: AbsoluteFsPath, dependencies: Set<AbsoluteFsPath>, missing: Set<string>,\n      deepImports: Set<AbsoluteFsPath>, alreadySeen: Set<AbsoluteFsPath>): void {\n    const fromContents = this.fs.readFile(file);\n    if (!this.hasRequireCalls(fromContents)) {\n      // Avoid parsing the source file as there are no require calls.\n      return;\n    }\n\n    // Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.\n    const sf =\n        ts.createSourceFile(file, fromContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);\n\n    for (const statement of sf.statements) {\n      const declarations =\n          ts.isVariableStatement(statement) ? statement.declarationList.declarations : [];\n      for (const declaration of declarations) {\n        if (declaration.initializer && isRequireCall(declaration.initializer)) {\n          const importPath = declaration.initializer.arguments[0].text;\n          const resolvedModule = this.moduleResolver.resolveModuleImport(importPath, file);\n          if (resolvedModule) {\n            if (resolvedModule instanceof ResolvedRelativeModule) {\n              const internalDependency = resolvedModule.modulePath;\n              if (!alreadySeen.has(internalDependency)) {\n                alreadySeen.add(internalDependency);\n                this.recursivelyFindDependencies(\n                    internalDependency, dependencies, missing, deepImports, alreadySeen);\n              }\n            } else {\n              if (resolvedModule instanceof ResolvedDeepImport) {\n                deepImports.add(resolvedModule.importPath);\n              } else {\n                dependencies.add(resolvedModule.entryPointPath);\n              }\n            }\n          } else {\n            missing.add(importPath);\n          }\n        }\n      }\n    }\n  }\n\n  /**\n   * Check whether a source file needs to be parsed for imports.\n   * This is a performance short-circuit, which saves us from creating\n   * a TypeScript AST unnecessarily.\n   *\n   * @param source The content of the source file to check.\n   *\n   * @returns false if there are definitely no require calls\n   * in this file, true otherwise.\n   */\n  hasRequireCalls(source: string): boolean { return /require\\(['\"]/.test(source); }\n}\n"]}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ /// <amd-module name="@angular/compiler-cli/ngcc/src/dependencies/dependency_host" />
9
+ import { AbsoluteFsPath, PathSegment } from '../../../src/ngtsc/path';
10
+ export interface DependencyHost {
11
+ findDependencies(entryPointPath: AbsoluteFsPath): DependencyInfo;
12
+ }
13
+ export interface DependencyInfo {
14
+ dependencies: Set<AbsoluteFsPath>;
15
+ missing: Set<AbsoluteFsPath | PathSegment>;
16
+ deepImports: Set<AbsoluteFsPath>;
17
+ }
@@ -0,0 +1,20 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ (function (factory) {
9
+ if (typeof module === "object" && typeof module.exports === "object") {
10
+ var v = factory(require, exports);
11
+ if (v !== undefined) module.exports = v;
12
+ }
13
+ else if (typeof define === "function" && define.amd) {
14
+ define("@angular/compiler-cli/ngcc/src/dependencies/dependency_host", ["require", "exports"], factory);
15
+ }
16
+ })(function (require, exports) {
17
+ "use strict";
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVwZW5kZW5jeV9ob3N0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL25nY2Mvc3JjL2RlcGVuZGVuY2llcy9kZXBlbmRlbmN5X2hvc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0Fic29sdXRlRnNQYXRoLCBQYXRoU2VnbWVudH0gZnJvbSAnLi4vLi4vLi4vc3JjL25ndHNjL3BhdGgnO1xuXG5leHBvcnQgaW50ZXJmYWNlIERlcGVuZGVuY3lIb3N0IHtcbiAgZmluZERlcGVuZGVuY2llcyhlbnRyeVBvaW50UGF0aDogQWJzb2x1dGVGc1BhdGgpOiBEZXBlbmRlbmN5SW5mbztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZXBlbmRlbmN5SW5mbyB7XG4gIGRlcGVuZGVuY2llczogU2V0PEFic29sdXRlRnNQYXRoPjtcbiAgbWlzc2luZzogU2V0PEFic29sdXRlRnNQYXRofFBhdGhTZWdtZW50PjtcbiAgZGVlcEltcG9ydHM6IFNldDxBYnNvbHV0ZUZzUGF0aD47XG59XG4iXX0=
@@ -5,10 +5,11 @@
5
5
  * Use of this source code is governed by an MIT-style license that can be
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
- /// <amd-module name="@angular/compiler-cli/ngcc/src/packages/dependency_resolver" />
8
+ /// <amd-module name="@angular/compiler-cli/ngcc/src/dependencies/dependency_resolver" />
9
+ import { FileSystem } from '../file_system/file_system';
9
10
  import { Logger } from '../logging/logger';
11
+ import { EntryPoint, EntryPointFormat } from '../packages/entry_point';
10
12
  import { DependencyHost } from './dependency_host';
11
- import { EntryPoint } from './entry_point';
12
13
  /**
13
14
  * Holds information about entry points that are removed because
14
15
  * they have dependencies that are missing (directly or transitively).
@@ -39,6 +40,10 @@ export interface IgnoredDependency {
39
40
  entryPoint: EntryPoint;
40
41
  dependencyPath: string;
41
42
  }
43
+ export interface DependencyDiagnostics {
44
+ invalidEntryPoints: InvalidEntryPoint[];
45
+ ignoredDependencies: IgnoredDependency[];
46
+ }
42
47
  /**
43
48
  * A list of entry-points, sorted by their dependencies.
44
49
  *
@@ -48,18 +53,17 @@ export interface IgnoredDependency {
48
53
  * Some entry points or their dependencies may be have been ignored. These are captured for
49
54
  * diagnostic purposes in `invalidEntryPoints` and `ignoredDependencies` respectively.
50
55
  */
51
- export interface SortedEntryPointsInfo {
56
+ export interface SortedEntryPointsInfo extends DependencyDiagnostics {
52
57
  entryPoints: EntryPoint[];
53
- invalidEntryPoints: InvalidEntryPoint[];
54
- ignoredDependencies: IgnoredDependency[];
55
58
  }
56
59
  /**
57
60
  * A class that resolves dependencies between entry-points.
58
61
  */
59
62
  export declare class DependencyResolver {
63
+ private fs;
60
64
  private logger;
61
- private host;
62
- constructor(logger: Logger, host: DependencyHost);
65
+ private hosts;
66
+ constructor(fs: FileSystem, logger: Logger, hosts: Partial<Record<EntryPointFormat, DependencyHost>>);
63
67
  /**
64
68
  * Sort the array of entry points so that the dependant entry points always come later than
65
69
  * their dependencies in the array.
@@ -74,5 +78,6 @@ export declare class DependencyResolver {
74
78
  * The graph only holds entry-points that ngcc cares about and whose dependencies
75
79
  * (direct and transitive) all exist.
76
80
  */
77
- private createDependencyInfo;
81
+ private computeDependencyGraph;
82
+ private getEntryPointFormatInfo;
78
83
  }
@@ -0,0 +1,138 @@
1
+ /**
2
+ * @license
3
+ * Copyright Google Inc. All Rights Reserved.
4
+ *
5
+ * Use of this source code is governed by an MIT-style license that can be
6
+ * found in the LICENSE file at https://angular.io/license
7
+ */
8
+ (function (factory) {
9
+ if (typeof module === "object" && typeof module.exports === "object") {
10
+ var v = factory(require, exports);
11
+ if (v !== undefined) module.exports = v;
12
+ }
13
+ else if (typeof define === "function" && define.amd) {
14
+ define("@angular/compiler-cli/ngcc/src/dependencies/dependency_resolver", ["require", "exports", "tslib", "dependency-graph", "@angular/compiler-cli/src/ngtsc/path", "@angular/compiler-cli/ngcc/src/packages/entry_point"], factory);
15
+ }
16
+ })(function (require, exports) {
17
+ "use strict";
18
+ Object.defineProperty(exports, "__esModule", { value: true });
19
+ var tslib_1 = require("tslib");
20
+ var dependency_graph_1 = require("dependency-graph");
21
+ var path_1 = require("@angular/compiler-cli/src/ngtsc/path");
22
+ var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
23
+ /**
24
+ * A class that resolves dependencies between entry-points.
25
+ */
26
+ var DependencyResolver = /** @class */ (function () {
27
+ function DependencyResolver(fs, logger, hosts) {
28
+ this.fs = fs;
29
+ this.logger = logger;
30
+ this.hosts = hosts;
31
+ }
32
+ /**
33
+ * Sort the array of entry points so that the dependant entry points always come later than
34
+ * their dependencies in the array.
35
+ * @param entryPoints An array entry points to sort.
36
+ * @param target If provided, only return entry-points depended on by this entry-point.
37
+ * @returns the result of sorting the entry points by dependency.
38
+ */
39
+ DependencyResolver.prototype.sortEntryPointsByDependency = function (entryPoints, target) {
40
+ var _a = this.computeDependencyGraph(entryPoints), invalidEntryPoints = _a.invalidEntryPoints, ignoredDependencies = _a.ignoredDependencies, graph = _a.graph;
41
+ var sortedEntryPointNodes;
42
+ if (target) {
43
+ if (target.compiledByAngular) {
44
+ sortedEntryPointNodes = graph.dependenciesOf(target.path);
45
+ sortedEntryPointNodes.push(target.path);
46
+ }
47
+ else {
48
+ sortedEntryPointNodes = [];
49
+ }
50
+ }
51
+ else {
52
+ sortedEntryPointNodes = graph.overallOrder();
53
+ }
54
+ return {
55
+ entryPoints: sortedEntryPointNodes.map(function (path) { return graph.getNodeData(path); }),
56
+ invalidEntryPoints: invalidEntryPoints,
57
+ ignoredDependencies: ignoredDependencies,
58
+ };
59
+ };
60
+ /**
61
+ * Computes a dependency graph of the given entry-points.
62
+ *
63
+ * The graph only holds entry-points that ngcc cares about and whose dependencies
64
+ * (direct and transitive) all exist.
65
+ */
66
+ DependencyResolver.prototype.computeDependencyGraph = function (entryPoints) {
67
+ var _this = this;
68
+ var invalidEntryPoints = [];
69
+ var ignoredDependencies = [];
70
+ var graph = new dependency_graph_1.DepGraph();
71
+ var angularEntryPoints = entryPoints.filter(function (entryPoint) { return entryPoint.compiledByAngular; });
72
+ // Add the Angular compiled entry points to the graph as nodes
73
+ angularEntryPoints.forEach(function (entryPoint) { return graph.addNode(entryPoint.path, entryPoint); });
74
+ // Now add the dependencies between them
75
+ angularEntryPoints.forEach(function (entryPoint) {
76
+ var formatInfo = _this.getEntryPointFormatInfo(entryPoint);
77
+ var host = _this.hosts[formatInfo.format];
78
+ if (!host) {
79
+ throw new Error("Could not find a suitable format for computing dependencies of entry-point: '" + entryPoint.path + "'.");
80
+ }
81
+ var _a = host.findDependencies(formatInfo.path), dependencies = _a.dependencies, missing = _a.missing, deepImports = _a.deepImports;
82
+ if (missing.size > 0) {
83
+ // This entry point has dependencies that are missing
84
+ // so remove it from the graph.
85
+ removeNodes(entryPoint, Array.from(missing));
86
+ }
87
+ else {
88
+ dependencies.forEach(function (dependencyPath) {
89
+ if (graph.hasNode(dependencyPath)) {
90
+ if (graph.hasNode(entryPoint.path)) {
91
+ // The entry-point is still valid (i.e. has no missing dependencies) and
92
+ // the dependency maps to an entry point that exists in the graph so add it
93
+ graph.addDependency(entryPoint.path, dependencyPath);
94
+ }
95
+ }
96
+ else if (invalidEntryPoints.some(function (i) { return i.entryPoint.path === dependencyPath; })) {
97
+ // The dependency path maps to an entry-point that was previously removed
98
+ // from the graph, so remove this entry-point as well.
99
+ removeNodes(entryPoint, [dependencyPath]);
100
+ }
101
+ else {
102
+ // The dependency path points to a package that ngcc does not care about.
103
+ ignoredDependencies.push({ entryPoint: entryPoint, dependencyPath: dependencyPath });
104
+ }
105
+ });
106
+ }
107
+ if (deepImports.size) {
108
+ var imports = Array.from(deepImports).map(function (i) { return "'" + i + "'"; }).join(', ');
109
+ _this.logger.warn("Entry point '" + entryPoint.name + "' contains deep imports into " + imports + ". " +
110
+ "This is probably not a problem, but may cause the compilation of entry points to be out of order.");
111
+ }
112
+ });
113
+ return { invalidEntryPoints: invalidEntryPoints, ignoredDependencies: ignoredDependencies, graph: graph };
114
+ function removeNodes(entryPoint, missingDependencies) {
115
+ var nodesToRemove = tslib_1.__spread([entryPoint.path], graph.dependantsOf(entryPoint.path));
116
+ nodesToRemove.forEach(function (node) {
117
+ invalidEntryPoints.push({ entryPoint: graph.getNodeData(node), missingDependencies: missingDependencies });
118
+ graph.removeNode(node);
119
+ });
120
+ }
121
+ };
122
+ DependencyResolver.prototype.getEntryPointFormatInfo = function (entryPoint) {
123
+ var properties = Object.keys(entryPoint.packageJson);
124
+ for (var i = 0; i < properties.length; i++) {
125
+ var property = properties[i];
126
+ var format = entry_point_1.getEntryPointFormat(this.fs, entryPoint, property);
127
+ if (format === 'esm2015' || format === 'esm5' || format === 'umd' || format === 'commonjs') {
128
+ var formatPath = entryPoint.packageJson[property];
129
+ return { format: format, path: path_1.AbsoluteFsPath.resolve(entryPoint.path, formatPath) };
130
+ }
131
+ }
132
+ throw new Error("There is no appropriate source code format in '" + entryPoint.path + "' entry-point.");
133
+ };
134
+ return DependencyResolver;
135
+ }());
136
+ exports.DependencyResolver = DependencyResolver;
137
+ });
138
+ //# 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} from '../../../src/ngtsc/path';\nimport {FileSystem} from '../file_system/file_system';\nimport {Logger} from '../logging/logger';\nimport {EntryPoint, EntryPointFormat, EntryPointJsonProperty, getEntryPointFormat} from '../packages/entry_point';\nimport {DependencyHost} from './dependency_host';\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 * A list of entry-points, sorted by their dependencies.\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 be have been ignored. These are captured for\n * diagnostic purposes in `invalidEntryPoints` and `ignoredDependencies` respectively.\n */\nexport interface SortedEntryPointsInfo extends DependencyDiagnostics { entryPoints: EntryPoint[]; }\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  /**\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) {\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.map(path => graph.getNodeData(path)),\n      invalidEntryPoints,\n      ignoredDependencies,\n    };\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 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 {dependencies, missing, deepImports} = host.findDependencies(formatInfo.path);\n\n      if (missing.size > 0) {\n        // This entry point has dependencies that are missing\n        // so remove it from the graph.\n        removeNodes(entryPoint, Array.from(missing));\n      } else {\n        dependencies.forEach(dependencyPath => {\n          if (graph.hasNode(dependencyPath)) {\n            if (graph.hasNode(entryPoint.path)) {\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            }\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    const properties = Object.keys(entryPoint.packageJson);\n    for (let i = 0; i < properties.length; i++) {\n      const property = properties[i] as EntryPointJsonProperty;\n      const format = getEntryPointFormat(this.fs, entryPoint, property);\n\n      if (format === 'esm2015' || format === 'esm5' || format === 'umd' || format === 'commonjs') {\n        const formatPath = entryPoint.packageJson[property] !;\n        return {format, path: AbsoluteFsPath.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"]}
@@ -0,0 +1,62 @@
1
+ /// <amd-module name="@angular/compiler-cli/ngcc/src/dependencies/esm_dependency_host" />
2
+ /**
3
+ * @license
4
+ * Copyright Google Inc. All Rights Reserved.
5
+ *
6
+ * Use of this source code is governed by an MIT-style license that can be
7
+ * found in the LICENSE file at https://angular.io/license
8
+ */
9
+ import * as ts from 'typescript';
10
+ import { AbsoluteFsPath } from '../../../src/ngtsc/path';
11
+ import { FileSystem } from '../file_system/file_system';
12
+ import { DependencyHost, DependencyInfo } from './dependency_host';
13
+ import { ModuleResolver } from './module_resolver';
14
+ /**
15
+ * Helper functions for computing dependencies.
16
+ */
17
+ export declare class EsmDependencyHost implements DependencyHost {
18
+ private fs;
19
+ private moduleResolver;
20
+ constructor(fs: FileSystem, moduleResolver: ModuleResolver);
21
+ /**
22
+ * Find all the dependencies for the entry-point at the given path.
23
+ *
24
+ * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.
25
+ * @returns Information about the dependencies of the entry-point, including those that were
26
+ * missing or deep imports into other entry-points.
27
+ */
28
+ findDependencies(entryPointPath: AbsoluteFsPath): DependencyInfo;
29
+ /**
30
+ * Compute the dependencies of the given file.
31
+ *
32
+ * @param file An absolute path to the file whose dependencies we want to get.
33
+ * @param dependencies A set that will have the absolute paths of resolved entry points added to
34
+ * it.
35
+ * @param missing A set that will have the dependencies that could not be found added to it.
36
+ * @param deepImports A set that will have the import paths that exist but cannot be mapped to
37
+ * entry-points, i.e. deep-imports.
38
+ * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck
39
+ * in a
40
+ * circular dependency loop.
41
+ */
42
+ private recursivelyFindDependencies;
43
+ /**
44
+ * Check whether the given statement is an import with a string literal module specifier.
45
+ * @param stmt the statement node to check.
46
+ * @returns true if the statement is an import with a string literal module specifier.
47
+ */
48
+ isStringImportOrReexport(stmt: ts.Statement): stmt is ts.ImportDeclaration & {
49
+ moduleSpecifier: ts.StringLiteral;
50
+ };
51
+ /**
52
+ * Check whether a source file needs to be parsed for imports.
53
+ * This is a performance short-circuit, which saves us from creating
54
+ * a TypeScript AST unnecessarily.
55
+ *
56
+ * @param source The content of the source file to check.
57
+ *
58
+ * @returns false if there are definitely no import or re-export statements
59
+ * in this file, true otherwise.
60
+ */
61
+ hasImportOrReexportStatements(source: string): boolean;
62
+ }
@@ -0,0 +1,122 @@
1
+ (function (factory) {
2
+ if (typeof module === "object" && typeof module.exports === "object") {
3
+ var v = factory(require, exports);
4
+ if (v !== undefined) module.exports = v;
5
+ }
6
+ else if (typeof define === "function" && define.amd) {
7
+ define("@angular/compiler-cli/ngcc/src/dependencies/esm_dependency_host", ["require", "exports", "typescript", "@angular/compiler-cli/ngcc/src/dependencies/module_resolver"], factory);
8
+ }
9
+ })(function (require, exports) {
10
+ "use strict";
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ /**
13
+ * @license
14
+ * Copyright Google Inc. All Rights Reserved.
15
+ *
16
+ * Use of this source code is governed by an MIT-style license that can be
17
+ * found in the LICENSE file at https://angular.io/license
18
+ */
19
+ var ts = require("typescript");
20
+ var module_resolver_1 = require("@angular/compiler-cli/ngcc/src/dependencies/module_resolver");
21
+ /**
22
+ * Helper functions for computing dependencies.
23
+ */
24
+ var EsmDependencyHost = /** @class */ (function () {
25
+ function EsmDependencyHost(fs, moduleResolver) {
26
+ this.fs = fs;
27
+ this.moduleResolver = moduleResolver;
28
+ }
29
+ /**
30
+ * Find all the dependencies for the entry-point at the given path.
31
+ *
32
+ * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.
33
+ * @returns Information about the dependencies of the entry-point, including those that were
34
+ * missing or deep imports into other entry-points.
35
+ */
36
+ EsmDependencyHost.prototype.findDependencies = function (entryPointPath) {
37
+ var dependencies = new Set();
38
+ var missing = new Set();
39
+ var deepImports = new Set();
40
+ var alreadySeen = new Set();
41
+ this.recursivelyFindDependencies(entryPointPath, dependencies, missing, deepImports, alreadySeen);
42
+ return { dependencies: dependencies, missing: missing, deepImports: deepImports };
43
+ };
44
+ /**
45
+ * Compute the dependencies of the given file.
46
+ *
47
+ * @param file An absolute path to the file whose dependencies we want to get.
48
+ * @param dependencies A set that will have the absolute paths of resolved entry points added to
49
+ * it.
50
+ * @param missing A set that will have the dependencies that could not be found added to it.
51
+ * @param deepImports A set that will have the import paths that exist but cannot be mapped to
52
+ * entry-points, i.e. deep-imports.
53
+ * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck
54
+ * in a
55
+ * circular dependency loop.
56
+ */
57
+ EsmDependencyHost.prototype.recursivelyFindDependencies = function (file, dependencies, missing, deepImports, alreadySeen) {
58
+ var _this = this;
59
+ var fromContents = this.fs.readFile(file);
60
+ if (!this.hasImportOrReexportStatements(fromContents)) {
61
+ return;
62
+ }
63
+ // Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
64
+ var sf = ts.createSourceFile(file, fromContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
65
+ sf.statements
66
+ // filter out statements that are not imports or reexports
67
+ .filter(this.isStringImportOrReexport)
68
+ // Grab the id of the module that is being imported
69
+ .map(function (stmt) { return stmt.moduleSpecifier.text; })
70
+ // Resolve this module id into an absolute path
71
+ .forEach(function (importPath) {
72
+ var resolvedModule = _this.moduleResolver.resolveModuleImport(importPath, file);
73
+ if (resolvedModule) {
74
+ if (resolvedModule instanceof module_resolver_1.ResolvedRelativeModule) {
75
+ var internalDependency = resolvedModule.modulePath;
76
+ if (!alreadySeen.has(internalDependency)) {
77
+ alreadySeen.add(internalDependency);
78
+ _this.recursivelyFindDependencies(internalDependency, dependencies, missing, deepImports, alreadySeen);
79
+ }
80
+ }
81
+ else {
82
+ if (resolvedModule instanceof module_resolver_1.ResolvedDeepImport) {
83
+ deepImports.add(resolvedModule.importPath);
84
+ }
85
+ else {
86
+ dependencies.add(resolvedModule.entryPointPath);
87
+ }
88
+ }
89
+ }
90
+ else {
91
+ missing.add(importPath);
92
+ }
93
+ });
94
+ };
95
+ /**
96
+ * Check whether the given statement is an import with a string literal module specifier.
97
+ * @param stmt the statement node to check.
98
+ * @returns true if the statement is an import with a string literal module specifier.
99
+ */
100
+ EsmDependencyHost.prototype.isStringImportOrReexport = function (stmt) {
101
+ return ts.isImportDeclaration(stmt) ||
102
+ ts.isExportDeclaration(stmt) && !!stmt.moduleSpecifier &&
103
+ ts.isStringLiteral(stmt.moduleSpecifier);
104
+ };
105
+ /**
106
+ * Check whether a source file needs to be parsed for imports.
107
+ * This is a performance short-circuit, which saves us from creating
108
+ * a TypeScript AST unnecessarily.
109
+ *
110
+ * @param source The content of the source file to check.
111
+ *
112
+ * @returns false if there are definitely no import or re-export statements
113
+ * in this file, true otherwise.
114
+ */
115
+ EsmDependencyHost.prototype.hasImportOrReexportStatements = function (source) {
116
+ return /(import|export)\s.+from/.test(source);
117
+ };
118
+ return EsmDependencyHost;
119
+ }());
120
+ exports.EsmDependencyHost = EsmDependencyHost;
121
+ });
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esm_dependency_host.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/dependencies/esm_dependency_host.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 * as ts from 'typescript';\n\nimport {AbsoluteFsPath, PathSegment} from '../../../src/ngtsc/path';\nimport {FileSystem} from '../file_system/file_system';\nimport {DependencyHost, DependencyInfo} from './dependency_host';\nimport {ModuleResolver, ResolvedDeepImport, ResolvedRelativeModule} from './module_resolver';\n\n\n/**\n * Helper functions for computing dependencies.\n */\nexport class EsmDependencyHost implements DependencyHost {\n  constructor(private fs: FileSystem, private moduleResolver: ModuleResolver) {}\n\n  /**\n   * Find all the dependencies for the entry-point at the given path.\n   *\n   * @param entryPointPath The absolute path to the JavaScript file that represents an entry-point.\n   * @returns Information about the dependencies of the entry-point, including those that were\n   * missing or deep imports into other entry-points.\n   */\n  findDependencies(entryPointPath: AbsoluteFsPath): DependencyInfo {\n    const dependencies = new Set<AbsoluteFsPath>();\n    const missing = new Set<AbsoluteFsPath|PathSegment>();\n    const deepImports = new Set<AbsoluteFsPath>();\n    const alreadySeen = new Set<AbsoluteFsPath>();\n    this.recursivelyFindDependencies(\n        entryPointPath, dependencies, missing, deepImports, alreadySeen);\n    return {dependencies, missing, deepImports};\n  }\n\n  /**\n   * Compute the dependencies of the given file.\n   *\n   * @param file An absolute path to the file whose dependencies we want to get.\n   * @param dependencies A set that will have the absolute paths of resolved entry points added to\n   * it.\n   * @param missing A set that will have the dependencies that could not be found added to it.\n   * @param deepImports A set that will have the import paths that exist but cannot be mapped to\n   * entry-points, i.e. deep-imports.\n   * @param alreadySeen A set that is used to track internal dependencies to prevent getting stuck\n   * in a\n   * circular dependency loop.\n   */\n  private recursivelyFindDependencies(\n      file: AbsoluteFsPath, dependencies: Set<AbsoluteFsPath>, missing: Set<string>,\n      deepImports: Set<string>, alreadySeen: Set<AbsoluteFsPath>): void {\n    const fromContents = this.fs.readFile(file);\n    if (!this.hasImportOrReexportStatements(fromContents)) {\n      return;\n    }\n\n    // Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.\n    const sf =\n        ts.createSourceFile(file, fromContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);\n    sf.statements\n        // filter out statements that are not imports or reexports\n        .filter(this.isStringImportOrReexport)\n        // Grab the id of the module that is being imported\n        .map(stmt => stmt.moduleSpecifier.text)\n        // Resolve this module id into an absolute path\n        .forEach(importPath => {\n          const resolvedModule = this.moduleResolver.resolveModuleImport(importPath, file);\n          if (resolvedModule) {\n            if (resolvedModule instanceof ResolvedRelativeModule) {\n              const internalDependency = resolvedModule.modulePath;\n              if (!alreadySeen.has(internalDependency)) {\n                alreadySeen.add(internalDependency);\n                this.recursivelyFindDependencies(\n                    internalDependency, dependencies, missing, deepImports, alreadySeen);\n              }\n            } else {\n              if (resolvedModule instanceof ResolvedDeepImport) {\n                deepImports.add(resolvedModule.importPath);\n              } else {\n                dependencies.add(resolvedModule.entryPointPath);\n              }\n            }\n          } else {\n            missing.add(importPath);\n          }\n        });\n  }\n\n  /**\n   * Check whether the given statement is an import with a string literal module specifier.\n   * @param stmt the statement node to check.\n   * @returns true if the statement is an import with a string literal module specifier.\n   */\n  isStringImportOrReexport(stmt: ts.Statement): stmt is ts.ImportDeclaration&\n      {moduleSpecifier: ts.StringLiteral} {\n    return ts.isImportDeclaration(stmt) ||\n        ts.isExportDeclaration(stmt) && !!stmt.moduleSpecifier &&\n        ts.isStringLiteral(stmt.moduleSpecifier);\n  }\n\n  /**\n   * Check whether a source file needs to be parsed for imports.\n   * This is a performance short-circuit, which saves us from creating\n   * a TypeScript AST unnecessarily.\n   *\n   * @param source The content of the source file to check.\n   *\n   * @returns false if there are definitely no import or re-export statements\n   * in this file, true otherwise.\n   */\n  hasImportOrReexportStatements(source: string): boolean {\n    return /(import|export)\\s.+from/.test(source);\n  }\n}\n"]}