45177c90b79cd4a3411c5919ce81e029a9114f1eb729d22c733e502d2bf5bd2781a902a48e8b6f67876418c2aed6b1745b970273660bcb80254c64bc581d37 39 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114
  1. /*!-----------------------------------------------------------------------------
  2. * Copyright (c) Microsoft Corporation. All rights reserved.
  3. * Version: 0.34.1(547870b6881302c5b4ff32173c16d06009e3588f)
  4. * Released under the MIT license
  5. * https://github.com/microsoft/monaco-editor/blob/main/LICENSE.txt
  6. *-----------------------------------------------------------------------------*/
  7. var __defProp = Object.defineProperty;
  8. var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
  9. var __getOwnPropNames = Object.getOwnPropertyNames;
  10. var __hasOwnProp = Object.prototype.hasOwnProperty;
  11. var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
  12. var __copyProps = (to, from, except, desc) => {
  13. if (from && typeof from === "object" || typeof from === "function") {
  14. for (let key of __getOwnPropNames(from))
  15. if (!__hasOwnProp.call(to, key) && key !== except)
  16. __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
  17. }
  18. return to;
  19. };
  20. var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
  21. var __publicField = (obj, key, value) => {
  22. __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
  23. return value;
  24. };
  25. // src/fillers/monaco-editor-core.ts
  26. var monaco_editor_core_exports = {};
  27. __reExport(monaco_editor_core_exports, monaco_editor_core_star);
  28. import * as monaco_editor_core_star from "../../editor/editor.api.js";
  29. // src/language/typescript/workerManager.ts
  30. var WorkerManager = class {
  31. constructor(_modeId, _defaults) {
  32. this._modeId = _modeId;
  33. this._defaults = _defaults;
  34. this._worker = null;
  35. this._client = null;
  36. this._configChangeListener = this._defaults.onDidChange(() => this._stopWorker());
  37. this._updateExtraLibsToken = 0;
  38. this._extraLibsChangeListener = this._defaults.onDidExtraLibsChange(() => this._updateExtraLibs());
  39. }
  40. _configChangeListener;
  41. _updateExtraLibsToken;
  42. _extraLibsChangeListener;
  43. _worker;
  44. _client;
  45. dispose() {
  46. this._configChangeListener.dispose();
  47. this._extraLibsChangeListener.dispose();
  48. this._stopWorker();
  49. }
  50. _stopWorker() {
  51. if (this._worker) {
  52. this._worker.dispose();
  53. this._worker = null;
  54. }
  55. this._client = null;
  56. }
  57. async _updateExtraLibs() {
  58. if (!this._worker) {
  59. return;
  60. }
  61. const myToken = ++this._updateExtraLibsToken;
  62. const proxy = await this._worker.getProxy();
  63. if (this._updateExtraLibsToken !== myToken) {
  64. return;
  65. }
  66. proxy.updateExtraLibs(this._defaults.getExtraLibs());
  67. }
  68. _getClient() {
  69. if (!this._client) {
  70. this._client = (async () => {
  71. this._worker = monaco_editor_core_exports.editor.createWebWorker({
  72. moduleId: "vs/language/typescript/tsWorker",
  73. label: this._modeId,
  74. keepIdleModels: true,
  75. createData: {
  76. compilerOptions: this._defaults.getCompilerOptions(),
  77. extraLibs: this._defaults.getExtraLibs(),
  78. customWorkerPath: this._defaults.workerOptions.customWorkerPath,
  79. inlayHintsOptions: this._defaults.inlayHintsOptions
  80. }
  81. });
  82. if (this._defaults.getEagerModelSync()) {
  83. return await this._worker.withSyncedResources(monaco_editor_core_exports.editor.getModels().filter((model) => model.getLanguageId() === this._modeId).map((model) => model.uri));
  84. }
  85. return await this._worker.getProxy();
  86. })();
  87. }
  88. return this._client;
  89. }
  90. async getLanguageServiceWorker(...resources) {
  91. const client = await this._getClient();
  92. if (this._worker) {
  93. await this._worker.withSyncedResources(resources);
  94. }
  95. return client;
  96. }
  97. };
  98. // src/language/typescript/languageFeatures.ts
  99. import {
  100. typescriptDefaults
  101. } from "./monaco.contribution.js";
  102. // src/language/typescript/lib/lib.index.ts
  103. var libFileSet = {};
  104. libFileSet["lib.d.ts"] = true;
  105. libFileSet["lib.dom.d.ts"] = true;
  106. libFileSet["lib.dom.iterable.d.ts"] = true;
  107. libFileSet["lib.es2015.collection.d.ts"] = true;
  108. libFileSet["lib.es2015.core.d.ts"] = true;
  109. libFileSet["lib.es2015.d.ts"] = true;
  110. libFileSet["lib.es2015.generator.d.ts"] = true;
  111. libFileSet["lib.es2015.iterable.d.ts"] = true;
  112. libFileSet["lib.es2015.promise.d.ts"] = true;
  113. libFileSet["lib.es2015.proxy.d.ts"] = true;
  114. libFileSet["lib.es2015.reflect.d.ts"] = true;
  115. libFileSet["lib.es2015.symbol.d.ts"] = true;
  116. libFileSet["lib.es2015.symbol.wellknown.d.ts"] = true;
  117. libFileSet["lib.es2016.array.include.d.ts"] = true;
  118. libFileSet["lib.es2016.d.ts"] = true;
  119. libFileSet["lib.es2016.full.d.ts"] = true;
  120. libFileSet["lib.es2017.d.ts"] = true;
  121. libFileSet["lib.es2017.full.d.ts"] = true;
  122. libFileSet["lib.es2017.intl.d.ts"] = true;
  123. libFileSet["lib.es2017.object.d.ts"] = true;
  124. libFileSet["lib.es2017.sharedmemory.d.ts"] = true;
  125. libFileSet["lib.es2017.string.d.ts"] = true;
  126. libFileSet["lib.es2017.typedarrays.d.ts"] = true;
  127. libFileSet["lib.es2018.asyncgenerator.d.ts"] = true;
  128. libFileSet["lib.es2018.asynciterable.d.ts"] = true;
  129. libFileSet["lib.es2018.d.ts"] = true;
  130. libFileSet["lib.es2018.full.d.ts"] = true;
  131. libFileSet["lib.es2018.intl.d.ts"] = true;
  132. libFileSet["lib.es2018.promise.d.ts"] = true;
  133. libFileSet["lib.es2018.regexp.d.ts"] = true;
  134. libFileSet["lib.es2019.array.d.ts"] = true;
  135. libFileSet["lib.es2019.d.ts"] = true;
  136. libFileSet["lib.es2019.full.d.ts"] = true;
  137. libFileSet["lib.es2019.object.d.ts"] = true;
  138. libFileSet["lib.es2019.string.d.ts"] = true;
  139. libFileSet["lib.es2019.symbol.d.ts"] = true;
  140. libFileSet["lib.es2020.bigint.d.ts"] = true;
  141. libFileSet["lib.es2020.d.ts"] = true;
  142. libFileSet["lib.es2020.full.d.ts"] = true;
  143. libFileSet["lib.es2020.intl.d.ts"] = true;
  144. libFileSet["lib.es2020.promise.d.ts"] = true;
  145. libFileSet["lib.es2020.sharedmemory.d.ts"] = true;
  146. libFileSet["lib.es2020.string.d.ts"] = true;
  147. libFileSet["lib.es2020.symbol.wellknown.d.ts"] = true;
  148. libFileSet["lib.es2021.d.ts"] = true;
  149. libFileSet["lib.es2021.full.d.ts"] = true;
  150. libFileSet["lib.es2021.intl.d.ts"] = true;
  151. libFileSet["lib.es2021.promise.d.ts"] = true;
  152. libFileSet["lib.es2021.string.d.ts"] = true;
  153. libFileSet["lib.es2021.weakref.d.ts"] = true;
  154. libFileSet["lib.es5.d.ts"] = true;
  155. libFileSet["lib.es6.d.ts"] = true;
  156. libFileSet["lib.esnext.d.ts"] = true;
  157. libFileSet["lib.esnext.full.d.ts"] = true;
  158. libFileSet["lib.esnext.intl.d.ts"] = true;
  159. libFileSet["lib.esnext.promise.d.ts"] = true;
  160. libFileSet["lib.esnext.string.d.ts"] = true;
  161. libFileSet["lib.esnext.weakref.d.ts"] = true;
  162. libFileSet["lib.scripthost.d.ts"] = true;
  163. libFileSet["lib.webworker.d.ts"] = true;
  164. libFileSet["lib.webworker.importscripts.d.ts"] = true;
  165. libFileSet["lib.webworker.iterable.d.ts"] = true;
  166. // src/language/typescript/languageFeatures.ts
  167. function flattenDiagnosticMessageText(diag, newLine, indent = 0) {
  168. if (typeof diag === "string") {
  169. return diag;
  170. } else if (diag === void 0) {
  171. return "";
  172. }
  173. let result = "";
  174. if (indent) {
  175. result += newLine;
  176. for (let i = 0; i < indent; i++) {
  177. result += " ";
  178. }
  179. }
  180. result += diag.messageText;
  181. indent++;
  182. if (diag.next) {
  183. for (const kid of diag.next) {
  184. result += flattenDiagnosticMessageText(kid, newLine, indent);
  185. }
  186. }
  187. return result;
  188. }
  189. function displayPartsToString(displayParts) {
  190. if (displayParts) {
  191. return displayParts.map((displayPart) => displayPart.text).join("");
  192. }
  193. return "";
  194. }
  195. var Adapter = class {
  196. constructor(_worker) {
  197. this._worker = _worker;
  198. }
  199. _textSpanToRange(model, span) {
  200. let p1 = model.getPositionAt(span.start);
  201. let p2 = model.getPositionAt(span.start + span.length);
  202. let { lineNumber: startLineNumber, column: startColumn } = p1;
  203. let { lineNumber: endLineNumber, column: endColumn } = p2;
  204. return { startLineNumber, startColumn, endLineNumber, endColumn };
  205. }
  206. };
  207. var LibFiles = class {
  208. constructor(_worker) {
  209. this._worker = _worker;
  210. this._libFiles = {};
  211. this._hasFetchedLibFiles = false;
  212. this._fetchLibFilesPromise = null;
  213. }
  214. _libFiles;
  215. _hasFetchedLibFiles;
  216. _fetchLibFilesPromise;
  217. isLibFile(uri) {
  218. if (!uri) {
  219. return false;
  220. }
  221. if (uri.path.indexOf("/lib.") === 0) {
  222. return !!libFileSet[uri.path.slice(1)];
  223. }
  224. return false;
  225. }
  226. getOrCreateModel(fileName) {
  227. const uri = monaco_editor_core_exports.Uri.parse(fileName);
  228. const model = monaco_editor_core_exports.editor.getModel(uri);
  229. if (model) {
  230. return model;
  231. }
  232. if (this.isLibFile(uri) && this._hasFetchedLibFiles) {
  233. return monaco_editor_core_exports.editor.createModel(this._libFiles[uri.path.slice(1)], "typescript", uri);
  234. }
  235. const matchedLibFile = typescriptDefaults.getExtraLibs()[fileName];
  236. if (matchedLibFile) {
  237. return monaco_editor_core_exports.editor.createModel(matchedLibFile.content, "typescript", uri);
  238. }
  239. return null;
  240. }
  241. _containsLibFile(uris) {
  242. for (let uri of uris) {
  243. if (this.isLibFile(uri)) {
  244. return true;
  245. }
  246. }
  247. return false;
  248. }
  249. async fetchLibFilesIfNecessary(uris) {
  250. if (!this._containsLibFile(uris)) {
  251. return;
  252. }
  253. await this._fetchLibFiles();
  254. }
  255. _fetchLibFiles() {
  256. if (!this._fetchLibFilesPromise) {
  257. this._fetchLibFilesPromise = this._worker().then((w) => w.getLibFiles()).then((libFiles) => {
  258. this._hasFetchedLibFiles = true;
  259. this._libFiles = libFiles;
  260. });
  261. }
  262. return this._fetchLibFilesPromise;
  263. }
  264. };
  265. var DiagnosticsAdapter = class extends Adapter {
  266. constructor(_libFiles, _defaults, _selector, worker) {
  267. super(worker);
  268. this._libFiles = _libFiles;
  269. this._defaults = _defaults;
  270. this._selector = _selector;
  271. const onModelAdd = (model) => {
  272. if (model.getLanguageId() !== _selector) {
  273. return;
  274. }
  275. const maybeValidate = () => {
  276. const { onlyVisible } = this._defaults.getDiagnosticsOptions();
  277. if (onlyVisible) {
  278. if (model.isAttachedToEditor()) {
  279. this._doValidate(model);
  280. }
  281. } else {
  282. this._doValidate(model);
  283. }
  284. };
  285. let handle;
  286. const changeSubscription = model.onDidChangeContent(() => {
  287. clearTimeout(handle);
  288. handle = window.setTimeout(maybeValidate, 500);
  289. });
  290. const visibleSubscription = model.onDidChangeAttached(() => {
  291. const { onlyVisible } = this._defaults.getDiagnosticsOptions();
  292. if (onlyVisible) {
  293. if (model.isAttachedToEditor()) {
  294. maybeValidate();
  295. } else {
  296. monaco_editor_core_exports.editor.setModelMarkers(model, this._selector, []);
  297. }
  298. }
  299. });
  300. this._listener[model.uri.toString()] = {
  301. dispose() {
  302. changeSubscription.dispose();
  303. visibleSubscription.dispose();
  304. clearTimeout(handle);
  305. }
  306. };
  307. maybeValidate();
  308. };
  309. const onModelRemoved = (model) => {
  310. monaco_editor_core_exports.editor.setModelMarkers(model, this._selector, []);
  311. const key = model.uri.toString();
  312. if (this._listener[key]) {
  313. this._listener[key].dispose();
  314. delete this._listener[key];
  315. }
  316. };
  317. this._disposables.push(monaco_editor_core_exports.editor.onDidCreateModel((model) => onModelAdd(model)));
  318. this._disposables.push(monaco_editor_core_exports.editor.onWillDisposeModel(onModelRemoved));
  319. this._disposables.push(monaco_editor_core_exports.editor.onDidChangeModelLanguage((event) => {
  320. onModelRemoved(event.model);
  321. onModelAdd(event.model);
  322. }));
  323. this._disposables.push({
  324. dispose() {
  325. for (const model of monaco_editor_core_exports.editor.getModels()) {
  326. onModelRemoved(model);
  327. }
  328. }
  329. });
  330. const recomputeDiagostics = () => {
  331. for (const model of monaco_editor_core_exports.editor.getModels()) {
  332. onModelRemoved(model);
  333. onModelAdd(model);
  334. }
  335. };
  336. this._disposables.push(this._defaults.onDidChange(recomputeDiagostics));
  337. this._disposables.push(this._defaults.onDidExtraLibsChange(recomputeDiagostics));
  338. monaco_editor_core_exports.editor.getModels().forEach((model) => onModelAdd(model));
  339. }
  340. _disposables = [];
  341. _listener = /* @__PURE__ */ Object.create(null);
  342. dispose() {
  343. this._disposables.forEach((d) => d && d.dispose());
  344. this._disposables = [];
  345. }
  346. async _doValidate(model) {
  347. const worker = await this._worker(model.uri);
  348. if (model.isDisposed()) {
  349. return;
  350. }
  351. const promises = [];
  352. const { noSyntaxValidation, noSemanticValidation, noSuggestionDiagnostics } = this._defaults.getDiagnosticsOptions();
  353. if (!noSyntaxValidation) {
  354. promises.push(worker.getSyntacticDiagnostics(model.uri.toString()));
  355. }
  356. if (!noSemanticValidation) {
  357. promises.push(worker.getSemanticDiagnostics(model.uri.toString()));
  358. }
  359. if (!noSuggestionDiagnostics) {
  360. promises.push(worker.getSuggestionDiagnostics(model.uri.toString()));
  361. }
  362. const allDiagnostics = await Promise.all(promises);
  363. if (!allDiagnostics || model.isDisposed()) {
  364. return;
  365. }
  366. const diagnostics = allDiagnostics.reduce((p, c) => c.concat(p), []).filter((d) => (this._defaults.getDiagnosticsOptions().diagnosticCodesToIgnore || []).indexOf(d.code) === -1);
  367. const relatedUris = diagnostics.map((d) => d.relatedInformation || []).reduce((p, c) => c.concat(p), []).map((relatedInformation) => relatedInformation.file ? monaco_editor_core_exports.Uri.parse(relatedInformation.file.fileName) : null);
  368. await this._libFiles.fetchLibFilesIfNecessary(relatedUris);
  369. if (model.isDisposed()) {
  370. return;
  371. }
  372. monaco_editor_core_exports.editor.setModelMarkers(model, this._selector, diagnostics.map((d) => this._convertDiagnostics(model, d)));
  373. }
  374. _convertDiagnostics(model, diag) {
  375. const diagStart = diag.start || 0;
  376. const diagLength = diag.length || 1;
  377. const { lineNumber: startLineNumber, column: startColumn } = model.getPositionAt(diagStart);
  378. const { lineNumber: endLineNumber, column: endColumn } = model.getPositionAt(diagStart + diagLength);
  379. const tags = [];
  380. if (diag.reportsUnnecessary) {
  381. tags.push(monaco_editor_core_exports.MarkerTag.Unnecessary);
  382. }
  383. if (diag.reportsDeprecated) {
  384. tags.push(monaco_editor_core_exports.MarkerTag.Deprecated);
  385. }
  386. return {
  387. severity: this._tsDiagnosticCategoryToMarkerSeverity(diag.category),
  388. startLineNumber,
  389. startColumn,
  390. endLineNumber,
  391. endColumn,
  392. message: flattenDiagnosticMessageText(diag.messageText, "\n"),
  393. code: diag.code.toString(),
  394. tags,
  395. relatedInformation: this._convertRelatedInformation(model, diag.relatedInformation)
  396. };
  397. }
  398. _convertRelatedInformation(model, relatedInformation) {
  399. if (!relatedInformation) {
  400. return [];
  401. }
  402. const result = [];
  403. relatedInformation.forEach((info) => {
  404. let relatedResource = model;
  405. if (info.file) {
  406. relatedResource = this._libFiles.getOrCreateModel(info.file.fileName);
  407. }
  408. if (!relatedResource) {
  409. return;
  410. }
  411. const infoStart = info.start || 0;
  412. const infoLength = info.length || 1;
  413. const { lineNumber: startLineNumber, column: startColumn } = relatedResource.getPositionAt(infoStart);
  414. const { lineNumber: endLineNumber, column: endColumn } = relatedResource.getPositionAt(infoStart + infoLength);
  415. result.push({
  416. resource: relatedResource.uri,
  417. startLineNumber,
  418. startColumn,
  419. endLineNumber,
  420. endColumn,
  421. message: flattenDiagnosticMessageText(info.messageText, "\n")
  422. });
  423. });
  424. return result;
  425. }
  426. _tsDiagnosticCategoryToMarkerSeverity(category) {
  427. switch (category) {
  428. case 1 /* Error */:
  429. return monaco_editor_core_exports.MarkerSeverity.Error;
  430. case 3 /* Message */:
  431. return monaco_editor_core_exports.MarkerSeverity.Info;
  432. case 0 /* Warning */:
  433. return monaco_editor_core_exports.MarkerSeverity.Warning;
  434. case 2 /* Suggestion */:
  435. return monaco_editor_core_exports.MarkerSeverity.Hint;
  436. }
  437. return monaco_editor_core_exports.MarkerSeverity.Info;
  438. }
  439. };
  440. var SuggestAdapter = class extends Adapter {
  441. get triggerCharacters() {
  442. return ["."];
  443. }
  444. async provideCompletionItems(model, position, _context, token) {
  445. const wordInfo = model.getWordUntilPosition(position);
  446. const wordRange = new monaco_editor_core_exports.Range(position.lineNumber, wordInfo.startColumn, position.lineNumber, wordInfo.endColumn);
  447. const resource = model.uri;
  448. const offset = model.getOffsetAt(position);
  449. const worker = await this._worker(resource);
  450. if (model.isDisposed()) {
  451. return;
  452. }
  453. const info = await worker.getCompletionsAtPosition(resource.toString(), offset);
  454. if (!info || model.isDisposed()) {
  455. return;
  456. }
  457. const suggestions = info.entries.map((entry) => {
  458. let range = wordRange;
  459. if (entry.replacementSpan) {
  460. const p1 = model.getPositionAt(entry.replacementSpan.start);
  461. const p2 = model.getPositionAt(entry.replacementSpan.start + entry.replacementSpan.length);
  462. range = new monaco_editor_core_exports.Range(p1.lineNumber, p1.column, p2.lineNumber, p2.column);
  463. }
  464. const tags = [];
  465. if (entry.kindModifiers?.indexOf("deprecated") !== -1) {
  466. tags.push(monaco_editor_core_exports.languages.CompletionItemTag.Deprecated);
  467. }
  468. return {
  469. uri: resource,
  470. position,
  471. offset,
  472. range,
  473. label: entry.name,
  474. insertText: entry.name,
  475. sortText: entry.sortText,
  476. kind: SuggestAdapter.convertKind(entry.kind),
  477. tags
  478. };
  479. });
  480. return {
  481. suggestions
  482. };
  483. }
  484. async resolveCompletionItem(item, token) {
  485. const myItem = item;
  486. const resource = myItem.uri;
  487. const position = myItem.position;
  488. const offset = myItem.offset;
  489. const worker = await this._worker(resource);
  490. const details = await worker.getCompletionEntryDetails(resource.toString(), offset, myItem.label);
  491. if (!details) {
  492. return myItem;
  493. }
  494. return {
  495. uri: resource,
  496. position,
  497. label: details.name,
  498. kind: SuggestAdapter.convertKind(details.kind),
  499. detail: displayPartsToString(details.displayParts),
  500. documentation: {
  501. value: SuggestAdapter.createDocumentationString(details)
  502. }
  503. };
  504. }
  505. static convertKind(kind) {
  506. switch (kind) {
  507. case Kind.primitiveType:
  508. case Kind.keyword:
  509. return monaco_editor_core_exports.languages.CompletionItemKind.Keyword;
  510. case Kind.variable:
  511. case Kind.localVariable:
  512. return monaco_editor_core_exports.languages.CompletionItemKind.Variable;
  513. case Kind.memberVariable:
  514. case Kind.memberGetAccessor:
  515. case Kind.memberSetAccessor:
  516. return monaco_editor_core_exports.languages.CompletionItemKind.Field;
  517. case Kind.function:
  518. case Kind.memberFunction:
  519. case Kind.constructSignature:
  520. case Kind.callSignature:
  521. case Kind.indexSignature:
  522. return monaco_editor_core_exports.languages.CompletionItemKind.Function;
  523. case Kind.enum:
  524. return monaco_editor_core_exports.languages.CompletionItemKind.Enum;
  525. case Kind.module:
  526. return monaco_editor_core_exports.languages.CompletionItemKind.Module;
  527. case Kind.class:
  528. return monaco_editor_core_exports.languages.CompletionItemKind.Class;
  529. case Kind.interface:
  530. return monaco_editor_core_exports.languages.CompletionItemKind.Interface;
  531. case Kind.warning:
  532. return monaco_editor_core_exports.languages.CompletionItemKind.File;
  533. }
  534. return monaco_editor_core_exports.languages.CompletionItemKind.Property;
  535. }
  536. static createDocumentationString(details) {
  537. let documentationString = displayPartsToString(details.documentation);
  538. if (details.tags) {
  539. for (const tag of details.tags) {
  540. documentationString += `
  541. ${tagToString(tag)}`;
  542. }
  543. }
  544. return documentationString;
  545. }
  546. };
  547. function tagToString(tag) {
  548. let tagLabel = `*@${tag.name}*`;
  549. if (tag.name === "param" && tag.text) {
  550. const [paramName, ...rest] = tag.text;
  551. tagLabel += `\`${paramName.text}\``;
  552. if (rest.length > 0)
  553. tagLabel += ` \u2014 ${rest.map((r) => r.text).join(" ")}`;
  554. } else if (Array.isArray(tag.text)) {
  555. tagLabel += ` \u2014 ${tag.text.map((r) => r.text).join(" ")}`;
  556. } else if (tag.text) {
  557. tagLabel += ` \u2014 ${tag.text}`;
  558. }
  559. return tagLabel;
  560. }
  561. var SignatureHelpAdapter = class extends Adapter {
  562. signatureHelpTriggerCharacters = ["(", ","];
  563. static _toSignatureHelpTriggerReason(context) {
  564. switch (context.triggerKind) {
  565. case monaco_editor_core_exports.languages.SignatureHelpTriggerKind.TriggerCharacter:
  566. if (context.triggerCharacter) {
  567. if (context.isRetrigger) {
  568. return { kind: "retrigger", triggerCharacter: context.triggerCharacter };
  569. } else {
  570. return { kind: "characterTyped", triggerCharacter: context.triggerCharacter };
  571. }
  572. } else {
  573. return { kind: "invoked" };
  574. }
  575. case monaco_editor_core_exports.languages.SignatureHelpTriggerKind.ContentChange:
  576. return context.isRetrigger ? { kind: "retrigger" } : { kind: "invoked" };
  577. case monaco_editor_core_exports.languages.SignatureHelpTriggerKind.Invoke:
  578. default:
  579. return { kind: "invoked" };
  580. }
  581. }
  582. async provideSignatureHelp(model, position, token, context) {
  583. const resource = model.uri;
  584. const offset = model.getOffsetAt(position);
  585. const worker = await this._worker(resource);
  586. if (model.isDisposed()) {
  587. return;
  588. }
  589. const info = await worker.getSignatureHelpItems(resource.toString(), offset, {
  590. triggerReason: SignatureHelpAdapter._toSignatureHelpTriggerReason(context)
  591. });
  592. if (!info || model.isDisposed()) {
  593. return;
  594. }
  595. const ret = {
  596. activeSignature: info.selectedItemIndex,
  597. activeParameter: info.argumentIndex,
  598. signatures: []
  599. };
  600. info.items.forEach((item) => {
  601. const signature = {
  602. label: "",
  603. parameters: []
  604. };
  605. signature.documentation = {
  606. value: displayPartsToString(item.documentation)
  607. };
  608. signature.label += displayPartsToString(item.prefixDisplayParts);
  609. item.parameters.forEach((p, i, a) => {
  610. const label = displayPartsToString(p.displayParts);
  611. const parameter = {
  612. label,
  613. documentation: {
  614. value: displayPartsToString(p.documentation)
  615. }
  616. };
  617. signature.label += label;
  618. signature.parameters.push(parameter);
  619. if (i < a.length - 1) {
  620. signature.label += displayPartsToString(item.separatorDisplayParts);
  621. }
  622. });
  623. signature.label += displayPartsToString(item.suffixDisplayParts);
  624. ret.signatures.push(signature);
  625. });
  626. return {
  627. value: ret,
  628. dispose() {
  629. }
  630. };
  631. }
  632. };
  633. var QuickInfoAdapter = class extends Adapter {
  634. async provideHover(model, position, token) {
  635. const resource = model.uri;
  636. const offset = model.getOffsetAt(position);
  637. const worker = await this._worker(resource);
  638. if (model.isDisposed()) {
  639. return;
  640. }
  641. const info = await worker.getQuickInfoAtPosition(resource.toString(), offset);
  642. if (!info || model.isDisposed()) {
  643. return;
  644. }
  645. const documentation = displayPartsToString(info.documentation);
  646. const tags = info.tags ? info.tags.map((tag) => tagToString(tag)).join(" \n\n") : "";
  647. const contents = displayPartsToString(info.displayParts);
  648. return {
  649. range: this._textSpanToRange(model, info.textSpan),
  650. contents: [
  651. {
  652. value: "```typescript\n" + contents + "\n```\n"
  653. },
  654. {
  655. value: documentation + (tags ? "\n\n" + tags : "")
  656. }
  657. ]
  658. };
  659. }
  660. };
  661. var OccurrencesAdapter = class extends Adapter {
  662. async provideDocumentHighlights(model, position, token) {
  663. const resource = model.uri;
  664. const offset = model.getOffsetAt(position);
  665. const worker = await this._worker(resource);
  666. if (model.isDisposed()) {
  667. return;
  668. }
  669. const entries = await worker.getOccurrencesAtPosition(resource.toString(), offset);
  670. if (!entries || model.isDisposed()) {
  671. return;
  672. }
  673. return entries.map((entry) => {
  674. return {
  675. range: this._textSpanToRange(model, entry.textSpan),
  676. kind: entry.isWriteAccess ? monaco_editor_core_exports.languages.DocumentHighlightKind.Write : monaco_editor_core_exports.languages.DocumentHighlightKind.Text
  677. };
  678. });
  679. }
  680. };
  681. var DefinitionAdapter = class extends Adapter {
  682. constructor(_libFiles, worker) {
  683. super(worker);
  684. this._libFiles = _libFiles;
  685. }
  686. async provideDefinition(model, position, token) {
  687. const resource = model.uri;
  688. const offset = model.getOffsetAt(position);
  689. const worker = await this._worker(resource);
  690. if (model.isDisposed()) {
  691. return;
  692. }
  693. const entries = await worker.getDefinitionAtPosition(resource.toString(), offset);
  694. if (!entries || model.isDisposed()) {
  695. return;
  696. }
  697. await this._libFiles.fetchLibFilesIfNecessary(entries.map((entry) => monaco_editor_core_exports.Uri.parse(entry.fileName)));
  698. if (model.isDisposed()) {
  699. return;
  700. }
  701. const result = [];
  702. for (let entry of entries) {
  703. const refModel = this._libFiles.getOrCreateModel(entry.fileName);
  704. if (refModel) {
  705. result.push({
  706. uri: refModel.uri,
  707. range: this._textSpanToRange(refModel, entry.textSpan)
  708. });
  709. }
  710. }
  711. return result;
  712. }
  713. };
  714. var ReferenceAdapter = class extends Adapter {
  715. constructor(_libFiles, worker) {
  716. super(worker);
  717. this._libFiles = _libFiles;
  718. }
  719. async provideReferences(model, position, context, token) {
  720. const resource = model.uri;
  721. const offset = model.getOffsetAt(position);
  722. const worker = await this._worker(resource);
  723. if (model.isDisposed()) {
  724. return;
  725. }
  726. const entries = await worker.getReferencesAtPosition(resource.toString(), offset);
  727. if (!entries || model.isDisposed()) {
  728. return;
  729. }
  730. await this._libFiles.fetchLibFilesIfNecessary(entries.map((entry) => monaco_editor_core_exports.Uri.parse(entry.fileName)));
  731. if (model.isDisposed()) {
  732. return;
  733. }
  734. const result = [];
  735. for (let entry of entries) {
  736. const refModel = this._libFiles.getOrCreateModel(entry.fileName);
  737. if (refModel) {
  738. result.push({
  739. uri: refModel.uri,
  740. range: this._textSpanToRange(refModel, entry.textSpan)
  741. });
  742. }
  743. }
  744. return result;
  745. }
  746. };
  747. var OutlineAdapter = class extends Adapter {
  748. async provideDocumentSymbols(model, token) {
  749. const resource = model.uri;
  750. const worker = await this._worker(resource);
  751. if (model.isDisposed()) {
  752. return;
  753. }
  754. const items = await worker.getNavigationBarItems(resource.toString());
  755. if (!items || model.isDisposed()) {
  756. return;
  757. }
  758. const convert = (bucket, item, containerLabel) => {
  759. let result2 = {
  760. name: item.text,
  761. detail: "",
  762. kind: outlineTypeTable[item.kind] || monaco_editor_core_exports.languages.SymbolKind.Variable,
  763. range: this._textSpanToRange(model, item.spans[0]),
  764. selectionRange: this._textSpanToRange(model, item.spans[0]),
  765. tags: []
  766. };
  767. if (containerLabel)
  768. result2.containerName = containerLabel;
  769. if (item.childItems && item.childItems.length > 0) {
  770. for (let child of item.childItems) {
  771. convert(bucket, child, result2.name);
  772. }
  773. }
  774. bucket.push(result2);
  775. };
  776. let result = [];
  777. items.forEach((item) => convert(result, item));
  778. return result;
  779. }
  780. };
  781. var Kind = class {
  782. };
  783. __publicField(Kind, "unknown", "");
  784. __publicField(Kind, "keyword", "keyword");
  785. __publicField(Kind, "script", "script");
  786. __publicField(Kind, "module", "module");
  787. __publicField(Kind, "class", "class");
  788. __publicField(Kind, "interface", "interface");
  789. __publicField(Kind, "type", "type");
  790. __publicField(Kind, "enum", "enum");
  791. __publicField(Kind, "variable", "var");
  792. __publicField(Kind, "localVariable", "local var");
  793. __publicField(Kind, "function", "function");
  794. __publicField(Kind, "localFunction", "local function");
  795. __publicField(Kind, "memberFunction", "method");
  796. __publicField(Kind, "memberGetAccessor", "getter");
  797. __publicField(Kind, "memberSetAccessor", "setter");
  798. __publicField(Kind, "memberVariable", "property");
  799. __publicField(Kind, "constructorImplementation", "constructor");
  800. __publicField(Kind, "callSignature", "call");
  801. __publicField(Kind, "indexSignature", "index");
  802. __publicField(Kind, "constructSignature", "construct");
  803. __publicField(Kind, "parameter", "parameter");
  804. __publicField(Kind, "typeParameter", "type parameter");
  805. __publicField(Kind, "primitiveType", "primitive type");
  806. __publicField(Kind, "label", "label");
  807. __publicField(Kind, "alias", "alias");
  808. __publicField(Kind, "const", "const");
  809. __publicField(Kind, "let", "let");
  810. __publicField(Kind, "warning", "warning");
  811. var outlineTypeTable = /* @__PURE__ */ Object.create(null);
  812. outlineTypeTable[Kind.module] = monaco_editor_core_exports.languages.SymbolKind.Module;
  813. outlineTypeTable[Kind.class] = monaco_editor_core_exports.languages.SymbolKind.Class;
  814. outlineTypeTable[Kind.enum] = monaco_editor_core_exports.languages.SymbolKind.Enum;
  815. outlineTypeTable[Kind.interface] = monaco_editor_core_exports.languages.SymbolKind.Interface;
  816. outlineTypeTable[Kind.memberFunction] = monaco_editor_core_exports.languages.SymbolKind.Method;
  817. outlineTypeTable[Kind.memberVariable] = monaco_editor_core_exports.languages.SymbolKind.Property;
  818. outlineTypeTable[Kind.memberGetAccessor] = monaco_editor_core_exports.languages.SymbolKind.Property;
  819. outlineTypeTable[Kind.memberSetAccessor] = monaco_editor_core_exports.languages.SymbolKind.Property;
  820. outlineTypeTable[Kind.variable] = monaco_editor_core_exports.languages.SymbolKind.Variable;
  821. outlineTypeTable[Kind.const] = monaco_editor_core_exports.languages.SymbolKind.Variable;
  822. outlineTypeTable[Kind.localVariable] = monaco_editor_core_exports.languages.SymbolKind.Variable;
  823. outlineTypeTable[Kind.variable] = monaco_editor_core_exports.languages.SymbolKind.Variable;
  824. outlineTypeTable[Kind.function] = monaco_editor_core_exports.languages.SymbolKind.Function;
  825. outlineTypeTable[Kind.localFunction] = monaco_editor_core_exports.languages.SymbolKind.Function;
  826. var FormatHelper = class extends Adapter {
  827. static _convertOptions(options) {
  828. return {
  829. ConvertTabsToSpaces: options.insertSpaces,
  830. TabSize: options.tabSize,
  831. IndentSize: options.tabSize,
  832. IndentStyle: 2 /* Smart */,
  833. NewLineCharacter: "\n",
  834. InsertSpaceAfterCommaDelimiter: true,
  835. InsertSpaceAfterSemicolonInForStatements: true,
  836. InsertSpaceBeforeAndAfterBinaryOperators: true,
  837. InsertSpaceAfterKeywordsInControlFlowStatements: true,
  838. InsertSpaceAfterFunctionKeywordForAnonymousFunctions: true,
  839. InsertSpaceAfterOpeningAndBeforeClosingNonemptyParenthesis: false,
  840. InsertSpaceAfterOpeningAndBeforeClosingNonemptyBrackets: false,
  841. InsertSpaceAfterOpeningAndBeforeClosingTemplateStringBraces: false,
  842. PlaceOpenBraceOnNewLineForControlBlocks: false,
  843. PlaceOpenBraceOnNewLineForFunctions: false
  844. };
  845. }
  846. _convertTextChanges(model, change) {
  847. return {
  848. text: change.newText,
  849. range: this._textSpanToRange(model, change.span)
  850. };
  851. }
  852. };
  853. var FormatAdapter = class extends FormatHelper {
  854. async provideDocumentRangeFormattingEdits(model, range, options, token) {
  855. const resource = model.uri;
  856. const startOffset = model.getOffsetAt({
  857. lineNumber: range.startLineNumber,
  858. column: range.startColumn
  859. });
  860. const endOffset = model.getOffsetAt({
  861. lineNumber: range.endLineNumber,
  862. column: range.endColumn
  863. });
  864. const worker = await this._worker(resource);
  865. if (model.isDisposed()) {
  866. return;
  867. }
  868. const edits = await worker.getFormattingEditsForRange(resource.toString(), startOffset, endOffset, FormatHelper._convertOptions(options));
  869. if (!edits || model.isDisposed()) {
  870. return;
  871. }
  872. return edits.map((edit) => this._convertTextChanges(model, edit));
  873. }
  874. };
  875. var FormatOnTypeAdapter = class extends FormatHelper {
  876. get autoFormatTriggerCharacters() {
  877. return [";", "}", "\n"];
  878. }
  879. async provideOnTypeFormattingEdits(model, position, ch, options, token) {
  880. const resource = model.uri;
  881. const offset = model.getOffsetAt(position);
  882. const worker = await this._worker(resource);
  883. if (model.isDisposed()) {
  884. return;
  885. }
  886. const edits = await worker.getFormattingEditsAfterKeystroke(resource.toString(), offset, ch, FormatHelper._convertOptions(options));
  887. if (!edits || model.isDisposed()) {
  888. return;
  889. }
  890. return edits.map((edit) => this._convertTextChanges(model, edit));
  891. }
  892. };
  893. var CodeActionAdaptor = class extends FormatHelper {
  894. async provideCodeActions(model, range, context, token) {
  895. const resource = model.uri;
  896. const start = model.getOffsetAt({
  897. lineNumber: range.startLineNumber,
  898. column: range.startColumn
  899. });
  900. const end = model.getOffsetAt({
  901. lineNumber: range.endLineNumber,
  902. column: range.endColumn
  903. });
  904. const formatOptions = FormatHelper._convertOptions(model.getOptions());
  905. const errorCodes = context.markers.filter((m) => m.code).map((m) => m.code).map(Number);
  906. const worker = await this._worker(resource);
  907. if (model.isDisposed()) {
  908. return;
  909. }
  910. const codeFixes = await worker.getCodeFixesAtPosition(resource.toString(), start, end, errorCodes, formatOptions);
  911. if (!codeFixes || model.isDisposed()) {
  912. return { actions: [], dispose: () => {
  913. } };
  914. }
  915. const actions = codeFixes.filter((fix) => {
  916. return fix.changes.filter((change) => change.isNewFile).length === 0;
  917. }).map((fix) => {
  918. return this._tsCodeFixActionToMonacoCodeAction(model, context, fix);
  919. });
  920. return {
  921. actions,
  922. dispose: () => {
  923. }
  924. };
  925. }
  926. _tsCodeFixActionToMonacoCodeAction(model, context, codeFix) {
  927. const edits = [];
  928. for (const change of codeFix.changes) {
  929. for (const textChange of change.textChanges) {
  930. edits.push({
  931. resource: model.uri,
  932. versionId: void 0,
  933. textEdit: {
  934. range: this._textSpanToRange(model, textChange.span),
  935. text: textChange.newText
  936. }
  937. });
  938. }
  939. }
  940. const action = {
  941. title: codeFix.description,
  942. edit: { edits },
  943. diagnostics: context.markers,
  944. kind: "quickfix"
  945. };
  946. return action;
  947. }
  948. };
  949. var RenameAdapter = class extends Adapter {
  950. constructor(_libFiles, worker) {
  951. super(worker);
  952. this._libFiles = _libFiles;
  953. }
  954. async provideRenameEdits(model, position, newName, token) {
  955. const resource = model.uri;
  956. const fileName = resource.toString();
  957. const offset = model.getOffsetAt(position);
  958. const worker = await this._worker(resource);
  959. if (model.isDisposed()) {
  960. return;
  961. }
  962. const renameInfo = await worker.getRenameInfo(fileName, offset, {
  963. allowRenameOfImportPath: false
  964. });
  965. if (renameInfo.canRename === false) {
  966. return {
  967. edits: [],
  968. rejectReason: renameInfo.localizedErrorMessage
  969. };
  970. }
  971. if (renameInfo.fileToRename !== void 0) {
  972. throw new Error("Renaming files is not supported.");
  973. }
  974. const renameLocations = await worker.findRenameLocations(fileName, offset, false, false, false);
  975. if (!renameLocations || model.isDisposed()) {
  976. return;
  977. }
  978. const edits = [];
  979. for (const renameLocation of renameLocations) {
  980. const model2 = this._libFiles.getOrCreateModel(renameLocation.fileName);
  981. if (model2) {
  982. edits.push({
  983. resource: model2.uri,
  984. versionId: void 0,
  985. textEdit: {
  986. range: this._textSpanToRange(model2, renameLocation.textSpan),
  987. text: newName
  988. }
  989. });
  990. } else {
  991. throw new Error(`Unknown file ${renameLocation.fileName}.`);
  992. }
  993. }
  994. return { edits };
  995. }
  996. };
  997. var InlayHintsAdapter = class extends Adapter {
  998. async provideInlayHints(model, range, token) {
  999. const resource = model.uri;
  1000. const fileName = resource.toString();
  1001. const start = model.getOffsetAt({
  1002. lineNumber: range.startLineNumber,
  1003. column: range.startColumn
  1004. });
  1005. const end = model.getOffsetAt({
  1006. lineNumber: range.endLineNumber,
  1007. column: range.endColumn
  1008. });
  1009. const worker = await this._worker(resource);
  1010. if (model.isDisposed()) {
  1011. return null;
  1012. }
  1013. const tsHints = await worker.provideInlayHints(fileName, start, end);
  1014. const hints = tsHints.map((hint) => {
  1015. return {
  1016. ...hint,
  1017. label: hint.text,
  1018. position: model.getPositionAt(hint.position),
  1019. kind: this._convertHintKind(hint.kind)
  1020. };
  1021. });
  1022. return { hints, dispose: () => {
  1023. } };
  1024. }
  1025. _convertHintKind(kind) {
  1026. switch (kind) {
  1027. case "Parameter":
  1028. return monaco_editor_core_exports.languages.InlayHintKind.Parameter;
  1029. case "Type":
  1030. return monaco_editor_core_exports.languages.InlayHintKind.Type;
  1031. default:
  1032. return monaco_editor_core_exports.languages.InlayHintKind.Type;
  1033. }
  1034. }
  1035. };
  1036. // src/language/typescript/tsMode.ts
  1037. var javaScriptWorker;
  1038. var typeScriptWorker;
  1039. function setupTypeScript(defaults) {
  1040. typeScriptWorker = setupMode(defaults, "typescript");
  1041. }
  1042. function setupJavaScript(defaults) {
  1043. javaScriptWorker = setupMode(defaults, "javascript");
  1044. }
  1045. function getJavaScriptWorker() {
  1046. return new Promise((resolve, reject) => {
  1047. if (!javaScriptWorker) {
  1048. return reject("JavaScript not registered!");
  1049. }
  1050. resolve(javaScriptWorker);
  1051. });
  1052. }
  1053. function getTypeScriptWorker() {
  1054. return new Promise((resolve, reject) => {
  1055. if (!typeScriptWorker) {
  1056. return reject("TypeScript not registered!");
  1057. }
  1058. resolve(typeScriptWorker);
  1059. });
  1060. }
  1061. function setupMode(defaults, modeId) {
  1062. const client = new WorkerManager(modeId, defaults);
  1063. const worker = (...uris) => {
  1064. return client.getLanguageServiceWorker(...uris);
  1065. };
  1066. const libFiles = new LibFiles(worker);
  1067. monaco_editor_core_exports.languages.registerCompletionItemProvider(modeId, new SuggestAdapter(worker));
  1068. monaco_editor_core_exports.languages.registerSignatureHelpProvider(modeId, new SignatureHelpAdapter(worker));
  1069. monaco_editor_core_exports.languages.registerHoverProvider(modeId, new QuickInfoAdapter(worker));
  1070. monaco_editor_core_exports.languages.registerDocumentHighlightProvider(modeId, new OccurrencesAdapter(worker));
  1071. monaco_editor_core_exports.languages.registerDefinitionProvider(modeId, new DefinitionAdapter(libFiles, worker));
  1072. monaco_editor_core_exports.languages.registerReferenceProvider(modeId, new ReferenceAdapter(libFiles, worker));
  1073. monaco_editor_core_exports.languages.registerDocumentSymbolProvider(modeId, new OutlineAdapter(worker));
  1074. monaco_editor_core_exports.languages.registerDocumentRangeFormattingEditProvider(modeId, new FormatAdapter(worker));
  1075. monaco_editor_core_exports.languages.registerOnTypeFormattingEditProvider(modeId, new FormatOnTypeAdapter(worker));
  1076. monaco_editor_core_exports.languages.registerCodeActionProvider(modeId, new CodeActionAdaptor(worker));
  1077. monaco_editor_core_exports.languages.registerRenameProvider(modeId, new RenameAdapter(libFiles, worker));
  1078. monaco_editor_core_exports.languages.registerInlayHintsProvider(modeId, new InlayHintsAdapter(worker));
  1079. new DiagnosticsAdapter(libFiles, defaults, modeId, worker);
  1080. return worker;
  1081. }
  1082. export {
  1083. Adapter,
  1084. CodeActionAdaptor,
  1085. DefinitionAdapter,
  1086. DiagnosticsAdapter,
  1087. FormatAdapter,
  1088. FormatHelper,
  1089. FormatOnTypeAdapter,
  1090. InlayHintsAdapter,
  1091. Kind,
  1092. LibFiles,
  1093. OccurrencesAdapter,
  1094. OutlineAdapter,
  1095. QuickInfoAdapter,
  1096. ReferenceAdapter,
  1097. RenameAdapter,
  1098. SignatureHelpAdapter,
  1099. SuggestAdapter,
  1100. WorkerManager,
  1101. flattenDiagnosticMessageText,
  1102. getJavaScriptWorker,
  1103. getTypeScriptWorker,
  1104. setupJavaScript,
  1105. setupTypeScript
  1106. };