@vscode/chat-lib 0.0.1 → 0.0.2

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.
Files changed (391) hide show
  1. package/dist/src/_internal/extension/xtab/common/promptCrafting.d.ts.map +1 -1
  2. package/dist/src/_internal/extension/xtab/common/promptCrafting.js +6 -5
  3. package/dist/src/_internal/extension/xtab/common/promptCrafting.js.map +1 -1
  4. package/dist/src/_internal/platform/configuration/common/configurationService.d.ts +1 -0
  5. package/dist/src/_internal/platform/configuration/common/configurationService.d.ts.map +1 -1
  6. package/dist/src/_internal/platform/configuration/common/configurationService.js +1 -0
  7. package/dist/src/_internal/platform/configuration/common/configurationService.js.map +1 -1
  8. package/dist/src/_internal/platform/env/common/envService.d.ts +5 -0
  9. package/dist/src/_internal/platform/env/common/envService.d.ts.map +1 -1
  10. package/dist/src/_internal/platform/env/common/envService.js +2 -1
  11. package/dist/src/_internal/platform/env/common/envService.js.map +1 -1
  12. package/dist/src/_internal/platform/env/common/nullEnvService.d.ts +3 -0
  13. package/dist/src/_internal/platform/env/common/nullEnvService.d.ts.map +1 -1
  14. package/dist/src/_internal/platform/env/common/nullEnvService.js +8 -1
  15. package/dist/src/_internal/platform/env/common/nullEnvService.js.map +1 -1
  16. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.d.ts +7 -0
  17. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.d.ts.map +1 -1
  18. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.js +1 -0
  19. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.js.map +1 -1
  20. package/dist/src/_internal/util/common/test/shims/chatTypes.d.ts +8 -0
  21. package/dist/src/_internal/util/common/test/shims/chatTypes.d.ts.map +1 -1
  22. package/dist/src/_internal/util/common/test/shims/chatTypes.js +19 -1
  23. package/dist/src/_internal/util/common/test/shims/chatTypes.js.map +1 -1
  24. package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.d.ts.map +1 -1
  25. package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.js +8 -1
  26. package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.js.map +1 -1
  27. package/dist/src/_internal/vscodeTypes.d.ts +4 -0
  28. package/dist/src/_internal/vscodeTypes.d.ts.map +1 -1
  29. package/dist/src/_internal/vscodeTypes.js +5 -1
  30. package/dist/src/_internal/vscodeTypes.js.map +1 -1
  31. package/dist/src/main.d.ts +5 -0
  32. package/dist/src/main.d.ts.map +1 -1
  33. package/dist/src/main.js +12 -0
  34. package/dist/src/main.js.map +1 -1
  35. package/dist/src/package.json +46 -19
  36. package/package.json +3 -6
  37. package/src/_internal/extension/byok/node/openAIEndpoint.ts +0 -171
  38. package/src/_internal/extension/common/constants.ts +0 -90
  39. package/src/_internal/extension/inlineEdits/common/delayer.ts +0 -108
  40. package/src/_internal/extension/inlineEdits/common/editRebase.ts +0 -268
  41. package/src/_internal/extension/inlineEdits/common/ghNearbyNesProvider.tsx +0 -163
  42. package/src/_internal/extension/inlineEdits/common/nearbyCursorInlineEditProvider.ts +0 -225
  43. package/src/_internal/extension/inlineEdits/common/rejectionCollector.ts +0 -164
  44. package/src/_internal/extension/inlineEdits/node/debugRecorder.ts +0 -205
  45. package/src/_internal/extension/inlineEdits/node/importFiltering.ts +0 -25
  46. package/src/_internal/extension/inlineEdits/node/nesConfigs.ts +0 -12
  47. package/src/_internal/extension/inlineEdits/node/nextEditCache.ts +0 -278
  48. package/src/_internal/extension/inlineEdits/node/nextEditProvider.ts +0 -778
  49. package/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.ts +0 -983
  50. package/src/_internal/extension/inlineEdits/node/nextEditResult.ts +0 -40
  51. package/src/_internal/extension/prompt/common/importStatement.ts +0 -25
  52. package/src/_internal/extension/prompt/node/chatMLFetcher.ts +0 -706
  53. package/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.ts +0 -146
  54. package/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.ts +0 -527
  55. package/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.ts +0 -76
  56. package/src/_internal/extension/prompts/node/inline/visualization.ts +0 -65
  57. package/src/_internal/extension/vscode.proposed.activeComment.d.ts +0 -23
  58. package/src/_internal/extension/vscode.proposed.aiRelatedInformation.d.ts +0 -49
  59. package/src/_internal/extension/vscode.proposed.aiSettingsSearch.d.ts +0 -31
  60. package/src/_internal/extension/vscode.proposed.aiTextSearchProvider.d.ts +0 -41
  61. package/src/_internal/extension/vscode.proposed.authLearnMore.d.ts +0 -16
  62. package/src/_internal/extension/vscode.proposed.chatBinaryReferenceData.d.ts +0 -41
  63. package/src/_internal/extension/vscode.proposed.chatEditing.d.ts +0 -29
  64. package/src/_internal/extension/vscode.proposed.chatParticipantAdditions.d.ts +0 -636
  65. package/src/_internal/extension/vscode.proposed.chatParticipantPrivate.d.ts +0 -276
  66. package/src/_internal/extension/vscode.proposed.chatProvider.d.ts +0 -62
  67. package/src/_internal/extension/vscode.proposed.chatReadonlyPromptReference.d.ts +0 -17
  68. package/src/_internal/extension/vscode.proposed.chatReferenceDiagnostic.d.ts +0 -23
  69. package/src/_internal/extension/vscode.proposed.chatSessionsProvider.d.ts +0 -218
  70. package/src/_internal/extension/vscode.proposed.chatStatusItem.d.ts +0 -61
  71. package/src/_internal/extension/vscode.proposed.codeActionAI.d.ts +0 -16
  72. package/src/_internal/extension/vscode.proposed.commentReveal.d.ts +0 -32
  73. package/src/_internal/extension/vscode.proposed.contribCommentThreadAdditionalMenu.d.ts +0 -8
  74. package/src/_internal/extension/vscode.proposed.contribCommentsViewThreadMenus.d.ts +0 -6
  75. package/src/_internal/extension/vscode.proposed.contribSourceControlInputBoxMenu.d.ts +0 -7
  76. package/src/_internal/extension/vscode.proposed.dataChannels.d.ts +0 -19
  77. package/src/_internal/extension/vscode.proposed.defaultChatParticipant.d.ts +0 -52
  78. package/src/_internal/extension/vscode.proposed.documentFiltersExclusive.d.ts +0 -13
  79. package/src/_internal/extension/vscode.proposed.embeddings.d.ts +0 -33
  80. package/src/_internal/extension/vscode.proposed.extensionsAny.d.ts +0 -40
  81. package/src/_internal/extension/vscode.proposed.findFiles2.d.ts +0 -125
  82. package/src/_internal/extension/vscode.proposed.findTextInFiles.d.ts +0 -104
  83. package/src/_internal/extension/vscode.proposed.findTextInFiles2.d.ts +0 -144
  84. package/src/_internal/extension/vscode.proposed.inlineCompletionsAdditions.d.ts +0 -202
  85. package/src/_internal/extension/vscode.proposed.interactive.d.ts +0 -11
  86. package/src/_internal/extension/vscode.proposed.languageModelCapabilities.d.ts +0 -25
  87. package/src/_internal/extension/vscode.proposed.languageModelDataPart.d.ts +0 -163
  88. package/src/_internal/extension/vscode.proposed.languageModelSystem.d.ts +0 -17
  89. package/src/_internal/extension/vscode.proposed.languageModelThinkingPart.d.ts +0 -49
  90. package/src/_internal/extension/vscode.proposed.languageModelToolResultAudience.d.ts +0 -36
  91. package/src/_internal/extension/vscode.proposed.mappedEditsProvider.d.ts +0 -110
  92. package/src/_internal/extension/vscode.proposed.newSymbolNamesProvider.d.ts +0 -47
  93. package/src/_internal/extension/vscode.proposed.readonlyMessage.d.ts +0 -14
  94. package/src/_internal/extension/vscode.proposed.resolvers.d.ts +0 -475
  95. package/src/_internal/extension/vscode.proposed.scmInputBoxValueProvider.d.ts +0 -25
  96. package/src/_internal/extension/vscode.proposed.taskProblemMatcherStatus.d.ts +0 -42
  97. package/src/_internal/extension/vscode.proposed.terminalDataWriteEvent.d.ts +0 -32
  98. package/src/_internal/extension/vscode.proposed.terminalExecuteCommandEvent.d.ts +0 -48
  99. package/src/_internal/extension/vscode.proposed.terminalQuickFixProvider.d.ts +0 -87
  100. package/src/_internal/extension/vscode.proposed.terminalSelection.d.ts +0 -16
  101. package/src/_internal/extension/vscode.proposed.testObserver.d.ts +0 -199
  102. package/src/_internal/extension/vscode.proposed.textDocumentChangeReason.d.ts +0 -30
  103. package/src/_internal/extension/vscode.proposed.textSearchProvider.d.ts +0 -281
  104. package/src/_internal/extension/vscode.proposed.textSearchProvider2.d.ts +0 -297
  105. package/src/_internal/extension/xtab/common/promptCrafting.ts +0 -670
  106. package/src/_internal/extension/xtab/node/xtabEndpoint.ts +0 -102
  107. package/src/_internal/extension/xtab/node/xtabProvider.ts +0 -976
  108. package/src/_internal/extension/xtab/node/xtabUtils.ts +0 -62
  109. package/src/_internal/platform/authentication/common/authentication.ts +0 -309
  110. package/src/_internal/platform/authentication/common/copilotToken.ts +0 -300
  111. package/src/_internal/platform/authentication/common/copilotTokenManager.ts +0 -59
  112. package/src/_internal/platform/authentication/common/copilotTokenStore.ts +0 -40
  113. package/src/_internal/platform/authentication/common/staticGitHubAuthenticationService.ts +0 -96
  114. package/src/_internal/platform/authentication/node/copilotTokenManager.ts +0 -303
  115. package/src/_internal/platform/chat/common/chatMLFetcher.ts +0 -124
  116. package/src/_internal/platform/chat/common/chatQuotaService.ts +0 -63
  117. package/src/_internal/platform/chat/common/chatQuotaServiceImpl.ts +0 -96
  118. package/src/_internal/platform/chat/common/commonTypes.ts +0 -353
  119. package/src/_internal/platform/chat/common/conversationOptions.ts +0 -16
  120. package/src/_internal/platform/chat/common/globalStringUtils.ts +0 -54
  121. package/src/_internal/platform/chat/common/interactionService.ts +0 -35
  122. package/src/_internal/platform/configuration/common/configurationService.ts +0 -803
  123. package/src/_internal/platform/configuration/common/defaultsOnlyConfigurationService.ts +0 -39
  124. package/src/_internal/platform/configuration/common/jsonSchema.ts +0 -139
  125. package/src/_internal/platform/configuration/common/validator.ts +0 -242
  126. package/src/_internal/platform/diff/common/diffService.ts +0 -41
  127. package/src/_internal/platform/diff/common/diffWorker.ts +0 -83
  128. package/src/_internal/platform/diff/node/diffServiceImpl.ts +0 -85
  129. package/src/_internal/platform/editing/common/abstractText.ts +0 -177
  130. package/src/_internal/platform/editing/common/notebookDocumentSnapshot.ts +0 -122
  131. package/src/_internal/platform/editing/common/positionOffsetTransformer.ts +0 -202
  132. package/src/_internal/platform/editing/common/textDocumentSnapshot.ts +0 -274
  133. package/src/_internal/platform/endpoint/common/capiClient.ts +0 -37
  134. package/src/_internal/platform/endpoint/common/chatModelCapabilities.ts +0 -115
  135. package/src/_internal/platform/endpoint/common/domainService.ts +0 -27
  136. package/src/_internal/platform/endpoint/common/endpointProvider.ts +0 -104
  137. package/src/_internal/platform/endpoint/common/endpointTypes.ts +0 -12
  138. package/src/_internal/platform/endpoint/common/licenseAgreement.ts +0 -11
  139. package/src/_internal/platform/endpoint/common/statefulMarkerContainer.tsx +0 -85
  140. package/src/_internal/platform/endpoint/common/thinkingDataContainer.tsx +0 -44
  141. package/src/_internal/platform/endpoint/node/capiClientImpl.ts +0 -18
  142. package/src/_internal/platform/endpoint/node/chatEndpoint.ts +0 -435
  143. package/src/_internal/platform/endpoint/node/domainServiceImpl.ts +0 -80
  144. package/src/_internal/platform/endpoint/node/proxyXtabEndpoint.ts +0 -43
  145. package/src/_internal/platform/endpoint/node/responsesApi.ts +0 -326
  146. package/src/_internal/platform/env/common/envService.ts +0 -134
  147. package/src/_internal/platform/env/common/nullEnvService.ts +0 -68
  148. package/src/_internal/platform/env/common/packagejson.ts +0 -49
  149. package/src/_internal/platform/git/common/gitExtensionService.ts +0 -21
  150. package/src/_internal/platform/git/common/nullGitExtensionService.ts +0 -20
  151. package/src/_internal/platform/git/vscode/git.d.ts +0 -414
  152. package/src/_internal/platform/github/common/githubAPI.ts +0 -44
  153. package/src/_internal/platform/github/common/githubService.ts +0 -87
  154. package/src/_internal/platform/github/common/nullOctokitServiceImpl.ts +0 -21
  155. package/src/_internal/platform/ignore/common/ignoreService.ts +0 -72
  156. package/src/_internal/platform/inlineCompletions/common/api.ts +0 -198
  157. package/src/_internal/platform/inlineEdits/common/dataTypes/diagnosticData.ts +0 -32
  158. package/src/_internal/platform/inlineEdits/common/dataTypes/documentId.ts +0 -52
  159. package/src/_internal/platform/inlineEdits/common/dataTypes/edit.ts +0 -165
  160. package/src/_internal/platform/inlineEdits/common/dataTypes/editUtils.ts +0 -74
  161. package/src/_internal/platform/inlineEdits/common/dataTypes/fetchCancellationError.ts +0 -14
  162. package/src/_internal/platform/inlineEdits/common/dataTypes/languageContext.ts +0 -107
  163. package/src/_internal/platform/inlineEdits/common/dataTypes/languageId.ts +0 -14
  164. package/src/_internal/platform/inlineEdits/common/dataTypes/permutation.ts +0 -69
  165. package/src/_internal/platform/inlineEdits/common/dataTypes/rootedLineEdit.ts +0 -49
  166. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLength.ts +0 -74
  167. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/combineTextEditInfos.ts +0 -132
  168. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/length.ts +0 -184
  169. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/textEditInfo.ts +0 -32
  170. package/src/_internal/platform/inlineEdits/common/dataTypes/xtabPromptOptions.ts +0 -89
  171. package/src/_internal/platform/inlineEdits/common/debugRecorderBookmark.ts +0 -10
  172. package/src/_internal/platform/inlineEdits/common/editReason.ts +0 -134
  173. package/src/_internal/platform/inlineEdits/common/inlineEditLogContext.ts +0 -490
  174. package/src/_internal/platform/inlineEdits/common/observableGit.ts +0 -49
  175. package/src/_internal/platform/inlineEdits/common/observableWorkspace.ts +0 -239
  176. package/src/_internal/platform/inlineEdits/common/responseProcessor.ts +0 -249
  177. package/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.ts +0 -468
  178. package/src/_internal/platform/inlineEdits/common/statelessNextEditProviders.ts +0 -59
  179. package/src/_internal/platform/inlineEdits/common/utils/observable.ts +0 -54
  180. package/src/_internal/platform/inlineEdits/common/utils/stringifyChatMessages.ts +0 -29
  181. package/src/_internal/platform/inlineEdits/common/utils/utils.ts +0 -56
  182. package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/historyContextProvider.ts +0 -60
  183. package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/nesHistoryContextProvider.ts +0 -353
  184. package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/nesXtabHistoryTracker.ts +0 -176
  185. package/src/_internal/platform/languageContextProvider/common/languageContextProviderService.ts +0 -25
  186. package/src/_internal/platform/languageContextProvider/common/nullLanguageContextProviderService.ts +0 -38
  187. package/src/_internal/platform/languageServer/common/languageContextService.ts +0 -186
  188. package/src/_internal/platform/languages/common/languageDiagnosticsService.ts +0 -67
  189. package/src/_internal/platform/languages/common/testLanguageDiagnosticsService.ts +0 -28
  190. package/src/_internal/platform/log/common/logService.ts +0 -232
  191. package/src/_internal/platform/nesFetch/common/completionsAPI.ts +0 -78
  192. package/src/_internal/platform/nesFetch/common/completionsFetchService.ts +0 -118
  193. package/src/_internal/platform/nesFetch/common/responseStream.ts +0 -151
  194. package/src/_internal/platform/nesFetch/node/completionsFetchServiceImpl.ts +0 -236
  195. package/src/_internal/platform/nesFetch/node/streamTransformer.ts +0 -95
  196. package/src/_internal/platform/networking/common/fetch.ts +0 -349
  197. package/src/_internal/platform/networking/common/fetcherService.ts +0 -84
  198. package/src/_internal/platform/networking/common/networking.ts +0 -442
  199. package/src/_internal/platform/networking/common/openai.ts +0 -273
  200. package/src/_internal/platform/networking/node/chatStream.ts +0 -137
  201. package/src/_internal/platform/networking/node/stream.ts +0 -749
  202. package/src/_internal/platform/notebook/common/alternativeContent.ts +0 -89
  203. package/src/_internal/platform/notebook/common/alternativeContentFormat.ts +0 -10
  204. package/src/_internal/platform/notebook/common/alternativeContentProvider.json.ts +0 -262
  205. package/src/_internal/platform/notebook/common/alternativeContentProvider.text.ts +0 -243
  206. package/src/_internal/platform/notebook/common/alternativeContentProvider.ts +0 -41
  207. package/src/_internal/platform/notebook/common/alternativeContentProvider.xml.ts +0 -205
  208. package/src/_internal/platform/notebook/common/alternativeNotebookDocument.ts +0 -155
  209. package/src/_internal/platform/notebook/common/helpers.ts +0 -212
  210. package/src/_internal/platform/notebook/common/notebookService.ts +0 -43
  211. package/src/_internal/platform/openai/node/fetch.ts +0 -596
  212. package/src/_internal/platform/parser/node/nodes.ts +0 -190
  213. package/src/_internal/platform/requestLogger/node/nullRequestLogger.ts +0 -26
  214. package/src/_internal/platform/requestLogger/node/requestLogger.ts +0 -383
  215. package/src/_internal/platform/simulationTestContext/common/simulationTestContext.ts +0 -29
  216. package/src/_internal/platform/snippy/common/snippyService.ts +0 -25
  217. package/src/_internal/platform/telemetry/common/nullExperimentationService.ts +0 -64
  218. package/src/_internal/platform/telemetry/common/nullTelemetryService.ts +0 -53
  219. package/src/_internal/platform/telemetry/common/telemetry.ts +0 -215
  220. package/src/_internal/platform/telemetry/common/telemetryData.ts +0 -205
  221. package/src/_internal/platform/thinking/common/thinking.ts +0 -61
  222. package/src/_internal/platform/thinking/common/thinkingUtils.ts +0 -57
  223. package/src/_internal/platform/tokenizer/node/parseTikTokens.ts +0 -23
  224. package/src/_internal/platform/tokenizer/node/tikTokenizerImpl.ts +0 -74
  225. package/src/_internal/platform/tokenizer/node/tikTokenizerWorker.ts +0 -24
  226. package/src/_internal/platform/tokenizer/node/tokenizer.ts +0 -357
  227. package/src/_internal/platform/workspace/common/workspaceService.ts +0 -226
  228. package/src/_internal/platform/workspaceRecorder/common/workspaceLog.ts +0 -118
  229. package/src/_internal/util/common/anomalyDetection.ts +0 -112
  230. package/src/_internal/util/common/arrays.ts +0 -81
  231. package/src/_internal/util/common/async.ts +0 -155
  232. package/src/_internal/util/common/cache.ts +0 -183
  233. package/src/_internal/util/common/crypto.ts +0 -41
  234. package/src/_internal/util/common/errors.ts +0 -22
  235. package/src/_internal/util/common/globals.d.ts +0 -12
  236. package/src/_internal/util/common/imageUtils.ts +0 -154
  237. package/src/_internal/util/common/languages.ts +0 -940
  238. package/src/_internal/util/common/notebooks.ts +0 -286
  239. package/src/_internal/util/common/result.ts +0 -71
  240. package/src/_internal/util/common/services.ts +0 -43
  241. package/src/_internal/util/common/test/shims/chatTypes.ts +0 -448
  242. package/src/_internal/util/common/test/shims/editing.ts +0 -233
  243. package/src/_internal/util/common/test/shims/enums.ts +0 -61
  244. package/src/_internal/util/common/test/shims/l10n.ts +0 -37
  245. package/src/_internal/util/common/test/shims/newSymbolName.ts +0 -23
  246. package/src/_internal/util/common/test/shims/terminal.ts +0 -33
  247. package/src/_internal/util/common/test/shims/vscodeTypesShim.ts +0 -115
  248. package/src/_internal/util/common/time.ts +0 -31
  249. package/src/_internal/util/common/tokenizer.ts +0 -30
  250. package/src/_internal/util/common/tracing.ts +0 -52
  251. package/src/_internal/util/common/types.ts +0 -33
  252. package/src/_internal/util/common/variableLengthQuantity.ts +0 -40
  253. package/src/_internal/util/node/worker.ts +0 -130
  254. package/src/_internal/util/vs/base/common/arrays.ts +0 -926
  255. package/src/_internal/util/vs/base/common/arraysFind.ts +0 -206
  256. package/src/_internal/util/vs/base/common/assert.ts +0 -89
  257. package/src/_internal/util/vs/base/common/async.ts +0 -2582
  258. package/src/_internal/util/vs/base/common/buffer.ts +0 -501
  259. package/src/_internal/util/vs/base/common/cache.ts +0 -122
  260. package/src/_internal/util/vs/base/common/cancellation.ts +0 -150
  261. package/src/_internal/util/vs/base/common/charCode.ts +0 -452
  262. package/src/_internal/util/vs/base/common/codicons.ts +0 -66
  263. package/src/_internal/util/vs/base/common/codiconsLibrary.ts +0 -618
  264. package/src/_internal/util/vs/base/common/codiconsUtil.ts +0 -30
  265. package/src/_internal/util/vs/base/common/collections.ts +0 -156
  266. package/src/_internal/util/vs/base/common/diff/diff.ts +0 -1317
  267. package/src/_internal/util/vs/base/common/diff/diffChange.ts +0 -62
  268. package/src/_internal/util/vs/base/common/equals.ts +0 -148
  269. package/src/_internal/util/vs/base/common/errors.ts +0 -342
  270. package/src/_internal/util/vs/base/common/event.ts +0 -1782
  271. package/src/_internal/util/vs/base/common/extpath.ts +0 -425
  272. package/src/_internal/util/vs/base/common/filters.ts +0 -928
  273. package/src/_internal/util/vs/base/common/functional.ts +0 -34
  274. package/src/_internal/util/vs/base/common/glob.ts +0 -839
  275. package/src/_internal/util/vs/base/common/hash.ts +0 -326
  276. package/src/_internal/util/vs/base/common/htmlContent.ts +0 -212
  277. package/src/_internal/util/vs/base/common/iconLabels.ts +0 -118
  278. package/src/_internal/util/vs/base/common/iterator.ts +0 -196
  279. package/src/_internal/util/vs/base/common/lazy.ts +0 -59
  280. package/src/_internal/util/vs/base/common/lifecycle.ts +0 -845
  281. package/src/_internal/util/vs/base/common/linkedList.ts +0 -144
  282. package/src/_internal/util/vs/base/common/map.ts +0 -954
  283. package/src/_internal/util/vs/base/common/marshallingIds.ts +0 -35
  284. package/src/_internal/util/vs/base/common/mime.ts +0 -136
  285. package/src/_internal/util/vs/base/common/naturalLanguage/korean.ts +0 -425
  286. package/src/_internal/util/vs/base/common/network.ts +0 -429
  287. package/src/_internal/util/vs/base/common/numbers.ts +0 -166
  288. package/src/_internal/util/vs/base/common/objects.ts +0 -242
  289. package/src/_internal/util/vs/base/common/observable.ts +0 -10
  290. package/src/_internal/util/vs/base/common/observableInternal/base.ts +0 -208
  291. package/src/_internal/util/vs/base/common/observableInternal/changeTracker.ts +0 -96
  292. package/src/_internal/util/vs/base/common/observableInternal/commonFacade/cancellation.ts +0 -9
  293. package/src/_internal/util/vs/base/common/observableInternal/commonFacade/deps.ts +0 -12
  294. package/src/_internal/util/vs/base/common/observableInternal/debugLocation.ts +0 -88
  295. package/src/_internal/util/vs/base/common/observableInternal/debugName.ts +0 -150
  296. package/src/_internal/util/vs/base/common/observableInternal/experimental/utils.ts +0 -62
  297. package/src/_internal/util/vs/base/common/observableInternal/index.ts +0 -61
  298. package/src/_internal/util/vs/base/common/observableInternal/logging/consoleObservableLogger.ts +0 -388
  299. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/debuggerApi.d.ts +0 -154
  300. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/debuggerRpc.ts +0 -80
  301. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/devToolsLogger.ts +0 -485
  302. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/rpc.ts +0 -103
  303. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/utils.ts +0 -69
  304. package/src/_internal/util/vs/base/common/observableInternal/logging/logging.ts +0 -133
  305. package/src/_internal/util/vs/base/common/observableInternal/map.ts +0 -81
  306. package/src/_internal/util/vs/base/common/observableInternal/observables/baseObservable.ts +0 -172
  307. package/src/_internal/util/vs/base/common/observableInternal/observables/constObservable.ts +0 -44
  308. package/src/_internal/util/vs/base/common/observableInternal/observables/derived.ts +0 -190
  309. package/src/_internal/util/vs/base/common/observableInternal/observables/derivedImpl.ts +0 -445
  310. package/src/_internal/util/vs/base/common/observableInternal/observables/lazyObservableValue.ts +0 -154
  311. package/src/_internal/util/vs/base/common/observableInternal/observables/observableFromEvent.ts +0 -174
  312. package/src/_internal/util/vs/base/common/observableInternal/observables/observableSignal.ts +0 -67
  313. package/src/_internal/util/vs/base/common/observableInternal/observables/observableSignalFromEvent.ts +0 -62
  314. package/src/_internal/util/vs/base/common/observableInternal/observables/observableValue.ts +0 -131
  315. package/src/_internal/util/vs/base/common/observableInternal/observables/observableValueOpts.ts +0 -37
  316. package/src/_internal/util/vs/base/common/observableInternal/reactions/autorun.ts +0 -188
  317. package/src/_internal/util/vs/base/common/observableInternal/reactions/autorunImpl.ts +0 -256
  318. package/src/_internal/util/vs/base/common/observableInternal/set.ts +0 -78
  319. package/src/_internal/util/vs/base/common/observableInternal/transaction.ts +0 -115
  320. package/src/_internal/util/vs/base/common/observableInternal/utils/promise.ts +0 -129
  321. package/src/_internal/util/vs/base/common/observableInternal/utils/runOnChange.ts +0 -65
  322. package/src/_internal/util/vs/base/common/observableInternal/utils/utils.ts +0 -281
  323. package/src/_internal/util/vs/base/common/observableInternal/utils/utilsCancellation.ts +0 -101
  324. package/src/_internal/util/vs/base/common/observableInternal/utils/valueWithChangeEvent.ts +0 -31
  325. package/src/_internal/util/vs/base/common/path.ts +0 -1591
  326. package/src/_internal/util/vs/base/common/platform.ts +0 -282
  327. package/src/_internal/util/vs/base/common/process.ts +0 -78
  328. package/src/_internal/util/vs/base/common/resources.ts +0 -446
  329. package/src/_internal/util/vs/base/common/sequence.ts +0 -36
  330. package/src/_internal/util/vs/base/common/sseParser.ts +0 -247
  331. package/src/_internal/util/vs/base/common/stopwatch.ts +0 -43
  332. package/src/_internal/util/vs/base/common/stream.ts +0 -792
  333. package/src/_internal/util/vs/base/common/strings.ts +0 -1364
  334. package/src/_internal/util/vs/base/common/symbols.ts +0 -11
  335. package/src/_internal/util/vs/base/common/themables.ts +0 -106
  336. package/src/_internal/util/vs/base/common/types.ts +0 -345
  337. package/src/_internal/util/vs/base/common/uint.ts +0 -61
  338. package/src/_internal/util/vs/base/common/uri.ts +0 -752
  339. package/src/_internal/util/vs/base/common/uuid.ts +0 -72
  340. package/src/_internal/util/vs/base-common.d.ts +0 -42
  341. package/src/_internal/util/vs/editor/common/core/editOperation.ts +0 -62
  342. package/src/_internal/util/vs/editor/common/core/edits/edit.ts +0 -399
  343. package/src/_internal/util/vs/editor/common/core/edits/lineEdit.ts +0 -414
  344. package/src/_internal/util/vs/editor/common/core/edits/stringEdit.ts +0 -568
  345. package/src/_internal/util/vs/editor/common/core/edits/textEdit.ts +0 -411
  346. package/src/_internal/util/vs/editor/common/core/position.ts +0 -186
  347. package/src/_internal/util/vs/editor/common/core/range.ts +0 -519
  348. package/src/_internal/util/vs/editor/common/core/ranges/lineRange.ts +0 -416
  349. package/src/_internal/util/vs/editor/common/core/ranges/offsetRange.ts +0 -275
  350. package/src/_internal/util/vs/editor/common/core/text/abstractText.ts +0 -127
  351. package/src/_internal/util/vs/editor/common/core/text/positionToOffset.ts +0 -26
  352. package/src/_internal/util/vs/editor/common/core/text/positionToOffsetImpl.ts +0 -144
  353. package/src/_internal/util/vs/editor/common/core/text/textLength.ts +0 -150
  354. package/src/_internal/util/vs/editor/common/core/wordHelper.ts +0 -177
  355. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/diffAlgorithm.ts +0 -210
  356. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/dynamicProgrammingDiffing.ts +0 -109
  357. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/myersDiffAlgorithm.ts +0 -178
  358. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/computeMovedLines.ts +0 -331
  359. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/defaultLinesDiffComputer.ts +0 -273
  360. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/heuristicSequenceOptimizations.ts +0 -475
  361. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/lineSequence.ts +0 -47
  362. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/linesSliceCharSequence.ts +0 -248
  363. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/utils.ts +0 -76
  364. package/src/_internal/util/vs/editor/common/diff/legacyLinesDiffComputer.ts +0 -693
  365. package/src/_internal/util/vs/editor/common/diff/linesDiffComputer.ts +0 -61
  366. package/src/_internal/util/vs/editor/common/diff/rangeMapping.ts +0 -418
  367. package/src/_internal/util/vs/editor/common/model/prefixSumComputer.ts +0 -304
  368. package/src/_internal/util/vs/nls.messages.ts +0 -21
  369. package/src/_internal/util/vs/nls.ts +0 -243
  370. package/src/_internal/util/vs/platform/instantiation/common/descriptors.ts +0 -23
  371. package/src/_internal/util/vs/platform/instantiation/common/graph.ts +0 -113
  372. package/src/_internal/util/vs/platform/instantiation/common/instantiation.ts +0 -127
  373. package/src/_internal/util/vs/platform/instantiation/common/instantiationService.ts +0 -483
  374. package/src/_internal/util/vs/platform/instantiation/common/serviceCollection.ts +0 -34
  375. package/src/_internal/util/vs/vscode-globals-nls.d.ts +0 -42
  376. package/src/_internal/util/vs/vscode-globals-product.d.ts +0 -35
  377. package/src/_internal/util/vs/workbench/api/common/extHostTypes/diagnostic.ts +0 -109
  378. package/src/_internal/util/vs/workbench/api/common/extHostTypes/es5ClassCompat.ts +0 -34
  379. package/src/_internal/util/vs/workbench/api/common/extHostTypes/location.ts +0 -51
  380. package/src/_internal/util/vs/workbench/api/common/extHostTypes/markdownString.ts +0 -83
  381. package/src/_internal/util/vs/workbench/api/common/extHostTypes/notebooks.ts +0 -296
  382. package/src/_internal/util/vs/workbench/api/common/extHostTypes/position.ts +0 -195
  383. package/src/_internal/util/vs/workbench/api/common/extHostTypes/range.ts +0 -167
  384. package/src/_internal/util/vs/workbench/api/common/extHostTypes/selection.ts +0 -94
  385. package/src/_internal/util/vs/workbench/api/common/extHostTypes/snippetString.ts +0 -103
  386. package/src/_internal/util/vs/workbench/api/common/extHostTypes/snippetTextEdit.ts +0 -44
  387. package/src/_internal/util/vs/workbench/api/common/extHostTypes/symbolInformation.ts +0 -89
  388. package/src/_internal/util/vs/workbench/api/common/extHostTypes/textEdit.ts +0 -99
  389. package/src/_internal/vscodeTypes.ts +0 -100
  390. package/src/main.ts +0 -207
  391. package/src/package.json +0 -4063
