UNPKG

16.9 kBJavaScriptView Raw
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8(function (factory) {
9 if (typeof module === "object" && typeof module.exports === "object") {
10 var v = factory(require, exports);
11 if (v !== undefined) module.exports = v;
12 }
13 else if (typeof define === "function" && define.amd) {
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 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.createLanguageService = void 0;
20 var tslib_1 = require("tslib");
21 var tss = require("typescript/lib/tsserverlibrary");
22 var completions_1 = require("@angular/language-service/src/completions");
23 var definitions_1 = require("@angular/language-service/src/definitions");
24 var diagnostics_1 = require("@angular/language-service/src/diagnostics");
25 var hover_1 = require("@angular/language-service/src/hover");
26 /**
27 * Create an instance of an Angular `LanguageService`.
28 *
29 * @publicApi
30 */
31 function createLanguageService(host) {
32 return new LanguageServiceImpl(host);
33 }
34 exports.createLanguageService = createLanguageService;
35 var LanguageServiceImpl = /** @class */ (function () {
36 function LanguageServiceImpl(host) {
37 this.host = host;
38 }
39 LanguageServiceImpl.prototype.getSemanticDiagnostics = function (fileName) {
40 var e_1, _a;
41 var analyzedModules = this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
42 var ngDiagnostics = [];
43 var templates = this.host.getTemplates(fileName);
44 try {
45 for (var templates_1 = tslib_1.__values(templates), templates_1_1 = templates_1.next(); !templates_1_1.done; templates_1_1 = templates_1.next()) {
46 var template = templates_1_1.value;
47 var ast = this.host.getTemplateAst(template);
48 if (ast) {
49 ngDiagnostics.push.apply(ngDiagnostics, tslib_1.__spread(diagnostics_1.getTemplateDiagnostics(ast)));
50 }
51 }
52 }
53 catch (e_1_1) { e_1 = { error: e_1_1 }; }
54 finally {
55 try {
56 if (templates_1_1 && !templates_1_1.done && (_a = templates_1.return)) _a.call(templates_1);
57 }
58 finally { if (e_1) throw e_1.error; }
59 }
60 var declarations = this.host.getDeclarations(fileName);
61 ngDiagnostics.push.apply(ngDiagnostics, tslib_1.__spread(diagnostics_1.getDeclarationDiagnostics(declarations, analyzedModules, this.host)));
62 var sourceFile = fileName.endsWith('.ts') ? this.host.getSourceFile(fileName) : undefined;
63 var tsDiagnostics = ngDiagnostics.map(function (d) { return diagnostics_1.ngDiagnosticToTsDiagnostic(d, sourceFile); });
64 return tslib_1.__spread(tss.sortAndDeduplicateDiagnostics(tsDiagnostics));
65 };
66 LanguageServiceImpl.prototype.getCompletionsAtPosition = function (fileName, position, _options) {
67 this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
68 var ast = this.host.getTemplateAstAtPosition(fileName, position);
69 if (!ast) {
70 return;
71 }
72 var results = completions_1.getTemplateCompletions(ast, position);
73 if (!results || !results.length) {
74 return;
75 }
76 return {
77 isGlobalCompletion: false,
78 isMemberCompletion: false,
79 isNewIdentifierLocation: false,
80 // Cast CompletionEntry.kind from ng.CompletionKind to ts.ScriptElementKind
81 entries: results,
82 };
83 };
84 LanguageServiceImpl.prototype.getDefinitionAndBoundSpan = function (fileName, position) {
85 this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
86 var templateInfo = this.host.getTemplateAstAtPosition(fileName, position);
87 if (templateInfo) {
88 return definitions_1.getDefinitionAndBoundSpan(templateInfo, position);
89 }
90 // Attempt to get Angular-specific definitions in a TypeScript file, like templates defined
91 // in a `templateUrl` property.
92 if (fileName.endsWith('.ts')) {
93 var sf = this.host.getSourceFile(fileName);
94 if (sf) {
95 return definitions_1.getTsDefinitionAndBoundSpan(sf, position, this.host.tsLsHost);
96 }
97 }
98 };
99 LanguageServiceImpl.prototype.getQuickInfoAtPosition = function (fileName, position) {
100 var analyzedModules = this.host.getAnalyzedModules(); // same role as 'synchronizeHostData'
101 var templateInfo = this.host.getTemplateAstAtPosition(fileName, position);
102 if (templateInfo) {
103 return hover_1.getTemplateHover(templateInfo, position, analyzedModules);
104 }
105 // Attempt to get Angular-specific hover information in a TypeScript file, the NgModule a
106 // directive belongs to.
107 var declarations = this.host.getDeclarations(fileName);
108 return hover_1.getTsHover(position, declarations, analyzedModules);
109 };
110 LanguageServiceImpl.prototype.getReferencesAtPosition = function (fileName, position) {
111 var defAndSpan = this.getDefinitionAndBoundSpan(fileName, position);
112 if (!(defAndSpan === null || defAndSpan === void 0 ? void 0 : defAndSpan.definitions)) {
113 return;
114 }
115 var definitions = defAndSpan.definitions;
116 var tsDef = definitions.find(function (def) { return def.fileName.endsWith('.ts'); });
117 if (!tsDef) {
118 return;
119 }
120 return this.host.tsLS.getReferencesAtPosition(tsDef.fileName, tsDef.textSpan.start);
121 };
122 return LanguageServiceImpl;
123 }());
124});
125//# 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 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 * 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    // 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  getReferencesAtPosition(fileName: string, position: number): tss.ReferenceEntry[]|undefined {\n    const defAndSpan = this.getDefinitionAndBoundSpan(fileName, position);\n    if (!defAndSpan?.definitions) {\n      return;\n    }\n    const {definitions} = defAndSpan;\n    const tsDef = definitions.find(def => def.fileName.endsWith('.ts'));\n    if (!tsDef) {\n      return;\n    }\n    return this.host.tsLS.getReferencesAtPosition(tsDef.fileName, tsDef.textSpan.start);\n  }\n}\n"]}
\No newline at end of file