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 | ;
|
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 |