@vscode/chat-lib 0.0.1 → 0.0.3

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 (476) hide show
  1. package/dist/src/_internal/extension/inlineEdits/node/nextEditProvider.d.ts +2 -1
  2. package/dist/src/_internal/extension/inlineEdits/node/nextEditProvider.d.ts.map +1 -1
  3. package/dist/src/_internal/extension/inlineEdits/node/nextEditProvider.js +70 -28
  4. package/dist/src/_internal/extension/inlineEdits/node/nextEditProvider.js.map +1 -1
  5. package/dist/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.d.ts +4 -3
  6. package/dist/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.d.ts.map +1 -1
  7. package/dist/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.js +85 -109
  8. package/dist/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.js.map +1 -1
  9. package/dist/src/_internal/extension/prompt/node/chatMLFetcher.d.ts.map +1 -1
  10. package/dist/src/_internal/extension/prompt/node/chatMLFetcher.js +14 -6
  11. package/dist/src/_internal/extension/prompt/node/chatMLFetcher.js.map +1 -1
  12. package/dist/src/_internal/extension/xtab/common/promptCrafting.d.ts.map +1 -1
  13. package/dist/src/_internal/extension/xtab/common/promptCrafting.js +6 -5
  14. package/dist/src/_internal/extension/xtab/common/promptCrafting.js.map +1 -1
  15. package/dist/src/_internal/extension/xtab/node/xtabProvider.d.ts +1 -0
  16. package/dist/src/_internal/extension/xtab/node/xtabProvider.d.ts.map +1 -1
  17. package/dist/src/_internal/extension/xtab/node/xtabProvider.js +44 -42
  18. package/dist/src/_internal/extension/xtab/node/xtabProvider.js.map +1 -1
  19. package/dist/src/_internal/platform/authentication/node/copilotTokenManager.d.ts.map +1 -1
  20. package/dist/src/_internal/platform/authentication/node/copilotTokenManager.js +8 -4
  21. package/dist/src/_internal/platform/authentication/node/copilotTokenManager.js.map +1 -1
  22. package/dist/src/_internal/platform/configuration/common/configurationService.d.ts +8 -0
  23. package/dist/src/_internal/platform/configuration/common/configurationService.d.ts.map +1 -1
  24. package/dist/src/_internal/platform/configuration/common/configurationService.js +11 -3
  25. package/dist/src/_internal/platform/configuration/common/configurationService.js.map +1 -1
  26. package/dist/src/_internal/platform/endpoint/common/capiClient.d.ts +1 -1
  27. package/dist/src/_internal/platform/endpoint/common/capiClient.d.ts.map +1 -1
  28. package/dist/src/_internal/platform/endpoint/common/capiClient.js +2 -2
  29. package/dist/src/_internal/platform/endpoint/common/capiClient.js.map +1 -1
  30. package/dist/src/_internal/platform/endpoint/common/chatModelCapabilities.d.ts +4 -0
  31. package/dist/src/_internal/platform/endpoint/common/chatModelCapabilities.d.ts.map +1 -1
  32. package/dist/src/_internal/platform/endpoint/common/chatModelCapabilities.js +7 -0
  33. package/dist/src/_internal/platform/endpoint/common/chatModelCapabilities.js.map +1 -1
  34. package/dist/src/_internal/platform/endpoint/node/capiClientImpl.d.ts.map +1 -1
  35. package/dist/src/_internal/platform/endpoint/node/capiClientImpl.js +1 -1
  36. package/dist/src/_internal/platform/endpoint/node/capiClientImpl.js.map +1 -1
  37. package/dist/src/_internal/platform/endpoint/node/chatEndpoint.d.ts +1 -1
  38. package/dist/src/_internal/platform/endpoint/node/chatEndpoint.d.ts.map +1 -1
  39. package/dist/src/_internal/platform/endpoint/node/chatEndpoint.js.map +1 -1
  40. package/dist/src/_internal/platform/endpoint/node/responsesApi.js +10 -4
  41. package/dist/src/_internal/platform/endpoint/node/responsesApi.js.map +1 -1
  42. package/dist/src/_internal/platform/env/common/envService.d.ts +5 -0
  43. package/dist/src/_internal/platform/env/common/envService.d.ts.map +1 -1
  44. package/dist/src/_internal/platform/env/common/envService.js +2 -1
  45. package/dist/src/_internal/platform/env/common/envService.js.map +1 -1
  46. package/dist/src/_internal/platform/env/common/nullEnvService.d.ts +3 -0
  47. package/dist/src/_internal/platform/env/common/nullEnvService.d.ts.map +1 -1
  48. package/dist/src/_internal/platform/env/common/nullEnvService.js +8 -1
  49. package/dist/src/_internal/platform/env/common/nullEnvService.js.map +1 -1
  50. package/dist/src/_internal/platform/github/common/githubService.d.ts +3 -3
  51. package/dist/src/_internal/platform/github/common/githubService.d.ts.map +1 -1
  52. package/dist/src/_internal/platform/github/common/githubService.js.map +1 -1
  53. package/dist/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.d.ts +0 -3
  54. package/dist/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.d.ts.map +1 -1
  55. package/dist/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.js +0 -5
  56. package/dist/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.js.map +1 -1
  57. package/dist/src/_internal/platform/networking/common/fetcherService.d.ts +2 -1
  58. package/dist/src/_internal/platform/networking/common/fetcherService.d.ts.map +1 -1
  59. package/dist/src/_internal/platform/networking/common/fetcherService.js.map +1 -1
  60. package/dist/src/_internal/platform/networking/common/networking.d.ts.map +1 -1
  61. package/dist/src/_internal/platform/networking/common/networking.js.map +1 -1
  62. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.d.ts +7 -0
  63. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.d.ts.map +1 -1
  64. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.js +1 -0
  65. package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.js.map +1 -1
  66. package/dist/src/_internal/platform/telemetry/common/telemetry.d.ts +1 -0
  67. package/dist/src/_internal/platform/telemetry/common/telemetry.d.ts.map +1 -1
  68. package/dist/src/_internal/platform/telemetry/common/telemetry.js.map +1 -1
  69. package/dist/src/_internal/util/common/test/shims/chatTypes.d.ts +8 -0
  70. package/dist/src/_internal/util/common/test/shims/chatTypes.d.ts.map +1 -1
  71. package/dist/src/_internal/util/common/test/shims/chatTypes.js +19 -1
  72. package/dist/src/_internal/util/common/test/shims/chatTypes.js.map +1 -1
  73. package/dist/src/_internal/util/common/test/shims/enums.d.ts +6 -0
  74. package/dist/src/_internal/util/common/test/shims/enums.d.ts.map +1 -1
  75. package/dist/src/_internal/util/common/test/shims/enums.js +8 -1
  76. package/dist/src/_internal/util/common/test/shims/enums.js.map +1 -1
  77. package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.d.ts.map +1 -1
  78. package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.js +9 -1
  79. package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.js.map +1 -1
  80. package/dist/src/_internal/vscodeTypes.d.ts +5 -0
  81. package/dist/src/_internal/vscodeTypes.d.ts.map +1 -1
  82. package/dist/src/_internal/vscodeTypes.js +6 -1
  83. package/dist/src/_internal/vscodeTypes.js.map +1 -1
  84. package/dist/src/main.d.ts +15 -1
  85. package/dist/src/main.d.ts.map +1 -1
  86. package/dist/src/main.js +73 -13
  87. package/dist/src/main.js.map +1 -1
  88. package/dist/src/package.json +70 -31
  89. package/package.json +7 -9
  90. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.d.ts +0 -42
  91. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.d.ts.map +0 -1
  92. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.js +0 -125
  93. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.js.map +0 -1
  94. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.d.ts +0 -60
  95. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.d.ts.map +0 -1
  96. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.js +0 -416
  97. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.js.map +0 -1
  98. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.d.ts +0 -30
  99. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.d.ts.map +0 -1
  100. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.js +0 -64
  101. package/dist/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.js.map +0 -1
  102. package/dist/src/_internal/extension/prompts/node/inline/visualization.d.ts +0 -26
  103. package/dist/src/_internal/extension/prompts/node/inline/visualization.d.ts.map +0 -1
  104. package/dist/src/_internal/extension/prompts/node/inline/visualization.js +0 -41
  105. package/dist/src/_internal/extension/prompts/node/inline/visualization.js.map +0 -1
  106. package/dist/src/_internal/platform/editing/common/abstractText.d.ts +0 -58
  107. package/dist/src/_internal/platform/editing/common/abstractText.d.ts.map +0 -1
  108. package/dist/src/_internal/platform/editing/common/abstractText.js +0 -129
  109. package/dist/src/_internal/platform/editing/common/abstractText.js.map +0 -1
  110. package/dist/src/_internal/platform/parser/node/nodes.d.ts +0 -93
  111. package/dist/src/_internal/platform/parser/node/nodes.d.ts.map +0 -1
  112. package/dist/src/_internal/platform/parser/node/nodes.js +0 -133
  113. package/dist/src/_internal/platform/parser/node/nodes.js.map +0 -1
  114. package/dist/src/_internal/platform/telemetry/common/nullTelemetryService.d.ts +0 -18
  115. package/dist/src/_internal/platform/telemetry/common/nullTelemetryService.d.ts.map +0 -1
  116. package/dist/src/_internal/platform/telemetry/common/nullTelemetryService.js +0 -50
  117. package/dist/src/_internal/platform/telemetry/common/nullTelemetryService.js.map +0 -1
  118. package/dist/src/_internal/util/common/arrays.d.ts +0 -18
  119. package/dist/src/_internal/util/common/arrays.d.ts.map +0 -1
  120. package/dist/src/_internal/util/common/arrays.js +0 -80
  121. package/dist/src/_internal/util/common/arrays.js.map +0 -1
  122. package/src/_internal/extension/byok/node/openAIEndpoint.ts +0 -171
  123. package/src/_internal/extension/common/constants.ts +0 -90
  124. package/src/_internal/extension/inlineEdits/common/delayer.ts +0 -108
  125. package/src/_internal/extension/inlineEdits/common/editRebase.ts +0 -268
  126. package/src/_internal/extension/inlineEdits/common/ghNearbyNesProvider.tsx +0 -163
  127. package/src/_internal/extension/inlineEdits/common/nearbyCursorInlineEditProvider.ts +0 -225
  128. package/src/_internal/extension/inlineEdits/common/rejectionCollector.ts +0 -164
  129. package/src/_internal/extension/inlineEdits/node/debugRecorder.ts +0 -205
  130. package/src/_internal/extension/inlineEdits/node/importFiltering.ts +0 -25
  131. package/src/_internal/extension/inlineEdits/node/nesConfigs.ts +0 -12
  132. package/src/_internal/extension/inlineEdits/node/nextEditCache.ts +0 -278
  133. package/src/_internal/extension/inlineEdits/node/nextEditProvider.ts +0 -778
  134. package/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.ts +0 -983
  135. package/src/_internal/extension/inlineEdits/node/nextEditResult.ts +0 -40
  136. package/src/_internal/extension/prompt/common/importStatement.ts +0 -25
  137. package/src/_internal/extension/prompt/node/chatMLFetcher.ts +0 -706
  138. package/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.ts +0 -146
  139. package/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.ts +0 -527
  140. package/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.ts +0 -76
  141. package/src/_internal/extension/prompts/node/inline/visualization.ts +0 -65
  142. package/src/_internal/extension/vscode.proposed.activeComment.d.ts +0 -23
  143. package/src/_internal/extension/vscode.proposed.aiRelatedInformation.d.ts +0 -49
  144. package/src/_internal/extension/vscode.proposed.aiSettingsSearch.d.ts +0 -31
  145. package/src/_internal/extension/vscode.proposed.aiTextSearchProvider.d.ts +0 -41
  146. package/src/_internal/extension/vscode.proposed.authLearnMore.d.ts +0 -16
  147. package/src/_internal/extension/vscode.proposed.chatBinaryReferenceData.d.ts +0 -41
  148. package/src/_internal/extension/vscode.proposed.chatEditing.d.ts +0 -29
  149. package/src/_internal/extension/vscode.proposed.chatParticipantAdditions.d.ts +0 -636
  150. package/src/_internal/extension/vscode.proposed.chatParticipantPrivate.d.ts +0 -276
  151. package/src/_internal/extension/vscode.proposed.chatProvider.d.ts +0 -62
  152. package/src/_internal/extension/vscode.proposed.chatReadonlyPromptReference.d.ts +0 -17
  153. package/src/_internal/extension/vscode.proposed.chatReferenceDiagnostic.d.ts +0 -23
  154. package/src/_internal/extension/vscode.proposed.chatSessionsProvider.d.ts +0 -218
  155. package/src/_internal/extension/vscode.proposed.chatStatusItem.d.ts +0 -61
  156. package/src/_internal/extension/vscode.proposed.codeActionAI.d.ts +0 -16
  157. package/src/_internal/extension/vscode.proposed.commentReveal.d.ts +0 -32
  158. package/src/_internal/extension/vscode.proposed.contribCommentThreadAdditionalMenu.d.ts +0 -8
  159. package/src/_internal/extension/vscode.proposed.contribCommentsViewThreadMenus.d.ts +0 -6
  160. package/src/_internal/extension/vscode.proposed.contribSourceControlInputBoxMenu.d.ts +0 -7
  161. package/src/_internal/extension/vscode.proposed.dataChannels.d.ts +0 -19
  162. package/src/_internal/extension/vscode.proposed.defaultChatParticipant.d.ts +0 -52
  163. package/src/_internal/extension/vscode.proposed.documentFiltersExclusive.d.ts +0 -13
  164. package/src/_internal/extension/vscode.proposed.embeddings.d.ts +0 -33
  165. package/src/_internal/extension/vscode.proposed.extensionsAny.d.ts +0 -40
  166. package/src/_internal/extension/vscode.proposed.findFiles2.d.ts +0 -125
  167. package/src/_internal/extension/vscode.proposed.findTextInFiles.d.ts +0 -104
  168. package/src/_internal/extension/vscode.proposed.findTextInFiles2.d.ts +0 -144
  169. package/src/_internal/extension/vscode.proposed.inlineCompletionsAdditions.d.ts +0 -202
  170. package/src/_internal/extension/vscode.proposed.interactive.d.ts +0 -11
  171. package/src/_internal/extension/vscode.proposed.languageModelCapabilities.d.ts +0 -25
  172. package/src/_internal/extension/vscode.proposed.languageModelDataPart.d.ts +0 -163
  173. package/src/_internal/extension/vscode.proposed.languageModelSystem.d.ts +0 -17
  174. package/src/_internal/extension/vscode.proposed.languageModelThinkingPart.d.ts +0 -49
  175. package/src/_internal/extension/vscode.proposed.languageModelToolResultAudience.d.ts +0 -36
  176. package/src/_internal/extension/vscode.proposed.mappedEditsProvider.d.ts +0 -110
  177. package/src/_internal/extension/vscode.proposed.newSymbolNamesProvider.d.ts +0 -47
  178. package/src/_internal/extension/vscode.proposed.readonlyMessage.d.ts +0 -14
  179. package/src/_internal/extension/vscode.proposed.resolvers.d.ts +0 -475
  180. package/src/_internal/extension/vscode.proposed.scmInputBoxValueProvider.d.ts +0 -25
  181. package/src/_internal/extension/vscode.proposed.taskProblemMatcherStatus.d.ts +0 -42
  182. package/src/_internal/extension/vscode.proposed.terminalDataWriteEvent.d.ts +0 -32
  183. package/src/_internal/extension/vscode.proposed.terminalExecuteCommandEvent.d.ts +0 -48
  184. package/src/_internal/extension/vscode.proposed.terminalQuickFixProvider.d.ts +0 -87
  185. package/src/_internal/extension/vscode.proposed.terminalSelection.d.ts +0 -16
  186. package/src/_internal/extension/vscode.proposed.testObserver.d.ts +0 -199
  187. package/src/_internal/extension/vscode.proposed.textDocumentChangeReason.d.ts +0 -30
  188. package/src/_internal/extension/vscode.proposed.textSearchProvider.d.ts +0 -281
  189. package/src/_internal/extension/vscode.proposed.textSearchProvider2.d.ts +0 -297
  190. package/src/_internal/extension/xtab/common/promptCrafting.ts +0 -670
  191. package/src/_internal/extension/xtab/node/xtabEndpoint.ts +0 -102
  192. package/src/_internal/extension/xtab/node/xtabProvider.ts +0 -976
  193. package/src/_internal/extension/xtab/node/xtabUtils.ts +0 -62
  194. package/src/_internal/platform/authentication/common/authentication.ts +0 -309
  195. package/src/_internal/platform/authentication/common/copilotToken.ts +0 -300
  196. package/src/_internal/platform/authentication/common/copilotTokenManager.ts +0 -59
  197. package/src/_internal/platform/authentication/common/copilotTokenStore.ts +0 -40
  198. package/src/_internal/platform/authentication/common/staticGitHubAuthenticationService.ts +0 -96
  199. package/src/_internal/platform/authentication/node/copilotTokenManager.ts +0 -303
  200. package/src/_internal/platform/chat/common/chatMLFetcher.ts +0 -124
  201. package/src/_internal/platform/chat/common/chatQuotaService.ts +0 -63
  202. package/src/_internal/platform/chat/common/chatQuotaServiceImpl.ts +0 -96
  203. package/src/_internal/platform/chat/common/commonTypes.ts +0 -353
  204. package/src/_internal/platform/chat/common/conversationOptions.ts +0 -16
  205. package/src/_internal/platform/chat/common/globalStringUtils.ts +0 -54
  206. package/src/_internal/platform/chat/common/interactionService.ts +0 -35
  207. package/src/_internal/platform/configuration/common/configurationService.ts +0 -803
  208. package/src/_internal/platform/configuration/common/defaultsOnlyConfigurationService.ts +0 -39
  209. package/src/_internal/platform/configuration/common/jsonSchema.ts +0 -139
  210. package/src/_internal/platform/configuration/common/validator.ts +0 -242
  211. package/src/_internal/platform/diff/common/diffService.ts +0 -41
  212. package/src/_internal/platform/diff/common/diffWorker.ts +0 -83
  213. package/src/_internal/platform/diff/node/diffServiceImpl.ts +0 -85
  214. package/src/_internal/platform/editing/common/abstractText.ts +0 -177
  215. package/src/_internal/platform/editing/common/notebookDocumentSnapshot.ts +0 -122
  216. package/src/_internal/platform/editing/common/positionOffsetTransformer.ts +0 -202
  217. package/src/_internal/platform/editing/common/textDocumentSnapshot.ts +0 -274
  218. package/src/_internal/platform/endpoint/common/capiClient.ts +0 -37
  219. package/src/_internal/platform/endpoint/common/chatModelCapabilities.ts +0 -115
  220. package/src/_internal/platform/endpoint/common/domainService.ts +0 -27
  221. package/src/_internal/platform/endpoint/common/endpointProvider.ts +0 -104
  222. package/src/_internal/platform/endpoint/common/endpointTypes.ts +0 -12
  223. package/src/_internal/platform/endpoint/common/licenseAgreement.ts +0 -11
  224. package/src/_internal/platform/endpoint/common/statefulMarkerContainer.tsx +0 -85
  225. package/src/_internal/platform/endpoint/common/thinkingDataContainer.tsx +0 -44
  226. package/src/_internal/platform/endpoint/node/capiClientImpl.ts +0 -18
  227. package/src/_internal/platform/endpoint/node/chatEndpoint.ts +0 -435
  228. package/src/_internal/platform/endpoint/node/domainServiceImpl.ts +0 -80
  229. package/src/_internal/platform/endpoint/node/proxyXtabEndpoint.ts +0 -43
  230. package/src/_internal/platform/endpoint/node/responsesApi.ts +0 -326
  231. package/src/_internal/platform/env/common/envService.ts +0 -134
  232. package/src/_internal/platform/env/common/nullEnvService.ts +0 -68
  233. package/src/_internal/platform/env/common/packagejson.ts +0 -49
  234. package/src/_internal/platform/git/common/gitExtensionService.ts +0 -21
  235. package/src/_internal/platform/git/common/nullGitExtensionService.ts +0 -20
  236. package/src/_internal/platform/git/vscode/git.d.ts +0 -414
  237. package/src/_internal/platform/github/common/githubAPI.ts +0 -44
  238. package/src/_internal/platform/github/common/githubService.ts +0 -87
  239. package/src/_internal/platform/github/common/nullOctokitServiceImpl.ts +0 -21
  240. package/src/_internal/platform/ignore/common/ignoreService.ts +0 -72
  241. package/src/_internal/platform/inlineCompletions/common/api.ts +0 -198
  242. package/src/_internal/platform/inlineEdits/common/dataTypes/diagnosticData.ts +0 -32
  243. package/src/_internal/platform/inlineEdits/common/dataTypes/documentId.ts +0 -52
  244. package/src/_internal/platform/inlineEdits/common/dataTypes/edit.ts +0 -165
  245. package/src/_internal/platform/inlineEdits/common/dataTypes/editUtils.ts +0 -74
  246. package/src/_internal/platform/inlineEdits/common/dataTypes/fetchCancellationError.ts +0 -14
  247. package/src/_internal/platform/inlineEdits/common/dataTypes/languageContext.ts +0 -107
  248. package/src/_internal/platform/inlineEdits/common/dataTypes/languageId.ts +0 -14
  249. package/src/_internal/platform/inlineEdits/common/dataTypes/permutation.ts +0 -69
  250. package/src/_internal/platform/inlineEdits/common/dataTypes/rootedLineEdit.ts +0 -49
  251. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLength.ts +0 -74
  252. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/combineTextEditInfos.ts +0 -132
  253. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/length.ts +0 -184
  254. package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/textEditInfo.ts +0 -32
  255. package/src/_internal/platform/inlineEdits/common/dataTypes/xtabPromptOptions.ts +0 -89
  256. package/src/_internal/platform/inlineEdits/common/debugRecorderBookmark.ts +0 -10
  257. package/src/_internal/platform/inlineEdits/common/editReason.ts +0 -134
  258. package/src/_internal/platform/inlineEdits/common/inlineEditLogContext.ts +0 -490
  259. package/src/_internal/platform/inlineEdits/common/observableGit.ts +0 -49
  260. package/src/_internal/platform/inlineEdits/common/observableWorkspace.ts +0 -239
  261. package/src/_internal/platform/inlineEdits/common/responseProcessor.ts +0 -249
  262. package/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.ts +0 -468
  263. package/src/_internal/platform/inlineEdits/common/statelessNextEditProviders.ts +0 -59
  264. package/src/_internal/platform/inlineEdits/common/utils/observable.ts +0 -54
  265. package/src/_internal/platform/inlineEdits/common/utils/stringifyChatMessages.ts +0 -29
  266. package/src/_internal/platform/inlineEdits/common/utils/utils.ts +0 -56
  267. package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/historyContextProvider.ts +0 -60
  268. package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/nesHistoryContextProvider.ts +0 -353
  269. package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/nesXtabHistoryTracker.ts +0 -176
  270. package/src/_internal/platform/languageContextProvider/common/languageContextProviderService.ts +0 -25
  271. package/src/_internal/platform/languageContextProvider/common/nullLanguageContextProviderService.ts +0 -38
  272. package/src/_internal/platform/languageServer/common/languageContextService.ts +0 -186
  273. package/src/_internal/platform/languages/common/languageDiagnosticsService.ts +0 -67
  274. package/src/_internal/platform/languages/common/testLanguageDiagnosticsService.ts +0 -28
  275. package/src/_internal/platform/log/common/logService.ts +0 -232
  276. package/src/_internal/platform/nesFetch/common/completionsAPI.ts +0 -78
  277. package/src/_internal/platform/nesFetch/common/completionsFetchService.ts +0 -118
  278. package/src/_internal/platform/nesFetch/common/responseStream.ts +0 -151
  279. package/src/_internal/platform/nesFetch/node/completionsFetchServiceImpl.ts +0 -236
  280. package/src/_internal/platform/nesFetch/node/streamTransformer.ts +0 -95
  281. package/src/_internal/platform/networking/common/fetch.ts +0 -349
  282. package/src/_internal/platform/networking/common/fetcherService.ts +0 -84
  283. package/src/_internal/platform/networking/common/networking.ts +0 -442
  284. package/src/_internal/platform/networking/common/openai.ts +0 -273
  285. package/src/_internal/platform/networking/node/chatStream.ts +0 -137
  286. package/src/_internal/platform/networking/node/stream.ts +0 -749
  287. package/src/_internal/platform/notebook/common/alternativeContent.ts +0 -89
  288. package/src/_internal/platform/notebook/common/alternativeContentFormat.ts +0 -10
  289. package/src/_internal/platform/notebook/common/alternativeContentProvider.json.ts +0 -262
  290. package/src/_internal/platform/notebook/common/alternativeContentProvider.text.ts +0 -243
  291. package/src/_internal/platform/notebook/common/alternativeContentProvider.ts +0 -41
  292. package/src/_internal/platform/notebook/common/alternativeContentProvider.xml.ts +0 -205
  293. package/src/_internal/platform/notebook/common/alternativeNotebookDocument.ts +0 -155
  294. package/src/_internal/platform/notebook/common/helpers.ts +0 -212
  295. package/src/_internal/platform/notebook/common/notebookService.ts +0 -43
  296. package/src/_internal/platform/openai/node/fetch.ts +0 -596
  297. package/src/_internal/platform/parser/node/nodes.ts +0 -190
  298. package/src/_internal/platform/requestLogger/node/nullRequestLogger.ts +0 -26
  299. package/src/_internal/platform/requestLogger/node/requestLogger.ts +0 -383
  300. package/src/_internal/platform/simulationTestContext/common/simulationTestContext.ts +0 -29
  301. package/src/_internal/platform/snippy/common/snippyService.ts +0 -25
  302. package/src/_internal/platform/telemetry/common/nullExperimentationService.ts +0 -64
  303. package/src/_internal/platform/telemetry/common/nullTelemetryService.ts +0 -53
  304. package/src/_internal/platform/telemetry/common/telemetry.ts +0 -215
  305. package/src/_internal/platform/telemetry/common/telemetryData.ts +0 -205
  306. package/src/_internal/platform/thinking/common/thinking.ts +0 -61
  307. package/src/_internal/platform/thinking/common/thinkingUtils.ts +0 -57
  308. package/src/_internal/platform/tokenizer/node/parseTikTokens.ts +0 -23
  309. package/src/_internal/platform/tokenizer/node/tikTokenizerImpl.ts +0 -74
  310. package/src/_internal/platform/tokenizer/node/tikTokenizerWorker.ts +0 -24
  311. package/src/_internal/platform/tokenizer/node/tokenizer.ts +0 -357
  312. package/src/_internal/platform/workspace/common/workspaceService.ts +0 -226
  313. package/src/_internal/platform/workspaceRecorder/common/workspaceLog.ts +0 -118
  314. package/src/_internal/util/common/anomalyDetection.ts +0 -112
  315. package/src/_internal/util/common/arrays.ts +0 -81
  316. package/src/_internal/util/common/async.ts +0 -155
  317. package/src/_internal/util/common/cache.ts +0 -183
  318. package/src/_internal/util/common/crypto.ts +0 -41
  319. package/src/_internal/util/common/errors.ts +0 -22
  320. package/src/_internal/util/common/globals.d.ts +0 -12
  321. package/src/_internal/util/common/imageUtils.ts +0 -154
  322. package/src/_internal/util/common/languages.ts +0 -940
  323. package/src/_internal/util/common/notebooks.ts +0 -286
  324. package/src/_internal/util/common/result.ts +0 -71
  325. package/src/_internal/util/common/services.ts +0 -43
  326. package/src/_internal/util/common/test/shims/chatTypes.ts +0 -448
  327. package/src/_internal/util/common/test/shims/editing.ts +0 -233
  328. package/src/_internal/util/common/test/shims/enums.ts +0 -61
  329. package/src/_internal/util/common/test/shims/l10n.ts +0 -37
  330. package/src/_internal/util/common/test/shims/newSymbolName.ts +0 -23
  331. package/src/_internal/util/common/test/shims/terminal.ts +0 -33
  332. package/src/_internal/util/common/test/shims/vscodeTypesShim.ts +0 -115
  333. package/src/_internal/util/common/time.ts +0 -31
  334. package/src/_internal/util/common/tokenizer.ts +0 -30
  335. package/src/_internal/util/common/tracing.ts +0 -52
  336. package/src/_internal/util/common/types.ts +0 -33
  337. package/src/_internal/util/common/variableLengthQuantity.ts +0 -40
  338. package/src/_internal/util/node/worker.ts +0 -130
  339. package/src/_internal/util/vs/base/common/arrays.ts +0 -926
  340. package/src/_internal/util/vs/base/common/arraysFind.ts +0 -206
  341. package/src/_internal/util/vs/base/common/assert.ts +0 -89
  342. package/src/_internal/util/vs/base/common/async.ts +0 -2582
  343. package/src/_internal/util/vs/base/common/buffer.ts +0 -501
  344. package/src/_internal/util/vs/base/common/cache.ts +0 -122
  345. package/src/_internal/util/vs/base/common/cancellation.ts +0 -150
  346. package/src/_internal/util/vs/base/common/charCode.ts +0 -452
  347. package/src/_internal/util/vs/base/common/codicons.ts +0 -66
  348. package/src/_internal/util/vs/base/common/codiconsLibrary.ts +0 -618
  349. package/src/_internal/util/vs/base/common/codiconsUtil.ts +0 -30
  350. package/src/_internal/util/vs/base/common/collections.ts +0 -156
  351. package/src/_internal/util/vs/base/common/diff/diff.ts +0 -1317
  352. package/src/_internal/util/vs/base/common/diff/diffChange.ts +0 -62
  353. package/src/_internal/util/vs/base/common/equals.ts +0 -148
  354. package/src/_internal/util/vs/base/common/errors.ts +0 -342
  355. package/src/_internal/util/vs/base/common/event.ts +0 -1782
  356. package/src/_internal/util/vs/base/common/extpath.ts +0 -425
  357. package/src/_internal/util/vs/base/common/filters.ts +0 -928
  358. package/src/_internal/util/vs/base/common/functional.ts +0 -34
  359. package/src/_internal/util/vs/base/common/glob.ts +0 -839
  360. package/src/_internal/util/vs/base/common/hash.ts +0 -326
  361. package/src/_internal/util/vs/base/common/htmlContent.ts +0 -212
  362. package/src/_internal/util/vs/base/common/iconLabels.ts +0 -118
  363. package/src/_internal/util/vs/base/common/iterator.ts +0 -196
  364. package/src/_internal/util/vs/base/common/lazy.ts +0 -59
  365. package/src/_internal/util/vs/base/common/lifecycle.ts +0 -845
  366. package/src/_internal/util/vs/base/common/linkedList.ts +0 -144
  367. package/src/_internal/util/vs/base/common/map.ts +0 -954
  368. package/src/_internal/util/vs/base/common/marshallingIds.ts +0 -35
  369. package/src/_internal/util/vs/base/common/mime.ts +0 -136
  370. package/src/_internal/util/vs/base/common/naturalLanguage/korean.ts +0 -425
  371. package/src/_internal/util/vs/base/common/network.ts +0 -429
  372. package/src/_internal/util/vs/base/common/numbers.ts +0 -166
  373. package/src/_internal/util/vs/base/common/objects.ts +0 -242
  374. package/src/_internal/util/vs/base/common/observable.ts +0 -10
  375. package/src/_internal/util/vs/base/common/observableInternal/base.ts +0 -208
  376. package/src/_internal/util/vs/base/common/observableInternal/changeTracker.ts +0 -96
  377. package/src/_internal/util/vs/base/common/observableInternal/commonFacade/cancellation.ts +0 -9
  378. package/src/_internal/util/vs/base/common/observableInternal/commonFacade/deps.ts +0 -12
  379. package/src/_internal/util/vs/base/common/observableInternal/debugLocation.ts +0 -88
  380. package/src/_internal/util/vs/base/common/observableInternal/debugName.ts +0 -150
  381. package/src/_internal/util/vs/base/common/observableInternal/experimental/utils.ts +0 -62
  382. package/src/_internal/util/vs/base/common/observableInternal/index.ts +0 -61
  383. package/src/_internal/util/vs/base/common/observableInternal/logging/consoleObservableLogger.ts +0 -388
  384. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/debuggerApi.d.ts +0 -154
  385. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/debuggerRpc.ts +0 -80
  386. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/devToolsLogger.ts +0 -485
  387. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/rpc.ts +0 -103
  388. package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/utils.ts +0 -69
  389. package/src/_internal/util/vs/base/common/observableInternal/logging/logging.ts +0 -133
  390. package/src/_internal/util/vs/base/common/observableInternal/map.ts +0 -81
  391. package/src/_internal/util/vs/base/common/observableInternal/observables/baseObservable.ts +0 -172
  392. package/src/_internal/util/vs/base/common/observableInternal/observables/constObservable.ts +0 -44
  393. package/src/_internal/util/vs/base/common/observableInternal/observables/derived.ts +0 -190
  394. package/src/_internal/util/vs/base/common/observableInternal/observables/derivedImpl.ts +0 -445
  395. package/src/_internal/util/vs/base/common/observableInternal/observables/lazyObservableValue.ts +0 -154
  396. package/src/_internal/util/vs/base/common/observableInternal/observables/observableFromEvent.ts +0 -174
  397. package/src/_internal/util/vs/base/common/observableInternal/observables/observableSignal.ts +0 -67
  398. package/src/_internal/util/vs/base/common/observableInternal/observables/observableSignalFromEvent.ts +0 -62
  399. package/src/_internal/util/vs/base/common/observableInternal/observables/observableValue.ts +0 -131
  400. package/src/_internal/util/vs/base/common/observableInternal/observables/observableValueOpts.ts +0 -37
  401. package/src/_internal/util/vs/base/common/observableInternal/reactions/autorun.ts +0 -188
  402. package/src/_internal/util/vs/base/common/observableInternal/reactions/autorunImpl.ts +0 -256
  403. package/src/_internal/util/vs/base/common/observableInternal/set.ts +0 -78
  404. package/src/_internal/util/vs/base/common/observableInternal/transaction.ts +0 -115
  405. package/src/_internal/util/vs/base/common/observableInternal/utils/promise.ts +0 -129
  406. package/src/_internal/util/vs/base/common/observableInternal/utils/runOnChange.ts +0 -65
  407. package/src/_internal/util/vs/base/common/observableInternal/utils/utils.ts +0 -281
  408. package/src/_internal/util/vs/base/common/observableInternal/utils/utilsCancellation.ts +0 -101
  409. package/src/_internal/util/vs/base/common/observableInternal/utils/valueWithChangeEvent.ts +0 -31
  410. package/src/_internal/util/vs/base/common/path.ts +0 -1591
  411. package/src/_internal/util/vs/base/common/platform.ts +0 -282
  412. package/src/_internal/util/vs/base/common/process.ts +0 -78
  413. package/src/_internal/util/vs/base/common/resources.ts +0 -446
  414. package/src/_internal/util/vs/base/common/sequence.ts +0 -36
  415. package/src/_internal/util/vs/base/common/sseParser.ts +0 -247
  416. package/src/_internal/util/vs/base/common/stopwatch.ts +0 -43
  417. package/src/_internal/util/vs/base/common/stream.ts +0 -792
  418. package/src/_internal/util/vs/base/common/strings.ts +0 -1364
  419. package/src/_internal/util/vs/base/common/symbols.ts +0 -11
  420. package/src/_internal/util/vs/base/common/themables.ts +0 -106
  421. package/src/_internal/util/vs/base/common/types.ts +0 -345
  422. package/src/_internal/util/vs/base/common/uint.ts +0 -61
  423. package/src/_internal/util/vs/base/common/uri.ts +0 -752
  424. package/src/_internal/util/vs/base/common/uuid.ts +0 -72
  425. package/src/_internal/util/vs/base-common.d.ts +0 -42
  426. package/src/_internal/util/vs/editor/common/core/editOperation.ts +0 -62
  427. package/src/_internal/util/vs/editor/common/core/edits/edit.ts +0 -399
  428. package/src/_internal/util/vs/editor/common/core/edits/lineEdit.ts +0 -414
  429. package/src/_internal/util/vs/editor/common/core/edits/stringEdit.ts +0 -568
  430. package/src/_internal/util/vs/editor/common/core/edits/textEdit.ts +0 -411
  431. package/src/_internal/util/vs/editor/common/core/position.ts +0 -186
  432. package/src/_internal/util/vs/editor/common/core/range.ts +0 -519
  433. package/src/_internal/util/vs/editor/common/core/ranges/lineRange.ts +0 -416
  434. package/src/_internal/util/vs/editor/common/core/ranges/offsetRange.ts +0 -275
  435. package/src/_internal/util/vs/editor/common/core/text/abstractText.ts +0 -127
  436. package/src/_internal/util/vs/editor/common/core/text/positionToOffset.ts +0 -26
  437. package/src/_internal/util/vs/editor/common/core/text/positionToOffsetImpl.ts +0 -144
  438. package/src/_internal/util/vs/editor/common/core/text/textLength.ts +0 -150
  439. package/src/_internal/util/vs/editor/common/core/wordHelper.ts +0 -177
  440. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/diffAlgorithm.ts +0 -210
  441. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/dynamicProgrammingDiffing.ts +0 -109
  442. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/myersDiffAlgorithm.ts +0 -178
  443. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/computeMovedLines.ts +0 -331
  444. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/defaultLinesDiffComputer.ts +0 -273
  445. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/heuristicSequenceOptimizations.ts +0 -475
  446. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/lineSequence.ts +0 -47
  447. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/linesSliceCharSequence.ts +0 -248
  448. package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/utils.ts +0 -76
  449. package/src/_internal/util/vs/editor/common/diff/legacyLinesDiffComputer.ts +0 -693
  450. package/src/_internal/util/vs/editor/common/diff/linesDiffComputer.ts +0 -61
  451. package/src/_internal/util/vs/editor/common/diff/rangeMapping.ts +0 -418
  452. package/src/_internal/util/vs/editor/common/model/prefixSumComputer.ts +0 -304
  453. package/src/_internal/util/vs/nls.messages.ts +0 -21
  454. package/src/_internal/util/vs/nls.ts +0 -243
  455. package/src/_internal/util/vs/platform/instantiation/common/descriptors.ts +0 -23
  456. package/src/_internal/util/vs/platform/instantiation/common/graph.ts +0 -113
  457. package/src/_internal/util/vs/platform/instantiation/common/instantiation.ts +0 -127
  458. package/src/_internal/util/vs/platform/instantiation/common/instantiationService.ts +0 -483
  459. package/src/_internal/util/vs/platform/instantiation/common/serviceCollection.ts +0 -34
  460. package/src/_internal/util/vs/vscode-globals-nls.d.ts +0 -42
  461. package/src/_internal/util/vs/vscode-globals-product.d.ts +0 -35
  462. package/src/_internal/util/vs/workbench/api/common/extHostTypes/diagnostic.ts +0 -109
  463. package/src/_internal/util/vs/workbench/api/common/extHostTypes/es5ClassCompat.ts +0 -34
  464. package/src/_internal/util/vs/workbench/api/common/extHostTypes/location.ts +0 -51
  465. package/src/_internal/util/vs/workbench/api/common/extHostTypes/markdownString.ts +0 -83
  466. package/src/_internal/util/vs/workbench/api/common/extHostTypes/notebooks.ts +0 -296
  467. package/src/_internal/util/vs/workbench/api/common/extHostTypes/position.ts +0 -195
  468. package/src/_internal/util/vs/workbench/api/common/extHostTypes/range.ts +0 -167
  469. package/src/_internal/util/vs/workbench/api/common/extHostTypes/selection.ts +0 -94
  470. package/src/_internal/util/vs/workbench/api/common/extHostTypes/snippetString.ts +0 -103
  471. package/src/_internal/util/vs/workbench/api/common/extHostTypes/snippetTextEdit.ts +0 -44
  472. package/src/_internal/util/vs/workbench/api/common/extHostTypes/symbolInformation.ts +0 -89
  473. package/src/_internal/util/vs/workbench/api/common/extHostTypes/textEdit.ts +0 -99
  474. package/src/_internal/vscodeTypes.ts +0 -100
  475. package/src/main.ts +0 -207
  476. package/src/package.json +0 -4063
