@angular/language-service 11.1.2 → 11.2.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/bundles/ivy.js +483 -230
- package/bundles/language-service.js +54 -41
- package/ivy/definitions.js +2 -2
- package/ivy/language_service.d.ts +5 -0
- package/ivy/language_service.js +72 -3
- package/ivy/references.d.ts +33 -4
- package/ivy/references.js +313 -70
- package/ivy/ts_plugin.js +15 -6
- package/ivy/utils.d.ts +1 -1
- package/ivy/utils.js +2 -2
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v11.
|
|
2
|
+
* @license Angular v11.2.0
|
|
3
3
|
* Copyright Google LLC All Rights Reserved.
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -13675,6 +13675,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13675
13675
|
return new Chain(this.span(start), this.sourceSpan(start), exprs);
|
|
13676
13676
|
}
|
|
13677
13677
|
parsePipe() {
|
|
13678
|
+
const start = this.inputIndex;
|
|
13678
13679
|
let result = this.parseExpression();
|
|
13679
13680
|
if (this.consumeOptionalOperator('|')) {
|
|
13680
13681
|
if (this.parseAction) {
|
|
@@ -13710,7 +13711,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13710
13711
|
// If there are additional expressions beyond the name, then the artificial end for the
|
|
13711
13712
|
// name is no longer relevant.
|
|
13712
13713
|
}
|
|
13713
|
-
const { start } = result.span;
|
|
13714
13714
|
result = new BindingPipe(this.span(start), this.sourceSpan(start, fullSpanEnd), result, nameId, args, nameSpan);
|
|
13715
13715
|
} while (this.consumeOptionalOperator('|'));
|
|
13716
13716
|
}
|
|
@@ -13742,26 +13742,27 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13742
13742
|
}
|
|
13743
13743
|
parseLogicalOr() {
|
|
13744
13744
|
// '||'
|
|
13745
|
+
const start = this.inputIndex;
|
|
13745
13746
|
let result = this.parseLogicalAnd();
|
|
13746
13747
|
while (this.consumeOptionalOperator('||')) {
|
|
13747
13748
|
const right = this.parseLogicalAnd();
|
|
13748
|
-
const { start } = result.span;
|
|
13749
13749
|
result = new Binary(this.span(start), this.sourceSpan(start), '||', result, right);
|
|
13750
13750
|
}
|
|
13751
13751
|
return result;
|
|
13752
13752
|
}
|
|
13753
13753
|
parseLogicalAnd() {
|
|
13754
13754
|
// '&&'
|
|
13755
|
+
const start = this.inputIndex;
|
|
13755
13756
|
let result = this.parseEquality();
|
|
13756
13757
|
while (this.consumeOptionalOperator('&&')) {
|
|
13757
13758
|
const right = this.parseEquality();
|
|
13758
|
-
const { start } = result.span;
|
|
13759
13759
|
result = new Binary(this.span(start), this.sourceSpan(start), '&&', result, right);
|
|
13760
13760
|
}
|
|
13761
13761
|
return result;
|
|
13762
13762
|
}
|
|
13763
13763
|
parseEquality() {
|
|
13764
13764
|
// '==','!=','===','!=='
|
|
13765
|
+
const start = this.inputIndex;
|
|
13765
13766
|
let result = this.parseRelational();
|
|
13766
13767
|
while (this.next.type == TokenType$1.Operator) {
|
|
13767
13768
|
const operator = this.next.strValue;
|
|
@@ -13772,7 +13773,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13772
13773
|
case '!==':
|
|
13773
13774
|
this.advance();
|
|
13774
13775
|
const right = this.parseRelational();
|
|
13775
|
-
const { start } = result.span;
|
|
13776
13776
|
result = new Binary(this.span(start), this.sourceSpan(start), operator, result, right);
|
|
13777
13777
|
continue;
|
|
13778
13778
|
}
|
|
@@ -13782,6 +13782,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13782
13782
|
}
|
|
13783
13783
|
parseRelational() {
|
|
13784
13784
|
// '<', '>', '<=', '>='
|
|
13785
|
+
const start = this.inputIndex;
|
|
13785
13786
|
let result = this.parseAdditive();
|
|
13786
13787
|
while (this.next.type == TokenType$1.Operator) {
|
|
13787
13788
|
const operator = this.next.strValue;
|
|
@@ -13792,7 +13793,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13792
13793
|
case '>=':
|
|
13793
13794
|
this.advance();
|
|
13794
13795
|
const right = this.parseAdditive();
|
|
13795
|
-
const { start } = result.span;
|
|
13796
13796
|
result = new Binary(this.span(start), this.sourceSpan(start), operator, result, right);
|
|
13797
13797
|
continue;
|
|
13798
13798
|
}
|
|
@@ -13802,6 +13802,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13802
13802
|
}
|
|
13803
13803
|
parseAdditive() {
|
|
13804
13804
|
// '+', '-'
|
|
13805
|
+
const start = this.inputIndex;
|
|
13805
13806
|
let result = this.parseMultiplicative();
|
|
13806
13807
|
while (this.next.type == TokenType$1.Operator) {
|
|
13807
13808
|
const operator = this.next.strValue;
|
|
@@ -13810,7 +13811,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13810
13811
|
case '-':
|
|
13811
13812
|
this.advance();
|
|
13812
13813
|
let right = this.parseMultiplicative();
|
|
13813
|
-
const { start } = result.span;
|
|
13814
13814
|
result = new Binary(this.span(start), this.sourceSpan(start), operator, result, right);
|
|
13815
13815
|
continue;
|
|
13816
13816
|
}
|
|
@@ -13820,6 +13820,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13820
13820
|
}
|
|
13821
13821
|
parseMultiplicative() {
|
|
13822
13822
|
// '*', '%', '/'
|
|
13823
|
+
const start = this.inputIndex;
|
|
13823
13824
|
let result = this.parsePrefix();
|
|
13824
13825
|
while (this.next.type == TokenType$1.Operator) {
|
|
13825
13826
|
const operator = this.next.strValue;
|
|
@@ -13829,7 +13830,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13829
13830
|
case '/':
|
|
13830
13831
|
this.advance();
|
|
13831
13832
|
let right = this.parsePrefix();
|
|
13832
|
-
const { start } = result.span;
|
|
13833
13833
|
result = new Binary(this.span(start), this.sourceSpan(start), operator, result, right);
|
|
13834
13834
|
continue;
|
|
13835
13835
|
}
|
|
@@ -13860,14 +13860,14 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13860
13860
|
return this.parseCallChain();
|
|
13861
13861
|
}
|
|
13862
13862
|
parseCallChain() {
|
|
13863
|
+
const start = this.inputIndex;
|
|
13863
13864
|
let result = this.parsePrimary();
|
|
13864
|
-
const resultStart = result.span.start;
|
|
13865
13865
|
while (true) {
|
|
13866
13866
|
if (this.consumeOptionalCharacter($PERIOD)) {
|
|
13867
|
-
result = this.parseAccessMemberOrMethodCall(result, false);
|
|
13867
|
+
result = this.parseAccessMemberOrMethodCall(result, start, false);
|
|
13868
13868
|
}
|
|
13869
13869
|
else if (this.consumeOptionalOperator('?.')) {
|
|
13870
|
-
result = this.parseAccessMemberOrMethodCall(result, true);
|
|
13870
|
+
result = this.parseAccessMemberOrMethodCall(result, start, true);
|
|
13871
13871
|
}
|
|
13872
13872
|
else if (this.consumeOptionalCharacter($LBRACKET)) {
|
|
13873
13873
|
this.withContext(ParseContextFlags.Writable, () => {
|
|
@@ -13880,11 +13880,10 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13880
13880
|
this.expectCharacter($RBRACKET);
|
|
13881
13881
|
if (this.consumeOptionalOperator('=')) {
|
|
13882
13882
|
const value = this.parseConditional();
|
|
13883
|
-
result = new KeyedWrite(this.span(
|
|
13883
|
+
result = new KeyedWrite(this.span(start), this.sourceSpan(start), result, key, value);
|
|
13884
13884
|
}
|
|
13885
13885
|
else {
|
|
13886
|
-
result =
|
|
13887
|
-
new KeyedRead(this.span(resultStart), this.sourceSpan(resultStart), result, key);
|
|
13886
|
+
result = new KeyedRead(this.span(start), this.sourceSpan(start), result, key);
|
|
13888
13887
|
}
|
|
13889
13888
|
});
|
|
13890
13889
|
}
|
|
@@ -13893,11 +13892,10 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13893
13892
|
const args = this.parseCallArguments();
|
|
13894
13893
|
this.rparensExpected--;
|
|
13895
13894
|
this.expectCharacter($RPAREN);
|
|
13896
|
-
result =
|
|
13897
|
-
new FunctionCall(this.span(resultStart), this.sourceSpan(resultStart), result, args);
|
|
13895
|
+
result = new FunctionCall(this.span(start), this.sourceSpan(start), result, args);
|
|
13898
13896
|
}
|
|
13899
13897
|
else if (this.consumeOptionalOperator('!')) {
|
|
13900
|
-
result = new NonNullAssert(this.span(
|
|
13898
|
+
result = new NonNullAssert(this.span(start), this.sourceSpan(start), result);
|
|
13901
13899
|
}
|
|
13902
13900
|
else {
|
|
13903
13901
|
return result;
|
|
@@ -13944,7 +13942,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13944
13942
|
return this.parseLiteralMap();
|
|
13945
13943
|
}
|
|
13946
13944
|
else if (this.next.isIdentifier()) {
|
|
13947
|
-
return this.parseAccessMemberOrMethodCall(new ImplicitReceiver(this.span(start), this.sourceSpan(start)), false);
|
|
13945
|
+
return this.parseAccessMemberOrMethodCall(new ImplicitReceiver(this.span(start), this.sourceSpan(start)), start, false);
|
|
13948
13946
|
}
|
|
13949
13947
|
else if (this.next.isNumber()) {
|
|
13950
13948
|
const value = this.next.toNumber();
|
|
@@ -13996,8 +13994,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13996
13994
|
}
|
|
13997
13995
|
return new LiteralMap(this.span(start), this.sourceSpan(start), keys, values);
|
|
13998
13996
|
}
|
|
13999
|
-
parseAccessMemberOrMethodCall(receiver, isSafe = false) {
|
|
14000
|
-
const start = receiver.span.start;
|
|
13997
|
+
parseAccessMemberOrMethodCall(receiver, start, isSafe = false) {
|
|
14001
13998
|
const nameStart = this.inputIndex;
|
|
14002
13999
|
const id = this.withContext(ParseContextFlags.Writable, () => {
|
|
14003
14000
|
var _a;
|
|
@@ -15230,6 +15227,9 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
15230
15227
|
else if (identifier.length === 0) {
|
|
15231
15228
|
this.reportError(`Reference does not have a name`, sourceSpan);
|
|
15232
15229
|
}
|
|
15230
|
+
else if (references.some(reference => reference.name === identifier)) {
|
|
15231
|
+
this.reportError(`Reference "#${identifier}" is defined more than once`, sourceSpan);
|
|
15232
|
+
}
|
|
15233
15233
|
references.push(new Reference(identifier, value, sourceSpan, keySpan, valueSpan));
|
|
15234
15234
|
}
|
|
15235
15235
|
parseAssignmentEvent(name, expression, sourceSpan, valueSpan, targetMatchableAttrs, boundEvents, keySpan) {
|
|
@@ -19021,7 +19021,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
19021
19021
|
* Use of this source code is governed by an MIT-style license that can be
|
|
19022
19022
|
* found in the LICENSE file at https://angular.io/license
|
|
19023
19023
|
*/
|
|
19024
|
-
const VERSION$1 = new Version('11.
|
|
19024
|
+
const VERSION$1 = new Version('11.2.0');
|
|
19025
19025
|
|
|
19026
19026
|
/**
|
|
19027
19027
|
* @license
|
|
@@ -27602,6 +27602,14 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
27602
27602
|
throwError(`Index out of range (expecting ${lower} <= ${index} < ${upper})`);
|
|
27603
27603
|
}
|
|
27604
27604
|
}
|
|
27605
|
+
function assertProjectionSlots(lView, errMessage) {
|
|
27606
|
+
assertDefined(lView[DECLARATION_COMPONENT_VIEW], 'Component views should exist.');
|
|
27607
|
+
assertDefined(lView[DECLARATION_COMPONENT_VIEW][T_HOST].projection, errMessage ||
|
|
27608
|
+
'Components with projection nodes (<ng-content>) must have projection slots defined.');
|
|
27609
|
+
}
|
|
27610
|
+
function assertParentView(lView, errMessage) {
|
|
27611
|
+
assertDefined(lView, errMessage || 'Component views should always have a parent view (component\'s host view)');
|
|
27612
|
+
}
|
|
27605
27613
|
/**
|
|
27606
27614
|
* This is a basic sanity check that the `injectorIndex` seems to point to what looks like a
|
|
27607
27615
|
* NodeInjector data structure.
|
|
@@ -31041,6 +31049,16 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
31041
31049
|
function nativeParentNode(renderer, node) {
|
|
31042
31050
|
return (isProceduralRenderer(renderer) ? renderer.parentNode(node) : node.parentNode);
|
|
31043
31051
|
}
|
|
31052
|
+
function getProjectionNodes(lView, tNode) {
|
|
31053
|
+
if (tNode !== null) {
|
|
31054
|
+
const componentView = lView[DECLARATION_COMPONENT_VIEW];
|
|
31055
|
+
const componentHost = componentView[T_HOST];
|
|
31056
|
+
const slotIdx = tNode.projection;
|
|
31057
|
+
ngDevMode && assertProjectionSlots(lView);
|
|
31058
|
+
return componentHost.projection[slotIdx];
|
|
31059
|
+
}
|
|
31060
|
+
return null;
|
|
31061
|
+
}
|
|
31044
31062
|
/**
|
|
31045
31063
|
* Removes a native node itself using a given renderer. To remove the node we are looking up its
|
|
31046
31064
|
* parent from the native tree as not all platforms / browsers support the equivalent of
|
|
@@ -35029,7 +35047,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
35029
35047
|
/**
|
|
35030
35048
|
* @publicApi
|
|
35031
35049
|
*/
|
|
35032
|
-
const VERSION$2 = new Version$1('11.
|
|
35050
|
+
const VERSION$2 = new Version$1('11.2.0');
|
|
35033
35051
|
|
|
35034
35052
|
/**
|
|
35035
35053
|
* @license
|
|
@@ -35281,24 +35299,25 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
35281
35299
|
// Remove the record from the collection since we know it does not match the item.
|
|
35282
35300
|
this._remove(record);
|
|
35283
35301
|
}
|
|
35284
|
-
//
|
|
35285
|
-
record = this.
|
|
35302
|
+
// See if we have evicted the item, which used to be at some anterior position of _itHead list.
|
|
35303
|
+
record = this._unlinkedRecords === null ? null : this._unlinkedRecords.get(itemTrackBy, null);
|
|
35286
35304
|
if (record !== null) {
|
|
35287
|
-
//
|
|
35288
|
-
// But first we need to check if identity changed, so we can update in view if necessary
|
|
35305
|
+
// It is an item which we have evicted earlier: reinsert it back into the list.
|
|
35306
|
+
// But first we need to check if identity changed, so we can update in view if necessary.
|
|
35289
35307
|
if (!Object.is(record.item, item))
|
|
35290
35308
|
this._addIdentityChange(record, item);
|
|
35291
|
-
this.
|
|
35309
|
+
this._reinsertAfter(record, previousRecord, index);
|
|
35292
35310
|
}
|
|
35293
35311
|
else {
|
|
35294
|
-
//
|
|
35295
|
-
record = this.
|
|
35312
|
+
// Attempt to see if the item is at some posterior position of _itHead list.
|
|
35313
|
+
record = this._linkedRecords === null ? null : this._linkedRecords.get(itemTrackBy, index);
|
|
35296
35314
|
if (record !== null) {
|
|
35297
|
-
//
|
|
35298
|
-
//
|
|
35315
|
+
// We have the item in _itHead at/after `index` position. We need to move it forward in the
|
|
35316
|
+
// collection.
|
|
35317
|
+
// But first we need to check if identity changed, so we can update in view if necessary.
|
|
35299
35318
|
if (!Object.is(record.item, item))
|
|
35300
35319
|
this._addIdentityChange(record, item);
|
|
35301
|
-
this.
|
|
35320
|
+
this._moveAfter(record, previousRecord, index);
|
|
35302
35321
|
}
|
|
35303
35322
|
else {
|
|
35304
35323
|
// It is a new item: add it.
|
|
@@ -36129,19 +36148,13 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
36129
36148
|
}
|
|
36130
36149
|
}
|
|
36131
36150
|
else if (tNodeType & 16 /* Projection */) {
|
|
36132
|
-
const
|
|
36133
|
-
const componentHost = componentView[T_HOST];
|
|
36134
|
-
const slotIdx = tNode.projection;
|
|
36135
|
-
ngDevMode &&
|
|
36136
|
-
assertDefined(componentHost.projection, 'Components with projection nodes (<ng-content>) must have projection slots defined.');
|
|
36137
|
-
const nodesInSlot = componentHost.projection[slotIdx];
|
|
36151
|
+
const nodesInSlot = getProjectionNodes(lView, tNode);
|
|
36138
36152
|
if (Array.isArray(nodesInSlot)) {
|
|
36139
36153
|
result.push(...nodesInSlot);
|
|
36140
36154
|
}
|
|
36141
36155
|
else {
|
|
36142
|
-
const parentView = getLViewParent(
|
|
36143
|
-
ngDevMode &&
|
|
36144
|
-
assertDefined(parentView, 'Component views should always have a parent view (component\'s host view)');
|
|
36156
|
+
const parentView = getLViewParent(lView[DECLARATION_COMPONENT_VIEW]);
|
|
36157
|
+
ngDevMode && assertParentView(parentView);
|
|
36145
36158
|
collectNativeNodes(parentView[TVIEW], parentView, nodesInSlot, result, true);
|
|
36146
36159
|
}
|
|
36147
36160
|
}
|
package/ivy/definitions.js
CHANGED
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
for (var definitionMetas_1 = tslib_1.__values(definitionMetas), definitionMetas_1_1 = definitionMetas_1.next(); !definitionMetas_1_1.done; definitionMetas_1_1 = definitionMetas_1.next()) {
|
|
53
53
|
var definitionMeta = definitionMetas_1_1.value;
|
|
54
54
|
// The `$event` of event handlers would point to the $event parameter in the shim file, as in
|
|
55
|
-
// `
|
|
55
|
+
// `_t3["x"].subscribe(function ($event): any { $event }) ;`
|
|
56
56
|
// If we wanted to return something for this, it would be more appropriate for something like
|
|
57
57
|
// `getTypeDefinition`.
|
|
58
58
|
if (utils_1.isDollarEvent(definitionMeta.node)) {
|
|
@@ -343,4 +343,4 @@
|
|
|
343
343
|
};
|
|
344
344
|
}
|
|
345
345
|
});
|
|
346
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"definitions.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/definitions.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AST, TmplAstBoundAttribute, TmplAstBoundEvent, TmplAstElement, TmplAstNode, TmplAstTemplate, TmplAstTextAttribute} from '@angular/compiler';\nimport {NgCompiler} from '@angular/compiler-cli/src/ngtsc/core';\nimport {isExternalResource} from '@angular/compiler-cli/src/ngtsc/metadata';\nimport {DirectiveSymbol, DomBindingSymbol, ElementSymbol, ShimLocation, Symbol, SymbolKind, TemplateSymbol} from '@angular/compiler-cli/src/ngtsc/typecheck/api';\nimport * as ts from 'typescript';\n\nimport {getTargetAtPosition, TargetNodeKind} from './template_target';\nimport {findTightestNode, getParentClassDeclaration} from './ts_utils';\nimport {flatMap, getDirectiveMatchesForAttribute, getDirectiveMatchesForElementTag, getTemplateInfoAtPosition, getTemplateLocationFromShimLocation, getTextSpanOfNode, isDollarEvent, isTypeScriptFile, TemplateInfo, toTextSpan} from './utils';\n\ninterface DefinitionMeta {\n  node: AST|TmplAstNode;\n  parent: AST|TmplAstNode|null;\n  symbol: Symbol;\n}\n\ninterface HasShimLocation {\n  shimLocation: ShimLocation;\n}\n\nexport class DefinitionBuilder {\n  constructor(private readonly tsLS: ts.LanguageService, private readonly compiler: NgCompiler) {}\n\n  getDefinitionAndBoundSpan(fileName: string, position: number): ts.DefinitionInfoAndBoundSpan\n      |undefined {\n    const templateInfo = getTemplateInfoAtPosition(fileName, position, this.compiler);\n    if (templateInfo === undefined) {\n      // We were unable to get a template at the given position. If we are in a TS file, instead\n      // attempt to get an Angular definition at the location inside a TS file (examples of this\n      // would be templateUrl or a url in styleUrls).\n      if (!isTypeScriptFile(fileName)) {\n        return;\n      }\n      return getDefinitionForExpressionAtPosition(fileName, position, this.compiler);\n    }\n    const definitionMetas = this.getDefinitionMetaAtPosition(templateInfo, position);\n    if (definitionMetas === undefined) {\n      return undefined;\n    }\n    const definitions: ts.DefinitionInfo[] = [];\n    for (const definitionMeta of definitionMetas) {\n      // The `$event` of event handlers would point to the $event parameter in the shim file, as in\n      // `_outputHelper(_t3[\"x\"]).subscribe(function ($event): any { $event }) ;`\n      // If we wanted to return something for this, it would be more appropriate for something like\n      // `getTypeDefinition`.\n      if (isDollarEvent(definitionMeta.node)) {\n        continue;\n      }\n\n      definitions.push(\n          ...(this.getDefinitionsForSymbol({...definitionMeta, ...templateInfo}) ?? []));\n    }\n\n    if (definitions.length === 0) {\n      return undefined;\n    }\n\n    return {definitions, textSpan: getTextSpanOfNode(definitionMetas[0].node)};\n  }\n\n  private getDefinitionsForSymbol({symbol, node, parent, component}: DefinitionMeta&\n                                  TemplateInfo): readonly ts.DefinitionInfo[]|undefined {\n    switch (symbol.kind) {\n      case SymbolKind.Directive:\n      case SymbolKind.Element:\n      case SymbolKind.Template:\n      case SymbolKind.DomBinding:\n        // Though it is generally more appropriate for the above symbol definitions to be\n        // associated with \"type definitions\" since the location in the template is the\n        // actual definition location, the better user experience would be to allow\n        // LS users to \"go to definition\" on an item in the template that maps to a class and be\n        // taken to the directive or HTML class.\n        return this.getTypeDefinitionsForTemplateInstance(symbol, node);\n      case SymbolKind.Pipe: {\n        if (symbol.tsSymbol !== null) {\n          return this.getDefinitionsForSymbols(symbol);\n        } else {\n          // If there is no `ts.Symbol` for the pipe transform, we want to return the\n          // type definition (the pipe class).\n          return this.getTypeDefinitionsForSymbols(symbol.classSymbol);\n        }\n      }\n      case SymbolKind.Output:\n      case SymbolKind.Input: {\n        const bindingDefs = this.getDefinitionsForSymbols(...symbol.bindings);\n        // Also attempt to get directive matches for the input name. If there is a directive that\n        // has the input name as part of the selector, we want to return that as well.\n        const directiveDefs = this.getDirectiveTypeDefsForBindingNode(node, parent, component);\n        return [...bindingDefs, ...directiveDefs];\n      }\n      case SymbolKind.Variable:\n      case SymbolKind.Reference: {\n        const definitions: ts.DefinitionInfo[] = [];\n        if (symbol.declaration !== node) {\n          const shimLocation = symbol.kind === SymbolKind.Variable ? symbol.localVarLocation :\n                                                                     symbol.referenceVarLocation;\n          const mapping = getTemplateLocationFromShimLocation(\n              this.compiler.getTemplateTypeChecker(), shimLocation.shimPath,\n              shimLocation.positionInShimFile);\n          if (mapping !== null) {\n            definitions.push({\n              name: symbol.declaration.name,\n              containerName: '',\n              containerKind: ts.ScriptElementKind.unknown,\n              kind: ts.ScriptElementKind.variableElement,\n              textSpan: getTextSpanOfNode(symbol.declaration),\n              contextSpan: toTextSpan(symbol.declaration.sourceSpan),\n              fileName: mapping.templateUrl,\n            });\n          }\n        }\n        if (symbol.kind === SymbolKind.Variable) {\n          definitions.push(\n              ...this.getDefinitionsForSymbols({shimLocation: symbol.initializerLocation}));\n        }\n        return definitions;\n      }\n      case SymbolKind.Expression: {\n        return this.getDefinitionsForSymbols(symbol);\n      }\n    }\n  }\n\n  private getDefinitionsForSymbols(...symbols: HasShimLocation[]): ts.DefinitionInfo[] {\n    return flatMap(symbols, ({shimLocation}) => {\n      const {shimPath, positionInShimFile} = shimLocation;\n      return this.tsLS.getDefinitionAtPosition(shimPath, positionInShimFile) ?? [];\n    });\n  }\n\n  getTypeDefinitionsAtPosition(fileName: string, position: number):\n      readonly ts.DefinitionInfo[]|undefined {\n    const templateInfo = getTemplateInfoAtPosition(fileName, position, this.compiler);\n    if (templateInfo === undefined) {\n      return;\n    }\n    const definitionMetas = this.getDefinitionMetaAtPosition(templateInfo, position);\n    if (definitionMetas === undefined) {\n      return undefined;\n    }\n\n    const definitions: ts.DefinitionInfo[] = [];\n    for (const {symbol, node, parent} of definitionMetas) {\n      switch (symbol.kind) {\n        case SymbolKind.Directive:\n        case SymbolKind.DomBinding:\n        case SymbolKind.Element:\n        case SymbolKind.Template:\n          definitions.push(...this.getTypeDefinitionsForTemplateInstance(symbol, node));\n          break;\n        case SymbolKind.Output:\n        case SymbolKind.Input: {\n          const bindingDefs = this.getTypeDefinitionsForSymbols(...symbol.bindings);\n          definitions.push(...bindingDefs);\n          // Also attempt to get directive matches for the input name. If there is a directive that\n          // has the input name as part of the selector, we want to return that as well.\n          const directiveDefs =\n              this.getDirectiveTypeDefsForBindingNode(node, parent, templateInfo.component);\n          definitions.push(...directiveDefs);\n          break;\n        }\n        case SymbolKind.Pipe: {\n          if (symbol.tsSymbol !== null) {\n            definitions.push(...this.getTypeDefinitionsForSymbols(symbol));\n          } else {\n            // If there is no `ts.Symbol` for the pipe transform, we want to return the\n            // type definition (the pipe class).\n            definitions.push(...this.getTypeDefinitionsForSymbols(symbol.classSymbol));\n          }\n          break;\n        }\n        case SymbolKind.Reference:\n          definitions.push(\n              ...this.getTypeDefinitionsForSymbols({shimLocation: symbol.targetLocation}));\n          break;\n        case SymbolKind.Expression:\n          definitions.push(...this.getTypeDefinitionsForSymbols(symbol));\n          break;\n        case SymbolKind.Variable: {\n          definitions.push(\n              ...this.getTypeDefinitionsForSymbols({shimLocation: symbol.initializerLocation}));\n          break;\n        }\n      }\n      return definitions;\n    }\n  }\n\n  private getTypeDefinitionsForTemplateInstance(\n      symbol: TemplateSymbol|ElementSymbol|DomBindingSymbol|DirectiveSymbol,\n      node: AST|TmplAstNode): ts.DefinitionInfo[] {\n    switch (symbol.kind) {\n      case SymbolKind.Template: {\n        const matches = getDirectiveMatchesForElementTag(symbol.templateNode, symbol.directives);\n        return this.getTypeDefinitionsForSymbols(...matches);\n      }\n      case SymbolKind.Element: {\n        const matches = getDirectiveMatchesForElementTag(symbol.templateNode, symbol.directives);\n        // If one of the directive matches is a component, we should not include the native element\n        // in the results because it is replaced by the component.\n        return Array.from(matches).some(dir => dir.isComponent) ?\n            this.getTypeDefinitionsForSymbols(...matches) :\n            this.getTypeDefinitionsForSymbols(...matches, symbol);\n      }\n      case SymbolKind.DomBinding: {\n        if (!(node instanceof TmplAstTextAttribute)) {\n          return [];\n        }\n        const dirs = getDirectiveMatchesForAttribute(\n            node.name, symbol.host.templateNode, symbol.host.directives);\n        return this.getTypeDefinitionsForSymbols(...dirs);\n      }\n      case SymbolKind.Directive:\n        return this.getTypeDefinitionsForSymbols(symbol);\n    }\n  }\n\n  private getDirectiveTypeDefsForBindingNode(\n      node: TmplAstNode|AST, parent: TmplAstNode|AST|null, component: ts.ClassDeclaration) {\n    if (!(node instanceof TmplAstBoundAttribute) && !(node instanceof TmplAstTextAttribute) &&\n        !(node instanceof TmplAstBoundEvent)) {\n      return [];\n    }\n    if (parent === null ||\n        !(parent instanceof TmplAstTemplate || parent instanceof TmplAstElement)) {\n      return [];\n    }\n    const templateOrElementSymbol =\n        this.compiler.getTemplateTypeChecker().getSymbolOfNode(parent, component);\n    if (templateOrElementSymbol === null ||\n        (templateOrElementSymbol.kind !== SymbolKind.Template &&\n         templateOrElementSymbol.kind !== SymbolKind.Element)) {\n      return [];\n    }\n    const dirs =\n        getDirectiveMatchesForAttribute(node.name, parent, templateOrElementSymbol.directives);\n    return this.getTypeDefinitionsForSymbols(...dirs);\n  }\n\n  private getTypeDefinitionsForSymbols(...symbols: HasShimLocation[]): ts.DefinitionInfo[] {\n    return flatMap(symbols, ({shimLocation}) => {\n      const {shimPath, positionInShimFile} = shimLocation;\n      return this.tsLS.getTypeDefinitionAtPosition(shimPath, positionInShimFile) ?? [];\n    });\n  }\n\n  private getDefinitionMetaAtPosition({template, component}: TemplateInfo, position: number):\n      DefinitionMeta[]|undefined {\n    const target = getTargetAtPosition(template, position);\n    if (target === null) {\n      return undefined;\n    }\n    const {context, parent} = target;\n\n    const nodes =\n        context.kind === TargetNodeKind.TwoWayBindingContext ? context.nodes : [context.node];\n\n\n    const definitionMetas: DefinitionMeta[] = [];\n    for (const node of nodes) {\n      const symbol = this.compiler.getTemplateTypeChecker().getSymbolOfNode(node, component);\n      if (symbol === null) {\n        continue;\n      }\n      definitionMetas.push({node, parent, symbol});\n    }\n    return definitionMetas.length > 0 ? definitionMetas : undefined;\n  }\n}\n\n/**\n * Gets an Angular-specific definition in a TypeScript source file.\n */\nfunction getDefinitionForExpressionAtPosition(\n    fileName: string, position: number, compiler: NgCompiler): ts.DefinitionInfoAndBoundSpan|\n    undefined {\n  const sf = compiler.getNextProgram().getSourceFile(fileName);\n  if (sf === undefined) {\n    return;\n  }\n\n  const expression = findTightestNode(sf, position);\n  if (expression === undefined) {\n    return;\n  }\n  const classDeclaration = getParentClassDeclaration(expression);\n  if (classDeclaration === undefined) {\n    return;\n  }\n  const componentResources = compiler.getComponentResources(classDeclaration);\n  if (componentResources === null) {\n    return;\n  }\n\n  const allResources = [...componentResources.styles, componentResources.template];\n\n  const resourceForExpression = allResources.find(resource => resource.expression === expression);\n  if (resourceForExpression === undefined || !isExternalResource(resourceForExpression)) {\n    return;\n  }\n\n  const templateDefinitions: ts.DefinitionInfo[] = [{\n    kind: ts.ScriptElementKind.externalModuleName,\n    name: resourceForExpression.path,\n    containerKind: ts.ScriptElementKind.unknown,\n    containerName: '',\n    // Reading the template is expensive, so don't provide a preview.\n    // TODO(ayazhafiz): Consider providing an actual span:\n    //  1. We're likely to read the template anyway\n    //  2. We could show just the first 100 chars or so\n    textSpan: {start: 0, length: 0},\n    fileName: resourceForExpression.path,\n  }];\n\n  return {\n    definitions: templateDefinitions,\n    textSpan: {\n      // Exclude opening and closing quotes in the url span.\n      start: expression.getStart() + 1,\n      length: expression.getWidth() - 2,\n    },\n  };\n}\n"]}
|
|
346
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"definitions.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/definitions.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {AST, TmplAstBoundAttribute, TmplAstBoundEvent, TmplAstElement, TmplAstNode, TmplAstTemplate, TmplAstTextAttribute} from '@angular/compiler';\nimport {NgCompiler} from '@angular/compiler-cli/src/ngtsc/core';\nimport {isExternalResource} from '@angular/compiler-cli/src/ngtsc/metadata';\nimport {DirectiveSymbol, DomBindingSymbol, ElementSymbol, ShimLocation, Symbol, SymbolKind, TemplateSymbol} from '@angular/compiler-cli/src/ngtsc/typecheck/api';\nimport * as ts from 'typescript';\n\nimport {getTargetAtPosition, TargetNodeKind} from './template_target';\nimport {findTightestNode, getParentClassDeclaration} from './ts_utils';\nimport {flatMap, getDirectiveMatchesForAttribute, getDirectiveMatchesForElementTag, getTemplateInfoAtPosition, getTemplateLocationFromShimLocation, getTextSpanOfNode, isDollarEvent, isTypeScriptFile, TemplateInfo, toTextSpan} from './utils';\n\ninterface DefinitionMeta {\n  node: AST|TmplAstNode;\n  parent: AST|TmplAstNode|null;\n  symbol: Symbol;\n}\n\ninterface HasShimLocation {\n  shimLocation: ShimLocation;\n}\n\nexport class DefinitionBuilder {\n  constructor(private readonly tsLS: ts.LanguageService, private readonly compiler: NgCompiler) {}\n\n  getDefinitionAndBoundSpan(fileName: string, position: number): ts.DefinitionInfoAndBoundSpan\n      |undefined {\n    const templateInfo = getTemplateInfoAtPosition(fileName, position, this.compiler);\n    if (templateInfo === undefined) {\n      // We were unable to get a template at the given position. If we are in a TS file, instead\n      // attempt to get an Angular definition at the location inside a TS file (examples of this\n      // would be templateUrl or a url in styleUrls).\n      if (!isTypeScriptFile(fileName)) {\n        return;\n      }\n      return getDefinitionForExpressionAtPosition(fileName, position, this.compiler);\n    }\n    const definitionMetas = this.getDefinitionMetaAtPosition(templateInfo, position);\n    if (definitionMetas === undefined) {\n      return undefined;\n    }\n    const definitions: ts.DefinitionInfo[] = [];\n    for (const definitionMeta of definitionMetas) {\n      // The `$event` of event handlers would point to the $event parameter in the shim file, as in\n      // `_t3[\"x\"].subscribe(function ($event): any { $event }) ;`\n      // If we wanted to return something for this, it would be more appropriate for something like\n      // `getTypeDefinition`.\n      if (isDollarEvent(definitionMeta.node)) {\n        continue;\n      }\n\n      definitions.push(\n          ...(this.getDefinitionsForSymbol({...definitionMeta, ...templateInfo}) ?? []));\n    }\n\n    if (definitions.length === 0) {\n      return undefined;\n    }\n\n    return {definitions, textSpan: getTextSpanOfNode(definitionMetas[0].node)};\n  }\n\n  private getDefinitionsForSymbol({symbol, node, parent, component}: DefinitionMeta&\n                                  TemplateInfo): readonly ts.DefinitionInfo[]|undefined {\n    switch (symbol.kind) {\n      case SymbolKind.Directive:\n      case SymbolKind.Element:\n      case SymbolKind.Template:\n      case SymbolKind.DomBinding:\n        // Though it is generally more appropriate for the above symbol definitions to be\n        // associated with \"type definitions\" since the location in the template is the\n        // actual definition location, the better user experience would be to allow\n        // LS users to \"go to definition\" on an item in the template that maps to a class and be\n        // taken to the directive or HTML class.\n        return this.getTypeDefinitionsForTemplateInstance(symbol, node);\n      case SymbolKind.Pipe: {\n        if (symbol.tsSymbol !== null) {\n          return this.getDefinitionsForSymbols(symbol);\n        } else {\n          // If there is no `ts.Symbol` for the pipe transform, we want to return the\n          // type definition (the pipe class).\n          return this.getTypeDefinitionsForSymbols(symbol.classSymbol);\n        }\n      }\n      case SymbolKind.Output:\n      case SymbolKind.Input: {\n        const bindingDefs = this.getDefinitionsForSymbols(...symbol.bindings);\n        // Also attempt to get directive matches for the input name. If there is a directive that\n        // has the input name as part of the selector, we want to return that as well.\n        const directiveDefs = this.getDirectiveTypeDefsForBindingNode(node, parent, component);\n        return [...bindingDefs, ...directiveDefs];\n      }\n      case SymbolKind.Variable:\n      case SymbolKind.Reference: {\n        const definitions: ts.DefinitionInfo[] = [];\n        if (symbol.declaration !== node) {\n          const shimLocation = symbol.kind === SymbolKind.Variable ? symbol.localVarLocation :\n                                                                     symbol.referenceVarLocation;\n          const mapping = getTemplateLocationFromShimLocation(\n              this.compiler.getTemplateTypeChecker(), shimLocation.shimPath,\n              shimLocation.positionInShimFile);\n          if (mapping !== null) {\n            definitions.push({\n              name: symbol.declaration.name,\n              containerName: '',\n              containerKind: ts.ScriptElementKind.unknown,\n              kind: ts.ScriptElementKind.variableElement,\n              textSpan: getTextSpanOfNode(symbol.declaration),\n              contextSpan: toTextSpan(symbol.declaration.sourceSpan),\n              fileName: mapping.templateUrl,\n            });\n          }\n        }\n        if (symbol.kind === SymbolKind.Variable) {\n          definitions.push(\n              ...this.getDefinitionsForSymbols({shimLocation: symbol.initializerLocation}));\n        }\n        return definitions;\n      }\n      case SymbolKind.Expression: {\n        return this.getDefinitionsForSymbols(symbol);\n      }\n    }\n  }\n\n  private getDefinitionsForSymbols(...symbols: HasShimLocation[]): ts.DefinitionInfo[] {\n    return flatMap(symbols, ({shimLocation}) => {\n      const {shimPath, positionInShimFile} = shimLocation;\n      return this.tsLS.getDefinitionAtPosition(shimPath, positionInShimFile) ?? [];\n    });\n  }\n\n  getTypeDefinitionsAtPosition(fileName: string, position: number):\n      readonly ts.DefinitionInfo[]|undefined {\n    const templateInfo = getTemplateInfoAtPosition(fileName, position, this.compiler);\n    if (templateInfo === undefined) {\n      return;\n    }\n    const definitionMetas = this.getDefinitionMetaAtPosition(templateInfo, position);\n    if (definitionMetas === undefined) {\n      return undefined;\n    }\n\n    const definitions: ts.DefinitionInfo[] = [];\n    for (const {symbol, node, parent} of definitionMetas) {\n      switch (symbol.kind) {\n        case SymbolKind.Directive:\n        case SymbolKind.DomBinding:\n        case SymbolKind.Element:\n        case SymbolKind.Template:\n          definitions.push(...this.getTypeDefinitionsForTemplateInstance(symbol, node));\n          break;\n        case SymbolKind.Output:\n        case SymbolKind.Input: {\n          const bindingDefs = this.getTypeDefinitionsForSymbols(...symbol.bindings);\n          definitions.push(...bindingDefs);\n          // Also attempt to get directive matches for the input name. If there is a directive that\n          // has the input name as part of the selector, we want to return that as well.\n          const directiveDefs =\n              this.getDirectiveTypeDefsForBindingNode(node, parent, templateInfo.component);\n          definitions.push(...directiveDefs);\n          break;\n        }\n        case SymbolKind.Pipe: {\n          if (symbol.tsSymbol !== null) {\n            definitions.push(...this.getTypeDefinitionsForSymbols(symbol));\n          } else {\n            // If there is no `ts.Symbol` for the pipe transform, we want to return the\n            // type definition (the pipe class).\n            definitions.push(...this.getTypeDefinitionsForSymbols(symbol.classSymbol));\n          }\n          break;\n        }\n        case SymbolKind.Reference:\n          definitions.push(\n              ...this.getTypeDefinitionsForSymbols({shimLocation: symbol.targetLocation}));\n          break;\n        case SymbolKind.Expression:\n          definitions.push(...this.getTypeDefinitionsForSymbols(symbol));\n          break;\n        case SymbolKind.Variable: {\n          definitions.push(\n              ...this.getTypeDefinitionsForSymbols({shimLocation: symbol.initializerLocation}));\n          break;\n        }\n      }\n      return definitions;\n    }\n  }\n\n  private getTypeDefinitionsForTemplateInstance(\n      symbol: TemplateSymbol|ElementSymbol|DomBindingSymbol|DirectiveSymbol,\n      node: AST|TmplAstNode): ts.DefinitionInfo[] {\n    switch (symbol.kind) {\n      case SymbolKind.Template: {\n        const matches = getDirectiveMatchesForElementTag(symbol.templateNode, symbol.directives);\n        return this.getTypeDefinitionsForSymbols(...matches);\n      }\n      case SymbolKind.Element: {\n        const matches = getDirectiveMatchesForElementTag(symbol.templateNode, symbol.directives);\n        // If one of the directive matches is a component, we should not include the native element\n        // in the results because it is replaced by the component.\n        return Array.from(matches).some(dir => dir.isComponent) ?\n            this.getTypeDefinitionsForSymbols(...matches) :\n            this.getTypeDefinitionsForSymbols(...matches, symbol);\n      }\n      case SymbolKind.DomBinding: {\n        if (!(node instanceof TmplAstTextAttribute)) {\n          return [];\n        }\n        const dirs = getDirectiveMatchesForAttribute(\n            node.name, symbol.host.templateNode, symbol.host.directives);\n        return this.getTypeDefinitionsForSymbols(...dirs);\n      }\n      case SymbolKind.Directive:\n        return this.getTypeDefinitionsForSymbols(symbol);\n    }\n  }\n\n  private getDirectiveTypeDefsForBindingNode(\n      node: TmplAstNode|AST, parent: TmplAstNode|AST|null, component: ts.ClassDeclaration) {\n    if (!(node instanceof TmplAstBoundAttribute) && !(node instanceof TmplAstTextAttribute) &&\n        !(node instanceof TmplAstBoundEvent)) {\n      return [];\n    }\n    if (parent === null ||\n        !(parent instanceof TmplAstTemplate || parent instanceof TmplAstElement)) {\n      return [];\n    }\n    const templateOrElementSymbol =\n        this.compiler.getTemplateTypeChecker().getSymbolOfNode(parent, component);\n    if (templateOrElementSymbol === null ||\n        (templateOrElementSymbol.kind !== SymbolKind.Template &&\n         templateOrElementSymbol.kind !== SymbolKind.Element)) {\n      return [];\n    }\n    const dirs =\n        getDirectiveMatchesForAttribute(node.name, parent, templateOrElementSymbol.directives);\n    return this.getTypeDefinitionsForSymbols(...dirs);\n  }\n\n  private getTypeDefinitionsForSymbols(...symbols: HasShimLocation[]): ts.DefinitionInfo[] {\n    return flatMap(symbols, ({shimLocation}) => {\n      const {shimPath, positionInShimFile} = shimLocation;\n      return this.tsLS.getTypeDefinitionAtPosition(shimPath, positionInShimFile) ?? [];\n    });\n  }\n\n  private getDefinitionMetaAtPosition({template, component}: TemplateInfo, position: number):\n      DefinitionMeta[]|undefined {\n    const target = getTargetAtPosition(template, position);\n    if (target === null) {\n      return undefined;\n    }\n    const {context, parent} = target;\n\n    const nodes =\n        context.kind === TargetNodeKind.TwoWayBindingContext ? context.nodes : [context.node];\n\n\n    const definitionMetas: DefinitionMeta[] = [];\n    for (const node of nodes) {\n      const symbol = this.compiler.getTemplateTypeChecker().getSymbolOfNode(node, component);\n      if (symbol === null) {\n        continue;\n      }\n      definitionMetas.push({node, parent, symbol});\n    }\n    return definitionMetas.length > 0 ? definitionMetas : undefined;\n  }\n}\n\n/**\n * Gets an Angular-specific definition in a TypeScript source file.\n */\nfunction getDefinitionForExpressionAtPosition(\n    fileName: string, position: number, compiler: NgCompiler): ts.DefinitionInfoAndBoundSpan|\n    undefined {\n  const sf = compiler.getNextProgram().getSourceFile(fileName);\n  if (sf === undefined) {\n    return;\n  }\n\n  const expression = findTightestNode(sf, position);\n  if (expression === undefined) {\n    return;\n  }\n  const classDeclaration = getParentClassDeclaration(expression);\n  if (classDeclaration === undefined) {\n    return;\n  }\n  const componentResources = compiler.getComponentResources(classDeclaration);\n  if (componentResources === null) {\n    return;\n  }\n\n  const allResources = [...componentResources.styles, componentResources.template];\n\n  const resourceForExpression = allResources.find(resource => resource.expression === expression);\n  if (resourceForExpression === undefined || !isExternalResource(resourceForExpression)) {\n    return;\n  }\n\n  const templateDefinitions: ts.DefinitionInfo[] = [{\n    kind: ts.ScriptElementKind.externalModuleName,\n    name: resourceForExpression.path,\n    containerKind: ts.ScriptElementKind.unknown,\n    containerName: '',\n    // Reading the template is expensive, so don't provide a preview.\n    // TODO(ayazhafiz): Consider providing an actual span:\n    //  1. We're likely to read the template anyway\n    //  2. We could show just the first 100 chars or so\n    textSpan: {start: 0, length: 0},\n    fileName: resourceForExpression.path,\n  }];\n\n  return {\n    definitions: templateDefinitions,\n    textSpan: {\n      // Exclude opening and closing quotes in the url span.\n      start: expression.getStart() + 1,\n      length: expression.getWidth() - 2,\n    },\n  };\n}\n"]}
|
|
@@ -8,6 +8,7 @@
|
|
|
8
8
|
/// <amd-module name="@angular/language-service/ivy/language_service" />
|
|
9
9
|
import { CompilerOptions } from '@angular/compiler-cli';
|
|
10
10
|
import * as ts from 'typescript/lib/tsserverlibrary';
|
|
11
|
+
import { GetTcbResponse } from '../api';
|
|
11
12
|
import { CompilerFactory } from './compiler_factory';
|
|
12
13
|
export declare class LanguageService {
|
|
13
14
|
private readonly project;
|
|
@@ -24,10 +25,14 @@ export declare class LanguageService {
|
|
|
24
25
|
getTypeDefinitionAtPosition(fileName: string, position: number): readonly ts.DefinitionInfo[] | undefined;
|
|
25
26
|
getQuickInfoAtPosition(fileName: string, position: number): ts.QuickInfo | undefined;
|
|
26
27
|
getReferencesAtPosition(fileName: string, position: number): ts.ReferenceEntry[] | undefined;
|
|
28
|
+
getRenameInfo(fileName: string, position: number): ts.RenameInfo;
|
|
29
|
+
findRenameLocations(fileName: string, position: number): readonly ts.RenameLocation[] | undefined;
|
|
27
30
|
private getCompletionBuilder;
|
|
28
31
|
getCompletionsAtPosition(fileName: string, position: number, options: ts.GetCompletionsAtPositionOptions | undefined): ts.WithMetadata<ts.CompletionInfo> | undefined;
|
|
29
32
|
getCompletionEntryDetails(fileName: string, position: number, entryName: string, formatOptions: ts.FormatCodeOptions | ts.FormatCodeSettings | undefined, preferences: ts.UserPreferences | undefined): ts.CompletionEntryDetails | undefined;
|
|
30
33
|
getCompletionEntrySymbol(fileName: string, position: number, entryName: string): ts.Symbol | undefined;
|
|
34
|
+
getTcb(fileName: string, position: number): GetTcbResponse;
|
|
35
|
+
private withCompiler;
|
|
31
36
|
getCompilerOptionsDiagnostics(): ts.Diagnostic[];
|
|
32
37
|
private watchConfigFile;
|
|
33
38
|
}
|