@@ -1,954 +0,0 @@
1
- //!!! DO NOT modify, this file was COPIED from 'microsoft/vscode'
2
-
3
- /*---------------------------------------------------------------------------------------------
4
- * Copyright (c) Microsoft Corporation. All rights reserved.
5
- * Licensed under the MIT License. See License.txt in the project root for license information.
6
- *--------------------------------------------------------------------------------------------*/
7
-
8
- import { URI } from './uri';
9
-
10
- export function getOrSet<K, V>(map: Map<K, V>, key: K, value: V): V {
11
- let result = map.get(key);
12
- if (result === undefined) {
13
- result = value;
14
- map.set(key, result);
15
- }
16
-
17
- return result;
18
- }
19
-
20
- export function mapToString<K, V>(map: Map<K, V>): string {
21
- const entries: string[] = [];
22
- map.forEach((value, key) => {
23
- entries.push(`${key} => ${value}`);
24
- });
25
-
26
- return `Map(${map.size}) {${entries.join(', ')}}`;
27
- }
28
-
29
- export function setToString<K>(set: Set<K>): string {
30
- const entries: K[] = [];
31
- set.forEach(value => {
32
- entries.push(value);
33
- });
34
-
35
- return `Set(${set.size}) {${entries.join(', ')}}`;
36
- }
37
-
38
- interface ResourceMapKeyFn {
39
- (resource: URI): string;
40
- }
41
-
42
- class ResourceMapEntry<T> {
43
- constructor(readonly uri: URI, readonly value: T) { }
44
- }
45
-
46
- function isEntries<T>(arg: ResourceMap<T> | ResourceMapKeyFn | readonly (readonly [URI, T])[] | undefined): arg is readonly (readonly [URI, T])[] {
47
- return Array.isArray(arg);
48
- }
49
-
50
- export class ResourceMap<T> implements Map<URI, T> {
51
-
52
- private static readonly defaultToKey = (resource: URI) => resource.toString();
53
-
54
- readonly [Symbol.toStringTag] = 'ResourceMap';
55
-
56
- private readonly map: Map<string, ResourceMapEntry<T>>;
57
- private readonly toKey: ResourceMapKeyFn;
58
-
59
- /**
60
- *
61
- * @param toKey Custom uri identity function, e.g use an existing `IExtUri#getComparison`-util
62
- */
63
- constructor(toKey?: ResourceMapKeyFn);
64
-
65
- /**
66
- *
67
- * @param other Another resource which this maps is created from
68
- * @param toKey Custom uri identity function, e.g use an existing `IExtUri#getComparison`-util
69
- */
70
- constructor(other?: ResourceMap<T>, toKey?: ResourceMapKeyFn);
71
-
72
- /**
73
- *
74
- * @param other Another resource which this maps is created from
75
- * @param toKey Custom uri identity function, e.g use an existing `IExtUri#getComparison`-util
76
- */
77
- constructor(entries?: readonly (readonly [URI, T])[], toKey?: ResourceMapKeyFn);
78
-
79
- constructor(arg?: ResourceMap<T> | ResourceMapKeyFn | readonly (readonly [URI, T])[], toKey?: ResourceMapKeyFn) {
80
- if (arg instanceof ResourceMap) {
81
- this.map = new Map(arg.map);
82
- this.toKey = toKey ?? ResourceMap.defaultToKey;
83
- } else if (isEntries(arg)) {
84
- this.map = new Map();
85
- this.toKey = toKey ?? ResourceMap.defaultToKey;
86
-
87
- for (const [resource, value] of arg) {
88
- this.set(resource, value);
89
- }
90
- } else {
91
- this.map = new Map();
92
- this.toKey = arg ?? ResourceMap.defaultToKey;
93
- }
94
- }
95
-
96
- set(resource: URI, value: T): this {
97
- this.map.set(this.toKey(resource), new ResourceMapEntry(resource, value));
98
- return this;
99
- }
100
-
101
- get(resource: URI): T | undefined {
102
- return this.map.get(this.toKey(resource))?.value;
103
- }
104
-
105
- has(resource: URI): boolean {
106
- return this.map.has(this.toKey(resource));
107
- }
108
-
109
- get size(): number {
110
- return this.map.size;
111
- }
112
-
113
- clear(): void {
114
- this.map.clear();
115
- }
116
-
117
- delete(resource: URI): boolean {
118
- return this.map.delete(this.toKey(resource));
119
- }
120
-
121
- forEach(clb: (value: T, key: URI, map: Map<URI, T>) => void, thisArg?: any): void {
122
- if (typeof thisArg !== 'undefined') {
123
- clb = clb.bind(thisArg);
124
- }
125
- for (const [_, entry] of this.map) {
126
- clb(entry.value, entry.uri, <any>this);
127
- }
128
- }
129
-
130
- *values(): IterableIterator<T> {
131
- for (const entry of this.map.values()) {
132
- yield entry.value;
133
- }
134
- }
135
-
136
- *keys(): IterableIterator<URI> {
137
- for (const entry of this.map.values()) {
138
- yield entry.uri;
139
- }
140
- }
141
-
142
- *entries(): IterableIterator<[URI, T]> {
143
- for (const entry of this.map.values()) {
144
- yield [entry.uri, entry.value];
145
- }
146
- }
147
-
148
- *[Symbol.iterator](): IterableIterator<[URI, T]> {
149
- for (const [, entry] of this.map) {
150
- yield [entry.uri, entry.value];
151
- }
152
- }
153
- }
154
-
155
- export class ResourceSet implements Set<URI> {
156
-
157
- readonly [Symbol.toStringTag]: string = 'ResourceSet';
158
-
159
- private readonly _map: ResourceMap<URI>;
160
-
161
- constructor(toKey?: ResourceMapKeyFn);
162
- constructor(entries: readonly URI[], toKey?: ResourceMapKeyFn);
163
- constructor(entriesOrKey?: readonly URI[] | ResourceMapKeyFn, toKey?: ResourceMapKeyFn) {
164
- if (!entriesOrKey || typeof entriesOrKey === 'function') {
165
- this._map = new ResourceMap(entriesOrKey);
166
- } else {
167
- this._map = new ResourceMap(toKey);
168
- entriesOrKey.forEach(this.add, this);
169
- }
170
- }
171
-
172
-
173
- get size(): number {
174
- return this._map.size;
175
- }
176
-
177
- add(value: URI): this {
178
- this._map.set(value, value);
179
- return this;
180
- }
181
-
182
- clear(): void {
183
- this._map.clear();
184
- }
185
-
186
- delete(value: URI): boolean {
187
- return this._map.delete(value);
188
- }
189
-
190
- forEach(callbackfn: (value: URI, value2: URI, set: Set<URI>) => void, thisArg?: any): void {
191
- this._map.forEach((_value, key) => callbackfn.call(thisArg, key, key, this));
192
- }
193
-
194
- has(value: URI): boolean {
195
- return this._map.has(value);
196
- }
197
-
198
- entries(): IterableIterator<[URI, URI]> {
199
- return this._map.entries();
200
- }
201
-
202
- keys(): IterableIterator<URI> {
203
- return this._map.keys();
204
- }
205
-
206
- values(): IterableIterator<URI> {
207
- return this._map.keys();
208
- }
209
-
210
- [Symbol.iterator](): IterableIterator<URI> {
211
- return this.keys();
212
- }
213
- }
214
-
215
-
216
- interface Item<K, V> {
217
- previous: Item<K, V> | undefined;
218
- next: Item<K, V> | undefined;
219
- key: K;
220
- value: V;
221
- }
222
-
223
- export const enum Touch {
224
- None = 0,
225
- AsOld = 1,
226
- AsNew = 2
227
- }
228
-
229
- export class LinkedMap<K, V> implements Map<K, V> {
230
-
231
- readonly [Symbol.toStringTag] = 'LinkedMap';
232
-
233
- private _map: Map<K, Item<K, V>>;
234
- private _head: Item<K, V> | undefined;
235
- private _tail: Item<K, V> | undefined;
236
- private _size: number;
237
-
238
- private _state: number;
239
-
240
- constructor() {
241
- this._map = new Map<K, Item<K, V>>();
242
- this._head = undefined;
243
- this._tail = undefined;
244
- this._size = 0;
245
- this._state = 0;
246
- }
247
-
248
- clear(): void {
249
- this._map.clear();
250
- this._head = undefined;
251
- this._tail = undefined;
252
- this._size = 0;
253
- this._state++;
254
- }
255
-
256
- isEmpty(): boolean {
257
- return !this._head && !this._tail;
258
- }
259
-
260
- get size(): number {
261
- return this._size;
262
- }
263
-
264
- get first(): V | undefined {
265
- return this._head?.value;
266
- }
267
-
268
- get last(): V | undefined {
269
- return this._tail?.value;
270
- }
271
-
272
- has(key: K): boolean {
273
- return this._map.has(key);
274
- }
275
-
276
- get(key: K, touch: Touch = Touch.None): V | undefined {
277
- const item = this._map.get(key);
278
- if (!item) {
279
- return undefined;
280
- }
281
- if (touch !== Touch.None) {
282
- this.touch(item, touch);
283
- }
284
- return item.value;
285
- }
286
-
287
- set(key: K, value: V, touch: Touch = Touch.None): this {
288
- let item = this._map.get(key);
289
- if (item) {
290
- item.value = value;
291
- if (touch !== Touch.None) {
292
- this.touch(item, touch);
293
- }
294
- } else {
295
- item = { key, value, next: undefined, previous: undefined };
296
- switch (touch) {
297
- case Touch.None:
298
- this.addItemLast(item);
299
- break;
300
- case Touch.AsOld:
301
- this.addItemFirst(item);
302
- break;
303
- case Touch.AsNew:
304
- this.addItemLast(item);
305
- break;
306
- default:
307
- this.addItemLast(item);
308
- break;
309
- }
310
- this._map.set(key, item);
311
- this._size++;
312
- }
313
- return this;
314
- }
315
-
316
- delete(key: K): boolean {
317
- return !!this.remove(key);
318
- }
319
-
320
- remove(key: K): V | undefined {
321
- const item = this._map.get(key);
322
- if (!item) {
323
- return undefined;
324
- }
325
- this._map.delete(key);
326
- this.removeItem(item);
327
- this._size--;
328
- return item.value;
329
- }
330
-
331
- shift(): V | undefined {
332
- if (!this._head && !this._tail) {
333
- return undefined;
334
- }
335
- if (!this._head || !this._tail) {
336
- throw new Error('Invalid list');
337
- }
338
- const item = this._head;
339
- this._map.delete(item.key);
340
- this.removeItem(item);
341
- this._size--;
342
- return item.value;
343
- }
344
-
345
- forEach(callbackfn: (value: V, key: K, map: LinkedMap<K, V>) => void, thisArg?: any): void {
346
- const state = this._state;
347
- let current = this._head;
348
- while (current) {
349
- if (thisArg) {
350
- callbackfn.bind(thisArg)(current.value, current.key, this);
351
- } else {
352
- callbackfn(current.value, current.key, this);
353
- }
354
- if (this._state !== state) {
355
- throw new Error(`LinkedMap got modified during iteration.`);
356
- }
357
- current = current.next;
358
- }
359
- }
360
-
361
- keys(): IterableIterator<K> {
362
- const map = this;
363
- const state = this._state;
364
- let current = this._head;
365
- const iterator: IterableIterator<K> = {
366
- [Symbol.iterator]() {
367
- return iterator;
368
- },
369
- next(): IteratorResult<K> {
370
- if (map._state !== state) {
371
- throw new Error(`LinkedMap got modified during iteration.`);
372
- }
373
- if (current) {
374
- const result = { value: current.key, done: false };
375
- current = current.next;
376
- return result;
377
- } else {
378
- return { value: undefined, done: true };
379
- }
380
- }
381
- };
382
- return iterator;
383
- }
384
-
385
- values(): IterableIterator<V> {
386
- const map = this;
387
- const state = this._state;
388
- let current = this._head;
389
- const iterator: IterableIterator<V> = {
390
- [Symbol.iterator]() {
391
- return iterator;
392
- },
393
- next(): IteratorResult<V> {
394
- if (map._state !== state) {
395
- throw new Error(`LinkedMap got modified during iteration.`);
396
- }
397
- if (current) {
398
- const result = { value: current.value, done: false };
399
- current = current.next;
400
- return result;
401
- } else {
402
- return { value: undefined, done: true };
403
- }
404
- }
405
- };
406
- return iterator;
407
- }
408
-
409
- entries(): IterableIterator<[K, V]> {
410
- const map = this;
411
- const state = this._state;
412
- let current = this._head;
413
- const iterator: IterableIterator<[K, V]> = {
414
- [Symbol.iterator]() {
415
- return iterator;
416
- },
417
- next(): IteratorResult<[K, V]> {
418
- if (map._state !== state) {
419
- throw new Error(`LinkedMap got modified during iteration.`);
420
- }
421
- if (current) {
422
- const result: IteratorResult<[K, V]> = { value: [current.key, current.value], done: false };
423
- current = current.next;
424
- return result;
425
- } else {
426
- return { value: undefined, done: true };
427
- }
428
- }
429
- };
430
- return iterator;
431
- }
432
-
433
- [Symbol.iterator](): IterableIterator<[K, V]> {
434
- return this.entries();
435
- }
436
-
437
- protected trimOld(newSize: number) {
438
- if (newSize >= this.size) {
439
- return;
440
- }
441
- if (newSize === 0) {
442
- this.clear();
443
- return;
444
- }
445
- let current = this._head;
446
- let currentSize = this.size;
447
- while (current && currentSize > newSize) {
448
- this._map.delete(current.key);
449
- current = current.next;
450
- currentSize--;
451
- }
452
- this._head = current;
453
- this._size = currentSize;
454
- if (current) {
455
- current.previous = undefined;
456
- }
457
- this._state++;
458
- }
459
-
460
- protected trimNew(newSize: number) {
461
- if (newSize >= this.size) {
462
- return;
463
- }
464
- if (newSize === 0) {
465
- this.clear();
466
- return;
467
- }
468
- let current = this._tail;
469
- let currentSize = this.size;
470
- while (current && currentSize > newSize) {
471
- this._map.delete(current.key);
472
- current = current.previous;
473
- currentSize--;
474
- }
475
- this._tail = current;
476
- this._size = currentSize;
477
- if (current) {
478
- current.next = undefined;
479
- }
480
- this._state++;
481
- }
482
-
483
- private addItemFirst(item: Item<K, V>): void {
484
- // First time Insert
485
- if (!this._head && !this._tail) {
486
- this._tail = item;
487
- } else if (!this._head) {
488
- throw new Error('Invalid list');
489
- } else {
490
- item.next = this._head;
491
- this._head.previous = item;
492
- }
493
- this._head = item;
494
- this._state++;
495
- }
496
-
497
- private addItemLast(item: Item<K, V>): void {
498
- // First time Insert
499
- if (!this._head && !this._tail) {
500
- this._head = item;
501
- } else if (!this._tail) {
502
- throw new Error('Invalid list');
503
- } else {
504
- item.previous = this._tail;
505
- this._tail.next = item;
506
- }
507
- this._tail = item;
508
- this._state++;
509
- }
510
-
511
- private removeItem(item: Item<K, V>): void {
512
- if (item === this._head && item === this._tail) {
513
- this._head = undefined;
514
- this._tail = undefined;
515
- }
516
- else if (item === this._head) {
517
- // This can only happen if size === 1 which is handled
518
- // by the case above.
519
- if (!item.next) {
520
- throw new Error('Invalid list');
521
- }
522
- item.next.previous = undefined;
523
- this._head = item.next;
524
- }
525
- else if (item === this._tail) {
526
- // This can only happen if size === 1 which is handled
527
- // by the case above.
528
- if (!item.previous) {
529
- throw new Error('Invalid list');
530
- }
531
- item.previous.next = undefined;
532
- this._tail = item.previous;
533
- }
534
- else {
535
- const next = item.next;
536
- const previous = item.previous;
537
- if (!next || !previous) {
538
- throw new Error('Invalid list');
539
- }
540
- next.previous = previous;
541
- previous.next = next;
542
- }
543
- item.next = undefined;
544
- item.previous = undefined;
545
- this._state++;
546
- }
547
-
548
- private touch(item: Item<K, V>, touch: Touch): void {
549
- if (!this._head || !this._tail) {
550
- throw new Error('Invalid list');
551
- }
552
- if ((touch !== Touch.AsOld && touch !== Touch.AsNew)) {
553
- return;
554
- }
555
-
556
- if (touch === Touch.AsOld) {
557
- if (item === this._head) {
558
- return;
559
- }
560
-
561
- const next = item.next;
562
- const previous = item.previous;
563
-
564
- // Unlink the item
565
- if (item === this._tail) {
566
- // previous must be defined since item was not head but is tail
567
- // So there are more than on item in the map
568
- previous!.next = undefined;
569
- this._tail = previous;
570
- }
571
- else {
572
- // Both next and previous are not undefined since item was neither head nor tail.
573
- next!.previous = previous;
574
- previous!.next = next;
575
- }
576
-
577
- // Insert the node at head
578
- item.previous = undefined;
579
- item.next = this._head;
580
- this._head.previous = item;
581
- this._head = item;
582
- this._state++;
583
- } else if (touch === Touch.AsNew) {
584
- if (item === this._tail) {
585
- return;
586
- }
587
-
588
- const next = item.next;
589
- const previous = item.previous;
590
-
591
- // Unlink the item.
592
- if (item === this._head) {
593
- // next must be defined since item was not tail but is head
594
- // So there are more than on item in the map
595
- next!.previous = undefined;
596
- this._head = next;
597
- } else {
598
- // Both next and previous are not undefined since item was neither head nor tail.
599
- next!.previous = previous;
600
- previous!.next = next;
601
- }
602
- item.next = undefined;
603
- item.previous = this._tail;
604
- this._tail.next = item;
605
- this._tail = item;
606
- this._state++;
607
- }
608
- }
609
-
610
- toJSON(): [K, V][] {
611
- const data: [K, V][] = [];
612
-
613
- this.forEach((value, key) => {
614
- data.push([key, value]);
615
- });
616
-
617
- return data;
618
- }
619
-
620
- fromJSON(data: [K, V][]): void {
621
- this.clear();
622
-
623
- for (const [key, value] of data) {
624
- this.set(key, value);
625
- }
626
- }
627
- }
628
-
629
- abstract class Cache<K, V> extends LinkedMap<K, V> {
630
-
631
- protected _limit: number;
632
- protected _ratio: number;
633
-
634
- constructor(limit: number, ratio: number = 1) {
635
- super();
636
- this._limit = limit;
637
- this._ratio = Math.min(Math.max(0, ratio), 1);
638
- }
639
-
640
- get limit(): number {
641
- return this._limit;
642
- }
643
-
644
- set limit(limit: number) {
645
- this._limit = limit;
646
- this.checkTrim();
647
- }
648
-
649
- get ratio(): number {
650
- return this._ratio;
651
- }
652
-
653
- set ratio(ratio: number) {
654
- this._ratio = Math.min(Math.max(0, ratio), 1);
655
- this.checkTrim();
656
- }
657
-
658
- override get(key: K, touch: Touch = Touch.AsNew): V | undefined {
659
- return super.get(key, touch);
660
- }
661
-
662
- peek(key: K): V | undefined {
663
- return super.get(key, Touch.None);
664
- }
665
-
666
- override set(key: K, value: V): this {
667
- super.set(key, value, Touch.AsNew);
668
- return this;
669
- }
670
-
671
- protected checkTrim() {
672
- if (this.size > this._limit) {
673
- this.trim(Math.round(this._limit * this._ratio));
674
- }
675
- }
676
-
677
- protected abstract trim(newSize: number): void;
678
- }
679
-
680
- export class LRUCache<K, V> extends Cache<K, V> {
681
-
682
- constructor(limit: number, ratio: number = 1) {
683
- super(limit, ratio);
684
- }
685
-
686
- protected override trim(newSize: number) {
687
- this.trimOld(newSize);
688
- }
689
-
690
- override set(key: K, value: V): this {
691
- super.set(key, value);
692
- this.checkTrim();
693
- return this;
694
- }
695
- }
696
-
697
- export class MRUCache<K, V> extends Cache<K, V> {
698
-
699
- constructor(limit: number, ratio: number = 1) {
700
- super(limit, ratio);
701
- }
702
-
703
- protected override trim(newSize: number) {
704
- this.trimNew(newSize);
705
- }
706
-
707
- override set(key: K, value: V): this {
708
- if (this._limit <= this.size && !this.has(key)) {
709
- this.trim(Math.round(this._limit * this._ratio) - 1);
710
- }
711
-
712
- super.set(key, value);
713
- return this;
714
- }
715
- }
716
-
717
- export class CounterSet<T> {
718
-
719
- private map = new Map<T, number>();
720
-
721
- add(value: T): CounterSet<T> {
722
- this.map.set(value, (this.map.get(value) || 0) + 1);
723
- return this;
724
- }
725
-
726
- delete(value: T): boolean {
727
- let counter = this.map.get(value) || 0;
728
-
729
- if (counter === 0) {
730
- return false;
731
- }
732
-
733
- counter--;
734
-
735
- if (counter === 0) {
736
- this.map.delete(value);
737
- } else {
738
- this.map.set(value, counter);
739
- }
740
-
741
- return true;
742
- }
743
-
744
- has(value: T): boolean {
745
- return this.map.has(value);
746
- }
747
- }
748
-
749
- /**
750
- * A map that allows access both by keys and values.
751
- * **NOTE**: values need to be unique.
752
- */
753
- export class BidirectionalMap<K, V> {
754
-
755
- private readonly _m1 = new Map<K, V>();
756
- private readonly _m2 = new Map<V, K>();
757
-
758
- constructor(entries?: readonly (readonly [K, V])[]) {
759
- if (entries) {
760
- for (const [key, value] of entries) {
761
- this.set(key, value);
762
- }
763
- }
764
- }
765
-
766
- clear(): void {
767
- this._m1.clear();
768
- this._m2.clear();
769
- }
770
-
771
- set(key: K, value: V): void {
772
- this._m1.set(key, value);
773
- this._m2.set(value, key);
774
- }
775
-
776
- get(key: K): V | undefined {
777
- return this._m1.get(key);
778
- }
779
-
780
- getKey(value: V): K | undefined {
781
- return this._m2.get(value);
782
- }
783
-
784
- delete(key: K): boolean {
785
- const value = this._m1.get(key);
786
- if (value === undefined) {
787
- return false;
788
- }
789
- this._m1.delete(key);
790
- this._m2.delete(value);
791
- return true;
792
- }
793
-
794
- forEach(callbackfn: (value: V, key: K, map: BidirectionalMap<K, V>) => void, thisArg?: any): void {
795
- this._m1.forEach((value, key) => {
796
- callbackfn.call(thisArg, value, key, this);
797
- });
798
- }
799
-
800
- keys(): IterableIterator<K> {
801
- return this._m1.keys();
802
- }
803
-
804
- values(): IterableIterator<V> {
805
- return this._m1.values();
806
- }
807
- }
808
-
809
- export class SetMap<K, V> {
810
-
811
- private map = new Map<K, Set<V>>();
812
-
813
- add(key: K, value: V): void {
814
- let values = this.map.get(key);
815
-
816
- if (!values) {
817
- values = new Set<V>();
818
- this.map.set(key, values);
819
- }
820
-
821
- values.add(value);
822
- }
823
-
824
- delete(key: K, value: V): void {
825
- const values = this.map.get(key);
826
-
827
- if (!values) {
828
- return;
829
- }
830
-
831
- values.delete(value);
832
-
833
- if (values.size === 0) {
834
- this.map.delete(key);
835
- }
836
- }
837
-
838
- forEach(key: K, fn: (value: V) => void): void {
839
- const values = this.map.get(key);
840
-
841
- if (!values) {
842
- return;
843
- }
844
-
845
- values.forEach(fn);
846
- }
847
-
848
- get(key: K): ReadonlySet<V> {
849
- const values = this.map.get(key);
850
- if (!values) {
851
- return new Set<V>();
852
- }
853
- return values;
854
- }
855
- }
856
-
857
- export function mapsStrictEqualIgnoreOrder(a: Map<unknown, unknown>, b: Map<unknown, unknown>): boolean {
858
- if (a === b) {
859
- return true;
860
- }
861
-
862
- if (a.size !== b.size) {
863
- return false;
864
- }
865
-
866
- for (const [key, value] of a) {
867
- if (!b.has(key) || b.get(key) !== value) {
868
- return false;
869
- }
870
- }
871
-
872
- for (const [key] of b) {
873
- if (!a.has(key)) {
874
- return false;
875
- }
876
- }
877
-
878
- return true;
879
- }
880
-
881
- /**
882
- * A map that is addressable with an arbitrary number of keys. This is useful in high performance
883
- * scenarios where creating a composite key whenever the data is accessed is too expensive. For
884
- * example for a very hot function, constructing a string like `first-second-third` for every call
885
- * will cause a significant hit to performance.
886
- */
887
- export class NKeyMap<TValue, TKeys extends (string | boolean | number)[]> {
888
- private _data: Map<any, any> = new Map();
889
-
890
- /**
891
- * Sets a value on the map. Note that unlike a standard `Map`, the first argument is the value.
892
- * This is because the spread operator is used for the keys and must be last..
893
- * @param value The value to set.
894
- * @param keys The keys for the value.
895
- */
896
- public set(value: TValue, ...keys: [...TKeys]): void {
897
- let currentMap = this._data;
898
- for (let i = 0; i < keys.length - 1; i++) {
899
- if (!currentMap.has(keys[i])) {
900
- currentMap.set(keys[i], new Map());
901
- }
902
- currentMap = currentMap.get(keys[i]);
903
- }
904
- currentMap.set(keys[keys.length - 1], value);
905
- }
906
-
907
- public get(...keys: [...TKeys]): TValue | undefined {
908
- let currentMap = this._data;
909
- for (let i = 0; i < keys.length - 1; i++) {
910
- if (!currentMap.has(keys[i])) {
911
- return undefined;
912
- }
913
- currentMap = currentMap.get(keys[i]);
914
- }
915
- return currentMap.get(keys[keys.length - 1]);
916
- }
917
-
918
- public clear(): void {
919
- this._data.clear();
920
- }
921
-
922
- public *values(): IterableIterator<TValue> {
923
- function* iterate(map: Map<any, any>): IterableIterator<TValue> {
924
- for (const value of map.values()) {
925
- if (value instanceof Map) {
926
- yield* iterate(value);
927
- } else {
928
- yield value;
929
- }
930
- }
931
- }
932
- yield* iterate(this._data);
933
- }
934
-
935
- /**
936
- * Get a textual representation of the map for debugging purposes.
937
- */
938
- public toString(): string {
939
- const printMap = (map: Map<any, any>, depth: number): string => {
940
- let result = '';
941
- for (const [key, value] of map) {
942
- result += `${' '.repeat(depth)}${key}: `;
943
- if (value instanceof Map) {
944
- result += '\n' + printMap(value, depth + 1);
945
- } else {
946
- result += `${value}\n`;
947
- }
948
- }
949
- return result;
950
- };
951
-
952
- return printMap(this._data, 0);
953
- }
954
- }