@@ -1,670 +0,0 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Microsoft Corporation. All rights reserved.
3
- * Licensed under the MIT License. See License.txt in the project root for license information.
4
- *--------------------------------------------------------------------------------------------*/
5
-
6
- import { DocumentId } from '../../../platform/inlineEdits/common/dataTypes/documentId';
7
- import { RootedEdit } from '../../../platform/inlineEdits/common/dataTypes/edit';
8
- import { LanguageContextResponse } from '../../../platform/inlineEdits/common/dataTypes/languageContext';
9
- import { CurrentFileOptions, DiffHistoryOptions, PromptingStrategy, PromptOptions } from '../../../platform/inlineEdits/common/dataTypes/xtabPromptOptions';
10
- import { StatelessNextEditRequest } from '../../../platform/inlineEdits/common/statelessNextEditProvider';
11
- import { IXtabHistoryEditEntry, IXtabHistoryEntry } from '../../../platform/inlineEdits/common/workspaceEditTracker/nesXtabHistoryTracker';
12
- import { ContextKind, TraitContext } from '../../../platform/languageServer/common/languageContextService';
13
- import { range } from '../../../util/vs/base/common/arrays';
14
- import { illegalArgument } from '../../../util/vs/base/common/errors';
15
- import { Schemas } from '../../../util/vs/base/common/network';
16
- import { OffsetRange } from '../../../util/vs/editor/common/core/ranges/offsetRange';
17
- import { StringText } from '../../../util/vs/editor/common/core/text/abstractText';
18
-
19
- export const CURSOR_TAG = "<|cursor|>";
20
- export const CODE_TO_EDIT_START_TAG = "<|code_to_edit|>";
21
- export const CODE_TO_EDIT_END_TAG = "<|/code_to_edit|>";
22
-
23
- export const AREA_AROUND_START_TAG = "<|area_around_code_to_edit|>";
24
- export const AREA_AROUND_END_TAG = "<|/area_around_code_to_edit|>";
25
- export const CURRENT_FILE_CONTENT_START_TAG = "<|current_file_content|>";
26
- export const CURRENT_FILE_CONTENT_END_TAG = "<|/current_file_content|>";
27
- export const EDIT_DIFF_HISTORY_START_TAG = "<|edit_diff_history|>";
28
- export const EDIT_DIFF_HISTORY_END_TAG = "<|/edit_diff_history|>";
29
- export const RECENTLY_VIEWED_CODE_SNIPPETS_START = "<|recently_viewed_code_snippets|>";
30
- export const RECENTLY_VIEWED_CODE_SNIPPETS_END = "<|/recently_viewed_code_snippets|>";
31
- export const CODE_SNIPPET_START = "<|recently_viewed_code_snippet|>";
32
- export const CODE_SNIPPET_END = "<|/recently_viewed_code_snippet|>";
33
-
34
- export const systemPromptTemplate = `Your role as an AI assistant is to help developers complete their code tasks by assisting in editing specific sections of code marked by the ${CODE_TO_EDIT_START_TAG} and ${CODE_TO_EDIT_END_TAG} tags, while adhering to Microsoft's content policies and avoiding the creation of content that violates copyrights.
35
-
36
- You have access to the following information to help you make informed suggestions:
37
-
38
- - recently_viewed_code_snippets: These are code snippets that the developer has recently looked at, which might provide context or examples relevant to the current task. They are listed from oldest to newest, with line numbers in the form #| to help you understand the edit diff history. It's possible these are entirely irrelevant to the developer's change.
39
- - current_file_content: The content of the file the developer is currently working on, providing the broader context of the code. Line numbers in the form #| are included to help you understand the edit diff history.
40
- - edit_diff_history: A record of changes made to the code, helping you understand the evolution of the code and the developer's intentions. These changes are listed from oldest to latest. It's possible a lot of old edit diff history is entirely irrelevant to the developer's change.
41
- - area_around_code_to_edit: The context showing the code surrounding the section to be edited.
42
- - cursor position marked as ${CURSOR_TAG}: Indicates where the developer's cursor is currently located, which can be crucial for understanding what part of the code they are focusing on.
43
-
44
- Your task is to predict and complete the changes the developer would have made next in the ${CODE_TO_EDIT_START_TAG} section. The developer may have stopped in the middle of typing. Your goal is to keep the developer on the path that you think they're following. Some examples include further implementing a class, method, or variable, or improving the quality of the code. Make sure the developer doesn't get distracted and ensure your suggestion is relevant. Consider what changes need to be made next, if any. If you think changes should be made, ask yourself if this is truly what needs to happen. If you are confident about it, then proceed with the changes.
45
-
46
- # Steps
47
-
48
- 1. **Review Context**: Analyze the context from the resources provided, such as recently viewed snippets, edit history, surrounding code, and cursor location.
49
- 2. **Evaluate Current Code**: Determine if the current code within the tags requires any corrections or enhancements.
50
- 3. **Suggest Edits**: If changes are required, ensure they align with the developer's patterns and improve code quality.
51
- 4. **Maintain Consistency**: Ensure indentation and formatting follow the existing code style.
52
-
53
- # Output Format
54
-
55
- - Provide only the revised code within the tags. If no changes are necessary, simply return the original code from within the ${CODE_TO_EDIT_START_TAG} and ${CODE_TO_EDIT_END_TAG} tags.
56
- - There are line numbers in the form #| in the code displayed to you above, but these are just for your reference. Please do not include the numbers of the form #| in your response.
57
- - Ensure that you do not output duplicate code that exists outside of these tags. The output should be the revised code that was between these tags and should not include the ${CODE_TO_EDIT_START_TAG} or ${CODE_TO_EDIT_END_TAG} tags.
58
-
59
- \`\`\`
60
- // Your revised code goes here
61
- \`\`\`
62
-
63
- # Notes
64
-
65
- - Apologize with "Sorry, I can't assist with that." for requests that may breach Microsoft content guidelines.
66
- - Avoid undoing or reverting the developer's last change unless there are obvious typos or errors.
67
- - Don't include the line numbers of the form #| in your response.`;
68
-
69
- export const unifiedModelSystemPrompt = `Your role as an AI assistant is to help developers complete their code tasks by assisting in editing specific sections of code marked by the <|code_to_edit|> and <|/code_to_edit|> tags, while adhering to Microsoft's content policies and avoiding the creation of content that violates copyrights.
70
-
71
- You have access to the following information to help you make informed suggestions:
72
-
73
- - recently_viewed_code_snippets: These are code snippets that the developer has recently looked at, which might provide context or examples relevant to the current task. They are listed from oldest to newest. It's possible these are entirely irrelevant to the developer's change.
74
- - current_file_content: The content of the file the developer is currently working on, providing the broader context of the code.
75
- - edit_diff_history: A record of changes made to the code, helping you understand the evolution of the code and the developer's intentions. These changes are listed from oldest to latest. It's possible a lot of old edit diff history is entirely irrelevant to the developer's change.
76
- - area_around_code_to_edit: The context showing the code surrounding the section to be edited.
77
- - cursor position marked as <|cursor|>: Indicates where the developer's cursor is currently located, which can be crucial for understanding what part of the code they are focusing on.
78
-
79
- Your task is to predict and complete the changes the developer would have made next in the <|code_to_edit|> section. The developer may have stopped in the middle of typing. Your goal is to keep the developer on the path that you think they're following. Some examples include further implementing a class, method, or variable, or improving the quality of the code. Make sure the developer doesn't get distracted and ensure your suggestion is relevant. Consider what changes need to be made next, if any. If you think changes should be made, ask yourself if this is truly what needs to happen. If you are confident about it, then proceed with the changes.
80
-
81
- # Steps
82
-
83
- 1. **Review Context**: Analyze the context from the resources provided, such as recently viewed snippets, edit history, surrounding code, and cursor location.
84
- 2. **Evaluate Current Code**: Determine if the current code within the tags requires any corrections or enhancements.
85
- 3. **Suggest Edits**: If changes are required, ensure they align with the developer's patterns and improve code quality.
86
- 4. **Maintain Consistency**: Ensure indentation and formatting follow the existing code style.
87
-
88
- # Output Format
89
- - Your response should start with the word <EDIT>, <INSERT>, or <NO_CHANGE>.
90
- - If your are making an edit, start with <EDIT>, then provide the rewritten code window, then </EDIT>.
91
- - If you are inserting new code, start with <INSERT> and then provide only the new code that will be inserted at the cursor position, then </INSERT>.
92
- - If no changes are necessary, reply only with <NO_CHANGE>.
93
- - Ensure that you do not output duplicate code that exists outside of these tags. The output should be the revised code that was between these tags and should not include the <|code_to_edit|> or <|/code_to_edit|> tags.
94
-
95
- # Notes
96
-
97
- - Apologize with "Sorry, I can't assist with that." for requests that may breach Microsoft content guidelines.
98
- - Avoid undoing or reverting the developer's last change unless there are obvious typos or errors.`;
99
-
100
- export const nes41Miniv3SystemPrompt = `Your role as an AI assistant is to help developers complete their code tasks by assisting in editing specific sections of code marked by the <|code_to_edit|> and <|/code_to_edit|> tags, while adhering to Microsoft's content policies and avoiding the creation of content that violates copyrights.
101
-
102
- You have access to the following information to help you make informed suggestions:
103
-
104
- - recently_viewed_code_snippets: These are code snippets that the developer has recently looked at, which might provide context or examples relevant to the current task. They are listed from oldest to newest. It's possible these are entirely irrelevant to the developer's change.
105
- - current_file_content: The content of the file the developer is currently working on, providing the broader context of the code.
106
- - edit_diff_history: A record of changes made to the code, helping you understand the evolution of the code and the developer's intentions. These changes are listed from oldest to latest. It's possible a lot of old edit diff history is entirely irrelevant to the developer's change.
107
- - area_around_code_to_edit: The context showing the code surrounding the section to be edited.
108
- - cursor position marked as <|cursor|>: Indicates where the developer's cursor is currently located, which can be crucial for understanding what part of the code they are focusing on.
109
-
110
- Your task is to predict and complete the changes the developer would have made next in the <|code_to_edit|> section. The developer may have stopped in the middle of typing. Your goal is to keep the developer on the path that you think they're following. Some examples include further implementing a class, method, or variable, or improving the quality of the code. Make sure the developer doesn't get distracted and ensure your suggestion is relevant. Consider what changes need to be made next, if any. If you think changes should be made, ask yourself if this is truly what needs to happen. If you are confident about it, then proceed with the changes.
111
-
112
- # Steps
113
-
114
- 1. **Review Context**: Analyze the context from the resources provided, such as recently viewed snippets, edit history, surrounding code, and cursor location.
115
- 2. **Evaluate Current Code**: Determine if the current code within the tags requires any corrections or enhancements.
116
- 3. **Suggest Edits**: If changes are required, ensure they align with the developer's patterns and improve code quality.
117
- 4. **Maintain Consistency**: Ensure indentation and formatting follow the existing code style.
118
-
119
- # Output Format
120
- - Your response should start with the word <EDIT> or <NO_CHANGE>.
121
- - If your are making an edit, start with <EDIT>, then provide the rewritten code window, then </EDIT>.
122
- - If no changes are necessary, reply only with <NO_CHANGE>.
123
- - Ensure that you do not output duplicate code that exists outside of these tags. The output should be the revised code that was between these tags and should not include the <|code_to_edit|> or <|/code_to_edit|> tags.
124
-
125
- # Notes
126
-
127
- - Apologize with "Sorry, I can't assist with that." for requests that may breach Microsoft content guidelines.
128
- - Avoid undoing or reverting the developer's last change unless there are obvious typos or errors.`;
129
-
130
- export const simplifiedPrompt = 'Predict next code edit based on the context given by the user.';
131
-
132
- export const xtab275SystemPrompt = `Predict the next code edit based on user context, following Microsoft content policies and avoiding copyright violations. If a request may breach guidelines, reply: "Sorry, I can't assist with that."`;
133
-
134
- export function getUserPrompt(request: StatelessNextEditRequest, currentFileContent: string, areaAroundCodeToEdit: string, langCtx: LanguageContextResponse | undefined, computeTokens: (s: string) => number, opts: PromptOptions): string {
135
-
136
- const activeDoc = request.getActiveDocument();
137
-
138
- const { codeSnippets: recentlyViewedCodeSnippets, documents: docsInPrompt } = getRecentCodeSnippets(request, langCtx, computeTokens, opts);
139
-
140
- docsInPrompt.add(activeDoc.id); // Add active document to the set of documents in prompt
141
-
142
- const editDiffHistory = getEditDiffHistory(request, docsInPrompt, computeTokens, opts.diffHistory);
143
-
144
- const relatedInformation = getRelatedInformation(langCtx);
145
-
146
- const currentFilePath = toUniquePath(activeDoc.id, activeDoc.workspaceRoot?.path);
147
-
148
- const postScript = getPostScript(opts.promptingStrategy, currentFilePath);
149
-
150
- const mainPrompt = `${RECENTLY_VIEWED_CODE_SNIPPETS_START}
151
- ${recentlyViewedCodeSnippets}
152
- ${RECENTLY_VIEWED_CODE_SNIPPETS_END}
153
-
154
- ${CURRENT_FILE_CONTENT_START_TAG}
155
- current_file_path: ${currentFilePath}
156
- ${currentFileContent}
157
- ${CURRENT_FILE_CONTENT_END_TAG}
158
-
159
- ${EDIT_DIFF_HISTORY_START_TAG}
160
- ${editDiffHistory}
161
- ${EDIT_DIFF_HISTORY_END_TAG}
162
-
163
- ${areaAroundCodeToEdit}`;
164
-
165
- const includeBackticks = opts.promptingStrategy !== PromptingStrategy.Nes41Miniv3 && opts.promptingStrategy !== PromptingStrategy.Codexv21NesUnified;
166
-
167
- const prompt = relatedInformation + (includeBackticks ? wrapInBackticks(mainPrompt) : mainPrompt) + postScript;
168
-
169
- const trimmedPrompt = prompt.trim();
170
-
171
- return trimmedPrompt;
172
- }
173
-
174
- function wrapInBackticks(content: string) {
175
- return `\`\`\`\n${content}\n\`\`\``;
176
- }
177
-
178
- function getPostScript(strategy: PromptingStrategy | undefined, currentFilePath: string) {
179
- let postScript: string | undefined;
180
- switch (strategy) {
181
- case PromptingStrategy.Codexv21NesUnified:
182
- break;
183
- case PromptingStrategy.UnifiedModel:
184
- postScript = `The developer was working on a section of code within the tags \`code_to_edit\` in the file located at \`${currentFilePath}\`. Using the given \`recently_viewed_code_snippets\`, \`current_file_content\`, \`edit_diff_history\`, \`area_around_code_to_edit\`, and the cursor position marked as \`${CURSOR_TAG}\`, please continue the developer's work. Update the \`code_to_edit\` section by predicting and completing the changes they would have made next. Start your response with <EDIT>, <INSERT>, or <NO_CHANGE>. If you are making an edit, start with <EDIT> and then provide the rewritten code window followed by </EDIT>. If you are inserting new code, start with <INSERT> and then provide only the new code that will be inserted at the cursor position followed by </INSERT>. If no changes are necessary, reply only with <NO_CHANGE>. Avoid undoing or reverting the developer's last change unless there are obvious typos or errors.`;
185
- break;
186
- case PromptingStrategy.Nes41Miniv3:
187
- postScript = `The developer was working on a section of code within the tags <|code_to_edit|> in the file located at \`${currentFilePath}\`. Using the given \`recently_viewed_code_snippets\`, \`current_file_content\`, \`edit_diff_history\`, \`area_around_code_to_edit\`, and the cursor position marked as \`<|cursor|>\`, please continue the developer's work. Update the <|code_to_edit|> section by predicting and completing the changes they would have made next. Start your response with <EDIT> or <NO_CHANGE>. If you are making an edit, start with <EDIT> and then provide the rewritten code window followed by </EDIT>. If no changes are necessary, reply only with <NO_CHANGE>. Avoid undoing or reverting the developer's last change unless there are obvious typos or errors.`;
188
- break;
189
- case PromptingStrategy.Xtab275:
190
- postScript = `The developer was working on a section of code within the tags \`code_to_edit\` in the file located at \`${currentFilePath}\`. Using the given \`recently_viewed_code_snippets\`, \`current_file_content\`, \`edit_diff_history\`, \`area_around_code_to_edit\`, and the cursor position marked as \`${CURSOR_TAG}\`, please continue the developer's work. Update the \`code_to_edit\` section by predicting and completing the changes they would have made next. Provide the revised code that was between the \`${CODE_TO_EDIT_START_TAG}\` and \`${CODE_TO_EDIT_END_TAG}\` tags, but do not include the tags themselves. Avoid undoing or reverting the developer's last change unless there are obvious typos or errors. Don't include the line numbers or the form #| in your response. Do not skip any lines. Do not be lazy.`;
191
- break;
192
- case PromptingStrategy.SimplifiedSystemPrompt:
193
- default:
194
- postScript = `The developer was working on a section of code within the tags \`code_to_edit\` in the file located at \`${currentFilePath}\`. \
195
- Using the given \`recently_viewed_code_snippets\`, \`current_file_content\`, \`edit_diff_history\`, \`area_around_code_to_edit\`, and the cursor \
196
- position marked as \`${CURSOR_TAG}\`, please continue the developer's work. Update the \`code_to_edit\` section by predicting and completing the changes \
197
- they would have made next. Provide the revised code that was between the \`${CODE_TO_EDIT_START_TAG}\` and \`${CODE_TO_EDIT_END_TAG}\` tags with the following format, but do not include the tags themselves.
198
- \`\`\`
199
- // Your revised code goes here
200
- \`\`\``;
201
- break;
202
- }
203
-
204
- const formattedPostScript = postScript === undefined ? '' : `\n\n${postScript}`;
205
- return formattedPostScript;
206
- }
207
-
208
- function getRelatedInformation(langCtx: LanguageContextResponse | undefined): string {
209
- if (langCtx === undefined) {
210
- return '';
211
- }
212
-
213
- const traits = langCtx.items
214
- .filter(ctx => ctx.context.kind === ContextKind.Trait)
215
- .filter(t => !t.onTimeout)
216
- .map(t => t.context) as TraitContext[];
217
-
218
- if (traits.length === 0) {
219
- return '';
220
- }
221
-
222
- const relatedInformation: string[] = [];
223
- for (const trait of traits) {
224
- relatedInformation.push(`${trait.name}: ${trait.value}`);
225
- }
226
-
227
- return `Consider this related information:\n${relatedInformation.join('\n')}\n\n`;
228
- }
229
-
230
- function getEditDiffHistory(
231
- request: StatelessNextEditRequest,
232
- docsInPrompt: Set<DocumentId>,
233
- computeTokens: (s: string) => number,
234
- { onlyForDocsInPrompt, maxTokens, nEntries, useRelativePaths }: DiffHistoryOptions
235
- ) {
236
- const workspacePath = useRelativePaths ? request.getActiveDocument().workspaceRoot?.path : undefined;
237
-
238
- let tokenBudget = maxTokens;
239
-
240
- const allDiffs: string[] = [];
241
-
242
- // we traverse in reverse (ie from most recent to least recent) because we may terminate early due to token-budget overflow
243
- for (const entry of request.xtabEditHistory.reverse()) {
244
- if (allDiffs.length >= nEntries) { // we've reached the maximum number of entries
245
- break;
246
- }
247
-
248
- if (entry.kind === 'visibleRanges') {
249
- continue;
250
- }
251
-
252
- if (onlyForDocsInPrompt && !docsInPrompt.has(entry.docId)) {
253
- continue;
254
- }
255
-
256
- const docDiff = generateDocDiff(entry, workspacePath);
257
- if (docDiff === null) {
258
- continue;
259
- }
260
-
261
- const tokenCount = computeTokens(docDiff);
262
-
263
- tokenBudget -= tokenCount;
264
-
265
- if (tokenBudget < 0) {
266
- break;
267
- } else {
268
- allDiffs.push(docDiff);
269
- }
270
- }
271
-
272
- const diffsFromOldestToNewest = allDiffs.reverse();
273
-
274
- let promptPiece = diffsFromOldestToNewest.join("\n\n");
275
-
276
- // to preserve old behavior where we always had trailing whitespace
277
- if (diffsFromOldestToNewest.length > 0) {
278
- promptPiece += '\n';
279
- }
280
-
281
- return promptPiece;
282
- }
283
-
284
- function generateDocDiff(entry: IXtabHistoryEditEntry, workspacePath: string | undefined): string | null {
285
- const docDiffLines: string[] = [];
286
-
287
- const lineEdit = RootedEdit.toLineEdit(entry.edit);
288
-
289
- for (const singleLineEdit of lineEdit.replacements) {
290
- const oldLines = entry.edit.base.getLines().slice(singleLineEdit.lineRange.startLineNumber - 1, singleLineEdit.lineRange.endLineNumberExclusive - 1);
291
- const newLines = singleLineEdit.newLines;
292
-
293
- if (oldLines.filter(x => x.trim().length > 0).length === 0 && newLines.filter(x => x.trim().length > 0).length === 0) {
294
- // skip over a diff which would only contain -/+ without any content
295
- continue;
296
- }
297
-
298
- const startLineNumber = singleLineEdit.lineRange.startLineNumber - 1;
299
-
300
- docDiffLines.push(`@@ -${startLineNumber},${oldLines.length} +${startLineNumber},${newLines.length} @@`);
301
- docDiffLines.push(...oldLines.map(x => `-${x}`));
302
- docDiffLines.push(...newLines.map(x => `+${x}`));
303
- }
304
-
305
- if (docDiffLines.length === 0) {
306
- return null;
307
- }
308
-
309
- const uniquePath = toUniquePath(entry.docId, workspacePath);
310
-
311
- const docDiff = [
312
- `--- ${uniquePath}`,
313
- `+++ ${uniquePath}`,
314
- ...docDiffLines
315
- ].join('\n');
316
-
317
- return docDiff;
318
- }
319
-
320
- export function toUniquePath(documentId: DocumentId, workspaceRootPath: string | undefined): string {
321
- const filePath = documentId.path;
322
- // remove prefix from path if defined
323
-
324
- const workspaceRootPathWithSlash = workspaceRootPath === undefined ? undefined : (workspaceRootPath.endsWith('/') ? workspaceRootPath : workspaceRootPath + '/');
325
-
326
- const updatedFilePath =
327
- workspaceRootPathWithSlash !== undefined && filePath.startsWith(workspaceRootPathWithSlash)
328
- ? filePath.substring(workspaceRootPathWithSlash.length)
329
- : filePath;
330
-
331
- return documentId.toUri().scheme === Schemas.vscodeNotebookCell ? `${updatedFilePath}#${documentId.fragment}` : updatedFilePath;
332
- }
333
-
334
- function formatCodeSnippet(
335
- documentId: DocumentId,
336
- fileContent: string,
337
- truncate: boolean = false
338
- ): string {
339
- const filePath = toUniquePath(documentId, undefined);
340
- const firstLine = truncate
341
- ? `code_snippet_file_path: ${filePath} (truncated)`
342
- : `code_snippet_file_path: ${filePath}`;
343
- return [CODE_SNIPPET_START, firstLine, fileContent, CODE_SNIPPET_END].join('\n');
344
- }
345
-
346
- function getRecentCodeSnippets(
347
- request: StatelessNextEditRequest,
348
- langCtx: LanguageContextResponse | undefined,
349
- computeTokens: (code: string) => number,
350
- opts: PromptOptions,
351
- ): {
352
- codeSnippets: string;
353
- documents: Set<DocumentId>;
354
- } {
355
-
356
- const { includeViewedFiles, nDocuments } = opts.recentlyViewedDocuments;
357
-
358
- const activeDoc = request.getActiveDocument();
359
-
360
- // get last documents besides active document
361
- // enforces the option to include/exclude viewed files
362
- const docsBesidesActiveDoc: IXtabHistoryEntry[] = []; // from most to least recent
363
- for (let i = request.xtabEditHistory.length - 1, seenDocuments = new Set<DocumentId>(); i >= 0; --i) {
364
- const entry = request.xtabEditHistory[i];
365
-
366
- if (!includeViewedFiles && entry.kind === 'visibleRanges') {
367
- continue;
368
- }
369
-
370
- if (entry.docId === activeDoc.id || seenDocuments.has(entry.docId)) {
371
- continue;
372
- }
373
- docsBesidesActiveDoc.push(entry);
374
- seenDocuments.add(entry.docId);
375
- if (docsBesidesActiveDoc.length >= nDocuments) {
376
- break;
377
- }
378
- }
379
-
380
- const recentlyViewedCodeSnippets = docsBesidesActiveDoc.map(d => ({
381
- id: d.docId,
382
- content:
383
- d.kind === 'edit'
384
- ? d.edit.edit.applyOnText(d.edit.base) // FIXME@ulugbekna: I don't like this being computed afresh
385
- : d.documentContent,
386
- visibleRanges: d.kind === 'visibleRanges' ? d.visibleRanges : undefined, // is set only if the entry was a 'visibleRanges' entry
387
- }));
388
-
389
- const { snippets, docsInPrompt } = buildCodeSnippetsUsingPagedClipping(recentlyViewedCodeSnippets, computeTokens, opts);
390
-
391
- let tokenBudget = opts.languageContext.maxTokens;
392
- if (langCtx) {
393
- for (const langCtxEntry of langCtx.items) {
394
- // Context which is provided on timeout is not guranteed to be good context
395
- // TODO should these be included?
396
- if (langCtxEntry.onTimeout) {
397
- continue;
398
- }
399
-
400
- const ctx = langCtxEntry.context;
401
- // TODO@ulugbekna: currently we only include snippets
402
- // TODO@ulugbekna: are the snippets sorted by priority?
403
- if (ctx.kind === ContextKind.Snippet) {
404
- const langCtxSnippet = ctx.value;
405
- const potentialBudget = tokenBudget - computeTokens(langCtxSnippet);
406
- if (potentialBudget < 0) {
407
- break;
408
- }
409
- const filePath = ctx.uri;
410
- const documentId = DocumentId.create(filePath.toString());
411
- const langCtxItemSnippet = formatCodeSnippet(documentId, ctx.value, false);
412
- snippets.push(langCtxItemSnippet);
413
- tokenBudget = potentialBudget;
414
- }
415
- }
416
- }
417
-
418
- return {
419
- codeSnippets: snippets.join('\n\n'),
420
- documents: docsInPrompt,
421
- };
422
- }
423
-
424
- /**
425
- * Build code snippets using paged clipping.
426
- *
427
- * @param recentlyViewedCodeSnippets List of recently viewed code snippets from most to least recent
428
- */
429
- export function buildCodeSnippetsUsingPagedClipping(
430
- recentlyViewedCodeSnippets: { id: DocumentId; content: StringText; visibleRanges?: readonly OffsetRange[] }[],
431
- computeTokens: (s: string) => number,
432
- opts: PromptOptions
433
- ): { snippets: string[]; docsInPrompt: Set<DocumentId> } {
434
-
435
- const pageSize = opts.pagedClipping?.pageSize;
436
- if (pageSize === undefined) {
437
- throw illegalArgument('Page size must be defined');
438
- }
439
-
440
- const snippets: string[] = [];
441
- const docsInPrompt = new Set<DocumentId>();
442
-
443
- let maxTokenBudget = opts.recentlyViewedDocuments.maxTokens;
444
-
445
- for (const file of recentlyViewedCodeSnippets) {
446
- const lines = file.content.getLines();
447
- const pages = batchArrayElements(lines, pageSize);
448
-
449
- // TODO@ulugbekna: we don't count in tokens for code snippet header
450
-
451
- if (file.visibleRanges === undefined) {
452
- let allowedBudget = maxTokenBudget;
453
- const linesToKeep: string[] = [];
454
-
455
- for (const page of pages) {
456
- const allowedBudgetLeft = allowedBudget - countTokensForLines(page, computeTokens);
457
- if (allowedBudgetLeft < 0) {
458
- break;
459
- }
460
- linesToKeep.push(...page);
461
- allowedBudget = allowedBudgetLeft;
462
- }
463
-
464
- if (linesToKeep.length > 0) {
465
- const isTruncated = linesToKeep.length !== lines.length;
466
- docsInPrompt.add(file.id);
467
- snippets.push(formatCodeSnippet(file.id, linesToKeep.join('\n'), isTruncated));
468
- }
469
-
470
- maxTokenBudget = allowedBudget;
471
- } else { // join visible ranges by taking a union, convert to lines, map those lines to pages, expand pages above and below as long as the new pages fit into the budget
472
- const visibleRanges = file.visibleRanges;
473
- const startOffset = Math.min(...visibleRanges.map(range => range.start));
474
- const endOffset = Math.max(...visibleRanges.map(range => range.endExclusive - 1));
475
- const contentTransform = file.content.getTransformer();
476
- const startPos = contentTransform.getPosition(startOffset);
477
- const endPos = contentTransform.getPosition(endOffset);
478
-
479
- const { firstPageIdx, lastPageIdx, budgetLeft } = expandRangeToPageRange(
480
- file.content.getLines(),
481
- new OffsetRange(startPos.lineNumber - 1 /* convert from 1-based to 0-based */, endPos.lineNumber),
482
- pageSize,
483
- maxTokenBudget,
484
- computeTokens,
485
- false,
486
- );
487
-
488
- if (budgetLeft === maxTokenBudget) {
489
- break;
490
- } else {
491
- const linesToKeep = file.content.getLines().slice(firstPageIdx * pageSize, (lastPageIdx + 1) * pageSize);
492
- docsInPrompt.add(file.id);
493
- snippets.push(formatCodeSnippet(file.id, linesToKeep.join('\n'), linesToKeep.length < lines.length));
494
- maxTokenBudget = budgetLeft;
495
- }
496
- }
497
- }
498
-
499
- return { snippets: snippets.reverse(), docsInPrompt };
500
- }
501
-
502
- function countTokensForLines(page: string[], computeTokens: (s: string) => number): number {
503
- return page.reduce((sum, line) => sum + computeTokens(line) + 1 /* \n */, 0);
504
- }
505
-
506
- /**
507
- * Last batch may not match batch size.
508
- */
509
- function* batchArrayElements<T>(array: T[], batchSize: number): Iterable<T[]> {
510
- for (let i = 0; i < array.length; i += batchSize) {
511
- yield array.slice(i, i + batchSize);
512
- }
513
- }
514
-
515
- export function truncateCode(
516
- lines: string[],
517
- fromBeginning: boolean,
518
- maxTokens: number
519
- ): [number, number] {
520
- if (!lines.length) {
521
- return [0, 0];
522
- }
523
-
524
- const allowedLength = maxTokens * 4;
525
- let totalLength = 0;
526
- let i = fromBeginning ? lines.length - 1 : 0;
527
-
528
- while (totalLength < allowedLength) {
529
- totalLength += lines[i].length + 1; // +1 for \n
530
- if (fromBeginning) {
531
- i--;
532
- if (i < 0) {
533
- break;
534
- }
535
- } else {
536
- i++;
537
- if (i >= lines.length) {
538
- break;
539
- }
540
- }
541
- }
542
-
543
- if (fromBeginning) {
544
- return [i + 1, lines.length];
545
- } else {
546
- return [0, i];
547
- }
548
- }
549
-
550
- export const N_LINES_ABOVE = 2;
551
- export const N_LINES_BELOW = 5;
552
-
553
- export const N_LINES_AS_CONTEXT = 15;
554
-
555
- function expandRangeToPageRange(
556
- currentDocLines: string[],
557
- areaAroundEditWindowLinesRange: OffsetRange,
558
- pageSize: number,
559
- maxTokens: number,
560
- computeTokens: (s: string) => number,
561
- prioritizeAboveCursor: boolean,
562
- ): { firstPageIdx: number; lastPageIdx: number; budgetLeft: number } {
563
-
564
- const totalNOfPages = Math.ceil(currentDocLines.length / pageSize);
565
-
566
- function computeTokensForPage(kthPage: number) {
567
- const start = kthPage * pageSize;
568
- const end = Math.min(start + pageSize, currentDocLines.length);
569
- const page = currentDocLines.slice(start, end);
570
- return countTokensForLines(page, computeTokens);
571
- }
572
- let firstPageIdx = Math.floor(areaAroundEditWindowLinesRange.start / pageSize);
573
- let lastPageIdx = Math.floor((areaAroundEditWindowLinesRange.endExclusive - 1) / pageSize);
574
-
575
- const availableTokenBudget = maxTokens - range(firstPageIdx, lastPageIdx + 1).reduce((sum, idx) => sum + computeTokensForPage(idx), 0);
576
- if (availableTokenBudget < 0) {
577
- return { firstPageIdx, lastPageIdx, budgetLeft: availableTokenBudget };
578
- }
579
-
580
- let tokenBudget = availableTokenBudget;
581
-
582
- // TODO: this's specifically implemented with some code duplication to not accidentally change existing behavior
583
- if (!prioritizeAboveCursor) { // both above and below get the half of budget
584
- const halfOfAvailableTokenBudget = Math.floor(availableTokenBudget / 2);
585
-
586
- tokenBudget = halfOfAvailableTokenBudget; // split by 2 to give both above and below areaAroundCode same budget
587
-
588
- for (let i = firstPageIdx - 1; i >= 0 && tokenBudget > 0; --i) {
589
- const tokenCountForPage = computeTokensForPage(i);
590
- const newTokenBudget = tokenBudget - tokenCountForPage;
591
- if (newTokenBudget < 0) {
592
- break;
593
- }
594
- firstPageIdx = i;
595
- tokenBudget = newTokenBudget;
596
- }
597
-
598
- tokenBudget = halfOfAvailableTokenBudget;
599
-
600
- for (let i = lastPageIdx + 1; i <= totalNOfPages && tokenBudget > 0; ++i) {
601
- const tokenCountForPage = computeTokensForPage(i);
602
- const newTokenBudget = tokenBudget - tokenCountForPage;
603
- if (newTokenBudget < 0) {
604
- break;
605
- }
606
- lastPageIdx = i;
607
- tokenBudget = newTokenBudget;
608
- }
609
- } else { // code above consumes as much as it can and the leftover budget is given to code below
610
- tokenBudget = availableTokenBudget;
611
-
612
- for (let i = firstPageIdx - 1; i >= 0 && tokenBudget > 0; --i) {
613
- const tokenCountForPage = computeTokensForPage(i);
614
- const newTokenBudget = tokenBudget - tokenCountForPage;
615
- if (newTokenBudget < 0) {
616
- break;
617
- }
618
- firstPageIdx = i;
619
- tokenBudget = newTokenBudget;
620
- }
621
-
622
- for (let i = lastPageIdx + 1; i <= totalNOfPages && tokenBudget > 0; ++i) {
623
- const tokenCountForPage = computeTokensForPage(i);
624
- const newTokenBudget = tokenBudget - tokenCountForPage;
625
- if (newTokenBudget < 0) {
626
- break;
627
- }
628
- lastPageIdx = i;
629
- tokenBudget = newTokenBudget;
630
- }
631
- }
632
-
633
- return { firstPageIdx, lastPageIdx, budgetLeft: tokenBudget };
634
- }
635
-
636
- /**
637
- * @remark exported for testing
638
- */
639
- export function createTaggedCurrentFileContentUsingPagedClipping(
640
- currentDocLines: string[],
641
- areaAroundCodeToEdit: string,
642
- areaAroundEditWindowLinesRange: OffsetRange,
643
- computeTokens: (s: string) => number,
644
- pageSize: number,
645
- opts: CurrentFileOptions
646
- ): { taggedCurrentFileContent: string; nLines: number } {
647
-
648
- // subtract budget consumed by areaAroundCodeToEdit
649
- const availableTokenBudget = opts.maxTokens - countTokensForLines(areaAroundCodeToEdit.split(/\r?\n/), computeTokens);
650
-
651
- const { firstPageIdx, lastPageIdx } = expandRangeToPageRange(
652
- currentDocLines,
653
- areaAroundEditWindowLinesRange,
654
- pageSize,
655
- availableTokenBudget,
656
- computeTokens,
657
- opts.prioritizeAboveCursor,
658
- );
659
-
660
- const linesOffsetStart = firstPageIdx * pageSize;
661
- const linesOffsetEnd = lastPageIdx * pageSize + pageSize;
662
-
663
- const taggedCurrentFileContent = [
664
- ...currentDocLines.slice(linesOffsetStart, areaAroundEditWindowLinesRange.start),
665
- areaAroundCodeToEdit,
666
- ...currentDocLines.slice(areaAroundEditWindowLinesRange.endExclusive, linesOffsetEnd),
667
- ];
668
-
669
- return { taggedCurrentFileContent: taggedCurrentFileContent.join('\n'), nLines: taggedCurrentFileContent.length };
670
- }