@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.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v11.1.2
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(resultStart), this.sourceSpan(resultStart), result, key, value);
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(resultStart), this.sourceSpan(resultStart), result);
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.1.2');
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.1.2');
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
- // Attempt to see if we have seen the item before.
35285
- record = this._linkedRecords === null ? null : this._linkedRecords.get(itemTrackBy, index);
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
- // We have seen this before, we need to move it forward in the collection.
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._moveAfter(record, previousRecord, index);
35309
+ this._reinsertAfter(record, previousRecord, index);
35292
35310
  }
35293
35311
  else {
35294
- // Never seen it, check evicted list.
35295
- record = this._unlinkedRecords === null ? null : this._unlinkedRecords.get(itemTrackBy, null);
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
- // It is an item which we have evicted earlier: reinsert it back into the list.
35298
- // But first we need to check if identity changed, so we can update in view if necessary
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._reinsertAfter(record, previousRecord, index);
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 componentView = lView[DECLARATION_COMPONENT_VIEW];
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(componentView);
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
  }
@@ -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
- // `_outputHelper(_t3["x"]).subscribe(function ($event): any { $event }) ;`
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
  }