@angular/language-service 9.0.0-rc.6 → 9.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/src/hover.d.ts CHANGED
@@ -6,21 +6,22 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  /// <amd-module name="@angular/language-service/src/hover" />
9
+ import { NgAnalyzedModules } from '@angular/compiler';
9
10
  import * as ts from 'typescript';
10
11
  import { AstResult } from './common';
11
- import { TypeScriptServiceHost } from './typescript_host';
12
+ import * as ng from './types';
12
13
  /**
13
14
  * Traverse the template AST and look for the symbol located at `position`, then
14
15
  * return the corresponding quick info.
15
16
  * @param info template AST
16
17
  * @param position location of the symbol
17
- * @param host Language Service host to query
18
+ * @param analyzedModules all NgModules in the program.
18
19
  */
19
- export declare function getHover(info: AstResult, position: number, host: Readonly<TypeScriptServiceHost>): ts.QuickInfo | undefined;
20
+ export declare function getTemplateHover(info: AstResult, position: number, analyzedModules: NgAnalyzedModules): ts.QuickInfo | undefined;
20
21
  /**
21
22
  * Get quick info for Angular semantic entities in TypeScript files, like Directives.
22
- * @param sf TypeScript source file an Angular symbol is in
23
23
  * @param position location of the symbol in the source file
24
- * @param host Language Service host to query
24
+ * @param declarations All Directive-like declarations in the source file.
25
+ * @param analyzedModules all NgModules in the program.
25
26
  */
26
- export declare function getTsHover(sf: ts.SourceFile, position: number, host: Readonly<TypeScriptServiceHost>): ts.QuickInfo | undefined;
27
+ export declare function getTsHover(position: number, declarations: ng.Declaration[], analyzedModules: NgAnalyzedModules): ts.QuickInfo | undefined;
package/src/hover.js CHANGED
@@ -11,120 +11,115 @@
11
11
  if (v !== undefined) module.exports = v;
12
12
  }
13
13
  else if (typeof define === "function" && define.amd) {
14
- define("@angular/language-service/src/hover", ["require", "exports", "tslib", "@angular/compiler", "typescript", "@angular/language-service/src/locate_symbol", "@angular/language-service/src/utils"], factory);
14
+ define("@angular/language-service/src/hover", ["require", "exports", "tslib", "typescript", "@angular/language-service/src/locate_symbol", "@angular/language-service/src/utils"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
19
  var tslib_1 = require("tslib");
20
- var compiler_1 = require("@angular/compiler");
21
20
  var ts = require("typescript");
22
21
  var locate_symbol_1 = require("@angular/language-service/src/locate_symbol");
23
22
  var utils_1 = require("@angular/language-service/src/utils");
24
23
  // Reverse mappings of enum would generate strings
25
24
  var SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];
26
25
  var SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];
27
- var SYMBOL_CLASS = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.className];
28
26
  var SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];
27
+ var SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];
29
28
  /**
30
29
  * Traverse the template AST and look for the symbol located at `position`, then
31
30
  * return the corresponding quick info.
32
31
  * @param info template AST
33
32
  * @param position location of the symbol
34
- * @param host Language Service host to query
33
+ * @param analyzedModules all NgModules in the program.
35
34
  */
