@angular/language-service 9.0.0-rc.9 → 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/bundles/language-service.umd.js +1574 -2087
- package/package.json +1 -1
- package/src/definitions.js +61 -24
- package/src/diagnostics.d.ts +0 -7
- package/src/diagnostics.js +1 -37
- package/src/expression_diagnostics.d.ts +7 -3
- package/src/expression_diagnostics.js +61 -44
- package/src/expression_type.d.ts +6 -13
- package/src/expression_type.js +63 -66
- package/src/expressions.js +8 -2
- package/src/hover.d.ts +7 -6
- package/src/hover.js +69 -88
- package/src/language_service.d.ts +12 -2
- package/src/language_service.js +16 -20
- package/src/locate_symbol.d.ts +9 -8
- package/src/locate_symbol.js +200 -173
- package/src/ts_plugin.js +6 -6
- package/src/types.d.ts +6 -40
- package/src/types.js +1 -1
- package/src/typescript_host.d.ts +2 -11
- package/src/typescript_host.js +6 -18
- package/src/typescript_symbols.js +8 -25
- package/src/utils.d.ts +22 -8
- package/src/utils.js +63 -8
- package/src/version.js +1 -1
package/src/hover.js
CHANGED
|
@@ -11,20 +11,18 @@
|
|
|
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", "
|
|
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];
|
|
29
27
|
var SYMBOL_INTERFACE = ts.SymbolDisplayPartKind[ts.SymbolDisplayPartKind.interfaceName];
|
|
30
28
|
/**
|
|
@@ -32,113 +30,96 @@
|
|
|
32
30
|
* return the corresponding quick info.
|
|
33
31
|
* @param info template AST
|
|
34
32
|
* @param position location of the symbol
|
|
35
|
-
* @param
|
|
33
|
+
* @param analyzedModules all NgModules in the program.
|
|
36
34
|
*/
|
|
37
|
-
function
|
|
38
|
-
var
|
|
35
|
+
function getTemplateHover(info, position, analyzedModules) {
|
|
36
|
+
var _a, _b, _c;
|
|
37
|
+
var symbolInfo = locate_symbol_1.locateSymbols(info, position)[0];
|
|
39
38
|
if (!symbolInfo) {
|
|
40
39
|
return;
|
|
41
40
|
}
|
|
42
|
-
var symbol = symbolInfo.symbol, span = symbolInfo.span,
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
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;
|
|
46
50
|
}
|
|
47
|
-
|
|
51
|
+
return createQuickInfo(symbol.name, symbol.kind, span, containerName, (_c = symbol.type) === null || _c === void 0 ? void 0 : _c.name, symbol.documentation);
|
|
52
|
+
}
|
|
53
|
+
exports.getTemplateHover = getTemplateHover;
|
|
54
|
+
/**
|
|
55
|
+
* Get quick info for Angular semantic entities in TypeScript files, like Directives.
|
|
56
|
+
* @param position location of the symbol in the source file
|
|
57
|
+
* @param declarations All Directive-like declarations in the source file.
|
|
58
|
+
* @param analyzedModules all NgModules in the program.
|
|
59
|
+
*/
|
|
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);
|
|
74
|
+
}
|
|
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; }
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
exports.getTsHover = getTsHover;
|
|
86
|
+
/**
|
|
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
|
|
94
|
+
*/
|
|
95
|
+
function createQuickInfo(name, kind, textSpan, containerName, type, documentation) {
|
|
96
|
+
var containerDisplayParts = containerName ?
|
|
48
97
|
[
|
|
49
|
-
{ text:
|
|
98
|
+
{ text: containerName, kind: SYMBOL_INTERFACE },
|
|
50
99
|
{ text: '.', kind: SYMBOL_PUNC },
|
|
51
100
|
] :
|
|
52
101
|
[];
|
|
53
|
-
var typeDisplayParts =
|
|
102
|
+
var typeDisplayParts = type ?
|
|
54
103
|
[
|
|
55
104
|
{ text: ':', kind: SYMBOL_PUNC },
|
|
56
105
|
{ text: ' ', kind: SYMBOL_SPACE },
|
|
57
|
-
{ text:
|
|
106
|
+
{ text: type, kind: SYMBOL_INTERFACE },
|
|
58
107
|
] :
|
|
59
108
|
[];
|
|
60
109
|
return {
|
|
61
|
-
kind:
|
|
62
|
-
kindModifiers:
|
|
110
|
+
kind: kind,
|
|
111
|
+
kindModifiers: ts.ScriptElementKindModifier.none,
|
|
63
112
|
textSpan: textSpan,
|
|
64
|
-
documentation: symbol.documentation,
|
|
65
|
-
// this would generate a string like '(property) ClassX.propY: type'
|
|
66
|
-
// 'kind' in displayParts does not really matter because it's dropped when
|
|
67
|
-
// displayParts get converted to string.
|
|
68
113
|
displayParts: tslib_1.__spread([
|
|
69
114
|
{ text: '(', kind: SYMBOL_PUNC },
|
|
70
|
-
{ text:
|
|
115
|
+
{ text: kind, kind: SYMBOL_TEXT },
|
|
71
116
|
{ text: ')', kind: SYMBOL_PUNC },
|
|
72
117
|
{ text: ' ', kind: SYMBOL_SPACE }
|
|
73
118
|
], containerDisplayParts, [
|
|
74
|
-
{ text:
|
|
119
|
+
{ text: name, kind: SYMBOL_INTERFACE }
|
|
75
120
|
], typeDisplayParts),
|
|
76
|
-
|
|
77
|
-
}
|
|
78
|
-
exports.getHover = getHover;
|
|
79
|
-
/**
|
|
80
|
-
* Get quick info for Angular semantic entities in TypeScript files, like Directives.
|
|
81
|
-
* @param sf TypeScript source file an Angular symbol is in
|
|
82
|
-
* @param position location of the symbol in the source file
|
|
83
|
-
* @param host Language Service host to query
|
|
84
|
-
*/
|
|
85
|
-
function getTsHover(sf, position, host) {
|
|
86
|
-
var node = utils_1.findTightestNode(sf, position);
|
|
87
|
-
if (!node)
|
|
88
|
-
return;
|
|
89
|
-
switch (node.kind) {
|
|
90
|
-
case ts.SyntaxKind.Identifier:
|
|
91
|
-
var directiveId = node;
|
|
92
|
-
if (ts.isClassDeclaration(directiveId.parent)) {
|
|
93
|
-
var directiveName = directiveId.text;
|
|
94
|
-
var directiveSymbol = host.getStaticSymbol(node.getSourceFile().fileName, directiveName);
|
|
95
|
-
if (!directiveSymbol)
|
|
96
|
-
return;
|
|
97
|
-
return getDirectiveModule(directiveSymbol, { start: directiveId.getStart(), length: directiveId.end - directiveId.getStart() }, host);
|
|
98
|
-
}
|
|
99
|
-
break;
|
|
100
|
-
default:
|
|
101
|
-
break;
|
|
102
|
-
}
|
|
103
|
-
return undefined;
|
|
104
|
-
}
|
|
105
|
-
exports.getTsHover = getTsHover;
|
|
106
|
-
/**
|
|
107
|
-
* Attempts to get quick info for the NgModule a Directive is declared in.
|
|
108
|
-
* @param directive identifier on a potential Directive class declaration
|
|
109
|
-
* @param textSpan span of the symbol
|
|
110
|
-
* @param host Language Service host to query
|
|
111
|
-
* @param symbol the internal symbol that represents the directive
|
|
112
|
-
*/
|
|
113
|
-
function getDirectiveModule(directive, textSpan, host, symbol) {
|
|
114
|
-
var analyzedModules = host.getAnalyzedModules(false);
|
|
115
|
-
var ngModule = analyzedModules.ngModuleByPipeOrDirective.get(directive);
|
|
116
|
-
if (!ngModule)
|
|
117
|
-
return;
|
|
118
|
-
var isComponent = host.getDeclarations(directive.filePath)
|
|
119
|
-
.find(function (decl) { return decl.type === directive && decl.metadata && decl.metadata.isComponent; });
|
|
120
|
-
var moduleName = ngModule.type.reference.name;
|
|
121
|
-
return {
|
|
122
|
-
kind: ts.ScriptElementKind.classElement,
|
|
123
|
-
kindModifiers: ts.ScriptElementKindModifier.none,
|
|
124
|
-
textSpan: textSpan,
|
|
125
|
-
documentation: symbol ? symbol.documentation : undefined,
|
|
126
|
-
// This generates a string like '(directive) NgModule.Directive: class'
|
|
127
|
-
// 'kind' in displayParts does not really matter because it's dropped when
|
|
128
|
-
// displayParts get converted to string.
|
|
129
|
-
displayParts: [
|
|
130
|
-
{ text: '(', kind: SYMBOL_PUNC },
|
|
131
|
-
{ text: isComponent ? 'component' : 'directive', kind: SYMBOL_TEXT },
|
|
132
|
-
{ text: ')', kind: SYMBOL_PUNC },
|
|
133
|
-
{ text: ' ', kind: SYMBOL_SPACE },
|
|
134
|
-
{ text: moduleName, kind: SYMBOL_CLASS },
|
|
135
|
-
{ text: '.', kind: SYMBOL_PUNC },
|
|
136
|
-
{ text: directive.name, kind: SYMBOL_CLASS },
|
|
137
|
-
{ text: ':', kind: SYMBOL_PUNC },
|
|
138
|
-
{ text: ' ', kind: SYMBOL_SPACE },
|
|
139
|
-
{ text: ts.ScriptElementKind.classElement, kind: SYMBOL_TEXT },
|
|
140
|
-
],
|
|
121
|
+
documentation: documentation,
|
|
141
122
|
};
|
|
142
123
|
}
|
|
143
124
|
});
|
|
144
|
-
//# 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 {CompileSummaryKind, StaticSymbol} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {AstResult} from './common';\nimport {locateSymbol} from './locate_symbol';\nimport * as ng from './types';\nimport {TypeScriptServiceHost} from './typescript_host';\nimport {findTightestNode} from './utils';\n\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];\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 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, symbol);\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  const typeDisplayParts: ts.SymbolDisplayPart[] = symbol.type ?\n      [\n        {text: ':', kind: SYMBOL_PUNC},\n        {text: ' ', kind: SYMBOL_SPACE},\n        {text: symbol.type.name, kind: SYMBOL_INTERFACE},\n      ] :\n      [];\n  return {\n    kind: symbol.kind as ts.ScriptElementKind,\n    kindModifiers: '',  // kindModifier info not available on 'ng.Symbol'\n    textSpan,\n    documentation: symbol.documentation,\n    // this would generate a string like '(property) ClassX.propY: type'\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: symbol.kind, kind: symbol.kind},\n      {text: ')', kind: SYMBOL_PUNC},\n      {text: ' ', kind: SYMBOL_SPACE},\n      ...containerDisplayParts,\n      {text: symbol.name, kind: symbol.kind},\n      ...typeDisplayParts,\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 textSpan span of the symbol\n * @param host Language Service host to query\n * @param symbol the internal symbol that represents the directive\n */\nfunction getDirectiveModule(\n    directive: StaticSymbol, textSpan: ts.TextSpan, host: Readonly<TypeScriptServiceHost>,\n    symbol?: ng.Symbol): 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    documentation: symbol ? symbol.documentation : undefined,\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"]}
|
|
@@ -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
|
|
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):
|
|
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 {};
|
package/src/language_service.js
CHANGED
|
@@ -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.
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
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
|
-
|
|
107
|
-
|
|
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,
|
|
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"]}
|
package/src/locate_symbol.d.ts
CHANGED
|
@@ -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 {
|
|
9
|
+
import { StaticSymbol } from '@angular/compiler';
|
|
10
|
+
import * as tss from 'typescript/lib/tsserverlibrary';
|
|
10
11
|
import { AstResult } from './common';
|
|
11
|
-
import {
|
|
12
|
+
import { Symbol } from './types';
|
|
12
13
|
export interface SymbolInfo {
|
|
13
14
|
symbol: Symbol;
|
|
14
|
-
span:
|
|
15
|
-
|
|
15
|
+
span: tss.TextSpan;
|
|
16
|
+
staticSymbol?: StaticSymbol;
|
|
16
17
|
}
|
|
17
18
|
/**
|
|
18
|
-
*
|
|
19
|
-
* @param info
|
|
20
|
-
* @param position location to
|
|
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
|
|
23
|
+
export declare function locateSymbols(info: AstResult, position: number): SymbolInfo[];
|