@angular/compiler-cli 9.0.0-rc.6 → 9.0.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.
- package/ngcc/src/analysis/decoration_analyzer.d.ts +13 -26
- package/ngcc/src/analysis/decoration_analyzer.js +100 -134
- package/ngcc/src/analysis/migration_host.d.ts +5 -16
- package/ngcc/src/analysis/migration_host.js +20 -91
- package/ngcc/src/analysis/module_with_providers_analyzer.js +2 -2
- package/ngcc/src/analysis/ngcc_trait_compiler.d.ts +42 -0
- package/ngcc/src/analysis/ngcc_trait_compiler.js +107 -0
- package/ngcc/src/analysis/private_declarations_analyzer.d.ts +0 -1
- package/ngcc/src/analysis/private_declarations_analyzer.js +4 -35
- package/ngcc/src/analysis/types.d.ts +6 -21
- package/ngcc/src/analysis/types.js +1 -1
- package/ngcc/src/analysis/util.d.ts +2 -5
- package/ngcc/src/analysis/util.js +11 -94
- package/ngcc/src/dependencies/commonjs_dependency_host.d.ts +1 -1
- package/ngcc/src/dependencies/commonjs_dependency_host.js +90 -39
- package/ngcc/src/dependencies/dependency_host.d.ts +7 -5
- package/ngcc/src/dependencies/dependency_host.js +12 -10
- package/ngcc/src/dependencies/dependency_resolver.d.ts +2 -1
- package/ngcc/src/dependencies/dependency_resolver.js +9 -4
- package/ngcc/src/dependencies/dts_dependency_host.d.ts +21 -0
- package/ngcc/src/dependencies/dts_dependency_host.js +34 -0
- package/ngcc/src/dependencies/esm_dependency_host.d.ts +8 -1
- package/ngcc/src/dependencies/esm_dependency_host.js +30 -22
- package/ngcc/src/dependencies/module_resolver.d.ts +1 -1
- package/ngcc/src/dependencies/module_resolver.js +1 -1
- package/ngcc/src/dependencies/umd_dependency_host.d.ts +1 -1
- package/ngcc/src/dependencies/umd_dependency_host.js +3 -3
- package/ngcc/src/entry_point_finder/targeted_entry_point_finder.d.ts +2 -0
- package/ngcc/src/entry_point_finder/targeted_entry_point_finder.js +49 -9
- package/ngcc/src/execution/cluster/executor.d.ts +3 -1
- package/ngcc/src/execution/cluster/executor.js +12 -7
- package/ngcc/src/execution/cluster/package_json_updater.js +3 -2
- package/ngcc/src/execution/cluster/worker.d.ts +3 -1
- package/ngcc/src/execution/cluster/worker.js +10 -7
- package/ngcc/src/execution/lock_file.d.ts +43 -0
- package/ngcc/src/execution/lock_file.js +129 -0
- package/ngcc/src/execution/single_process_executor.d.ts +3 -1
- package/ngcc/src/execution/single_process_executor.js +18 -15
- package/ngcc/src/execution/task_selection/base_task_queue.d.ts +1 -1
- package/ngcc/src/host/commonjs_host.d.ts +6 -18
- package/ngcc/src/host/commonjs_host.js +45 -81
- package/ngcc/src/host/commonjs_umd_utils.d.ts +73 -0
- package/ngcc/src/host/commonjs_umd_utils.js +109 -0
- package/ngcc/src/host/esm2015_host.d.ts +46 -14
- package/ngcc/src/host/esm2015_host.js +182 -55
- package/ngcc/src/host/esm5_host.js +3 -1
- package/ngcc/src/host/umd_host.d.ts +12 -5
- package/ngcc/src/host/umd_host.js +144 -92
- package/ngcc/src/main.js +65 -122
- package/ngcc/src/migrations/migration.d.ts +1 -0
- package/ngcc/src/migrations/migration.js +1 -1
- package/ngcc/src/packages/build_marker.d.ts +17 -8
- package/ngcc/src/packages/build_marker.js +61 -32
- package/ngcc/src/packages/entry_point_bundle.js +2 -2
- package/ngcc/src/packages/transformer.js +5 -6
- package/ngcc/src/rendering/commonjs_rendering_formatter.js +9 -5
- package/ngcc/src/rendering/dts_renderer.js +8 -5
- package/ngcc/src/rendering/esm_rendering_formatter.js +17 -5
- package/ngcc/src/rendering/renderer.js +4 -4
- package/ngcc/src/rendering/umd_rendering_formatter.d.ts +18 -1
- package/ngcc/src/rendering/umd_rendering_formatter.js +69 -16
- package/ngcc/src/utils.d.ts +14 -0
- package/ngcc/src/utils.js +29 -1
- package/ngcc/src/writing/cleaning/cleaning_strategies.d.ts +45 -0
- package/ngcc/src/writing/cleaning/cleaning_strategies.js +77 -0
- package/ngcc/src/writing/cleaning/package_cleaner.d.ts +39 -0
- package/ngcc/src/writing/cleaning/package_cleaner.js +125 -0
- package/ngcc/src/writing/cleaning/utils.d.ts +16 -0
- package/ngcc/src/writing/cleaning/utils.js +29 -0
- package/ngcc/src/writing/in_place_file_writer.d.ts +1 -0
- package/ngcc/src/writing/in_place_file_writer.js +3 -2
- package/ngcc/src/writing/new_entry_point_file_writer.d.ts +2 -0
- package/ngcc/src/writing/new_entry_point_file_writer.js +5 -4
- package/ngcc/src/writing/package_json_updater.d.ts +24 -10
- package/ngcc/src/writing/package_json_updater.js +53 -10
- package/package.json +6 -5
- package/src/main.d.ts +2 -2
- package/src/metadata/symbols.d.ts +1 -1
- package/src/ngtsc/annotations/src/component.d.ts +58 -20
- package/src/ngtsc/annotations/src/component.js +149 -97
- package/src/ngtsc/annotations/src/diagnostics.d.ts +23 -0
- package/src/ngtsc/annotations/src/diagnostics.js +123 -0
- package/src/ngtsc/annotations/src/directive.d.ts +19 -8
- package/src/ngtsc/annotations/src/directive.js +41 -18
- package/src/ngtsc/annotations/src/injectable.d.ts +8 -4
- package/src/ngtsc/annotations/src/injectable.js +7 -3
- package/src/ngtsc/annotations/src/ng_module.d.ts +22 -7
- package/src/ngtsc/annotations/src/ng_module.js +115 -52
- package/src/ngtsc/annotations/src/pipe.d.ts +12 -6
- package/src/ngtsc/annotations/src/pipe.js +22 -5
- package/src/ngtsc/annotations/src/util.d.ts +22 -0
- package/src/ngtsc/annotations/src/util.js +92 -3
- package/src/ngtsc/core/api.d.ts +368 -0
- package/src/ngtsc/core/api.js +20 -0
- package/src/ngtsc/core/index.d.ts +10 -0
- package/src/ngtsc/core/index.js +24 -0
- package/src/ngtsc/core/src/compiler.d.ts +120 -0
- package/src/ngtsc/core/src/compiler.js +769 -0
- package/src/ngtsc/core/src/host.d.ts +85 -0
- package/src/ngtsc/core/src/host.js +208 -0
- package/src/ngtsc/cycles/src/imports.js +2 -2
- package/src/ngtsc/diagnostics/index.d.ts +1 -1
- package/src/ngtsc/diagnostics/index.js +5 -5
- package/src/ngtsc/diagnostics/src/error.d.ts +1 -1
- package/src/ngtsc/diagnostics/src/error.js +1 -1
- package/src/ngtsc/diagnostics/src/{code.d.ts → error_code.d.ts} +27 -4
- package/src/ngtsc/diagnostics/src/error_code.js +128 -0
- package/src/ngtsc/file_system/src/cached_file_system.d.ts +3 -1
- package/src/ngtsc/file_system/src/cached_file_system.js +48 -4
- package/src/ngtsc/file_system/src/invalid_file_system.d.ts +3 -1
- package/src/ngtsc/file_system/src/invalid_file_system.js +4 -2
- package/src/ngtsc/file_system/src/node_js_file_system.d.ts +3 -1
- package/src/ngtsc/file_system/src/node_js_file_system.js +8 -4
- package/src/ngtsc/file_system/src/types.d.ts +3 -1
- package/src/ngtsc/file_system/src/types.js +1 -1
- package/src/ngtsc/imports/index.d.ts +3 -3
- package/src/ngtsc/imports/index.js +4 -4
- package/src/ngtsc/imports/src/alias.d.ts +12 -11
- package/src/ngtsc/imports/src/alias.js +21 -16
- package/src/ngtsc/imports/src/emitter.d.ts +40 -19
- package/src/ngtsc/imports/src/emitter.js +54 -26
- package/src/ngtsc/imports/src/references.d.ts +30 -8
- package/src/ngtsc/imports/src/references.js +41 -6
- package/src/ngtsc/imports/src/resolver.d.ts +3 -6
- package/src/ngtsc/imports/src/resolver.js +5 -4
- package/src/ngtsc/incremental/api.d.ts +51 -0
- package/src/ngtsc/incremental/api.js +20 -0
- package/src/ngtsc/incremental/index.d.ts +1 -0
- package/src/ngtsc/incremental/index.js +4 -2
- package/src/ngtsc/incremental/src/dependency_tracking.d.ts +56 -0
- package/src/ngtsc/incremental/src/dependency_tracking.js +186 -0
- package/src/ngtsc/incremental/src/noop.d.ts +10 -0
- package/src/ngtsc/incremental/src/noop.js +23 -0
- package/src/ngtsc/incremental/src/state.d.ts +8 -14
- package/src/ngtsc/incremental/src/state.js +83 -80
- package/src/ngtsc/indexer/index.d.ts +1 -0
- package/src/ngtsc/indexer/index.js +4 -2
- package/src/ngtsc/metadata/index.d.ts +1 -1
- package/src/ngtsc/metadata/index.js +2 -1
- package/src/ngtsc/metadata/src/api.d.ts +8 -0
- package/src/ngtsc/metadata/src/api.js +1 -1
- package/src/ngtsc/metadata/src/dts.js +2 -1
- package/src/ngtsc/metadata/src/registry.d.ts +12 -1
- package/src/ngtsc/metadata/src/registry.js +22 -2
- package/src/ngtsc/metadata/src/util.d.ts +2 -0
- package/src/ngtsc/metadata/src/util.js +10 -1
- package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
- package/src/ngtsc/partial_evaluator/index.d.ts +1 -1
- package/src/ngtsc/partial_evaluator/index.js +1 -1
- package/src/ngtsc/partial_evaluator/src/builtin.d.ts +7 -6
- package/src/ngtsc/partial_evaluator/src/builtin.js +54 -9
- package/src/ngtsc/partial_evaluator/src/interface.d.ts +3 -9
- package/src/ngtsc/partial_evaluator/src/interface.js +4 -3
- package/src/ngtsc/partial_evaluator/src/interpreter.d.ts +4 -3
- package/src/ngtsc/partial_evaluator/src/interpreter.js +11 -7
- package/src/ngtsc/partial_evaluator/src/known_declaration.d.ts +19 -0
- package/src/ngtsc/partial_evaluator/src/known_declaration.js +38 -0
- package/src/ngtsc/partial_evaluator/src/result.d.ts +1 -1
- package/src/ngtsc/partial_evaluator/src/result.js +1 -1
- package/src/ngtsc/partial_evaluator/src/ts_helpers.d.ts +1 -1
- package/src/ngtsc/partial_evaluator/src/ts_helpers.js +13 -3
- package/src/ngtsc/program.d.ts +46 -57
- package/src/ngtsc/program.js +68 -574
- package/src/ngtsc/reflection/src/host.d.ts +19 -2
- package/src/ngtsc/reflection/src/host.js +17 -3
- package/src/ngtsc/reflection/src/typescript.js +11 -7
- package/src/ngtsc/resource/index.d.ts +9 -0
- package/src/ngtsc/resource/index.js +22 -0
- package/src/ngtsc/{resource_loader.d.ts → resource/src/loader.d.ts} +4 -4
- package/src/ngtsc/resource/src/loader.js +193 -0
- package/src/ngtsc/routing/src/route.js +2 -2
- package/src/ngtsc/scope/index.d.ts +1 -1
- package/src/ngtsc/scope/index.js +1 -1
- package/src/ngtsc/scope/src/component_scope.d.ts +2 -2
- package/src/ngtsc/scope/src/component_scope.js +1 -1
- package/src/ngtsc/scope/src/dependency.js +10 -8
- package/src/ngtsc/scope/src/local.d.ts +31 -4
- package/src/ngtsc/scope/src/local.js +83 -15
- package/src/ngtsc/shims/index.d.ts +2 -1
- package/src/ngtsc/shims/index.js +4 -5
- package/src/ngtsc/shims/src/api.d.ts +25 -0
- package/src/ngtsc/shims/src/api.js +13 -0
- package/src/ngtsc/shims/src/factory_generator.d.ts +2 -2
- package/src/ngtsc/shims/src/factory_generator.js +1 -1
- package/src/ngtsc/shims/src/factory_tracker.d.ts +24 -0
- package/src/ngtsc/shims/src/factory_tracker.js +47 -0
- package/src/ngtsc/shims/src/summary_generator.d.ts +1 -1
- package/src/ngtsc/shims/src/summary_generator.js +1 -1
- package/src/ngtsc/shims/src/typecheck_shim.d.ts +1 -1
- package/src/ngtsc/shims/src/typecheck_shim.js +1 -1
- package/src/ngtsc/synthetic_files_compiler_host.d.ts +1 -1
- package/src/ngtsc/transform/index.d.ts +3 -1
- package/src/ngtsc/transform/index.js +8 -3
- package/src/ngtsc/transform/src/alias.d.ts +1 -1
- package/src/ngtsc/transform/src/alias.js +1 -1
- package/src/ngtsc/transform/src/api.d.ts +52 -17
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.d.ts +68 -47
- package/src/ngtsc/transform/src/compilation.js +498 -313
- package/src/ngtsc/transform/src/declaration.d.ts +1 -1
- package/src/ngtsc/transform/src/declaration.js +6 -1
- package/src/ngtsc/transform/src/trait.d.ts +169 -0
- package/src/ngtsc/transform/src/trait.js +114 -0
- package/src/ngtsc/transform/src/transform.d.ts +2 -2
- package/src/ngtsc/transform/src/transform.js +4 -4
- package/src/ngtsc/translator/src/translator.d.ts +11 -9
- package/src/ngtsc/translator/src/translator.js +51 -18
- package/src/ngtsc/typecheck/index.d.ts +1 -0
- package/src/ngtsc/typecheck/index.js +4 -2
- package/src/ngtsc/typecheck/src/api.d.ts +12 -1
- package/src/ngtsc/typecheck/src/api.js +1 -1
- package/src/ngtsc/typecheck/src/context.d.ts +3 -2
- package/src/ngtsc/typecheck/src/context.js +10 -8
- package/src/ngtsc/typecheck/src/diagnostics.d.ts +30 -31
- package/src/ngtsc/typecheck/src/diagnostics.js +108 -70
- package/src/ngtsc/typecheck/src/dom.d.ts +6 -5
- package/src/ngtsc/typecheck/src/dom.js +3 -3
- package/src/ngtsc/typecheck/src/environment.d.ts +5 -3
- package/src/ngtsc/typecheck/src/environment.js +20 -8
- package/src/ngtsc/typecheck/src/expression.d.ts +2 -3
- package/src/ngtsc/typecheck/src/expression.js +26 -23
- package/src/ngtsc/typecheck/src/host.d.ts +1 -0
- package/src/ngtsc/typecheck/src/host.js +4 -1
- package/src/ngtsc/typecheck/src/oob.d.ts +11 -11
- package/src/ngtsc/typecheck/src/oob.js +15 -4
- package/src/ngtsc/typecheck/src/source.d.ts +9 -9
- package/src/ngtsc/typecheck/src/source.js +15 -15
- package/src/ngtsc/typecheck/src/template_semantics.d.ts +22 -0
- package/src/ngtsc/typecheck/src/template_semantics.js +51 -0
- package/src/ngtsc/typecheck/src/ts_util.js +36 -1
- package/src/ngtsc/typecheck/src/type_check_block.d.ts +3 -3
- package/src/ngtsc/typecheck/src/type_check_block.js +70 -43
- package/src/ngtsc/typecheck/src/type_check_file.d.ts +2 -2
- package/src/ngtsc/typecheck/src/type_check_file.js +3 -3
- package/src/ngtsc/typecheck/src/type_constructor.d.ts +4 -4
- package/src/ngtsc/typecheck/src/type_constructor.js +15 -10
- package/src/ngtsc/typecheck/src/type_emitter.d.ts +72 -0
- package/src/ngtsc/typecheck/src/type_emitter.js +150 -0
- package/src/ngtsc/typecheck/src/type_parameter_emitter.d.ts +31 -0
- package/src/ngtsc/typecheck/src/type_parameter_emitter.js +96 -0
- package/src/ngtsc/util/src/typescript.d.ts +7 -1
- package/src/ngtsc/util/src/typescript.js +15 -5
- package/src/perform_watch.js +6 -5
- package/src/transformers/api.d.ts +3 -204
- package/src/transformers/api.js +1 -1
- package/src/transformers/compiler_host.js +2 -2
- package/src/transformers/program.js +1 -1
- package/src/typescript_support.js +2 -2
- package/src/version.js +1 -1
- package/src/ngtsc/diagnostics/src/code.js +0 -101
- package/src/ngtsc/resource_loader.js +0 -193
- package/src/ngtsc/shims/src/host.d.ts +0 -46
- package/src/ngtsc/shims/src/host.js +0 -82
- package/src/ngtsc/util/src/resource_recorder.d.ts +0 -18
- package/src/ngtsc/util/src/resource_recorder.js +0 -20
|
@@ -8,10 +8,6 @@
|
|
|
8
8
|
/// <amd-module name="@angular/compiler-cli/src/ngtsc/imports/src/references" />
|
|
9
9
|
import { Expression } from '@angular/compiler';
|
|
10
10
|
import * as ts from 'typescript';
|
|
11
|
-
export declare enum ImportMode {
|
|
12
|
-
UseExistingImport = 0,
|
|
13
|
-
ForceNewImport = 1
|
|
14
|
-
}
|
|
15
11
|
export interface OwningModule {
|
|
16
12
|
specifier: string;
|
|
17
13
|
resolutionContext: string;
|
|
@@ -56,21 +52,21 @@ export declare class Reference<T extends ts.Node = ts.Node> {
|
|
|
56
52
|
* The best guess at which module specifier owns this particular reference, or `null` if there
|
|
57
53
|
* isn't one.
|
|
58
54
|
*/
|
|
59
|
-
|
|
55
|
+
get ownedByModuleGuess(): string | null;
|
|
60
56
|
/**
|
|
61
57
|
* Whether this reference has a potential owning module or not.
|
|
62
58
|
*
|
|
63
59
|
* See `bestGuessOwningModule`.
|
|
64
60
|
*/
|
|
65
|
-
|
|
61
|
+
get hasOwningModuleGuess(): boolean;
|
|
66
62
|
/**
|
|
67
63
|
* A name for the node, if one is available.
|
|
68
64
|
*
|
|
69
65
|
* This is only suited for debugging. Any actual references to this node should be made with
|
|
70
66
|
* `ts.Identifier`s (see `getIdentityIn`).
|
|
71
67
|
*/
|
|
72
|
-
|
|
73
|
-
|
|
68
|
+
get debugName(): string | null;
|
|
69
|
+
get alias(): Expression | null;
|
|
74
70
|
/**
|
|
75
71
|
* Record a `ts.Identifier` by which it's valid to refer to this node, within the context of this
|
|
76
72
|
* `Reference`.
|
|
@@ -81,6 +77,32 @@ export declare class Reference<T extends ts.Node = ts.Node> {
|
|
|
81
77
|
* given `ts.SourceFile`, if any.
|
|
82
78
|
*/
|
|
83
79
|
getIdentityIn(context: ts.SourceFile): ts.Identifier | null;
|
|
80
|
+
/**
|
|
81
|
+
* Get a `ts.Identifier` for this `Reference` that exists within the given expression.
|
|
82
|
+
*
|
|
83
|
+
* This is very useful for producing `ts.Diagnostic`s that reference `Reference`s that were
|
|
84
|
+
* extracted from some larger expression, as it can be used to pinpoint the `ts.Identifier` within
|
|
85
|
+
* the expression from which the `Reference` originated.
|
|
86
|
+
*/
|
|
87
|
+
getIdentityInExpression(expr: ts.Expression): ts.Identifier | null;
|
|
88
|
+
/**
|
|
89
|
+
* Given the 'container' expression from which this `Reference` was extracted, produce a
|
|
90
|
+
* `ts.Expression` to use in a diagnostic which best indicates the position within the container
|
|
91
|
+
* expression that generated the `Reference`.
|
|
92
|
+
*
|
|
93
|
+
* For example, given a `Reference` to the class 'Bar' and the containing expression:
|
|
94
|
+
* `[Foo, Bar, Baz]`, this function would attempt to return the `ts.Identifier` for `Bar` within
|
|
95
|
+
* the array. This could be used to produce a nice diagnostic context:
|
|
96
|
+
*
|
|
97
|
+
* ```text
|
|
98
|
+
* [Foo, Bar, Baz]
|
|
99
|
+
* ~~~
|
|
100
|
+
* ```
|
|
101
|
+
*
|
|
102
|
+
* If no specific node can be found, then the `fallback` expression is used, which defaults to the
|
|
103
|
+
* entire containing expression.
|
|
104
|
+
*/
|
|
105
|
+
getOriginForDiagnostics(container: ts.Expression, fallback?: ts.Expression): ts.Expression;
|
|
84
106
|
cloneWithAlias(alias: Expression): Reference<T>;
|
|
85
107
|
cloneWithNoIdentifiers(): Reference<T>;
|
|
86
108
|
}
|
|
@@ -18,11 +18,6 @@
|
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
19
|
var tslib_1 = require("tslib");
|
|
20
20
|
var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
|
|
21
|
-
var ImportMode;
|
|
22
|
-
(function (ImportMode) {
|
|
23
|
-
ImportMode[ImportMode["UseExistingImport"] = 0] = "UseExistingImport";
|
|
24
|
-
ImportMode[ImportMode["ForceNewImport"] = 1] = "ForceNewImport";
|
|
25
|
-
})(ImportMode = exports.ImportMode || (exports.ImportMode = {}));
|
|
26
21
|
/**
|
|
27
22
|
* A `ts.Node` plus the context in which it was discovered.
|
|
28
23
|
*
|
|
@@ -110,6 +105,46 @@
|
|
|
110
105
|
Reference.prototype.getIdentityIn = function (context) {
|
|
111
106
|
return this.identifiers.find(function (id) { return id.getSourceFile() === context; }) || null;
|
|
112
107
|
};
|
|
108
|
+
/**
|
|
109
|
+
* Get a `ts.Identifier` for this `Reference` that exists within the given expression.
|
|
110
|
+
*
|
|
111
|
+
* This is very useful for producing `ts.Diagnostic`s that reference `Reference`s that were
|
|
112
|
+
* extracted from some larger expression, as it can be used to pinpoint the `ts.Identifier` within
|
|
113
|
+
* the expression from which the `Reference` originated.
|
|
114
|
+
*/
|
|
115
|
+
Reference.prototype.getIdentityInExpression = function (expr) {
|
|
116
|
+
var sf = expr.getSourceFile();
|
|
117
|
+
return this.identifiers.find(function (id) {
|
|
118
|
+
if (id.getSourceFile() !== sf) {
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
// This identifier is a match if its position lies within the given expression.
|
|
122
|
+
return id.pos >= expr.pos && id.end <= expr.end;
|
|
123
|
+
}) ||
|
|
124
|
+
null;
|
|
125
|
+
};
|
|
126
|
+
/**
|
|
127
|
+
* Given the 'container' expression from which this `Reference` was extracted, produce a
|
|
128
|
+
* `ts.Expression` to use in a diagnostic which best indicates the position within the container
|
|
129
|
+
* expression that generated the `Reference`.
|
|
130
|
+
*
|
|
131
|
+
* For example, given a `Reference` to the class 'Bar' and the containing expression:
|
|
132
|
+
* `[Foo, Bar, Baz]`, this function would attempt to return the `ts.Identifier` for `Bar` within
|
|
133
|
+
* the array. This could be used to produce a nice diagnostic context:
|
|
134
|
+
*
|
|
135
|
+
* ```text
|
|
136
|
+
* [Foo, Bar, Baz]
|
|
137
|
+
* ~~~
|
|
138
|
+
* ```
|
|
139
|
+
*
|
|
140
|
+
* If no specific node can be found, then the `fallback` expression is used, which defaults to the
|
|
141
|
+
* entire containing expression.
|
|
142
|
+
*/
|
|
143
|
+
Reference.prototype.getOriginForDiagnostics = function (container, fallback) {
|
|
144
|
+
if (fallback === void 0) { fallback = container; }
|
|
145
|
+
var id = this.getIdentityInExpression(container);
|
|
146
|
+
return id !== null ? id : fallback;
|
|
147
|
+
};
|
|
113
148
|
Reference.prototype.cloneWithAlias = function (alias) {
|
|
114
149
|
var ref = new Reference(this.node, this.bestGuessOwningModule);
|
|
115
150
|
ref.identifiers = tslib_1.__spread(this.identifiers);
|
|
@@ -126,4 +161,4 @@
|
|
|
126
161
|
}());
|
|
127
162
|
exports.Reference = Reference;
|
|
128
163
|
});
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"references.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/references.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAKH,kFAA2D;IAE3D,IAAY,UAGX;IAHD,WAAY,UAAU;QACpB,qEAAiB,CAAA;QACjB,+DAAc,CAAA;IAChB,CAAC,EAHW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAGrB;IAOD;;;;;;;;;;OAUG;IACH;QA2BE,mBAAqB,IAAO,EAAE,qBAA+C;YAA/C,sCAAA,EAAA,4BAA+C;YAAxD,SAAI,GAAJ,IAAI,CAAG;YAZpB,gBAAW,GAAoB,EAAE,CAAC;YAE1C;;;;;eAKG;YACH,cAAS,GAAG,KAAK,CAAC;YAEV,WAAM,GAAoB,IAAI,CAAC;YAGrC,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC;YAEnD,IAAM,EAAE,GAAG,6BAAgB,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,EAAE,KAAK,IAAI,EAAE;gBACf,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;aAC3B;QACH,CAAC;QAMD,sBAAI,yCAAkB;YAJtB;;;eAGG;iBACH;gBACE,IAAI,IAAI,CAAC,qBAAqB,KAAK,IAAI,EAAE;oBACvC,OAAO,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC;iBAC7C;qBAAM;oBACL,OAAO,IAAI,CAAC;iBACb;YACH,CAAC;;;WAAA;QAOD,sBAAI,2CAAoB;YALxB;;;;eAIG;iBACH,cAAsC,OAAO,IAAI,CAAC,qBAAqB,KAAK,IAAI,CAAC,CAAC,CAAC;;;WAAA;QAQnF,sBAAI,gCAAS;YANb;;;;;eAKG;iBACH;gBACE,IAAM,EAAE,GAAG,6BAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACvC,OAAO,EAAE,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;YACtC,CAAC;;;WAAA;QAED,sBAAI,4BAAK;iBAAT,cAA+B,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;;;WAAA;QAGpD;;;WAGG;QACH,iCAAa,GAAb,UAAc,UAAyB,IAAU,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAErF;;;WAGG;QACH,iCAAa,GAAb,UAAc,OAAsB;YAClC,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAA,EAAE,IAAI,OAAA,EAAE,CAAC,aAAa,EAAE,KAAK,OAAO,EAA9B,CAA8B,CAAC,IAAI,IAAI,CAAC;QAC7E,CAAC;QAED,kCAAc,GAAd,UAAe,KAAiB;YAC9B,IAAM,GAAG,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACjE,GAAG,CAAC,WAAW,oBAAO,IAAI,CAAC,WAAW,CAAC,CAAC;YACxC,GAAG,CAAC,MAAM,GAAG,KAAK,CAAC;YACnB,OAAO,GAAG,CAAC;QACb,CAAC;QAED,0CAAsB,GAAtB;YACE,IAAM,GAAG,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACjE,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACzB,GAAG,CAAC,WAAW,GAAG,EAAE,CAAC;YACrB,OAAO,GAAG,CAAC;QACb,CAAC;QACH,gBAAC;IAAD,CAAC,AAhGD,IAgGC;IAhGY,8BAAS","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 {Expression} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {identifierOfNode} from '../../util/src/typescript';\n\nexport enum ImportMode {\n  UseExistingImport,\n  ForceNewImport,\n}\n\nexport interface OwningModule {\n  specifier: string;\n  resolutionContext: string;\n}\n\n/**\n * A `ts.Node` plus the context in which it was discovered.\n *\n * A `Reference` is a pointer to a `ts.Node` that was extracted from the program somehow. It\n * contains not only the node itself, but the information regarding how the node was located. In\n * particular, it might track different identifiers by which the node is exposed, as well as\n * potentially a module specifier which might expose the node.\n *\n * The Angular compiler uses `Reference`s instead of `ts.Node`s when tracking classes or generating\n * imports.\n */\nexport class Reference<T extends ts.Node = ts.Node> {\n  /**\n   * The compiler's best guess at an absolute module specifier which owns this `Reference`.\n   *\n   * This is usually determined by tracking the import statements which led the compiler to a given\n   * node. If any of these imports are absolute, it's an indication that the node being imported\n   * might come from that module.\n   *\n   * It is not _guaranteed_ that the node in question is exported from its `bestGuessOwningModule` -\n   * that is mostly a convention that applies in certain package formats.\n   *\n   * If `bestGuessOwningModule` is `null`, then it's likely the node came from the current program.\n   */\n  readonly bestGuessOwningModule: OwningModule|null;\n\n  private identifiers: ts.Identifier[] = [];\n\n  /**\n   * Indicates that the Reference was created synthetically, not as a result of natural value\n   * resolution.\n   *\n   * This is used to avoid misinterpreting the Reference in certain contexts.\n   */\n  synthetic = false;\n\n  private _alias: Expression|null = null;\n\n  constructor(readonly node: T, bestGuessOwningModule: OwningModule|null = null) {\n    this.bestGuessOwningModule = bestGuessOwningModule;\n\n    const id = identifierOfNode(node);\n    if (id !== null) {\n      this.identifiers.push(id);\n    }\n  }\n\n  /**\n   * The best guess at which module specifier owns this particular reference, or `null` if there\n   * isn't one.\n   */\n  get ownedByModuleGuess(): string|null {\n    if (this.bestGuessOwningModule !== null) {\n      return this.bestGuessOwningModule.specifier;\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Whether this reference has a potential owning module or not.\n   *\n   * See `bestGuessOwningModule`.\n   */\n  get hasOwningModuleGuess(): boolean { return this.bestGuessOwningModule !== null; }\n\n  /**\n   * A name for the node, if one is available.\n   *\n   * This is only suited for debugging. Any actual references to this node should be made with\n   * `ts.Identifier`s (see `getIdentityIn`).\n   */\n  get debugName(): string|null {\n    const id = identifierOfNode(this.node);\n    return id !== null ? id.text : null;\n  }\n\n  get alias(): Expression|null { return this._alias; }\n\n\n  /**\n   * Record a `ts.Identifier` by which it's valid to refer to this node, within the context of this\n   * `Reference`.\n   */\n  addIdentifier(identifier: ts.Identifier): void { this.identifiers.push(identifier); }\n\n  /**\n   * Get a `ts.Identifier` within this `Reference` that can be used to refer within the context of a\n   * given `ts.SourceFile`, if any.\n   */\n  getIdentityIn(context: ts.SourceFile): ts.Identifier|null {\n    return this.identifiers.find(id => id.getSourceFile() === context) || null;\n  }\n\n  cloneWithAlias(alias: Expression): Reference<T> {\n    const ref = new Reference(this.node, this.bestGuessOwningModule);\n    ref.identifiers = [...this.identifiers];\n    ref._alias = alias;\n    return ref;\n  }\n\n  cloneWithNoIdentifiers(): Reference<T> {\n    const ref = new Reference(this.node, this.bestGuessOwningModule);\n    ref._alias = this._alias;\n    ref.identifiers = [];\n    return ref;\n  }\n}\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"references.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/imports/src/references.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 {Expression} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {identifierOfNode} from '../../util/src/typescript';\n\nexport interface OwningModule {\n  specifier: string;\n  resolutionContext: string;\n}\n\n/**\n * A `ts.Node` plus the context in which it was discovered.\n *\n * A `Reference` is a pointer to a `ts.Node` that was extracted from the program somehow. It\n * contains not only the node itself, but the information regarding how the node was located. In\n * particular, it might track different identifiers by which the node is exposed, as well as\n * potentially a module specifier which might expose the node.\n *\n * The Angular compiler uses `Reference`s instead of `ts.Node`s when tracking classes or generating\n * imports.\n */\nexport class Reference<T extends ts.Node = ts.Node> {\n  /**\n   * The compiler's best guess at an absolute module specifier which owns this `Reference`.\n   *\n   * This is usually determined by tracking the import statements which led the compiler to a given\n   * node. If any of these imports are absolute, it's an indication that the node being imported\n   * might come from that module.\n   *\n   * It is not _guaranteed_ that the node in question is exported from its `bestGuessOwningModule` -\n   * that is mostly a convention that applies in certain package formats.\n   *\n   * If `bestGuessOwningModule` is `null`, then it's likely the node came from the current program.\n   */\n  readonly bestGuessOwningModule: OwningModule|null;\n\n  private identifiers: ts.Identifier[] = [];\n\n  /**\n   * Indicates that the Reference was created synthetically, not as a result of natural value\n   * resolution.\n   *\n   * This is used to avoid misinterpreting the Reference in certain contexts.\n   */\n  synthetic = false;\n\n  private _alias: Expression|null = null;\n\n  constructor(readonly node: T, bestGuessOwningModule: OwningModule|null = null) {\n    this.bestGuessOwningModule = bestGuessOwningModule;\n\n    const id = identifierOfNode(node);\n    if (id !== null) {\n      this.identifiers.push(id);\n    }\n  }\n\n  /**\n   * The best guess at which module specifier owns this particular reference, or `null` if there\n   * isn't one.\n   */\n  get ownedByModuleGuess(): string|null {\n    if (this.bestGuessOwningModule !== null) {\n      return this.bestGuessOwningModule.specifier;\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Whether this reference has a potential owning module or not.\n   *\n   * See `bestGuessOwningModule`.\n   */\n  get hasOwningModuleGuess(): boolean { return this.bestGuessOwningModule !== null; }\n\n  /**\n   * A name for the node, if one is available.\n   *\n   * This is only suited for debugging. Any actual references to this node should be made with\n   * `ts.Identifier`s (see `getIdentityIn`).\n   */\n  get debugName(): string|null {\n    const id = identifierOfNode(this.node);\n    return id !== null ? id.text : null;\n  }\n\n  get alias(): Expression|null { return this._alias; }\n\n\n  /**\n   * Record a `ts.Identifier` by which it's valid to refer to this node, within the context of this\n   * `Reference`.\n   */\n  addIdentifier(identifier: ts.Identifier): void { this.identifiers.push(identifier); }\n\n  /**\n   * Get a `ts.Identifier` within this `Reference` that can be used to refer within the context of a\n   * given `ts.SourceFile`, if any.\n   */\n  getIdentityIn(context: ts.SourceFile): ts.Identifier|null {\n    return this.identifiers.find(id => id.getSourceFile() === context) || null;\n  }\n\n  /**\n   * Get a `ts.Identifier` for this `Reference` that exists within the given expression.\n   *\n   * This is very useful for producing `ts.Diagnostic`s that reference `Reference`s that were\n   * extracted from some larger expression, as it can be used to pinpoint the `ts.Identifier` within\n   * the expression from which the `Reference` originated.\n   */\n  getIdentityInExpression(expr: ts.Expression): ts.Identifier|null {\n    const sf = expr.getSourceFile();\n    return this.identifiers.find(id => {\n      if (id.getSourceFile() !== sf) {\n        return false;\n      }\n\n      // This identifier is a match if its position lies within the given expression.\n      return id.pos >= expr.pos && id.end <= expr.end;\n    }) ||\n        null;\n  }\n\n  /**\n   * Given the 'container' expression from which this `Reference` was extracted, produce a\n   * `ts.Expression` to use in a diagnostic which best indicates the position within the container\n   * expression that generated the `Reference`.\n   *\n   * For example, given a `Reference` to the class 'Bar' and the containing expression:\n   * `[Foo, Bar, Baz]`, this function would attempt to return the `ts.Identifier` for `Bar` within\n   * the array. This could be used to produce a nice diagnostic context:\n   *\n   * ```text\n   * [Foo, Bar, Baz]\n   *       ~~~\n   * ```\n   *\n   * If no specific node can be found, then the `fallback` expression is used, which defaults to the\n   * entire containing expression.\n   */\n  getOriginForDiagnostics(container: ts.Expression, fallback: ts.Expression = container):\n      ts.Expression {\n    const id = this.getIdentityInExpression(container);\n    return id !== null ? id : fallback;\n  }\n\n  cloneWithAlias(alias: Expression): Reference<T> {\n    const ref = new Reference(this.node, this.bestGuessOwningModule);\n    ref.identifiers = [...this.identifiers];\n    ref._alias = alias;\n    return ref;\n  }\n\n  cloneWithNoIdentifiers(): Reference<T> {\n    const ref = new Reference(this.node, this.bestGuessOwningModule);\n    ref._alias = this._alias;\n    ref.identifiers = [];\n    return ref;\n  }\n}\n"]}
|
|
@@ -7,10 +7,6 @@
|
|
|
7
7
|
* found in the LICENSE file at https://angular.io/license
|
|
8
8
|
*/
|
|
9
9
|
import * as ts from 'typescript';
|
|
10
|
-
import { Reference } from './references';
|
|
11
|
-
export interface ReferenceResolver {
|
|
12
|
-
resolve(decl: ts.Declaration, importFromHint: string | null, fromFile: string): Reference<ts.Declaration>;
|
|
13
|
-
}
|
|
14
10
|
/**
|
|
15
11
|
* Used by `RouterEntryPointManager` and `NgModuleRouteAnalyzer` (which is in turn is used by
|
|
16
12
|
* `NgModuleDecoratorHandler`) for resolving the module source-files references in lazy-loaded
|
|
@@ -21,6 +17,7 @@ export declare class ModuleResolver {
|
|
|
21
17
|
private program;
|
|
22
18
|
private compilerOptions;
|
|
23
19
|
private host;
|
|
24
|
-
|
|
25
|
-
|
|
20
|
+
private moduleResolutionCache;
|
|
21
|
+
constructor(program: ts.Program, compilerOptions: ts.CompilerOptions, host: ts.CompilerHost, moduleResolutionCache: ts.ModuleResolutionCache | null);
|
|
22
|
+
resolveModule(moduleName: string, containingFile: string): ts.SourceFile | null;
|
|
26
23
|
}
|
|
@@ -18,13 +18,14 @@
|
|
|
18
18
|
* definitions).
|
|
19
19
|
*/
|
|
20
20
|
var ModuleResolver = /** @class */ (function () {
|
|
21
|
-
function ModuleResolver(program, compilerOptions, host) {
|
|
21
|
+
function ModuleResolver(program, compilerOptions, host, moduleResolutionCache) {
|
|
22
22
|
this.program = program;
|
|
23
23
|
this.compilerOptions = compilerOptions;
|
|
24
24
|
this.host = host;
|
|
25
|
+
this.moduleResolutionCache = moduleResolutionCache;
|
|
25
26
|
}
|
|
26
|
-
ModuleResolver.prototype.
|
|
27
|
-
var resolved = typescript_1.resolveModuleName(
|
|
27
|
+
ModuleResolver.prototype.resolveModule = function (moduleName, containingFile) {
|
|
28
|
+
var resolved = typescript_1.resolveModuleName(moduleName, containingFile, this.compilerOptions, this.host, this.moduleResolutionCache);
|
|
28
29
|
if (resolved === undefined) {
|
|
29
30
|
return null;
|
|
30
31
|
}
|
|
@@ -34,4 +35,4 @@
|
|
|
34
35
|
}());
|
|
35
36
|
exports.ModuleResolver = ModuleResolver;
|
|
36
37
|
});
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb2x2ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25ndHNjL2ltcG9ydHMvc3JjL3Jlc29sdmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0lBUUEsMkVBQStDO0lBQy9DLGtGQUFpRjtJQUVqRjs7Ozs7T0FLRztJQUNIO1FBQ0Usd0JBQ1ksT0FBbUIsRUFBVSxlQUFtQyxFQUNoRSxJQUFxQixFQUFVLHFCQUFvRDtZQURuRixZQUFPLEdBQVAsT0FBTyxDQUFZO1lBQVUsb0JBQWUsR0FBZixlQUFlLENBQW9CO1lBQ2hFLFNBQUksR0FBSixJQUFJLENBQWlCO1lBQVUsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUErQjtRQUMvRixDQUFDO1FBRUQsc0NBQWEsR0FBYixVQUFjLFVBQWtCLEVBQUUsY0FBc0I7WUFDdEQsSUFBTSxRQUFRLEdBQUcsOEJBQWlCLENBQzlCLFVBQVUsRUFBRSxjQUFjLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1lBQzdGLElBQUksUUFBUSxLQUFLLFNBQVMsRUFBRTtnQkFDMUIsT0FBTyxJQUFJLENBQUM7YUFDYjtZQUNELE9BQU8sZ0NBQW1CLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSwwQkFBWSxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUM7UUFDcEYsQ0FBQztRQUNILHFCQUFDO0lBQUQsQ0FBQyxBQWRELElBY0M7SUFkWSx3Q0FBYyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbmltcG9ydCAqIGFzIHRzIGZyb20gJ3R5cGVzY3JpcHQnO1xuaW1wb3J0IHthYnNvbHV0ZUZyb219IGZyb20gJy4uLy4uL2ZpbGVfc3lzdGVtJztcbmltcG9ydCB7Z2V0U291cmNlRmlsZU9yTnVsbCwgcmVzb2x2ZU1vZHVsZU5hbWV9IGZyb20gJy4uLy4uL3V0aWwvc3JjL3R5cGVzY3JpcHQnO1xuXG4vKipcbiAqIFVzZWQgYnkgYFJvdXRlckVudHJ5UG9pbnRNYW5hZ2VyYCBhbmQgYE5nTW9kdWxlUm91dGVBbmFseXplcmAgKHdoaWNoIGlzIGluIHR1cm4gaXMgdXNlZCBieVxuICogYE5nTW9kdWxlRGVjb3JhdG9ySGFuZGxlcmApIGZvciByZXNvbHZpbmcgdGhlIG1vZHVsZSBzb3VyY2UtZmlsZXMgcmVmZXJlbmNlcyBpbiBsYXp5LWxvYWRlZFxuICogcm91dGVzIChyZWxhdGl2ZSB0byB0aGUgc291cmNlLWZpbGUgY29udGFpbmluZyB0aGUgYE5nTW9kdWxlYCB0aGF0IHByb3ZpZGVzIHRoZSByb3V0ZVxuICogZGVmaW5pdGlvbnMpLlxuICovXG5leHBvcnQgY2xhc3MgTW9kdWxlUmVzb2x2ZXIge1xuICBjb25zdHJ1Y3RvcihcbiAgICAgIHByaXZhdGUgcHJvZ3JhbTogdHMuUHJvZ3JhbSwgcHJpdmF0ZSBjb21waWxlck9wdGlvbnM6IHRzLkNvbXBpbGVyT3B0aW9ucyxcbiAgICAgIHByaXZhdGUgaG9zdDogdHMuQ29tcGlsZXJIb3N0LCBwcml2YXRlIG1vZHVsZVJlc29sdXRpb25DYWNoZTogdHMuTW9kdWxlUmVzb2x1dGlvbkNhY2hlfG51bGwpIHtcbiAgfVxuXG4gIHJlc29sdmVNb2R1bGUobW9kdWxlTmFtZTogc3RyaW5nLCBjb250YWluaW5nRmlsZTogc3RyaW5nKTogdHMuU291cmNlRmlsZXxudWxsIHtcbiAgICBjb25zdCByZXNvbHZlZCA9IHJlc29sdmVNb2R1bGVOYW1lKFxuICAgICAgICBtb2R1bGVOYW1lLCBjb250YWluaW5nRmlsZSwgdGhpcy5jb21waWxlck9wdGlvbnMsIHRoaXMuaG9zdCwgdGhpcy5tb2R1bGVSZXNvbHV0aW9uQ2FjaGUpO1xuICAgIGlmIChyZXNvbHZlZCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gICAgcmV0dXJuIGdldFNvdXJjZUZpbGVPck51bGwodGhpcy5wcm9ncmFtLCBhYnNvbHV0ZUZyb20ocmVzb2x2ZWQucmVzb2x2ZWRGaWxlTmFtZSkpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,51 @@
|
|
|
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/src/ngtsc/incremental/api" />
|
|
9
|
+
import * as ts from 'typescript';
|
|
10
|
+
import { AbsoluteFsPath } from '../file_system';
|
|
11
|
+
/**
|
|
12
|
+
* Interface of the incremental build engine.
|
|
13
|
+
*
|
|
14
|
+
* `W` is a generic type representing a unit of work. This is generic to avoid a cyclic dependency
|
|
15
|
+
* between the incremental engine API definition and its consumer(s).
|
|
16
|
+
*/
|
|
17
|
+
export interface IncrementalBuild<W> {
|
|
18
|
+
/**
|
|
19
|
+
* Retrieve the prior analysis work, if any, done for the given source file.
|
|
20
|
+
*/
|
|
21
|
+
priorWorkFor(sf: ts.SourceFile): W[] | null;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Tracks dependencies between source files or resources in the application.
|
|
25
|
+
*/
|
|
26
|
+
export interface DependencyTracker<T extends {
|
|
27
|
+
fileName: string;
|
|
28
|
+
} = ts.SourceFile> {
|
|
29
|
+
/**
|
|
30
|
+
* Record that the file `from` depends on the file `on`.
|
|
31
|
+
*/
|
|
32
|
+
addDependency(from: T, on: T): void;
|
|
33
|
+
/**
|
|
34
|
+
* Record that the file `from` depends on the resource file `on`.
|
|
35
|
+
*/
|
|
36
|
+
addResourceDependency(from: T, on: AbsoluteFsPath): void;
|
|
37
|
+
/**
|
|
38
|
+
* Record that the file `from` depends on the file `on` as well as `on`'s direct dependencies.
|
|
39
|
+
*
|
|
40
|
+
* This operation is reified immediately, so if future dependencies are added to `on` they will
|
|
41
|
+
* not automatically be added to `from`.
|
|
42
|
+
*/
|
|
43
|
+
addTransitiveDependency(from: T, on: T): void;
|
|
44
|
+
/**
|
|
45
|
+
* Record that the file `from` depends on the resource dependencies of `resourcesOf`.
|
|
46
|
+
*
|
|
47
|
+
* This operation is reified immediately, so if future resource dependencies are added to
|
|
48
|
+
* `resourcesOf` they will not automatically be added to `from`.
|
|
49
|
+
*/
|
|
50
|
+
addTransitiveResources(from: T, resourcesOf: T): void;
|
|
51
|
+
}
|
|
@@ -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/src/ngtsc/incremental/api", ["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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9pbmNyZW1lbnRhbC9hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQgKiBhcyB0cyBmcm9tICd0eXBlc2NyaXB0JztcbmltcG9ydCB7QWJzb2x1dGVGc1BhdGh9IGZyb20gJy4uL2ZpbGVfc3lzdGVtJztcblxuLyoqXG4gKiBJbnRlcmZhY2Ugb2YgdGhlIGluY3JlbWVudGFsIGJ1aWxkIGVuZ2luZS5cbiAqXG4gKiBgV2AgaXMgYSBnZW5lcmljIHR5cGUgcmVwcmVzZW50aW5nIGEgdW5pdCBvZiB3b3JrLiBUaGlzIGlzIGdlbmVyaWMgdG8gYXZvaWQgYSBjeWNsaWMgZGVwZW5kZW5jeVxuICogYmV0d2VlbiB0aGUgaW5jcmVtZW50YWwgZW5naW5lIEFQSSBkZWZpbml0aW9uIGFuZCBpdHMgY29uc3VtZXIocykuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSW5jcmVtZW50YWxCdWlsZDxXPiB7XG4gIC8qKlxuICAgKiBSZXRyaWV2ZSB0aGUgcHJpb3IgYW5hbHlzaXMgd29yaywgaWYgYW55LCBkb25lIGZvciB0aGUgZ2l2ZW4gc291cmNlIGZpbGUuXG4gICAqL1xuICBwcmlvcldvcmtGb3Ioc2Y6IHRzLlNvdXJjZUZpbGUpOiBXW118bnVsbDtcbn1cblxuLyoqXG4gKiBUcmFja3MgZGVwZW5kZW5jaWVzIGJldHdlZW4gc291cmNlIGZpbGVzIG9yIHJlc291cmNlcyBpbiB0aGUgYXBwbGljYXRpb24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGVwZW5kZW5jeVRyYWNrZXI8VCBleHRlbmRze2ZpbGVOYW1lOiBzdHJpbmd9ID0gdHMuU291cmNlRmlsZT4ge1xuICAvKipcbiAgICogUmVjb3JkIHRoYXQgdGhlIGZpbGUgYGZyb21gIGRlcGVuZHMgb24gdGhlIGZpbGUgYG9uYC5cbiAgICovXG4gIGFkZERlcGVuZGVuY3koZnJvbTogVCwgb246IFQpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBSZWNvcmQgdGhhdCB0aGUgZmlsZSBgZnJvbWAgZGVwZW5kcyBvbiB0aGUgcmVzb3VyY2UgZmlsZSBgb25gLlxuICAgKi9cbiAgYWRkUmVzb3VyY2VEZXBlbmRlbmN5KGZyb206IFQsIG9uOiBBYnNvbHV0ZUZzUGF0aCk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIFJlY29yZCB0aGF0IHRoZSBmaWxlIGBmcm9tYCBkZXBlbmRzIG9uIHRoZSBmaWxlIGBvbmAgYXMgd2VsbCBhcyBgb25gJ3MgZGlyZWN0IGRlcGVuZGVuY2llcy5cbiAgICpcbiAgICogVGhpcyBvcGVyYXRpb24gaXMgcmVpZmllZCBpbW1lZGlhdGVseSwgc28gaWYgZnV0dXJlIGRlcGVuZGVuY2llcyBhcmUgYWRkZWQgdG8gYG9uYCB0aGV5IHdpbGxcbiAgICogbm90IGF1dG9tYXRpY2FsbHkgYmUgYWRkZWQgdG8gYGZyb21gLlxuICAgKi9cbiAgYWRkVHJhbnNpdGl2ZURlcGVuZGVuY3koZnJvbTogVCwgb246IFQpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBSZWNvcmQgdGhhdCB0aGUgZmlsZSBgZnJvbWAgZGVwZW5kcyBvbiB0aGUgcmVzb3VyY2UgZGVwZW5kZW5jaWVzIG9mIGByZXNvdXJjZXNPZmAuXG4gICAqXG4gICAqIFRoaXMgb3BlcmF0aW9uIGlzIHJlaWZpZWQgaW1tZWRpYXRlbHksIHNvIGlmIGZ1dHVyZSByZXNvdXJjZSBkZXBlbmRlbmNpZXMgYXJlIGFkZGVkIHRvXG4gICAqIGByZXNvdXJjZXNPZmAgdGhleSB3aWxsIG5vdCBhdXRvbWF0aWNhbGx5IGJlIGFkZGVkIHRvIGBmcm9tYC5cbiAgICovXG4gIGFkZFRyYW5zaXRpdmVSZXNvdXJjZXMoZnJvbTogVCwgcmVzb3VyY2VzT2Y6IFQpOiB2b2lkO1xufVxuIl19
|
|
@@ -11,12 +11,14 @@
|
|
|
11
11
|
if (v !== undefined) module.exports = v;
|
|
12
12
|
}
|
|
13
13
|
else if (typeof define === "function" && define.amd) {
|
|
14
|
-
define("@angular/compiler-cli/src/ngtsc/incremental", ["require", "exports", "@angular/compiler-cli/src/ngtsc/incremental/src/state"], factory);
|
|
14
|
+
define("@angular/compiler-cli/src/ngtsc/incremental", ["require", "exports", "@angular/compiler-cli/src/ngtsc/incremental/src/noop", "@angular/compiler-cli/src/ngtsc/incremental/src/state"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
+
var noop_1 = require("@angular/compiler-cli/src/ngtsc/incremental/src/noop");
|
|
20
|
+
exports.NOOP_INCREMENTAL_BUILD = noop_1.NOOP_INCREMENTAL_BUILD;
|
|
19
21
|
var state_1 = require("@angular/compiler-cli/src/ngtsc/incremental/src/state");
|
|
20
22
|
exports.IncrementalDriver = state_1.IncrementalDriver;
|
|
21
23
|
});
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvc3JjL25ndHNjL2luY3JlbWVudGFsL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRzs7Ozs7Ozs7Ozs7O0lBRUgsNkVBQWtEO0lBQTFDLHdDQUFBLHNCQUFzQixDQUFBO0lBQzlCLCtFQUE4QztJQUF0QyxvQ0FBQSxpQkFBaUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IHtOT09QX0lOQ1JFTUVOVEFMX0JVSUxEfSBmcm9tICcuL3NyYy9ub29wJztcbmV4cG9ydCB7SW5jcmVtZW50YWxEcml2ZXJ9IGZyb20gJy4vc3JjL3N0YXRlJztcbiJdfQ==
|
|
@@ -0,0 +1,56 @@
|
|
|
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/src/ngtsc/incremental/src/dependency_tracking" />
|
|
9
|
+
import * as ts from 'typescript';
|
|
10
|
+
import { AbsoluteFsPath } from '../../file_system';
|
|
11
|
+
import { DependencyTracker } from '../api';
|
|
12
|
+
/**
|
|
13
|
+
* An implementation of the `DependencyTracker` dependency graph API.
|
|
14
|
+
*
|
|
15
|
+
* The `FileDependencyGraph`'s primary job is to determine whether a given file has "logically"
|
|
16
|
+
* changed, given the set of physical changes (direct changes to files on disk).
|
|
17
|
+
*
|
|
18
|
+
* A file is logically changed if at least one of three conditions is met:
|
|
19
|
+
*
|
|
20
|
+
* 1. The file itself has physically changed.
|
|
21
|
+
* 2. One of its dependencies has physically changed.
|
|
22
|
+
* 3. One of its resource dependencies has physically changed.
|
|
23
|
+
*/
|
|
24
|
+
export declare class FileDependencyGraph<T extends {
|
|
25
|
+
fileName: string;
|
|
26
|
+
} = ts.SourceFile> implements DependencyTracker<T> {
|
|
27
|
+
private nodes;
|
|
28
|
+
addDependency(from: T, on: T): void;
|
|
29
|
+
addResourceDependency(from: T, resource: AbsoluteFsPath): void;
|
|
30
|
+
addTransitiveDependency(from: T, on: T): void;
|
|
31
|
+
addTransitiveResources(from: T, resourcesOf: T): void;
|
|
32
|
+
isStale(sf: T, changedTsPaths: Set<string>, changedResources: Set<AbsoluteFsPath>): boolean;
|
|
33
|
+
/**
|
|
34
|
+
* Update the current dependency graph from a previous one, incorporating a set of physical
|
|
35
|
+
* changes.
|
|
36
|
+
*
|
|
37
|
+
* This method performs two tasks:
|
|
38
|
+
*
|
|
39
|
+
* 1. For files which have not logically changed, their dependencies from `previous` are added to
|
|
40
|
+
* `this` graph.
|
|
41
|
+
* 2. For files which have logically changed, they're added to a set of logically changed files
|
|
42
|
+
* which is eventually returned.
|
|
43
|
+
*
|
|
44
|
+
* In essence, for build `n`, this method performs:
|
|
45
|
+
*
|
|
46
|
+
* G(n) + L(n) = G(n - 1) + P(n)
|
|
47
|
+
*
|
|
48
|
+
* where:
|
|
49
|
+
*
|
|
50
|
+
* G(n) = the dependency graph of build `n`
|
|
51
|
+
* L(n) = the logically changed files from build n - 1 to build n.
|
|
52
|
+
* P(n) = the physically changed files from build n - 1 to build n.
|
|
53
|
+
*/
|
|
54
|
+
updateWithPhysicalChanges(previous: FileDependencyGraph<T>, changedTsPaths: Set<string>, deletedTsPaths: Set<string>, changedResources: Set<AbsoluteFsPath>): Set<string>;
|
|
55
|
+
private nodeFor;
|
|
56
|
+
}
|
|
@@ -0,0 +1,186 @@
|
|
|
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/src/ngtsc/incremental/src/dependency_tracking", ["require", "exports", "tslib"], factory);
|
|
15
|
+
}
|
|
16
|
+
})(function (require, exports) {
|
|
17
|
+
"use strict";
|
|
18
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
+
var tslib_1 = require("tslib");
|
|
20
|
+
/**
|
|
21
|
+
* An implementation of the `DependencyTracker` dependency graph API.
|
|
22
|
+
*
|
|
23
|
+
* The `FileDependencyGraph`'s primary job is to determine whether a given file has "logically"
|
|
24
|
+
* changed, given the set of physical changes (direct changes to files on disk).
|
|
25
|
+
*
|
|
26
|
+
* A file is logically changed if at least one of three conditions is met:
|
|
27
|
+
*
|
|
28
|
+
* 1. The file itself has physically changed.
|
|
29
|
+
* 2. One of its dependencies has physically changed.
|
|
30
|
+
* 3. One of its resource dependencies has physically changed.
|
|
31
|
+
*/
|
|
32
|
+
var FileDependencyGraph = /** @class */ (function () {
|
|
33
|
+
function FileDependencyGraph() {
|
|
34
|
+
this.nodes = new Map();
|
|
35
|
+
}
|
|
36
|
+
FileDependencyGraph.prototype.addDependency = function (from, on) { this.nodeFor(from).dependsOn.add(on.fileName); };
|
|
37
|
+
FileDependencyGraph.prototype.addResourceDependency = function (from, resource) {
|
|
38
|
+
this.nodeFor(from).usesResources.add(resource);
|
|
39
|
+
};
|
|
40
|
+
FileDependencyGraph.prototype.addTransitiveDependency = function (from, on) {
|
|
41
|
+
var e_1, _a;
|
|
42
|
+
var nodeFrom = this.nodeFor(from);
|
|
43
|
+
nodeFrom.dependsOn.add(on.fileName);
|
|
44
|
+
var nodeOn = this.nodeFor(on);
|
|
45
|
+
try {
|
|
46
|
+
for (var _b = tslib_1.__values(nodeOn.dependsOn), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
47
|
+
var dep = _c.value;
|
|
48
|
+
nodeFrom.dependsOn.add(dep);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
52
|
+
finally {
|
|
53
|
+
try {
|
|
54
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
55
|
+
}
|
|
56
|
+
finally { if (e_1) throw e_1.error; }
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
FileDependencyGraph.prototype.addTransitiveResources = function (from, resourcesOf) {
|
|
60
|
+
var e_2, _a;
|
|
61
|
+
var nodeFrom = this.nodeFor(from);
|
|
62
|
+
var nodeOn = this.nodeFor(resourcesOf);
|
|
63
|
+
try {
|
|
64
|
+
for (var _b = tslib_1.__values(nodeOn.usesResources), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
65
|
+
var dep = _c.value;
|
|
66
|
+
nodeFrom.usesResources.add(dep);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
70
|
+
finally {
|
|
71
|
+
try {
|
|
72
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
73
|
+
}
|
|
74
|
+
finally { if (e_2) throw e_2.error; }
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
FileDependencyGraph.prototype.isStale = function (sf, changedTsPaths, changedResources) {
|
|
78
|
+
return isLogicallyChanged(sf, this.nodeFor(sf), changedTsPaths, EMPTY_SET, changedResources);
|
|
79
|
+
};
|
|
80
|
+
/**
|
|
81
|
+
* Update the current dependency graph from a previous one, incorporating a set of physical
|
|
82
|
+
* changes.
|
|
83
|
+
*
|
|
84
|
+
* This method performs two tasks:
|
|
85
|
+
*
|
|
86
|
+
* 1. For files which have not logically changed, their dependencies from `previous` are added to
|
|
87
|
+
* `this` graph.
|
|
88
|
+
* 2. For files which have logically changed, they're added to a set of logically changed files
|
|
89
|
+
* which is eventually returned.
|
|
90
|
+
*
|
|
91
|
+
* In essence, for build `n`, this method performs:
|
|
92
|
+
*
|
|
93
|
+
* G(n) + L(n) = G(n - 1) + P(n)
|
|
94
|
+
*
|
|
95
|
+
* where:
|
|
96
|
+
*
|
|
97
|
+
* G(n) = the dependency graph of build `n`
|
|
98
|
+
* L(n) = the logically changed files from build n - 1 to build n.
|
|
99
|
+
* P(n) = the physically changed files from build n - 1 to build n.
|
|
100
|
+
*/
|
|
101
|
+
FileDependencyGraph.prototype.updateWithPhysicalChanges = function (previous, changedTsPaths, deletedTsPaths, changedResources) {
|
|
102
|
+
var e_3, _a;
|
|
103
|
+
var logicallyChanged = new Set();
|
|
104
|
+
try {
|
|
105
|
+
for (var _b = tslib_1.__values(previous.nodes.keys()), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
106
|
+
var sf = _c.value;
|
|
107
|
+
var node = previous.nodeFor(sf);
|
|
108
|
+
if (isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources)) {
|
|
109
|
+
logicallyChanged.add(sf.fileName);
|
|
110
|
+
}
|
|
111
|
+
else if (!deletedTsPaths.has(sf.fileName)) {
|
|
112
|
+
this.nodes.set(sf, {
|
|
113
|
+
dependsOn: new Set(node.dependsOn),
|
|
114
|
+
usesResources: new Set(node.usesResources),
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
|
120
|
+
finally {
|
|
121
|
+
try {
|
|
122
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
123
|
+
}
|
|
124
|
+
finally { if (e_3) throw e_3.error; }
|
|
125
|
+
}
|
|
126
|
+
return logicallyChanged;
|
|
127
|
+
};
|
|
128
|
+
FileDependencyGraph.prototype.nodeFor = function (sf) {
|
|
129
|
+
if (!this.nodes.has(sf)) {
|
|
130
|
+
this.nodes.set(sf, {
|
|
131
|
+
dependsOn: new Set(),
|
|
132
|
+
usesResources: new Set(),
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
return this.nodes.get(sf);
|
|
136
|
+
};
|
|
137
|
+
return FileDependencyGraph;
|
|
138
|
+
}());
|
|
139
|
+
exports.FileDependencyGraph = FileDependencyGraph;
|
|
140
|
+
/**
|
|
141
|
+
* Determine whether `sf` has logically changed, given its dependencies and the set of physically
|
|
142
|
+
* changed files and resources.
|
|
143
|
+
*/
|
|
144
|
+
function isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources) {
|
|
145
|
+
var e_4, _a, e_5, _b;
|
|
146
|
+
// A file is logically changed if it has physically changed itself (including being deleted).
|
|
147
|
+
if (changedTsPaths.has(sf.fileName) || deletedTsPaths.has(sf.fileName)) {
|
|
148
|
+
return true;
|
|
149
|
+
}
|
|
150
|
+
try {
|
|
151
|
+
// A file is logically changed if one of its dependencies has physically changed.
|
|
152
|
+
for (var _c = tslib_1.__values(node.dependsOn), _d = _c.next(); !_d.done; _d = _c.next()) {
|
|
153
|
+
var dep = _d.value;
|
|
154
|
+
if (changedTsPaths.has(dep) || deletedTsPaths.has(dep)) {
|
|
155
|
+
return true;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
|
160
|
+
finally {
|
|
161
|
+
try {
|
|
162
|
+
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
|
|
163
|
+
}
|
|
164
|
+
finally { if (e_4) throw e_4.error; }
|
|
165
|
+
}
|
|
166
|
+
try {
|
|
167
|
+
// A file is logically changed if one of its resources has physically changed.
|
|
168
|
+
for (var _e = tslib_1.__values(node.usesResources), _f = _e.next(); !_f.done; _f = _e.next()) {
|
|
169
|
+
var dep = _f.value;
|
|
170
|
+
if (changedResources.has(dep)) {
|
|
171
|
+
return true;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
catch (e_5_1) { e_5 = { error: e_5_1 }; }
|
|
176
|
+
finally {
|
|
177
|
+
try {
|
|
178
|
+
if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
|
|
179
|
+
}
|
|
180
|
+
finally { if (e_5) throw e_5.error; }
|
|
181
|
+
}
|
|
182
|
+
return false;
|
|
183
|
+
}
|
|
184
|
+
var EMPTY_SET = new Set();
|
|
185
|
+
});
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_tracking.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/dependency_tracking.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 * as ts from 'typescript';\n\nimport {AbsoluteFsPath} from '../../file_system';\nimport {DependencyTracker} from '../api';\n\n/**\n * An implementation of the `DependencyTracker` dependency graph API.\n *\n * The `FileDependencyGraph`'s primary job is to determine whether a given file has \"logically\"\n * changed, given the set of physical changes (direct changes to files on disk).\n *\n * A file is logically changed if at least one of three conditions is met:\n *\n * 1. The file itself has physically changed.\n * 2. One of its dependencies has physically changed.\n * 3. One of its resource dependencies has physically changed.\n */\nexport class FileDependencyGraph<T extends{fileName: string} = ts.SourceFile> implements\n    DependencyTracker<T> {\n  private nodes = new Map<T, FileNode>();\n\n  addDependency(from: T, on: T): void { this.nodeFor(from).dependsOn.add(on.fileName); }\n\n  addResourceDependency(from: T, resource: AbsoluteFsPath): void {\n    this.nodeFor(from).usesResources.add(resource);\n  }\n\n  addTransitiveDependency(from: T, on: T): void {\n    const nodeFrom = this.nodeFor(from);\n    nodeFrom.dependsOn.add(on.fileName);\n\n    const nodeOn = this.nodeFor(on);\n    for (const dep of nodeOn.dependsOn) {\n      nodeFrom.dependsOn.add(dep);\n    }\n  }\n\n  addTransitiveResources(from: T, resourcesOf: T): void {\n    const nodeFrom = this.nodeFor(from);\n    const nodeOn = this.nodeFor(resourcesOf);\n    for (const dep of nodeOn.usesResources) {\n      nodeFrom.usesResources.add(dep);\n    }\n  }\n\n  isStale(sf: T, changedTsPaths: Set<string>, changedResources: Set<AbsoluteFsPath>): boolean {\n    return isLogicallyChanged(sf, this.nodeFor(sf), changedTsPaths, EMPTY_SET, changedResources);\n  }\n\n  /**\n   * Update the current dependency graph from a previous one, incorporating a set of physical\n   * changes.\n   *\n   * This method performs two tasks:\n   *\n   * 1. For files which have not logically changed, their dependencies from `previous` are added to\n   *    `this` graph.\n   * 2. For files which have logically changed, they're added to a set of logically changed files\n   *    which is eventually returned.\n   *\n   * In essence, for build `n`, this method performs:\n   *\n   * G(n) + L(n) = G(n - 1) + P(n)\n   *\n   * where:\n   *\n   * G(n) = the dependency graph of build `n`\n   * L(n) = the logically changed files from build n - 1 to build n.\n   * P(n) = the physically changed files from build n - 1 to build n.\n   */\n  updateWithPhysicalChanges(\n      previous: FileDependencyGraph<T>, changedTsPaths: Set<string>, deletedTsPaths: Set<string>,\n      changedResources: Set<AbsoluteFsPath>): Set<string> {\n    const logicallyChanged = new Set<string>();\n\n    for (const sf of previous.nodes.keys()) {\n      const node = previous.nodeFor(sf);\n      if (isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources)) {\n        logicallyChanged.add(sf.fileName);\n      } else if (!deletedTsPaths.has(sf.fileName)) {\n        this.nodes.set(sf, {\n          dependsOn: new Set(node.dependsOn),\n          usesResources: new Set(node.usesResources),\n        });\n      }\n    }\n\n    return logicallyChanged;\n  }\n\n  private nodeFor(sf: T): FileNode {\n    if (!this.nodes.has(sf)) {\n      this.nodes.set(sf, {\n        dependsOn: new Set<string>(),\n        usesResources: new Set<AbsoluteFsPath>(),\n      });\n    }\n    return this.nodes.get(sf) !;\n  }\n}\n\n/**\n * Determine whether `sf` has logically changed, given its dependencies and the set of physically\n * changed files and resources.\n */\nfunction isLogicallyChanged<T extends{fileName: string}>(\n    sf: T, node: FileNode, changedTsPaths: ReadonlySet<string>, deletedTsPaths: ReadonlySet<string>,\n    changedResources: ReadonlySet<AbsoluteFsPath>): boolean {\n  // A file is logically changed if it has physically changed itself (including being deleted).\n  if (changedTsPaths.has(sf.fileName) || deletedTsPaths.has(sf.fileName)) {\n    return true;\n  }\n\n  // A file is logically changed if one of its dependencies has physically changed.\n  for (const dep of node.dependsOn) {\n    if (changedTsPaths.has(dep) || deletedTsPaths.has(dep)) {\n      return true;\n    }\n  }\n\n  // A file is logically changed if one of its resources has physically changed.\n  for (const dep of node.usesResources) {\n    if (changedResources.has(dep)) {\n      return true;\n    }\n  }\n  return false;\n}\n\ninterface FileNode {\n  dependsOn: Set<string>;\n  usesResources: Set<AbsoluteFsPath>;\n}\n\nconst EMPTY_SET: ReadonlySet<any> = new Set<any>();\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
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/src/ngtsc/incremental/src/noop" />
|
|
9
|
+
import { IncrementalBuild } from '../api';
|
|
10
|
+
export declare const NOOP_INCREMENTAL_BUILD: IncrementalBuild<any>;
|
|
@@ -0,0 +1,23 @@
|
|
|
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/src/ngtsc/incremental/src/noop", ["require", "exports"], factory);
|
|
15
|
+
}
|
|
16
|
+
})(function (require, exports) {
|
|
17
|
+
"use strict";
|
|
18
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
+
exports.NOOP_INCREMENTAL_BUILD = {
|
|
20
|
+
priorWorkFor: function () { return null; }
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9vcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9zcmMvbmd0c2MvaW5jcmVtZW50YWwvc3JjL25vb3AudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFJVSxRQUFBLHNCQUFzQixHQUEwQjtRQUMzRCxZQUFZLEVBQUUsY0FBTSxPQUFBLElBQUksRUFBSixDQUFJO0tBQ3pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7SW5jcmVtZW50YWxCdWlsZH0gZnJvbSAnLi4vYXBpJztcblxuZXhwb3J0IGNvbnN0IE5PT1BfSU5DUkVNRU5UQUxfQlVJTEQ6IEluY3JlbWVudGFsQnVpbGQ8YW55PiA9IHtcbiAgcHJpb3JXb3JrRm9yOiAoKSA9PiBudWxsXG59O1xuIl19
|