@angular/compiler-cli 8.1.0-next.3 → 8.1.2
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/index.d.ts +0 -7
- package/index.js +4 -2
- package/ngcc/index.js +5 -2
- package/ngcc/main-ngcc.js +5 -4
- package/ngcc/src/analysis/decoration_analyzer.d.ts +7 -5
- package/ngcc/src/analysis/decoration_analyzer.js +17 -13
- package/ngcc/src/analysis/private_declarations_analyzer.d.ts +1 -1
- package/ngcc/src/analysis/private_declarations_analyzer.js +5 -5
- package/ngcc/src/analysis/switch_marker_analyzer.d.ts +3 -1
- package/ngcc/src/analysis/switch_marker_analyzer.js +8 -4
- package/ngcc/src/analysis/util.d.ts +11 -0
- package/ngcc/src/analysis/util.js +18 -0
- package/ngcc/src/dependencies/commonjs_dependency_host.d.ts +1 -2
- package/ngcc/src/dependencies/commonjs_dependency_host.js +1 -1
- package/ngcc/src/dependencies/dependency_host.d.ts +1 -1
- package/ngcc/src/dependencies/dependency_host.js +1 -1
- package/ngcc/src/dependencies/dependency_resolver.d.ts +1 -1
- package/ngcc/src/dependencies/dependency_resolver.js +12 -10
- package/ngcc/src/dependencies/esm_dependency_host.d.ts +1 -2
- package/ngcc/src/dependencies/esm_dependency_host.js +1 -1
- package/ngcc/src/dependencies/module_resolver.d.ts +1 -2
- package/ngcc/src/dependencies/module_resolver.js +15 -17
- package/ngcc/src/dependencies/umd_dependency_host.d.ts +1 -2
- package/ngcc/src/dependencies/umd_dependency_host.js +1 -1
- package/ngcc/src/host/commonjs_host.d.ts +26 -1
- package/ngcc/src/host/commonjs_host.js +52 -8
- package/ngcc/src/host/esm2015_host.d.ts +20 -7
- package/ngcc/src/host/esm2015_host.js +28 -10
- package/ngcc/src/host/esm5_host.js +7 -2
- package/ngcc/src/host/umd_host.js +5 -4
- package/ngcc/src/main.d.ts +12 -0
- package/ngcc/src/main.js +83 -67
- package/ngcc/src/packages/build_marker.d.ts +3 -4
- package/ngcc/src/packages/build_marker.js +14 -10
- package/ngcc/src/packages/bundle_program.d.ts +1 -2
- package/ngcc/src/packages/bundle_program.js +10 -7
- package/ngcc/src/packages/configuration.d.ts +51 -0
- package/ngcc/src/packages/configuration.js +97 -0
- package/ngcc/src/packages/entry_point.d.ts +4 -5
- package/ngcc/src/packages/entry_point.js +75 -17
- package/ngcc/src/packages/entry_point_bundle.d.ts +4 -4
- package/ngcc/src/packages/entry_point_bundle.js +12 -11
- package/ngcc/src/packages/entry_point_finder.d.ts +4 -3
- package/ngcc/src/packages/entry_point_finder.js +32 -24
- package/ngcc/src/packages/ngcc_compiler_host.d.ts +10 -18
- package/ngcc/src/packages/ngcc_compiler_host.js +4 -52
- package/ngcc/src/packages/transformer.d.ts +4 -4
- package/ngcc/src/packages/transformer.js +20 -22
- package/ngcc/src/rendering/dts_renderer.d.ts +3 -4
- package/ngcc/src/rendering/dts_renderer.js +3 -4
- package/ngcc/src/rendering/esm_rendering_formatter.d.ts +1 -1
- package/ngcc/src/rendering/esm_rendering_formatter.js +7 -7
- package/ngcc/src/rendering/renderer.d.ts +2 -5
- package/ngcc/src/rendering/renderer.js +3 -5
- package/ngcc/src/rendering/source_maps.d.ts +1 -1
- package/ngcc/src/rendering/source_maps.js +10 -10
- package/ngcc/src/rendering/utils.d.ts +1 -1
- package/ngcc/src/rendering/utils.js +1 -1
- package/ngcc/src/writing/file_writer.js +1 -1
- package/ngcc/src/writing/in_place_file_writer.d.ts +8 -1
- package/ngcc/src/writing/in_place_file_writer.js +5 -5
- package/ngcc/src/writing/new_entry_point_file_writer.d.ts +1 -1
- package/ngcc/src/writing/new_entry_point_file_writer.js +15 -16
- package/package.json +2 -3
- package/src/diagnostics/typescript_symbols.js +5 -5
- package/src/extract_i18n.js +6 -3
- package/src/main.d.ts +1 -1
- package/src/main.js +7 -4
- package/src/metadata/collector.js +7 -4
- package/src/metadata/evaluator.js +3 -3
- package/src/ngtools_api2.js +1 -1
- package/src/ngtsc/annotations/src/component.d.ts +17 -2
- package/src/ngtsc/annotations/src/component.js +94 -39
- package/src/ngtsc/annotations/src/directive.js +6 -5
- package/src/ngtsc/annotations/src/ng_module.js +4 -4
- package/src/ngtsc/annotations/src/references_registry.js +1 -1
- package/src/ngtsc/annotations/src/util.js +4 -2
- package/src/ngtsc/diagnostics/src/code.d.ts +1 -1
- package/src/ngtsc/diagnostics/src/code.js +2 -2
- package/src/ngtsc/entry_point/src/generator.d.ts +3 -2
- package/src/ngtsc/entry_point/src/generator.js +5 -6
- package/src/ngtsc/entry_point/src/logic.d.ts +2 -2
- package/src/ngtsc/entry_point/src/logic.js +4 -3
- package/src/ngtsc/file_system/index.d.ts +14 -0
- package/src/ngtsc/file_system/index.js +41 -0
- package/src/ngtsc/file_system/src/compiler_host.d.ts +25 -0
- package/src/ngtsc/file_system/src/compiler_host.js +73 -0
- package/src/ngtsc/file_system/src/helpers.d.ts +46 -0
- package/src/ngtsc/file_system/src/helpers.js +101 -0
- package/src/ngtsc/file_system/src/invalid_file_system.d.ts +43 -0
- package/src/ngtsc/file_system/src/invalid_file_system.js +66 -0
- package/src/ngtsc/{path → file_system}/src/logical.d.ts +2 -2
- package/src/ngtsc/file_system/src/logical.js +98 -0
- package/src/ngtsc/file_system/src/node_js_file_system.d.ts +32 -0
- package/src/ngtsc/file_system/src/node_js_file_system.js +102 -0
- package/src/ngtsc/file_system/src/types.d.ts +69 -0
- package/src/ngtsc/file_system/src/types.js +20 -0
- package/src/ngtsc/{path → file_system}/src/util.d.ts +4 -5
- package/src/ngtsc/file_system/src/util.js +37 -0
- package/src/ngtsc/imports/src/emitter.d.ts +2 -2
- package/src/ngtsc/imports/src/emitter.js +13 -13
- package/src/ngtsc/imports/src/resolver.d.ts +1 -1
- package/src/ngtsc/imports/src/resolver.js +4 -10
- package/src/ngtsc/incremental/src/state.d.ts +7 -3
- package/src/ngtsc/incremental/src/state.js +23 -6
- package/src/ngtsc/indexer/src/api.d.ts +5 -16
- package/src/ngtsc/indexer/src/api.js +1 -1
- package/src/ngtsc/indexer/src/context.d.ts +40 -2
- package/src/ngtsc/indexer/src/context.js +10 -3
- package/src/ngtsc/indexer/src/template.d.ts +5 -5
- package/src/ngtsc/indexer/src/template.js +72 -99
- package/src/ngtsc/indexer/src/transform.js +38 -3
- package/src/ngtsc/partial_evaluator/src/interpreter.js +9 -5
- package/src/ngtsc/perf/src/tracking.d.ts +0 -7
- package/src/ngtsc/perf/src/tracking.js +12 -12
- package/src/ngtsc/program.d.ts +3 -2
- package/src/ngtsc/program.js +26 -19
- package/src/ngtsc/reflection/src/typescript.js +9 -28
- package/src/ngtsc/resource_loader.js +5 -6
- package/src/ngtsc/shims/src/factory_generator.d.ts +2 -2
- package/src/ngtsc/shims/src/factory_generator.js +14 -13
- package/src/ngtsc/shims/src/host.d.ts +2 -2
- package/src/ngtsc/shims/src/host.js +5 -12
- package/src/ngtsc/shims/src/summary_generator.d.ts +1 -1
- package/src/ngtsc/shims/src/summary_generator.js +6 -4
- package/src/ngtsc/shims/src/typecheck_shim.d.ts +1 -1
- package/src/ngtsc/shims/src/typecheck_shim.js +1 -1
- package/src/ngtsc/transform/src/api.d.ts +1 -1
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.js +36 -16
- package/src/ngtsc/typecheck/src/context.d.ts +1 -1
- package/src/ngtsc/typecheck/src/context.js +1 -1
- package/src/ngtsc/typecheck/src/host.js +9 -1
- package/src/ngtsc/typecheck/src/type_check_file.d.ts +2 -2
- package/src/ngtsc/typecheck/src/type_check_file.js +11 -13
- package/src/ngtsc/util/src/path.d.ts +0 -7
- package/src/ngtsc/util/src/path.js +15 -16
- package/src/ngtsc/util/src/resource_recorder.d.ts +18 -0
- package/src/ngtsc/util/src/resource_recorder.js +20 -0
- package/src/ngtsc/util/src/typescript.d.ts +2 -1
- package/src/ngtsc/util/src/typescript.js +8 -4
- package/src/perform_compile.d.ts +5 -3
- package/src/perform_compile.js +23 -18
- package/src/perform_watch.js +19 -9
- package/src/transformers/api.d.ts +5 -0
- package/src/transformers/api.js +1 -1
- package/src/transformers/compiler_host.js +10 -3
- package/src/version.js +1 -1
- package/ngcc/src/file_system/file_system.d.ts +0 -36
- package/ngcc/src/file_system/file_system.js +0 -20
- package/ngcc/src/file_system/node_js_file_system.d.ts +0 -27
- package/ngcc/src/file_system/node_js_file_system.js +0 -44
- package/src/ngtsc/path/index.d.ts +0 -10
- package/src/ngtsc/path/index.js +0 -26
- package/src/ngtsc/path/src/logical.js +0 -107
- package/src/ngtsc/path/src/types.d.ts +0 -73
- package/src/ngtsc/path/src/types.js +0 -108
- package/src/ngtsc/path/src/util.js +0 -46
|
@@ -11,7 +11,7 @@
|
|
|
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/indexer/src/template", ["require", "exports", "tslib", "@angular/compiler", "@angular/compiler/src/render3/r3_ast", "@angular/compiler
|
|
14
|
+
define("@angular/compiler-cli/src/ngtsc/indexer/src/template", ["require", "exports", "tslib", "@angular/compiler", "@angular/compiler/src/render3/r3_ast", "@angular/compiler-cli/src/ngtsc/indexer/src/api"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
@@ -19,44 +19,7 @@
|
|
|
19
19
|
var tslib_1 = require("tslib");
|
|
20
20
|
var compiler_1 = require("@angular/compiler");
|
|
21
21
|
var r3_ast_1 = require("@angular/compiler/src/render3/r3_ast");
|
|
22
|
-
var r3_template_transform_1 = require("@angular/compiler/src/render3/r3_template_transform");
|
|
23
|
-
var meta_1 = require("@angular/compiler/src/render3/view/i18n/meta");
|
|
24
|
-
var template_1 = require("@angular/compiler/src/render3/view/template");
|
|
25
22
|
var api_1 = require("@angular/compiler-cli/src/ngtsc/indexer/src/api");
|
|
26
|
-
/**
|
|
27
|
-
* Updates the location of an identifier to its real anchor in a source code.
|
|
28
|
-
*
|
|
29
|
-
* The compiler's expression parser records the location of some expressions in a manner not
|
|
30
|
-
* useful to the indexer. For example, a `MethodCall` `foo(a, b)` will record the span of the
|
|
31
|
-
* entire method call, but the indexer is interested only in the method identifier.
|
|
32
|
-
*
|
|
33
|
-
* To remedy all this, the visitor tokenizes the template node the expression was discovered in,
|
|
34
|
-
* and updates the locations of entities found during expression traversal with those of the
|
|
35
|
-
* tokens.
|
|
36
|
-
*
|
|
37
|
-
* TODO(ayazhafiz): Think about how to handle `PropertyRead`s in `BoundAttribute`s. The Lexer
|
|
38
|
-
* tokenizes the attribute as a string and ignores quotes.
|
|
39
|
-
*
|
|
40
|
-
* @param entities entities to update
|
|
41
|
-
* @param currentNode node expression was in
|
|
42
|
-
*/
|
|
43
|
-
function updateIdentifierSpans(identifiers, currentNode) {
|
|
44
|
-
var localSpan = currentNode.sourceSpan;
|
|
45
|
-
var localExpression = localSpan.toString();
|
|
46
|
-
var lexedIdentifiers = new compiler_1.Lexer().tokenize(localExpression).filter(function (token) { return token.type === compiler_1.TokenType.Identifier; });
|
|
47
|
-
// Join the relative position of the expression within a node with the absolute position of the
|
|
48
|
-
// node to get the absolute position of the expression in the source code.
|
|
49
|
-
var absoluteOffset = currentNode.sourceSpan.start.offset;
|
|
50
|
-
identifiers.forEach(function (id, index) {
|
|
51
|
-
var lexedId = lexedIdentifiers[index];
|
|
52
|
-
if (id.name !== lexedId.strValue) {
|
|
53
|
-
throw new Error('Impossible state: lexed and parsed expression should contain the same tokens.');
|
|
54
|
-
}
|
|
55
|
-
var start = absoluteOffset + lexedId.index;
|
|
56
|
-
var absoluteSpan = new api_1.AbsoluteSourceSpan(start, start + lexedId.strValue.length);
|
|
57
|
-
id.span = absoluteSpan;
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
23
|
/**
|
|
61
24
|
* Visits the AST of an Angular template syntax expression, finding interesting
|
|
62
25
|
* entities (variable references, etc.). Creates an array of Entities found in
|
|
@@ -68,34 +31,67 @@
|
|
|
68
31
|
*/
|
|
69
32
|
var ExpressionVisitor = /** @class */ (function (_super) {
|
|
70
33
|
tslib_1.__extends(ExpressionVisitor, _super);
|
|
71
|
-
function ExpressionVisitor(context,
|
|
72
|
-
if (
|
|
34
|
+
function ExpressionVisitor(context, boundTemplate, expressionStr, absoluteOffset) {
|
|
35
|
+
if (expressionStr === void 0) { expressionStr = context.sourceSpan.toString(); }
|
|
36
|
+
if (absoluteOffset === void 0) { absoluteOffset = context.sourceSpan.start.offset; }
|
|
73
37
|
var _this = _super.call(this) || this;
|
|
74
|
-
_this.
|
|
75
|
-
_this.
|
|
38
|
+
_this.boundTemplate = boundTemplate;
|
|
39
|
+
_this.expressionStr = expressionStr;
|
|
40
|
+
_this.absoluteOffset = absoluteOffset;
|
|
41
|
+
_this.identifiers = [];
|
|
76
42
|
return _this;
|
|
77
43
|
}
|
|
78
|
-
|
|
79
|
-
|
|
44
|
+
/**
|
|
45
|
+
* Returns identifiers discovered in an expression.
|
|
46
|
+
*
|
|
47
|
+
* @param ast expression AST to visit
|
|
48
|
+
* @param context HTML node expression is defined in
|
|
49
|
+
* @param boundTemplate bound target of the entire template, which can be used to query for the
|
|
50
|
+
* entities expressions target.
|
|
51
|
+
*/
|
|
52
|
+
ExpressionVisitor.getIdentifiers = function (ast, context, boundTemplate) {
|
|
53
|
+
var visitor = new ExpressionVisitor(context, boundTemplate);
|
|
80
54
|
visitor.visit(ast);
|
|
81
|
-
|
|
82
|
-
updateIdentifierSpans(identifiers, context);
|
|
83
|
-
return identifiers;
|
|
55
|
+
return visitor.identifiers;
|
|
84
56
|
};
|
|
85
57
|
ExpressionVisitor.prototype.visit = function (ast) { ast.visit(this); };
|
|
86
58
|
ExpressionVisitor.prototype.visitMethodCall = function (ast, context) {
|
|
87
|
-
this.
|
|
59
|
+
this.visitIdentifier(ast, api_1.IdentifierKind.Method);
|
|
88
60
|
_super.prototype.visitMethodCall.call(this, ast, context);
|
|
89
61
|
};
|
|
90
62
|
ExpressionVisitor.prototype.visitPropertyRead = function (ast, context) {
|
|
91
|
-
this.
|
|
63
|
+
this.visitIdentifier(ast, api_1.IdentifierKind.Property);
|
|
92
64
|
_super.prototype.visitPropertyRead.call(this, ast, context);
|
|
93
65
|
};
|
|
94
|
-
|
|
66
|
+
/**
|
|
67
|
+
* Visits an identifier, adding it to the identifier store if it is useful for indexing.
|
|
68
|
+
*
|
|
69
|
+
* @param ast expression AST the identifier is in
|
|
70
|
+
* @param kind identifier kind
|
|
71
|
+
*/
|
|
72
|
+
ExpressionVisitor.prototype.visitIdentifier = function (ast, kind) {
|
|
73
|
+
// The definition of a non-top-level property such as `bar` in `{{foo.bar}}` is currently
|
|
74
|
+
// impossible to determine by an indexer and unsupported by the indexing module.
|
|
75
|
+
// The indexing module also does not currently support references to identifiers declared in the
|
|
76
|
+
// template itself, which have a non-null expression target.
|
|
77
|
+
if (!(ast.receiver instanceof compiler_1.ImplicitReceiver) ||
|
|
78
|
+
this.boundTemplate.getExpressionTarget(ast) !== null) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
// Get the location of the identifier of real interest.
|
|
82
|
+
// The compiler's expression parser records the location of some expressions in a manner not
|
|
83
|
+
// useful to the indexer. For example, a `MethodCall` `foo(a, b)` will record the span of the
|
|
84
|
+
// entire method call, but the indexer is interested only in the method identifier.
|
|
85
|
+
var localExpression = this.expressionStr.substr(ast.span.start, ast.span.end);
|
|
86
|
+
var identifierStart = ast.span.start + localExpression.indexOf(ast.name);
|
|
87
|
+
// Join the relative position of the expression within a node with the absolute position
|
|
88
|
+
// of the node to get the absolute position of the expression in the source code.
|
|
89
|
+
var absoluteStart = this.absoluteOffset + identifierStart;
|
|
90
|
+
var span = new api_1.AbsoluteSourceSpan(absoluteStart, absoluteStart + ast.name.length);
|
|
95
91
|
this.identifiers.push({
|
|
96
92
|
name: ast.name,
|
|
97
|
-
span:
|
|
98
|
-
|
|
93
|
+
span: span,
|
|
94
|
+
kind: kind,
|
|
99
95
|
});
|
|
100
96
|
};
|
|
101
97
|
return ExpressionVisitor;
|
|
@@ -106,14 +102,22 @@
|
|
|
106
102
|
*/
|
|
107
103
|
var TemplateVisitor = /** @class */ (function (_super) {
|
|
108
104
|
tslib_1.__extends(TemplateVisitor, _super);
|
|
109
|
-
|
|
110
|
-
|
|
105
|
+
/**
|
|
106
|
+
* Creates a template visitor for a bound template target. The bound target can be used when
|
|
107
|
+
* deferred to the expression visitor to get information about the target of an expression.
|
|
108
|
+
*
|
|
109
|
+
* @param boundTemplate bound template target
|
|
110
|
+
*/
|
|
111
|
+
function TemplateVisitor(boundTemplate) {
|
|
112
|
+
var _this = _super.call(this) || this;
|
|
113
|
+
_this.boundTemplate = boundTemplate;
|
|
111
114
|
// identifiers of interest found in the template
|
|
112
115
|
_this.identifiers = new Set();
|
|
113
116
|
return _this;
|
|
114
117
|
}
|
|
115
118
|
/**
|
|
116
119
|
* Visits a node in the template.
|
|
120
|
+
*
|
|
117
121
|
* @param node node to visit
|
|
118
122
|
*/
|
|
119
123
|
TemplateVisitor.prototype.visit = function (node) { node.visit(this); };
|
|
@@ -132,63 +136,32 @@
|
|
|
132
136
|
this.visitAll(template.references);
|
|
133
137
|
this.visitAll(template.variables);
|
|
134
138
|
};
|
|
135
|
-
TemplateVisitor.prototype.visitBoundText = function (text) { this.
|
|
139
|
+
TemplateVisitor.prototype.visitBoundText = function (text) { this.visitExpression(text); };
|
|
136
140
|
/**
|
|
137
|
-
*
|
|
138
|
-
*
|
|
139
|
-
* @param curretNode node
|
|
141
|
+
* Visits a node's expression and adds its identifiers, if any, to the visitor's state.
|
|
142
|
+
*
|
|
143
|
+
* @param curretNode node whose expression to visit
|
|
140
144
|
*/
|
|
141
|
-
TemplateVisitor.prototype.
|
|
145
|
+
TemplateVisitor.prototype.visitExpression = function (node) {
|
|
142
146
|
var _this = this;
|
|
143
|
-
var identifiers = ExpressionVisitor.getIdentifiers(node.value, node);
|
|
147
|
+
var identifiers = ExpressionVisitor.getIdentifiers(node.value, node, this.boundTemplate);
|
|
144
148
|
identifiers.forEach(function (id) { return _this.identifiers.add(id); });
|
|
145
149
|
};
|
|
146
150
|
return TemplateVisitor;
|
|
147
151
|
}(r3_ast_1.RecursiveVisitor));
|
|
148
|
-
/**
|
|
149
|
-
* Unwraps and reparses a template, preserving whitespace and with no leading trivial characters.
|
|
150
|
-
*
|
|
151
|
-
* A template may previously have been parsed without preserving whitespace, and was definitely
|
|
152
|
-
* parsed with leading trivial characters (see `parseTemplate` from the compiler package API).
|
|
153
|
-
* Both of these are detrimental for indexing as they result in a manipulated AST not representing
|
|
154
|
-
* the template source code.
|
|
155
|
-
*
|
|
156
|
-
* TODO(ayazhafiz): Remove once issues with `leadingTriviaChars` and `parseTemplate` are resolved.
|
|
157
|
-
*/
|
|
158
|
-
function restoreTemplate(template, options) {
|
|
159
|
-
// try to recapture the template content and URL
|
|
160
|
-
// if there was nothing in the template to begin with, this is just a no-op
|
|
161
|
-
if (template.length === 0) {
|
|
162
|
-
return [];
|
|
163
|
-
}
|
|
164
|
-
var _a = template[0].sourceSpan.start.file, templateStr = _a.content, templateUrl = _a.url;
|
|
165
|
-
options.preserveWhitespaces = true;
|
|
166
|
-
var interpolationConfig = options.interpolationConfig, preserveWhitespaces = options.preserveWhitespaces;
|
|
167
|
-
var bindingParser = template_1.makeBindingParser(interpolationConfig);
|
|
168
|
-
var htmlParser = new compiler_1.HtmlParser();
|
|
169
|
-
var parseResult = htmlParser.parse(templateStr, templateUrl, tslib_1.__assign({}, options, { tokenizeExpansionForms: true }));
|
|
170
|
-
if (parseResult.errors && parseResult.errors.length > 0) {
|
|
171
|
-
throw new Error('Impossible state: template must have been successfully parsed previously.');
|
|
172
|
-
}
|
|
173
|
-
var rootNodes = compiler_1.visitAll(new meta_1.I18nMetaVisitor(interpolationConfig, !preserveWhitespaces), parseResult.rootNodes);
|
|
174
|
-
var _b = r3_template_transform_1.htmlAstToRender3Ast(rootNodes, bindingParser), nodes = _b.nodes, errors = _b.errors;
|
|
175
|
-
if (errors && errors.length > 0) {
|
|
176
|
-
throw new Error('Impossible state: template must have been successfully parsed previously.');
|
|
177
|
-
}
|
|
178
|
-
return nodes;
|
|
179
|
-
}
|
|
180
152
|
/**
|
|
181
153
|
* Traverses a template AST and builds identifiers discovered in it.
|
|
182
|
-
*
|
|
183
|
-
* @param
|
|
154
|
+
*
|
|
155
|
+
* @param boundTemplate bound template target, which can be used for querying expression targets.
|
|
184
156
|
* @return identifiers in template
|
|
185
157
|
*/
|
|
186
|
-
function getTemplateIdentifiers(
|
|
187
|
-
var
|
|
188
|
-
|
|
189
|
-
|
|
158
|
+
function getTemplateIdentifiers(boundTemplate) {
|
|
159
|
+
var visitor = new TemplateVisitor(boundTemplate);
|
|
160
|
+
if (boundTemplate.target.template !== undefined) {
|
|
161
|
+
visitor.visitAll(boundTemplate.target.template);
|
|
162
|
+
}
|
|
190
163
|
return visitor.identifiers;
|
|
191
164
|
}
|
|
192
165
|
exports.getTemplateIdentifiers = getTemplateIdentifiers;
|
|
193
166
|
});
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/indexer/src/template.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 {AST, HtmlParser, Lexer, MethodCall, ParseSourceFile, PropertyRead, RecursiveAstVisitor, TmplAstNode, TokenType, visitAll} from '@angular/compiler';\nimport {BoundText, Element, Node, RecursiveVisitor as RecursiveTemplateVisitor, Template} from '@angular/compiler/src/render3/r3_ast';\nimport {htmlAstToRender3Ast} from '@angular/compiler/src/render3/r3_template_transform';\nimport {I18nMetaVisitor} from '@angular/compiler/src/render3/view/i18n/meta';\nimport {makeBindingParser} from '@angular/compiler/src/render3/view/template';\nimport {AbsoluteSourceSpan, IdentifierKind, RestoreTemplateOptions, TemplateIdentifier} from './api';\n\n/**\n * A parsed node in a template, which may have a name (if it is a selector) or\n * be anonymous (like a text span).\n */\ninterface HTMLNode extends Node {\n  tagName?: string;\n  name?: string;\n}\n\n/**\n * Updates the location of an identifier to its real anchor in a source code.\n *\n * The compiler's expression parser records the location of some expressions in a manner not\n * useful to the indexer. For example, a `MethodCall` `foo(a, b)` will record the span of the\n * entire method call, but the indexer is interested only in the method identifier.\n *\n * To remedy all this, the visitor tokenizes the template node the expression was discovered in,\n * and updates the locations of entities found during expression traversal with those of the\n * tokens.\n *\n * TODO(ayazhafiz): Think about how to handle `PropertyRead`s in `BoundAttribute`s. The Lexer\n * tokenizes the attribute as a string and ignores quotes.\n *\n * @param entities entities to update\n * @param currentNode node expression was in\n */\nfunction updateIdentifierSpans(identifiers: TemplateIdentifier[], currentNode: Node) {\n  const localSpan = currentNode.sourceSpan;\n  const localExpression = localSpan.toString();\n\n  const lexedIdentifiers =\n      new Lexer().tokenize(localExpression).filter(token => token.type === TokenType.Identifier);\n\n  // Join the relative position of the expression within a node with the absolute position of the\n  // node to get the absolute position of the expression in the source code.\n  const absoluteOffset = currentNode.sourceSpan.start.offset;\n  identifiers.forEach((id, index) => {\n    const lexedId = lexedIdentifiers[index];\n    if (id.name !== lexedId.strValue) {\n      throw new Error(\n          'Impossible state: lexed and parsed expression should contain the same tokens.');\n    }\n\n    const start = absoluteOffset + lexedId.index;\n    const absoluteSpan = new AbsoluteSourceSpan(start, start + lexedId.strValue.length);\n    id.span = absoluteSpan;\n  });\n}\n\n/**\n * Visits the AST of an Angular template syntax expression, finding interesting\n * entities (variable references, etc.). Creates an array of Entities found in\n * the expression, with the location of the Entities being relative to the\n * expression.\n *\n * Visiting `text {{prop}}` will return `[TemplateIdentifier {name: 'prop', span: {start: 7, end:\n * 11}}]`.\n */\nclass ExpressionVisitor extends RecursiveAstVisitor {\n  private readonly file: ParseSourceFile;\n\n  private constructor(context: Node, readonly identifiers: TemplateIdentifier[] = []) {\n    super();\n\n    this.file = context.sourceSpan.start.file;\n  }\n\n  static getIdentifiers(ast: AST, context: Node): TemplateIdentifier[] {\n    const visitor = new ExpressionVisitor(context);\n    visitor.visit(ast);\n    const identifiers = visitor.identifiers;\n\n    updateIdentifierSpans(identifiers, context);\n\n    return identifiers;\n  }\n\n  visit(ast: AST) { ast.visit(this); }\n\n  visitMethodCall(ast: MethodCall, context: {}) {\n    this.addIdentifier(ast, IdentifierKind.Method);\n    super.visitMethodCall(ast, context);\n  }\n\n  visitPropertyRead(ast: PropertyRead, context: {}) {\n    this.addIdentifier(ast, IdentifierKind.Property);\n    super.visitPropertyRead(ast, context);\n  }\n\n  private addIdentifier(ast: AST&{name: string}, kind: IdentifierKind) {\n    this.identifiers.push({\n      name: ast.name,\n      span: ast.span, kind,\n      file: this.file,\n    });\n  }\n}\n\n/**\n * Visits the AST of a parsed Angular template. Discovers and stores\n * identifiers of interest, deferring to an `ExpressionVisitor` as needed.\n */\nclass TemplateVisitor extends RecursiveTemplateVisitor {\n  // identifiers of interest found in the template\n  readonly identifiers = new Set<TemplateIdentifier>();\n\n  /**\n   * Visits a node in the template.\n   * @param node node to visit\n   */\n  visit(node: HTMLNode) { node.visit(this); }\n\n  visitAll(nodes: Node[]) { nodes.forEach(node => this.visit(node)); }\n\n  visitElement(element: Element) {\n    this.visitAll(element.attributes);\n    this.visitAll(element.children);\n    this.visitAll(element.references);\n  }\n  visitTemplate(template: Template) {\n    this.visitAll(template.attributes);\n    this.visitAll(template.children);\n    this.visitAll(template.references);\n    this.visitAll(template.variables);\n  }\n  visitBoundText(text: BoundText) { this.addIdentifiers(text); }\n\n  /**\n   * Adds identifiers to the visitor's state.\n   * @param visitedEntities interesting entities to add as identifiers\n   * @param curretNode node entities were discovered in\n   */\n  private addIdentifiers(node: Node&{value: AST}) {\n    const identifiers = ExpressionVisitor.getIdentifiers(node.value, node);\n    identifiers.forEach(id => this.identifiers.add(id));\n  }\n}\n\n/**\n * Unwraps and reparses a template, preserving whitespace and with no leading trivial characters.\n *\n * A template may previously have been parsed without preserving whitespace, and was definitely\n * parsed with leading trivial characters (see `parseTemplate` from the compiler package API).\n * Both of these are detrimental for indexing as they result in a manipulated AST not representing\n * the template source code.\n *\n * TODO(ayazhafiz): Remove once issues with `leadingTriviaChars` and `parseTemplate` are resolved.\n */\nfunction restoreTemplate(template: TmplAstNode[], options: RestoreTemplateOptions): TmplAstNode[] {\n  // try to recapture the template content and URL\n  // if there was nothing in the template to begin with, this is just a no-op\n  if (template.length === 0) {\n    return [];\n  }\n  const {content: templateStr, url: templateUrl} = template[0].sourceSpan.start.file;\n\n  options.preserveWhitespaces = true;\n  const {interpolationConfig, preserveWhitespaces} = options;\n\n  const bindingParser = makeBindingParser(interpolationConfig);\n  const htmlParser = new HtmlParser();\n  const parseResult = htmlParser.parse(templateStr, templateUrl, {\n    ...options,\n    tokenizeExpansionForms: true,\n  });\n\n  if (parseResult.errors && parseResult.errors.length > 0) {\n    throw new Error('Impossible state: template must have been successfully parsed previously.');\n  }\n\n  const rootNodes = visitAll(\n      new I18nMetaVisitor(interpolationConfig, !preserveWhitespaces), parseResult.rootNodes);\n\n  const {nodes, errors} = htmlAstToRender3Ast(rootNodes, bindingParser);\n  if (errors && errors.length > 0) {\n    throw new Error('Impossible state: template must have been successfully parsed previously.');\n  }\n\n  return nodes;\n}\n\n/**\n * Traverses a template AST and builds identifiers discovered in it.\n * @param template template to extract indentifiers from\n * @param options options for restoring the parsed template to a indexable state\n * @return identifiers in template\n */\nexport function getTemplateIdentifiers(\n    template: TmplAstNode[], options: RestoreTemplateOptions): Set<TemplateIdentifier> {\n  const restoredTemplate = restoreTemplate(template, options);\n  const visitor = new TemplateVisitor();\n  visitor.visitAll(restoredTemplate);\n  return visitor.identifiers;\n}\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/indexer/src/template.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 {AST, BoundTarget, DirectiveMeta, ImplicitReceiver, MethodCall, PropertyRead, RecursiveAstVisitor} from '@angular/compiler';\nimport {BoundText, Element, Node, RecursiveVisitor as RecursiveTemplateVisitor, Template} from '@angular/compiler/src/render3/r3_ast';\nimport {AbsoluteSourceSpan, IdentifierKind, TemplateIdentifier} from './api';\n\n/**\n * A parsed node in a template, which may have a name (if it is a selector) or\n * be anonymous (like a text span).\n */\ninterface HTMLNode extends Node {\n  tagName?: string;\n  name?: string;\n}\n\n/**\n * Visits the AST of an Angular template syntax expression, finding interesting\n * entities (variable references, etc.). Creates an array of Entities found in\n * the expression, with the location of the Entities being relative to the\n * expression.\n *\n * Visiting `text {{prop}}` will return `[TemplateIdentifier {name: 'prop', span: {start: 7, end:\n * 11}}]`.\n */\nclass ExpressionVisitor extends RecursiveAstVisitor {\n  readonly identifiers: TemplateIdentifier[] = [];\n\n  private constructor(\n      context: Node, private readonly boundTemplate: BoundTarget<DirectiveMeta>,\n      private readonly expressionStr = context.sourceSpan.toString(),\n      private readonly absoluteOffset = context.sourceSpan.start.offset) {\n    super();\n  }\n\n  /**\n   * Returns identifiers discovered in an expression.\n   *\n   * @param ast expression AST to visit\n   * @param context HTML node expression is defined in\n   * @param boundTemplate bound target of the entire template, which can be used to query for the\n   * entities expressions target.\n   */\n  static getIdentifiers(ast: AST, context: Node, boundTemplate: BoundTarget<DirectiveMeta>):\n      TemplateIdentifier[] {\n    const visitor = new ExpressionVisitor(context, boundTemplate);\n    visitor.visit(ast);\n    return visitor.identifiers;\n  }\n\n  visit(ast: AST) { ast.visit(this); }\n\n  visitMethodCall(ast: MethodCall, context: {}) {\n    this.visitIdentifier(ast, IdentifierKind.Method);\n    super.visitMethodCall(ast, context);\n  }\n\n  visitPropertyRead(ast: PropertyRead, context: {}) {\n    this.visitIdentifier(ast, IdentifierKind.Property);\n    super.visitPropertyRead(ast, context);\n  }\n\n  /**\n   * Visits an identifier, adding it to the identifier store if it is useful for indexing.\n   *\n   * @param ast expression AST the identifier is in\n   * @param kind identifier kind\n   */\n  private visitIdentifier(ast: AST&{name: string, receiver: AST}, kind: IdentifierKind) {\n    // The definition of a non-top-level property such as `bar` in `{{foo.bar}}` is currently\n    // impossible to determine by an indexer and unsupported by the indexing module.\n    // The indexing module also does not currently support references to identifiers declared in the\n    // template itself, which have a non-null expression target.\n    if (!(ast.receiver instanceof ImplicitReceiver) ||\n        this.boundTemplate.getExpressionTarget(ast) !== null) {\n      return;\n    }\n\n    // Get the location of the identifier of real interest.\n    // The compiler's expression parser records the location of some expressions in a manner not\n    // useful to the indexer. For example, a `MethodCall` `foo(a, b)` will record the span of the\n    // entire method call, but the indexer is interested only in the method identifier.\n    const localExpression = this.expressionStr.substr(ast.span.start, ast.span.end);\n    const identifierStart = ast.span.start + localExpression.indexOf(ast.name);\n\n    // Join the relative position of the expression within a node with the absolute position\n    // of the node to get the absolute position of the expression in the source code.\n    const absoluteStart = this.absoluteOffset + identifierStart;\n    const span = new AbsoluteSourceSpan(absoluteStart, absoluteStart + ast.name.length);\n\n    this.identifiers.push({\n      name: ast.name,\n      span,\n      kind,\n    });\n  }\n}\n\n/**\n * Visits the AST of a parsed Angular template. Discovers and stores\n * identifiers of interest, deferring to an `ExpressionVisitor` as needed.\n */\nclass TemplateVisitor extends RecursiveTemplateVisitor {\n  // identifiers of interest found in the template\n  readonly identifiers = new Set<TemplateIdentifier>();\n\n  /**\n   * Creates a template visitor for a bound template target. The bound target can be used when\n   * deferred to the expression visitor to get information about the target of an expression.\n   *\n   * @param boundTemplate bound template target\n   */\n  constructor(private boundTemplate: BoundTarget<DirectiveMeta>) { super(); }\n\n  /**\n   * Visits a node in the template.\n   *\n   * @param node node to visit\n   */\n  visit(node: HTMLNode) { node.visit(this); }\n\n  visitAll(nodes: Node[]) { nodes.forEach(node => this.visit(node)); }\n\n  visitElement(element: Element) {\n    this.visitAll(element.attributes);\n    this.visitAll(element.children);\n    this.visitAll(element.references);\n  }\n  visitTemplate(template: Template) {\n    this.visitAll(template.attributes);\n    this.visitAll(template.children);\n    this.visitAll(template.references);\n    this.visitAll(template.variables);\n  }\n  visitBoundText(text: BoundText) { this.visitExpression(text); }\n\n  /**\n   * Visits a node's expression and adds its identifiers, if any, to the visitor's state.\n   *\n   * @param curretNode node whose expression to visit\n   */\n  private visitExpression(node: Node&{value: AST}) {\n    const identifiers = ExpressionVisitor.getIdentifiers(node.value, node, this.boundTemplate);\n    identifiers.forEach(id => this.identifiers.add(id));\n  }\n}\n\n/**\n * Traverses a template AST and builds identifiers discovered in it.\n *\n * @param boundTemplate bound template target, which can be used for querying expression targets.\n * @return identifiers in template\n */\nexport function getTemplateIdentifiers(boundTemplate: BoundTarget<DirectiveMeta>):\n    Set<TemplateIdentifier> {\n  const visitor = new TemplateVisitor(boundTemplate);\n  if (boundTemplate.target.template !== undefined) {\n    visitor.visitAll(boundTemplate.target.template);\n  }\n  return visitor.identifiers;\n}\n"]}
|
|
@@ -11,11 +11,13 @@
|
|
|
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/indexer/src/transform", ["require", "exports"], factory);
|
|
14
|
+
define("@angular/compiler-cli/src/ngtsc/indexer/src/transform", ["require", "exports", "@angular/compiler/src/compiler", "@angular/compiler-cli/src/ngtsc/indexer/src/template"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
18
18
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
+
var compiler_1 = require("@angular/compiler/src/compiler");
|
|
20
|
+
var template_1 = require("@angular/compiler-cli/src/ngtsc/indexer/src/template");
|
|
19
21
|
/**
|
|
20
22
|
* Generates `IndexedComponent` entries from a `IndexingContext`, which has information
|
|
21
23
|
* about components discovered in the program registered in it.
|
|
@@ -23,8 +25,41 @@
|
|
|
23
25
|
* The context must be populated before `generateAnalysis` is called.
|
|
24
26
|
*/
|
|
25
27
|
function generateAnalysis(context) {
|
|
26
|
-
|
|
28
|
+
var analysis = new Map();
|
|
29
|
+
context.components.forEach(function (_a) {
|
|
30
|
+
var declaration = _a.declaration, selector = _a.selector, boundTemplate = _a.boundTemplate, templateMeta = _a.templateMeta;
|
|
31
|
+
var name = declaration.name.getText();
|
|
32
|
+
var usedComponents = new Set();
|
|
33
|
+
var usedDirs = boundTemplate.getUsedDirectives();
|
|
34
|
+
usedDirs.forEach(function (dir) {
|
|
35
|
+
if (dir.isComponent) {
|
|
36
|
+
usedComponents.add(dir.ref.node);
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
// Get source files for the component and the template. If the template is inline, its source
|
|
40
|
+
// file is the component's.
|
|
41
|
+
var componentFile = new compiler_1.ParseSourceFile(declaration.getSourceFile().getFullText(), declaration.getSourceFile().fileName);
|
|
42
|
+
var templateFile;
|
|
43
|
+
if (templateMeta.isInline) {
|
|
44
|
+
templateFile = componentFile;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
templateFile = templateMeta.file;
|
|
48
|
+
}
|
|
49
|
+
analysis.set(declaration, {
|
|
50
|
+
name: name,
|
|
51
|
+
selector: selector,
|
|
52
|
+
file: componentFile,
|
|
53
|
+
template: {
|
|
54
|
+
identifiers: template_1.getTemplateIdentifiers(boundTemplate),
|
|
55
|
+
usedComponents: usedComponents,
|
|
56
|
+
isInline: templateMeta.isInline,
|
|
57
|
+
file: templateFile,
|
|
58
|
+
},
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
return analysis;
|
|
27
62
|
}
|
|
28
63
|
exports.generateAnalysis = generateAnalysis;
|
|
29
64
|
});
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmb3JtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9pbmRleGVyL3NyYy90cmFuc2Zvcm0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7SUFFSCwyREFBK0Q7SUFJL0QsaUZBQWtEO0lBRWxEOzs7OztPQUtHO0lBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsT0FBd0I7UUFDdkQsSUFBTSxRQUFRLEdBQUcsSUFBSSxHQUFHLEVBQW9DLENBQUM7UUFFN0QsT0FBTyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsVUFBQyxFQUFvRDtnQkFBbkQsNEJBQVcsRUFBRSxzQkFBUSxFQUFFLGdDQUFhLEVBQUUsOEJBQVk7WUFDN0UsSUFBTSxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUV4QyxJQUFNLGNBQWMsR0FBRyxJQUFJLEdBQUcsRUFBa0IsQ0FBQztZQUNqRCxJQUFNLFFBQVEsR0FBRyxhQUFhLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUNuRCxRQUFRLENBQUMsT0FBTyxDQUFDLFVBQUEsR0FBRztnQkFDbEIsSUFBSSxHQUFHLENBQUMsV0FBVyxFQUFFO29CQUNuQixjQUFjLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7aUJBQ2xDO1lBQ0gsQ0FBQyxDQUFDLENBQUM7WUFFSCw2RkFBNkY7WUFDN0YsMkJBQTJCO1lBQzNCLElBQU0sYUFBYSxHQUFHLElBQUksMEJBQWUsQ0FDckMsV0FBVyxDQUFDLGFBQWEsRUFBRSxDQUFDLFdBQVcsRUFBRSxFQUFFLFdBQVcsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNyRixJQUFJLFlBQTZCLENBQUM7WUFDbEMsSUFBSSxZQUFZLENBQUMsUUFBUSxFQUFFO2dCQUN6QixZQUFZLEdBQUcsYUFBYSxDQUFDO2FBQzlCO2lCQUFNO2dCQUNMLFlBQVksR0FBRyxZQUFZLENBQUMsSUFBSSxDQUFDO2FBQ2xDO1lBRUQsUUFBUSxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUU7Z0JBQ3hCLElBQUksTUFBQTtnQkFDSixRQUFRLFVBQUE7Z0JBQ1IsSUFBSSxFQUFFLGFBQWE7Z0JBQ25CLFFBQVEsRUFBRTtvQkFDUixXQUFXLEVBQUUsaUNBQXNCLENBQUMsYUFBYSxDQUFDO29CQUNsRCxjQUFjLGdCQUFBO29CQUNkLFFBQVEsRUFBRSxZQUFZLENBQUMsUUFBUTtvQkFDL0IsSUFBSSxFQUFFLFlBQVk7aUJBQ25CO2FBQ0YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLFFBQVEsQ0FBQztJQUNsQixDQUFDO0lBdkNELDRDQXVDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgSW5jLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtQYXJzZVNvdXJjZUZpbGV9IGZyb20gJ0Bhbmd1bGFyL2NvbXBpbGVyL3NyYy9jb21waWxlcic7XG5pbXBvcnQgKiBhcyB0cyBmcm9tICd0eXBlc2NyaXB0JztcbmltcG9ydCB7SW5kZXhlZENvbXBvbmVudH0gZnJvbSAnLi9hcGknO1xuaW1wb3J0IHtJbmRleGluZ0NvbnRleHR9IGZyb20gJy4vY29udGV4dCc7XG5pbXBvcnQge2dldFRlbXBsYXRlSWRlbnRpZmllcnN9IGZyb20gJy4vdGVtcGxhdGUnO1xuXG4vKipcbiAqIEdlbmVyYXRlcyBgSW5kZXhlZENvbXBvbmVudGAgZW50cmllcyBmcm9tIGEgYEluZGV4aW5nQ29udGV4dGAsIHdoaWNoIGhhcyBpbmZvcm1hdGlvblxuICogYWJvdXQgY29tcG9uZW50cyBkaXNjb3ZlcmVkIGluIHRoZSBwcm9ncmFtIHJlZ2lzdGVyZWQgaW4gaXQuXG4gKlxuICogVGhlIGNvbnRleHQgbXVzdCBiZSBwb3B1bGF0ZWQgYmVmb3JlIGBnZW5lcmF0ZUFuYWx5c2lzYCBpcyBjYWxsZWQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZW5lcmF0ZUFuYWx5c2lzKGNvbnRleHQ6IEluZGV4aW5nQ29udGV4dCk6IE1hcDx0cy5EZWNsYXJhdGlvbiwgSW5kZXhlZENvbXBvbmVudD4ge1xuICBjb25zdCBhbmFseXNpcyA9IG5ldyBNYXA8dHMuRGVjbGFyYXRpb24sIEluZGV4ZWRDb21wb25lbnQ+KCk7XG5cbiAgY29udGV4dC5jb21wb25lbnRzLmZvckVhY2goKHtkZWNsYXJhdGlvbiwgc2VsZWN0b3IsIGJvdW5kVGVtcGxhdGUsIHRlbXBsYXRlTWV0YX0pID0+IHtcbiAgICBjb25zdCBuYW1lID0gZGVjbGFyYXRpb24ubmFtZS5nZXRUZXh0KCk7XG5cbiAgICBjb25zdCB1c2VkQ29tcG9uZW50cyA9IG5ldyBTZXQ8dHMuRGVjbGFyYXRpb24+KCk7XG4gICAgY29uc3QgdXNlZERpcnMgPSBib3VuZFRlbXBsYXRlLmdldFVzZWREaXJlY3RpdmVzKCk7XG4gICAgdXNlZERpcnMuZm9yRWFjaChkaXIgPT4ge1xuICAgICAgaWYgKGRpci5pc0NvbXBvbmVudCkge1xuICAgICAgICB1c2VkQ29tcG9uZW50cy5hZGQoZGlyLnJlZi5ub2RlKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIC8vIEdldCBzb3VyY2UgZmlsZXMgZm9yIHRoZSBjb21wb25lbnQgYW5kIHRoZSB0ZW1wbGF0ZS4gSWYgdGhlIHRlbXBsYXRlIGlzIGlubGluZSwgaXRzIHNvdXJjZVxuICAgIC8vIGZpbGUgaXMgdGhlIGNvbXBvbmVudCdzLlxuICAgIGNvbnN0IGNvbXBvbmVudEZpbGUgPSBuZXcgUGFyc2VTb3VyY2VGaWxlKFxuICAgICAgICBkZWNsYXJhdGlvbi5nZXRTb3VyY2VGaWxlKCkuZ2V0RnVsbFRleHQoKSwgZGVjbGFyYXRpb24uZ2V0U291cmNlRmlsZSgpLmZpbGVOYW1lKTtcbiAgICBsZXQgdGVtcGxhdGVGaWxlOiBQYXJzZVNvdXJjZUZpbGU7XG4gICAgaWYgKHRlbXBsYXRlTWV0YS5pc0lubGluZSkge1xuICAgICAgdGVtcGxhdGVGaWxlID0gY29tcG9uZW50RmlsZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGVtcGxhdGVGaWxlID0gdGVtcGxhdGVNZXRhLmZpbGU7XG4gICAgfVxuXG4gICAgYW5hbHlzaXMuc2V0KGRlY2xhcmF0aW9uLCB7XG4gICAgICBuYW1lLFxuICAgICAgc2VsZWN0b3IsXG4gICAgICBmaWxlOiBjb21wb25lbnRGaWxlLFxuICAgICAgdGVtcGxhdGU6IHtcbiAgICAgICAgaWRlbnRpZmllcnM6IGdldFRlbXBsYXRlSWRlbnRpZmllcnMoYm91bmRUZW1wbGF0ZSksXG4gICAgICAgIHVzZWRDb21wb25lbnRzLFxuICAgICAgICBpc0lubGluZTogdGVtcGxhdGVNZXRhLmlzSW5saW5lLFxuICAgICAgICBmaWxlOiB0ZW1wbGF0ZUZpbGUsXG4gICAgICB9LFxuICAgIH0pO1xuICB9KTtcblxuICByZXR1cm4gYW5hbHlzaXM7XG59XG4iXX0=
|