UNPKG

23.2 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/ivy/ts_plugin", ["require", "exports", "tslib", "typescript/lib/tsserverlibrary", "@angular/language-service/ivy/language_service"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.getExternalFiles = exports.create = void 0;
20 var tslib_1 = require("tslib");
21 var ts = require("typescript/lib/tsserverlibrary");
22 var language_service_1 = require("@angular/language-service/ivy/language_service");
23 function create(info) {
24 var project = info.project, tsLS = info.languageService, config = info.config;
25 var angularOnly = (config === null || config === void 0 ? void 0 : config.angularOnly) === true;
26 var ngLS = new language_service_1.LanguageService(project, tsLS);
27 function getSemanticDiagnostics(fileName) {
28 var diagnostics = [];
29 if (!angularOnly) {
30 diagnostics.push.apply(diagnostics, tslib_1.__spread(tsLS.getSemanticDiagnostics(fileName)));
31 }
32 diagnostics.push.apply(diagnostics, tslib_1.__spread(ngLS.getSemanticDiagnostics(fileName)));
33 return diagnostics;
34 }
35 function getQuickInfoAtPosition(fileName, position) {
36 var _a;
37 if (angularOnly) {
38 return ngLS.getQuickInfoAtPosition(fileName, position);
39 }
40 else {
41 // If TS could answer the query, then return that result. Otherwise, return from Angular LS.
42 return (_a = tsLS.getQuickInfoAtPosition(fileName, position)) !== null && _a !== void 0 ? _a : ngLS.getQuickInfoAtPosition(fileName, position);
43 }
44 }
45 function getTypeDefinitionAtPosition(fileName, position) {
46 var _a;
47 if (angularOnly) {
48 return ngLS.getTypeDefinitionAtPosition(fileName, position);
49 }
50 else {
51 // If TS could answer the query, then return that result. Otherwise, return from Angular LS.
52 return (_a = tsLS.getTypeDefinitionAtPosition(fileName, position)) !== null && _a !== void 0 ? _a : ngLS.getTypeDefinitionAtPosition(fileName, position);
53 }
54 }
55 function getDefinitionAndBoundSpan(fileName, position) {
56 var _a;
57 if (angularOnly) {
58 return ngLS.getDefinitionAndBoundSpan(fileName, position);
59 }
60 else {
61 // If TS could answer the query, then return that result. Otherwise, return from Angular LS.
62 return (_a = tsLS.getDefinitionAndBoundSpan(fileName, position)) !== null && _a !== void 0 ? _a : ngLS.getDefinitionAndBoundSpan(fileName, position);
63 }
64 }
65 function getReferencesAtPosition(fileName, position) {
66 return ngLS.getReferencesAtPosition(fileName, position);
67 }
68 function findRenameLocations(fileName, position, findInStrings, findInComments, providePrefixAndSuffixTextForRename) {
69 // Most operations combine results from all extensions. However, rename locations are exclusive
70 // (results from only one extension are used) so our rename locations are a superset of the TS
71 // rename locations. As a result, we do not check the `angularOnly` flag here because we always
72 // want to include results at TS locations as well as locations in templates.
73 return ngLS.findRenameLocations(fileName, position);
74 }
75 function getRenameInfo(fileName, position) {
76 // See the comment in `findRenameLocations` explaining why we don't check the `angularOnly`
77 // flag.
78 return ngLS.getRenameInfo(fileName, position);
79 }
80 function getCompletionsAtPosition(fileName, position, options) {
81 var _a;
82 if (angularOnly) {
83 return ngLS.getCompletionsAtPosition(fileName, position, options);
84 }
85 else {
86 // If TS could answer the query, then return that result. Otherwise, return from Angular LS.
87 return (_a = tsLS.getCompletionsAtPosition(fileName, position, options)) !== null && _a !== void 0 ? _a : ngLS.getCompletionsAtPosition(fileName, position, options);
88 }
89 }
90 function getCompletionEntryDetails(fileName, position, entryName, formatOptions, source, preferences) {
91 var _a;
92 if (angularOnly) {
93 return ngLS.getCompletionEntryDetails(fileName, position, entryName, formatOptions, preferences);
94 }
95 else {
96 // If TS could answer the query, then return that result. Otherwise, return from Angular LS.
97 return (_a = tsLS.getCompletionEntryDetails(fileName, position, entryName, formatOptions, source, preferences)) !== null && _a !== void 0 ? _a : ngLS.getCompletionEntryDetails(fileName, position, entryName, formatOptions, preferences);
98 }
99 }
100 function getCompletionEntrySymbol(fileName, position, name, source) {
101 var _a;
102 if (angularOnly) {
103 return ngLS.getCompletionEntrySymbol(fileName, position, name);
104 }
105 else {
106 // If TS could answer the query, then return that result. Otherwise, return from Angular LS.
107 return (_a = tsLS.getCompletionEntrySymbol(fileName, position, name, source)) !== null && _a !== void 0 ? _a : ngLS.getCompletionEntrySymbol(fileName, position, name);
108 }
109 }
110 /**
111 * Gets global diagnostics related to the program configuration and compiler options.
112 */
113 function getCompilerOptionsDiagnostics() {
114 var diagnostics = [];
115 if (!angularOnly) {
116 diagnostics.push.apply(diagnostics, tslib_1.__spread(tsLS.getCompilerOptionsDiagnostics()));
117 }
118 diagnostics.push.apply(diagnostics, tslib_1.__spread(ngLS.getCompilerOptionsDiagnostics()));
119 return diagnostics;
120 }
121 function getTcb(fileName, position) {
122 return ngLS.getTcb(fileName, position);
123 }
124 return tslib_1.__assign(tslib_1.__assign({}, tsLS), { getSemanticDiagnostics: getSemanticDiagnostics,
125 getTypeDefinitionAtPosition: getTypeDefinitionAtPosition,
126 getQuickInfoAtPosition: getQuickInfoAtPosition,
127 getDefinitionAndBoundSpan: getDefinitionAndBoundSpan,
128 getReferencesAtPosition: getReferencesAtPosition,
129 findRenameLocations: findRenameLocations,
130 getRenameInfo: getRenameInfo,
131 getCompletionsAtPosition: getCompletionsAtPosition,
132 getCompletionEntryDetails: getCompletionEntryDetails,
133 getCompletionEntrySymbol: getCompletionEntrySymbol,
134 getTcb: getTcb,
135 getCompilerOptionsDiagnostics: getCompilerOptionsDiagnostics });
136 }
137 exports.create = create;
138 function getExternalFiles(project) {
139 var e_1, _a;
140 if (!project.hasRoots()) {
141 return []; // project has not been initialized
142 }
143 var typecheckFiles = [];
144 try {
145 for (var _b = tslib_1.__values(project.getScriptInfos()), _c = _b.next(); !_c.done; _c = _b.next()) {
146 var scriptInfo = _c.value;
147 if (scriptInfo.scriptKind === ts.ScriptKind.External) {
148 // script info for typecheck file is marked as external, see
149 // getOrCreateTypeCheckScriptInfo() in
150 // packages/language-service/ivy/language_service.ts
151 typecheckFiles.push(scriptInfo.fileName);
152 }
153 }
154 }
155 catch (e_1_1) { e_1 = { error: e_1_1 }; }
156 finally {
157 try {
158 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
159 }
160 finally { if (e_1) throw e_1.error; }
161 }
162 return typecheckFiles;
163 }
164 exports.getExternalFiles = getExternalFiles;
165});
166//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ts_plugin.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/ts_plugin.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 ts from 'typescript/lib/tsserverlibrary';\nimport {GetTcbResponse, NgLanguageService} from '../api';\nimport {LanguageService} from './language_service';\n\nexport function create(info: ts.server.PluginCreateInfo): NgLanguageService {\n  const {project, languageService: tsLS, config} = info;\n  const angularOnly = config?.angularOnly === true;\n\n  const ngLS = new LanguageService(project, tsLS);\n\n  function getSemanticDiagnostics(fileName: string): ts.Diagnostic[] {\n    const diagnostics: ts.Diagnostic[] = [];\n    if (!angularOnly) {\n      diagnostics.push(...tsLS.getSemanticDiagnostics(fileName));\n    }\n    diagnostics.push(...ngLS.getSemanticDiagnostics(fileName));\n    return diagnostics;\n  }\n\n  function getQuickInfoAtPosition(fileName: string, position: number): ts.QuickInfo|undefined {\n    if (angularOnly) {\n      return ngLS.getQuickInfoAtPosition(fileName, position);\n    } else {\n      // If TS could answer the query, then return that result. Otherwise, return from Angular LS.\n      return tsLS.getQuickInfoAtPosition(fileName, position) ??\n          ngLS.getQuickInfoAtPosition(fileName, position);\n    }\n  }\n\n  function getTypeDefinitionAtPosition(\n      fileName: string, position: number): readonly ts.DefinitionInfo[]|undefined {\n    if (angularOnly) {\n      return ngLS.getTypeDefinitionAtPosition(fileName, position);\n    } else {\n      // If TS could answer the query, then return that result. Otherwise, return from Angular LS.\n      return tsLS.getTypeDefinitionAtPosition(fileName, position) ??\n          ngLS.getTypeDefinitionAtPosition(fileName, position);\n    }\n  }\n\n  function getDefinitionAndBoundSpan(\n      fileName: string, position: number): ts.DefinitionInfoAndBoundSpan|undefined {\n    if (angularOnly) {\n      return ngLS.getDefinitionAndBoundSpan(fileName, position);\n    } else {\n      // If TS could answer the query, then return that result. Otherwise, return from Angular LS.\n      return tsLS.getDefinitionAndBoundSpan(fileName, position) ??\n          ngLS.getDefinitionAndBoundSpan(fileName, position);\n    }\n  }\n\n  function getReferencesAtPosition(fileName: string, position: number): ts.ReferenceEntry[]|\n      undefined {\n    return ngLS.getReferencesAtPosition(fileName, position);\n  }\n\n  function findRenameLocations(\n      fileName: string, position: number, findInStrings: boolean, findInComments: boolean,\n      providePrefixAndSuffixTextForRename?: boolean): readonly ts.RenameLocation[]|undefined {\n    // Most operations combine results from all extensions. However, rename locations are exclusive\n    // (results from only one extension are used) so our rename locations are a superset of the TS\n    // rename locations. As a result, we do not check the `angularOnly` flag here because we always\n    // want to include results at TS locations as well as locations in templates.\n    return ngLS.findRenameLocations(fileName, position);\n  }\n\n  function getRenameInfo(fileName: string, position: number): ts.RenameInfo {\n    // See the comment in `findRenameLocations` explaining why we don't check the `angularOnly`\n    // flag.\n    return ngLS.getRenameInfo(fileName, position);\n  }\n\n  function getCompletionsAtPosition(\n      fileName: string, position: number,\n      options: ts.GetCompletionsAtPositionOptions): ts.WithMetadata<ts.CompletionInfo>|undefined {\n    if (angularOnly) {\n      return ngLS.getCompletionsAtPosition(fileName, position, options);\n    } else {\n      // If TS could answer the query, then return that result. Otherwise, return from Angular LS.\n      return tsLS.getCompletionsAtPosition(fileName, position, options) ??\n          ngLS.getCompletionsAtPosition(fileName, position, options);\n    }\n  }\n\n  function getCompletionEntryDetails(\n      fileName: string, position: number, entryName: string,\n      formatOptions: ts.FormatCodeOptions|ts.FormatCodeSettings|undefined, source: string|undefined,\n      preferences: ts.UserPreferences|undefined): ts.CompletionEntryDetails|undefined {\n    if (angularOnly) {\n      return ngLS.getCompletionEntryDetails(\n          fileName, position, entryName, formatOptions, preferences);\n    } else {\n      // If TS could answer the query, then return that result. Otherwise, return from Angular LS.\n      return tsLS.getCompletionEntryDetails(\n                 fileName, position, entryName, formatOptions, source, preferences) ??\n          ngLS.getCompletionEntryDetails(fileName, position, entryName, formatOptions, preferences);\n    }\n  }\n\n  function getCompletionEntrySymbol(\n      fileName: string, position: number, name: string, source: string|undefined): ts.Symbol|\n      undefined {\n    if (angularOnly) {\n      return ngLS.getCompletionEntrySymbol(fileName, position, name);\n    } else {\n      // If TS could answer the query, then return that result. Otherwise, return from Angular LS.\n      return tsLS.getCompletionEntrySymbol(fileName, position, name, source) ??\n          ngLS.getCompletionEntrySymbol(fileName, position, name);\n    }\n  }\n  /**\n   * Gets global diagnostics related to the program configuration and compiler options.\n   */\n  function getCompilerOptionsDiagnostics(): ts.Diagnostic[] {\n    const diagnostics: ts.Diagnostic[] = [];\n    if (!angularOnly) {\n      diagnostics.push(...tsLS.getCompilerOptionsDiagnostics());\n    }\n    diagnostics.push(...ngLS.getCompilerOptionsDiagnostics());\n    return diagnostics;\n  }\n\n  function getTcb(fileName: string, position: number): GetTcbResponse {\n    return ngLS.getTcb(fileName, position);\n  }\n\n  return {\n    ...tsLS,\n    getSemanticDiagnostics,\n    getTypeDefinitionAtPosition,\n    getQuickInfoAtPosition,\n    getDefinitionAndBoundSpan,\n    getReferencesAtPosition,\n    findRenameLocations,\n    getRenameInfo,\n    getCompletionsAtPosition,\n    getCompletionEntryDetails,\n    getCompletionEntrySymbol,\n    getTcb,\n    getCompilerOptionsDiagnostics,\n  };\n}\n\nexport function getExternalFiles(project: ts.server.Project): string[] {\n  if (!project.hasRoots()) {\n    return [];  // project has not been initialized\n  }\n  const typecheckFiles: string[] = [];\n  for (const scriptInfo of project.getScriptInfos()) {\n    if (scriptInfo.scriptKind === ts.ScriptKind.External) {\n      // script info for typecheck file is marked as external, see\n      // getOrCreateTypeCheckScriptInfo() in\n      // packages/language-service/ivy/language_service.ts\n      typecheckFiles.push(scriptInfo.fileName);\n    }\n  }\n  return typecheckFiles;\n}\n"]}
\No newline at end of file