36
- function getHover(info, position, host) {
37
- var symbolInfo = locate_symbol_1.locateSymbol(info, position);
35
+ function getTemplateHover(info, position, analyzedModules) {
36
+ var _a, _b, _c;
37
+ var symbolInfo = locate_symbol_1.locateSymbols(info, position)[0];
38
38
  if (!symbolInfo) {
39
39
  return;
40
40
  }
41
- var symbol = symbolInfo.symbol, span = symbolInfo.span, compileTypeSummary = symbolInfo.compileTypeSummary;
42
- var textSpan = { start: span.start, length: span.end - span.start };
43
- if (compileTypeSummary && compileTypeSummary.summaryKind === compiler_1.CompileSummaryKind.Directive) {
44
- return getDirectiveModule(compileTypeSummary.type.reference, textSpan, host);
41
+ var symbol = symbolInfo.symbol, span = symbolInfo.span, staticSymbol = symbolInfo.staticSymbol;
42
+ // The container is either the symbol's container (for example, 'AppComponent'
43
+ // is the container of the symbol 'title' in its template) or the NgModule
44
+ // that the directive belongs to (the container of AppComponent is AppModule).
45
+ var containerName = (_a = symbol.container) === null || _a === void 0 ? void 0 : _a.name;
46
+ if (!containerName && staticSymbol) {
47
+ // If there is a static symbol then the target is a directive.
48
+ var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);
49
+ containerName = (_b = ngModule) === null || _b === void 0 ? void 0 : _b.type.reference.name;
45
50
  }
46
- var containerDisplayParts = symbol.container ?
47
- [
48
- { text: symbol.container.name, kind: symbol.container.kind },
49
- { text: '.', kind: SYMBOL_PUNC },
50
- ] :
51
- [];
52
- return {
53
- kind: symbol.kind,
54
- kindModifiers: '',
55
- textSpan: textSpan,
56
- // this would generate a string like '(property) ClassX.propY'
57
- // 'kind' in displayParts does not really matter because it's dropped when
58
- // displayParts get converted to string.
59
- displayParts: tslib_1.__spread([
60
- { text: '(', kind: SYMBOL_PUNC }, { text: symbol.kind, kind: symbol.kind },
61
- { text: ')', kind: SYMBOL_PUNC }, { text: ' ', kind: SYMBOL_SPACE }
62
- ], containerDisplayParts, [
63
- { text: symbol.name, kind: symbol.kind },
64
- ]),
65
- };
51
+ return createQuickInfo(symbol.name, symbol.kind, span, containerName, (_c = symbol.type) === null || _c === void 0 ? void 0 : _c.name, symbol.documentation);
66
52
  }
67
- exports.getHover = getHover;
53
+ exports.getTemplateHover = getTemplateHover;
68
54
  /**
69
55
  * Get quick info for Angular semantic entities in TypeScript files, like Directives.
70
- * @param sf TypeScript source file an Angular symbol is in
71
56
  * @param position location of the symbol in the source file
72
- * @param host Language Service host to query
57
+ * @param declarations All Directive-like declarations in the source file.
58
+ * @param analyzedModules all NgModules in the program.
73
59
  */
74
- function getTsHover(sf, position, host) {
75
- var node = utils_1.findTightestNode(sf, position);
76
- if (!node)
77
- return;
78
- switch (node.kind) {
79
- case ts.SyntaxKind.Identifier:
80
- var directiveId = node;
81
- if (ts.isClassDeclaration(directiveId.parent)) {
82
- var directiveName = directiveId.text;
83
- var directiveSymbol = host.getStaticSymbol(node.getSourceFile().fileName, directiveName);
84
- if (!directiveSymbol)
85
- return;
86
- return getDirectiveModule(directiveSymbol, { start: directiveId.getStart(), length: directiveId.end - directiveId.getStart() }, host);
60
+ function getTsHover(position, declarations, analyzedModules) {
61
+ var e_1, _a;
62
+ var _b;
63
+ try {
64
+ for (var declarations_1 = tslib_1.__values(declarations), declarations_1_1 = declarations_1.next(); !declarations_1_1.done; declarations_1_1 = declarations_1.next()) {
65
+ var _c = declarations_1_1.value, declarationSpan = _c.declarationSpan, metadata = _c.metadata;
66
+ if (utils_1.inSpan(position, declarationSpan)) {
67
+ var staticSymbol = metadata.type.reference;
68
+ var directiveName = staticSymbol.name;
69
+ var kind = metadata.isComponent ? 'component' : 'directive';
70
+ var textSpan = ts.createTextSpanFromBounds(declarationSpan.start, declarationSpan.end);
71
+ var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);
72
+ var moduleName = (_b = ngModule) === null || _b === void 0 ? void 0 : _b.type.reference.name;
73
+ return createQuickInfo(directiveName, kind, textSpan, moduleName, ts.ScriptElementKind.classElement);
87
74
  }
88
- break;
89
- default:
90
- break;
75
+ }
76
+ }
77
+ catch (e_1_1) { e_1 = { error: e_1_1 }; }
78
+ finally {
79
+ try {
80
+ if (declarations_1_1 && !declarations_1_1.done && (_a = declarations_1.return)) _a.call(declarations_1);
81
+ }
82
+ finally { if (e_1) throw e_1.error; }
91
83
  }
92
- return undefined;
93
84
  }
94
85
  exports.getTsHover = getTsHover;
95
86
  /**
96
- * Attempts to get quick info for the NgModule a Directive is declared in.
97
- * @param directive identifier on a potential Directive class declaration
98
- * @param host Language Service host to query
87
+ * Construct a QuickInfo object taking into account its container and type.
88
+ * @param name Name of the QuickInfo target
89
+ * @param kind component, directive, pipe, etc.
90
+ * @param textSpan span of the target
91
+ * @param containerName either the Symbol's container or the NgModule that contains the directive
92
+ * @param type user-friendly name of the type
93
+ * @param documentation docstring or comment
99
94
  */
100
- function getDirectiveModule(directive, textSpan, host) {
101
- var analyzedModules = host.getAnalyzedModules(false);
102
- var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(directive);
103
- if (!ngModule)
104
- return;
105
- var isComponent = host.getDeclarations(directive.filePath)
106
- .find(function (decl) { return decl.type === directive && decl.metadata && decl.metadata.isComponent; });
107
- var moduleName = ngModule.type.reference.name;
95
+ function createQuickInfo(name, kind, textSpan, containerName, type, documentation) {
96
+ var containerDisplayParts = containerName ?
97
+ [
98
+ { text: containerName, kind: SYMBOL_INTERFACE },
99
+ { text: '.', kind: SYMBOL_PUNC },
100
+ ] :
101
+ [];
102
+ var typeDisplayParts = type ?
103
+ [
104
+ { text: ':', kind: SYMBOL_PUNC },
105
+ { text: ' ', kind: SYMBOL_SPACE },
106
+ { text: type, kind: SYMBOL_INTERFACE },
107
+ ] :
108
+ [];
108
109
  return {
109
- kind: ts.ScriptElementKind.classElement,
110
+ kind: kind,
110
111
  kindModifiers: ts.ScriptElementKindModifier.none,
111
112
  textSpan: textSpan,
112
- // This generates a string like '(directive) NgModule.Directive: class'
113
- // 'kind' in displayParts does not really matter because it's dropped when
114
- // displayParts get converted to string.
115
- displayParts: [
113
+ displayParts: tslib_1.__spread([
116
114
  { text: '(', kind: SYMBOL_PUNC },
117
- { text: isComponent ? 'component' : 'directive', kind: SYMBOL_TEXT },
115
+ { text: kind, kind: SYMBOL_TEXT },
118
116
  { text: ')', kind: SYMBOL_PUNC },
119
- { text: ' ', kind: SYMBOL_SPACE },
120
- { text: moduleName, kind: SYMBOL_CLASS },
121
- { text: '.', kind: SYMBOL_PUNC },
122
- { text: directive.name, kind: SYMBOL_CLASS },
123
- { text: ':', kind: SYMBOL_PUNC },
124
- { text: ' ', kind: SYMBOL_SPACE },
125
- { text: ts.ScriptElementKind.classElement, kind: SYMBOL_TEXT },
126
- ],
117
+ { text: ' ', kind: SYMBOL_SPACE }
118
+ ], containerDisplayParts, [
119
+ { text: name, kind: SYMBOL_INTERFACE }
120
+ ], typeDisplayParts),
121
+ documentation: documentation,
127
122
  };
128
123
  }
129
124
  });
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/hover.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;;;;;;;;;;;;;IAEH,8CAAmE;IACnE,+BAAiC;IAEjC,6EAA6C;IAE7C,6DAAyC;IAEzC,kDAAkD;IAClD,IAAM,YAAY,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC9E,IAAM,WAAW,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;IACnF,IAAM,YAAY,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC;IAClF,IAAM,WAAW,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;IAE5E;;;;;;OAMG;IACH,SAAgB,QAAQ,CAAC,IAAe,EAAE,QAAgB,EAAE,IAAqC;QAE/F,IAAM,UAAU,GAAG,4BAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAC,UAAU,EAAE;YACf,OAAO;SACR;QACM,IAAA,0BAAM,EAAE,sBAAI,EAAE,kDAAkB,CAAe;QACtD,IAAM,QAAQ,GAAG,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,EAAC,CAAC;QAEpE,IAAI,kBAAkB,IAAI,kBAAkB,CAAC,WAAW,KAAK,6BAAkB,CAAC,SAAS,EAAE;YACzF,OAAO,kBAAkB,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;SAC9E;QAED,IAAM,qBAAqB,GAA2B,MAAM,CAAC,SAAS,CAAC,CAAC;YACpE;gBACE,EAAC,IAAI,EAAE,MAAM,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,SAAS,CAAC,IAAI,EAAC;gBAC1D,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC;aAC/B,CAAC,CAAC;YACH,EAAE,CAAC;QACP,OAAO;YACL,IAAI,EAAE,MAAM,CAAC,IAA4B;YACzC,aAAa,EAAE,EAAE;YACjB,QAAQ,UAAA;YACR,8DAA8D;YAC9D,0EAA0E;YAC1E,wCAAwC;YACxC,YAAY;gBACV,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC,EAAE,EAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAC;gBACtE,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC,EAAE,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,YAAY,EAAC;eAAK,qBAAqB;gBACzF,EAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAC;cAGvC;SACF,CAAC;IACJ,CAAC;IAlCD,4BAkCC;IAED;;;;;OAKG;IACH,SAAgB,UAAU,CACtB,EAAiB,EAAE,QAAgB,EAAE,IAAqC;QAE5E,IAAM,IAAI,GAAG,wBAAgB,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAC5C,IAAI,CAAC,IAAI;YAAE,OAAO;QAClB,QAAQ,IAAI,CAAC,IAAI,EAAE;YACjB,KAAK,EAAE,CAAC,UAAU,CAAC,UAAU;gBAC3B,IAAM,WAAW,GAAG,IAAqB,CAAC;gBAC1C,IAAI,EAAE,CAAC,kBAAkB,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE;oBAC7C,IAAM,aAAa,GAAG,WAAW,CAAC,IAAI,CAAC;oBACvC,IAAM,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,QAAQ,EAAE,aAAa,CAAC,CAAC;oBAC3F,IAAI,CAAC,eAAe;wBAAE,OAAO;oBAC7B,OAAO,kBAAkB,CACrB,eAAe,EACf,EAAC,KAAK,EAAE,WAAW,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,GAAG,GAAG,WAAW,CAAC,QAAQ,EAAE,EAAC,EACjF,IAAI,CAAC,CAAC;iBACX;gBACD,MAAM;YACR;gBACE,MAAM;SACT;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAtBD,gCAsBC;IAED;;;;OAIG;IACH,SAAS,kBAAkB,CACvB,SAAuB,EAAE,QAAqB,EAC9C,IAAqC;QACvC,IAAM,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QACvD,IAAM,QAAQ,GAAG,eAAe,CAAC,yBAAyB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1E,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,IAAM,WAAW,GACb,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,QAAQ,CAAC;aACnC,IAAI,CAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,EAArE,CAAqE,CAAC,CAAC;QAE7F,IAAM,UAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QAChD,OAAO;YACL,IAAI,EAAE,EAAE,CAAC,iBAAiB,CAAC,YAAY;YACvC,aAAa,EACT,EAAE,CAAC,yBAAyB,CAAC,IAAI;YACrC,QAAQ,UAAA;YACR,uEAAuE;YACvE,0EAA0E;YAC1E,wCAAwC;YACxC,YAAY,EAAE;gBACZ,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC;gBAC9B,EAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,EAAE,IAAI,EAAE,WAAW,EAAC;gBAClE,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC;gBAC9B,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,YAAY,EAAC;gBAC/B,EAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,YAAY,EAAC;gBACtC,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC;gBAC9B,EAAC,IAAI,EAAE,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,YAAY,EAAC;gBAC1C,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,WAAW,EAAC;gBAC9B,EAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,YAAY,EAAC;gBAC/B,EAAC,IAAI,EAAE,EAAE,CAAC,iBAAiB,CAAC,YAAY,EAAE,IAAI,EAAE,WAAW,EAAC;aAC7D;SACF,CAAC;IACJ,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {CompileSummaryKind, StaticSymbol} from '@angular/compiler';\nimport * as ts from 'typescript';\nimport {AstResult} from './common';\nimport {locateSymbol} from './locate_symbol';\nimport {TypeScriptServiceHost} from './typescript_host';\nimport {findTightestNode} from './utils';\n\n// Reverse mappings of enum would generate strings\nconst SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];\nconst SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];\nconst SYMBOL_CLASS = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.className];\nconst SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];\n\n/**\n * Traverse the template AST and look for the symbol located at `position`, then\n * return the corresponding quick info.\n * @param info template AST\n * @param position location of the symbol\n * @param host Language Service host to query\n */\nexport function getHover(info: AstResult, position: number, host: Readonly<TypeScriptServiceHost>):\n    ts.QuickInfo|undefined {\n  const symbolInfo = locateSymbol(info, position);\n  if (!symbolInfo) {\n    return;\n  }\n  const {symbol, span, compileTypeSummary} = symbolInfo;\n  const textSpan = {start: span.start, length: span.end - span.start};\n\n  if (compileTypeSummary && compileTypeSummary.summaryKind === CompileSummaryKind.Directive) {\n    return getDirectiveModule(compileTypeSummary.type.reference, textSpan, host);\n  }\n\n  const containerDisplayParts: ts.SymbolDisplayPart[] = symbol.container ?\n      [\n        {text: symbol.container.name, kind: symbol.container.kind},\n        {text: '.', kind: SYMBOL_PUNC},\n      ] :\n      [];\n  return {\n    kind: symbol.kind as ts.ScriptElementKind,\n    kindModifiers: '',  // kindModifier info not available on 'ng.Symbol'\n    textSpan,\n    // this would generate a string like '(property) ClassX.propY'\n    // 'kind' in displayParts does not really matter because it's dropped when\n    // displayParts get converted to string.\n    displayParts: [\n      {text: '(', kind: SYMBOL_PUNC}, {text: symbol.kind, kind: symbol.kind},\n      {text: ')', kind: SYMBOL_PUNC}, {text: ' ', kind: SYMBOL_SPACE}, ...containerDisplayParts,\n      {text: symbol.name, kind: symbol.kind},\n      // TODO: Append type info as well, but Symbol doesn't expose that!\n      // Ideally hover text should be like '(property) ClassX.propY: string'\n    ],\n  };\n}\n\n/**\n * Get quick info for Angular semantic entities in TypeScript files, like Directives.\n * @param sf TypeScript source file an Angular symbol is in\n * @param position location of the symbol in the source file\n * @param host Language Service host to query\n */\nexport function getTsHover(\n    sf: ts.SourceFile, position: number, host: Readonly<TypeScriptServiceHost>): ts.QuickInfo|\n    undefined {\n  const node = findTightestNode(sf, position);\n  if (!node) return;\n  switch (node.kind) {\n    case ts.SyntaxKind.Identifier:\n      const directiveId = node as ts.Identifier;\n      if (ts.isClassDeclaration(directiveId.parent)) {\n        const directiveName = directiveId.text;\n        const directiveSymbol = host.getStaticSymbol(node.getSourceFile().fileName, directiveName);\n        if (!directiveSymbol) return;\n        return getDirectiveModule(\n            directiveSymbol,\n            {start: directiveId.getStart(), length: directiveId.end - directiveId.getStart()},\n            host);\n      }\n      break;\n    default:\n      break;\n  }\n  return undefined;\n}\n\n/**\n * Attempts to get quick info for the NgModule a Directive is declared in.\n * @param directive identifier on a potential Directive class declaration\n * @param host Language Service host to query\n */\nfunction getDirectiveModule(\n    directive: StaticSymbol, textSpan: ts.TextSpan,\n    host: Readonly<TypeScriptServiceHost>): ts.QuickInfo|undefined {\n  const analyzedModules = host.getAnalyzedModules(false);\n  const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(directive);\n  if (!ngModule) return;\n\n  const isComponent =\n      host.getDeclarations(directive.filePath)\n          .find(decl => decl.type === directive && decl.metadata && decl.metadata.isComponent);\n\n  const moduleName = ngModule.type.reference.name;\n  return {\n    kind: ts.ScriptElementKind.classElement,\n    kindModifiers:\n        ts.ScriptElementKindModifier.none,  // kindModifier info not available on 'ng.Symbol'\n    textSpan,\n    // This generates a string like '(directive) NgModule.Directive: class'\n    // 'kind' in displayParts does not really matter because it's dropped when\n    // displayParts get converted to string.\n    displayParts: [\n      {text: '(', kind: SYMBOL_PUNC},\n      {text: isComponent ? 'component' : 'directive', kind: SYMBOL_TEXT},\n      {text: ')', kind: SYMBOL_PUNC},\n      {text: ' ', kind: SYMBOL_SPACE},\n      {text: moduleName, kind: SYMBOL_CLASS},\n      {text: '.', kind: SYMBOL_PUNC},\n      {text: directive.name, kind: SYMBOL_CLASS},\n      {text: ':', kind: SYMBOL_PUNC},\n      {text: ' ', kind: SYMBOL_SPACE},\n      {text: ts.ScriptElementKind.classElement, kind: SYMBOL_TEXT},\n    ],\n  };\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/hover.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {NgAnalyzedModules} from '@angular/compiler';\nimport * as ts from 'typescript';\nimport {AstResult} from './common';\nimport {locateSymbols} from './locate_symbol';\nimport * as ng from './types';\nimport {inSpan} from './utils';\n\n// Reverse mappings of enum would generate strings\nconst SYMBOL_SPACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.space];\nconst SYMBOL_PUNC = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.punctuation];\nconst SYMBOL_TEXT = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.text];\nconst SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];\n\n/**\n * Traverse the template AST and look for the symbol located at `position`, then\n * return the corresponding quick info.\n * @param info template AST\n * @param position location of the symbol\n * @param analyzedModules all NgModules in the program.\n */\nexport function getTemplateHover(\n    info: AstResult, position: number, analyzedModules: NgAnalyzedModules): ts.QuickInfo|undefined {\n  const symbolInfo = locateSymbols(info, position)[0];\n  if (!symbolInfo) {\n    return;\n  }\n  const {symbol, span, staticSymbol} = symbolInfo;\n\n  // The container is either the symbol's container (for example, 'AppComponent'\n  // is the container of the symbol 'title' in its template) or the NgModule\n  // that the directive belongs to (the container of AppComponent is AppModule).\n  let containerName: string|undefined = symbol.container ?.name;\n  if (!containerName && staticSymbol) {\n    // If there is a static symbol then the target is a directive.\n    const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);\n    containerName = ngModule ?.type.reference.name;\n  }\n\n  return createQuickInfo(symbol.name, symbol.kind, span, containerName, symbol.type?.name, symbol.documentation);\n}\n\n/**\n * Get quick info for Angular semantic entities in TypeScript files, like Directives.\n * @param position location of the symbol in the source file\n * @param declarations All Directive-like declarations in the source file.\n * @param analyzedModules all NgModules in the program.\n */\nexport function getTsHover(\n    position: number, declarations: ng.Declaration[],\n    analyzedModules: NgAnalyzedModules): ts.QuickInfo|undefined {\n  for (const {declarationSpan, metadata} of declarations) {\n    if (inSpan(position, declarationSpan)) {\n      const staticSymbol: ng.StaticSymbol = metadata.type.reference;\n      const directiveName = staticSymbol.name;\n      const kind = metadata.isComponent ? 'component' : 'directive';\n      const textSpan = ts.createTextSpanFromBounds(declarationSpan.start, declarationSpan.end);\n      const ngModule = analyzedModules.ngModuleByPipeOrDirective.get(staticSymbol);\n      const moduleName = ngModule ?.type.reference.name;\n      return createQuickInfo(\n          directiveName, kind, textSpan, moduleName, ts.ScriptElementKind.classElement);\n    }\n  }\n}\n\n/**\n * Construct a QuickInfo object taking into account its container and type.\n * @param name Name of the QuickInfo target\n * @param kind component, directive, pipe, etc.\n * @param textSpan span of the target\n * @param containerName either the Symbol's container or the NgModule that contains the directive\n * @param type user-friendly name of the type\n * @param documentation docstring or comment\n */\nfunction createQuickInfo(\n    name: string, kind: string, textSpan: ts.TextSpan, containerName?: string, type?: string,\n    documentation?: ts.SymbolDisplayPart[]): ts.QuickInfo {\n  const containerDisplayParts = containerName ?\n      [\n        {text: containerName, kind: SYMBOL_INTERFACE},\n        {text: '.', kind: SYMBOL_PUNC},\n      ] :\n      [];\n\n  const typeDisplayParts = type ?\n      [\n        {text: ':', kind: SYMBOL_PUNC},\n        {text: ' ', kind: SYMBOL_SPACE},\n        {text: type, kind: SYMBOL_INTERFACE},\n      ] :\n      [];\n\n  return {\n    kind: kind as ts.ScriptElementKind,\n    kindModifiers: ts.ScriptElementKindModifier.none,\n    textSpan: textSpan,\n    displayParts: [\n      {text: '(', kind: SYMBOL_PUNC},\n      {text: kind, kind: SYMBOL_TEXT},\n      {text: ')', kind: SYMBOL_PUNC},\n      {text: ' ', kind: SYMBOL_SPACE},\n      ...containerDisplayParts,\n      {text: name, kind: SYMBOL_INTERFACE},\n      ...typeDisplayParts,\n    ],\n    documentation,\n  };\n}\n"]}
@@ -21,7 +21,7 @@ export declare class SchemaInformation {
21
21
  propertiesOf(elementName: string): string[];
22
22
  typeOf(elementName: string, property: string): string;
23
23
  private static _instance;
24
- static readonly instance: SchemaInformation;
24
+ static get instance(): SchemaInformation;
25
25
  }
26
26
  export declare function eventNames(elementName: string): string[];
27
27
  export declare function propertyNames(elementName: string): string[];
@@ -6,11 +6,21 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  /// <amd-module name="@angular/language-service/src/language_service" />
9
- import { LanguageService } from './types';
9
+ import * as tss from 'typescript/lib/tsserverlibrary';
10
+ import * as ng from './types';
10
11
  import { TypeScriptServiceHost } from './typescript_host';
11
12
  /**
12
13
  * Create an instance of an Angular `LanguageService`.
13
14
  *
14
15
  * @publicApi
15
16
  */
16
- export declare function createLanguageService(host: TypeScriptServiceHost): LanguageService;
17
+ export declare function createLanguageService(host: TypeScriptServiceHost): LanguageServiceImpl;
18
+ declare class LanguageServiceImpl implements ng.LanguageService {
19
+ private readonly host;
20
+ constructor(host: TypeScriptServiceHost);
21
+ getSemanticDiagnostics(fileName: string): tss.Diagnostic[];
22
+ getCompletionsAtPosition(fileName: string, position: number, options?: tss.GetCompletionsAtPositionOptions): tss.CompletionInfo | undefined;
23
+ getDefinitionAndBoundSpan(fileName: string, position: number): tss.DefinitionInfoAndBoundSpan | undefined;
24
+ getQuickInfoAtPosition(fileName: string, position: number): tss.QuickInfo | undefined;
25
+ }
26
+ export {};
@@ -11,12 +11,13 @@
11
11
  if (v !== undefined) module.exports = v;
12
12
  }
13
13
  else if (typeof define === "function" && define.amd) {
14
- define("@angular/language-service/src/language_service", ["require", "exports", "tslib", "@angular/language-service/src/completions", "@angular/language-service/src/definitions", "@angular/language-service/src/diagnostics", "@angular/language-service/src/hover"], factory);
14
+ define("@angular/language-service/src/language_service", ["require", "exports", "tslib", "typescript/lib/tsserverlibrary", "@angular/language-service/src/completions", "@angular/language-service/src/definitions", "@angular/language-service/src/diagnostics", "@angular/language-service/src/hover"], factory);
15
15
  }
16
16
  })(function (require, exports) {
17
17
  "use strict";
18
18
  Object.defineProperty(exports, "__esModule", { value: true });
19
19
  var tslib_1 = require("tslib");
20
+ var tss = require("typescript/lib/tsserverlibrary");
20
21
  var completions_1 = require("@angular/language-service/src/completions");
21
22
  var definitions_1 = require("@angular/language-service/src/definitions");
22
23
  var diagnostics_1 = require("@angular/language-service/src/diagnostics");
@@ -34,17 +35,17 @@
34
35
  function LanguageServiceImpl(host) {
35
36
  this.host = host;
36
37
  }
37
- LanguageServiceImpl.prototype.getDiagnostics = function (fileName) {
38
+ LanguageServiceImpl.prototype.getSemanticDiagnostics = function (fileName) {
38
39
  var e_1, _a;
39
40
  var analyzedModules = this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
40
- var results = [];
41
+ var ngDiagnostics = [];
41
42
  var templates = this.host.getTemplates(fileName);
42
43
  try {
43
44
  for (var templates_1 = tslib_1.__values(templates), templates_1_1 = templates_1.next(); !templates_1_1.done; templates_1_1 = templates_1.next()) {
44
45
  var template = templates_1_1.value;
45
46
  var ast = this.host.getTemplateAst(template);
46
47
  if (ast) {
47
- results.push.apply(results, tslib_1.__spread(diagnostics_1.getTemplateDiagnostics(ast)));
48
+ ngDiagnostics.push.apply(ngDiagnostics, tslib_1.__spread(diagnostics_1.getTemplateDiagnostics(ast)));
48
49
  }
49
50
  }
50
51
  }
@@ -56,13 +57,12 @@
56
57
  finally { if (e_1) throw e_1.error; }
57
58
  }
58
59
  var declarations = this.host.getDeclarations(fileName);
59
- if (declarations && declarations.length) {
60
- results.push.apply(results, tslib_1.__spread(diagnostics_1.getDeclarationDiagnostics(declarations, analyzedModules, this.host)));
61
- }
60
+ ngDiagnostics.push.apply(ngDiagnostics, tslib_1.__spread(diagnostics_1.getDeclarationDiagnostics(declarations, analyzedModules, this.host)));
62
61
  var sourceFile = fileName.endsWith('.ts') ? this.host.getSourceFile(fileName) : undefined;
63
- return diagnostics_1.uniqueBySpan(results).map(function (d) { return diagnostics_1.ngDiagnosticToTsDiagnostic(d, sourceFile); });
62
+ var tsDiagnostics = ngDiagnostics.map(function (d) { return diagnostics_1.ngDiagnosticToTsDiagnostic(d, sourceFile); });
63
+ return tslib_1.__spread(tss.sortAndDeduplicateDiagnostics(tsDiagnostics));
64
64
  };
65
- LanguageServiceImpl.prototype.getCompletionsAt = function (fileName, position) {
65
+ LanguageServiceImpl.prototype.getCompletionsAtPosition = function (fileName, position, options) {
66
66
  this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
67
67
  var ast = this.host.getTemplateAstAtPosition(fileName, position);
68
68
  if (!ast) {
@@ -80,7 +80,7 @@
80
80
  entries: results,
81
81
  };
82
82
  };
83
- LanguageServiceImpl.prototype.getDefinitionAt = function (fileName, position) {
83
+ LanguageServiceImpl.prototype.getDefinitionAndBoundSpan = function (fileName, position) {
84
84
  this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
85
85
  var templateInfo = this.host.getTemplateAstAtPosition(fileName, position);
86
86
  if (templateInfo) {
@@ -95,22 +95,18 @@
95
95
  }
96
96
  }
97
97
  };
98
- LanguageServiceImpl.prototype.getHoverAt = function (fileName, position) {
99
- this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
98
+ LanguageServiceImpl.prototype.getQuickInfoAtPosition = function (fileName, position) {
99
+ var analyzedModules = this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
100
100
  var templateInfo = this.host.getTemplateAstAtPosition(fileName, position);
101
101
  if (templateInfo) {
102
- return hover_1.getHover(templateInfo, position, this.host);
102
+ return hover_1.getTemplateHover(templateInfo, position, analyzedModules);
103
103
  }
104
104
  // Attempt to get Angular-specific hover information in a TypeScript file, the NgModule a
105
105
  // directive belongs to.
106
- if (fileName.endsWith('.ts')) {
107
- var sf = this.host.getSourceFile(fileName);
108
- if (sf) {
109
- return hover_1.getTsHover(sf, position, this.host);
110
- }
111
- }
106
+ var declarations = this.host.getDeclarations(fileName);
107
+ return hover_1.getTsHover(position, declarations, analyzedModules);
112
108
  };
113
109
  return LanguageServiceImpl;
114
110
  }());
115
111
  });
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language_service.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/language_service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as tss from 'typescript/lib/tsserverlibrary';\n\nimport {getTemplateCompletions} from './completions';\nimport {getDefinitionAndBoundSpan, getTsDefinitionAndBoundSpan} from './definitions';\nimport {getDeclarationDiagnostics, getTemplateDiagnostics, ngDiagnosticToTsDiagnostic, uniqueBySpan} from './diagnostics';\nimport {getHover, getTsHover} from './hover';\nimport {Diagnostic, LanguageService} from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\n\n/**\n * Create an instance of an Angular `LanguageService`.\n *\n * @publicApi\n */\nexport function createLanguageService(host: TypeScriptServiceHost): LanguageService {\n  return new LanguageServiceImpl(host);\n}\n\nclass LanguageServiceImpl implements LanguageService {\n  constructor(private readonly host: TypeScriptServiceHost) {}\n\n  getDiagnostics(fileName: string): tss.Diagnostic[] {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const results: Diagnostic[] = [];\n    const templates = this.host.getTemplates(fileName);\n\n    for (const template of templates) {\n      const ast = this.host.getTemplateAst(template);\n      if (ast) {\n        results.push(...getTemplateDiagnostics(ast));\n      }\n    }\n\n    const declarations = this.host.getDeclarations(fileName);\n    if (declarations && declarations.length) {\n      results.push(...getDeclarationDiagnostics(declarations, analyzedModules, this.host));\n    }\n\n    const sourceFile = fileName.endsWith('.ts') ? this.host.getSourceFile(fileName) : undefined;\n    return uniqueBySpan(results).map(d => ngDiagnosticToTsDiagnostic(d, sourceFile));\n  }\n\n  getCompletionsAt(fileName: string, position: number): tss.CompletionInfo|undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ast = this.host.getTemplateAstAtPosition(fileName, position);\n    if (!ast) {\n      return;\n    }\n    const results = getTemplateCompletions(ast, position);\n    if (!results || !results.length) {\n      return;\n    }\n    return {\n      isGlobalCompletion: false,\n      isMemberCompletion: false,\n      isNewIdentifierLocation: false,\n      // Cast CompletionEntry.kind from ng.CompletionKind to ts.ScriptElementKind\n      entries: results as unknown as ts.CompletionEntry[],\n    };\n  }\n\n  getDefinitionAt(fileName: string, position: number): tss.DefinitionInfoAndBoundSpan|undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getDefinitionAndBoundSpan(templateInfo, position);\n    }\n\n    // Attempt to get Angular-specific definitions in a TypeScript file, like templates defined\n    // in a `templateUrl` property.\n    if (fileName.endsWith('.ts')) {\n      const sf = this.host.getSourceFile(fileName);\n      if (sf) {\n        return getTsDefinitionAndBoundSpan(sf, position, this.host.tsLsHost);\n      }\n    }\n  }\n\n  getHoverAt(fileName: string, position: number): tss.QuickInfo|undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getHover(templateInfo, position, this.host);\n    }\n\n    // Attempt to get Angular-specific hover information in a TypeScript file, the NgModule a\n    // directive belongs to.\n    if (fileName.endsWith('.ts')) {\n      const sf = this.host.getSourceFile(fileName);\n      if (sf) {\n        return getTsHover(sf, position, this.host);\n      }\n    }\n  }\n}\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language_service.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/language_service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as tss from 'typescript/lib/tsserverlibrary';\n\nimport {getTemplateCompletions} from './completions';\nimport {getDefinitionAndBoundSpan, getTsDefinitionAndBoundSpan} from './definitions';\nimport {getDeclarationDiagnostics, getTemplateDiagnostics, ngDiagnosticToTsDiagnostic} from './diagnostics';\nimport {getTemplateHover, getTsHover} from './hover';\nimport * as ng from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\n\n/**\n * Create an instance of an Angular `LanguageService`.\n *\n * @publicApi\n */\nexport function createLanguageService(host: TypeScriptServiceHost) {\n  return new LanguageServiceImpl(host);\n}\n\nclass LanguageServiceImpl implements ng.LanguageService {\n  constructor(private readonly host: TypeScriptServiceHost) {}\n\n  getSemanticDiagnostics(fileName: string): tss.Diagnostic[] {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ngDiagnostics: ng.Diagnostic[] = [];\n\n    const templates = this.host.getTemplates(fileName);\n    for (const template of templates) {\n      const ast = this.host.getTemplateAst(template);\n      if (ast) {\n        ngDiagnostics.push(...getTemplateDiagnostics(ast));\n      }\n    }\n\n    const declarations = this.host.getDeclarations(fileName);\n    ngDiagnostics.push(...getDeclarationDiagnostics(declarations, analyzedModules, this.host));\n\n    const sourceFile = fileName.endsWith('.ts') ? this.host.getSourceFile(fileName) : undefined;\n    const tsDiagnostics = ngDiagnostics.map(d => ngDiagnosticToTsDiagnostic(d, sourceFile));\n    return [...tss.sortAndDeduplicateDiagnostics(tsDiagnostics)];\n  }\n\n  getCompletionsAtPosition(\n      fileName: string, position: number,\n      options?: tss.GetCompletionsAtPositionOptions): tss.CompletionInfo|undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const ast = this.host.getTemplateAstAtPosition(fileName, position);\n    if (!ast) {\n      return;\n    }\n    const results = getTemplateCompletions(ast, position);\n    if (!results || !results.length) {\n      return;\n    }\n    return {\n      isGlobalCompletion: false,\n      isMemberCompletion: false,\n      isNewIdentifierLocation: false,\n      // Cast CompletionEntry.kind from ng.CompletionKind to ts.ScriptElementKind\n      entries: results as unknown as ts.CompletionEntry[],\n    };\n  }\n\n  getDefinitionAndBoundSpan(fileName: string, position: number): tss.DefinitionInfoAndBoundSpan\n      |undefined {\n    this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getDefinitionAndBoundSpan(templateInfo, position);\n    }\n\n    // Attempt to get Angular-specific definitions in a TypeScript file, like templates defined\n    // in a `templateUrl` property.\n    if (fileName.endsWith('.ts')) {\n      const sf = this.host.getSourceFile(fileName);\n      if (sf) {\n        return getTsDefinitionAndBoundSpan(sf, position, this.host.tsLsHost);\n      }\n    }\n  }\n\n  getQuickInfoAtPosition(fileName: string, position: number): tss.QuickInfo|undefined {\n    const analyzedModules = this.host.getAnalyzedModules();  // same role as 'synchronizeHostData'\n    const templateInfo = this.host.getTemplateAstAtPosition(fileName, position);\n    if (templateInfo) {\n      return getTemplateHover(templateInfo, position, analyzedModules);\n    }\n\n    // Attempt to get Angular-specific hover information in a TypeScript file, the NgModule a\n    // directive belongs to.\n    const declarations = this.host.getDeclarations(fileName);\n    return getTsHover(position, declarations, analyzedModules);\n  }\n}\n"]}
@@ -6,17 +6,18 @@
6
6
  * found in the LICENSE file at https://angular.io/license
7
7
  */
8
8
  /// <amd-module name="@angular/language-service/src/locate_symbol" />
9
- import { CompileTypeSummary } from '@angular/compiler';
9
+ import { StaticSymbol } from '@angular/compiler';
10
+ import * as tss from 'typescript/lib/tsserverlibrary';
10
11
  import { AstResult } from './common';
11
- import { Span, Symbol } from './types';
12
+ import { Symbol } from './types';
12
13
  export interface SymbolInfo {
13
14
  symbol: Symbol;
14
- span: Span;
15
- compileTypeSummary: CompileTypeSummary | undefined;
15
+ span: tss.TextSpan;
16
+ staticSymbol?: StaticSymbol;
16
17
  }
17
18
  /**
18
- * Traverse the template AST and locate the Symbol at the specified `position`.
19
- * @param info Ast and Template Source
20
- * @param position location to look for
19
+ * Traverses a template AST and locates symbol(s) at a specified position.
20
+ * @param info template AST information set
21
+ * @param position location to locate symbols at
21
22
  */
22
- export declare function locateSymbol(info: AstResult, position: number): SymbolInfo | undefined;
23
+ export declare function locateSymbols(info: AstResult, position: number): SymbolInfo[];