@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.
- package/dist/src/_internal/extension/xtab/common/promptCrafting.d.ts.map +1 -1
- package/dist/src/_internal/extension/xtab/common/promptCrafting.js +6 -5
- package/dist/src/_internal/extension/xtab/common/promptCrafting.js.map +1 -1
- package/dist/src/_internal/platform/configuration/common/configurationService.d.ts +1 -0
- package/dist/src/_internal/platform/configuration/common/configurationService.d.ts.map +1 -1
- package/dist/src/_internal/platform/configuration/common/configurationService.js +1 -0
- package/dist/src/_internal/platform/configuration/common/configurationService.js.map +1 -1
- package/dist/src/_internal/platform/env/common/envService.d.ts +5 -0
- package/dist/src/_internal/platform/env/common/envService.d.ts.map +1 -1
- package/dist/src/_internal/platform/env/common/envService.js +2 -1
- package/dist/src/_internal/platform/env/common/envService.js.map +1 -1
- package/dist/src/_internal/platform/env/common/nullEnvService.d.ts +3 -0
- package/dist/src/_internal/platform/env/common/nullEnvService.d.ts.map +1 -1
- package/dist/src/_internal/platform/env/common/nullEnvService.js +8 -1
- package/dist/src/_internal/platform/env/common/nullEnvService.js.map +1 -1
- package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.d.ts +7 -0
- package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.d.ts.map +1 -1
- package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.js +1 -0
- package/dist/src/_internal/platform/telemetry/common/nullExperimentationService.js.map +1 -1
- package/dist/src/_internal/util/common/test/shims/chatTypes.d.ts +8 -0
- package/dist/src/_internal/util/common/test/shims/chatTypes.d.ts.map +1 -1
- package/dist/src/_internal/util/common/test/shims/chatTypes.js +19 -1
- package/dist/src/_internal/util/common/test/shims/chatTypes.js.map +1 -1
- package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.d.ts.map +1 -1
- package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.js +8 -1
- package/dist/src/_internal/util/common/test/shims/vscodeTypesShim.js.map +1 -1
- package/dist/src/_internal/vscodeTypes.d.ts +4 -0
- package/dist/src/_internal/vscodeTypes.d.ts.map +1 -1
- package/dist/src/_internal/vscodeTypes.js +5 -1
- package/dist/src/_internal/vscodeTypes.js.map +1 -1
- package/dist/src/main.d.ts +5 -0
- package/dist/src/main.d.ts.map +1 -1
- package/dist/src/main.js +12 -0
- package/dist/src/main.js.map +1 -1
- package/dist/src/package.json +46 -19
- package/package.json +3 -6
- package/src/_internal/extension/byok/node/openAIEndpoint.ts +0 -171
- package/src/_internal/extension/common/constants.ts +0 -90
- package/src/_internal/extension/inlineEdits/common/delayer.ts +0 -108
- package/src/_internal/extension/inlineEdits/common/editRebase.ts +0 -268
- package/src/_internal/extension/inlineEdits/common/ghNearbyNesProvider.tsx +0 -163
- package/src/_internal/extension/inlineEdits/common/nearbyCursorInlineEditProvider.ts +0 -225
- package/src/_internal/extension/inlineEdits/common/rejectionCollector.ts +0 -164
- package/src/_internal/extension/inlineEdits/node/debugRecorder.ts +0 -205
- package/src/_internal/extension/inlineEdits/node/importFiltering.ts +0 -25
- package/src/_internal/extension/inlineEdits/node/nesConfigs.ts +0 -12
- package/src/_internal/extension/inlineEdits/node/nextEditCache.ts +0 -278
- package/src/_internal/extension/inlineEdits/node/nextEditProvider.ts +0 -778
- package/src/_internal/extension/inlineEdits/node/nextEditProviderTelemetry.ts +0 -983
- package/src/_internal/extension/inlineEdits/node/nextEditResult.ts +0 -40
- package/src/_internal/extension/prompt/common/importStatement.ts +0 -25
- package/src/_internal/extension/prompt/node/chatMLFetcher.ts +0 -706
- package/src/_internal/extension/prompts/node/inline/summarizedDocument/fragments.ts +0 -146
- package/src/_internal/extension/prompts/node/inline/summarizedDocument/implementation.ts +0 -527
- package/src/_internal/extension/prompts/node/inline/summarizedDocument/projectedText.ts +0 -76
- package/src/_internal/extension/prompts/node/inline/visualization.ts +0 -65
- package/src/_internal/extension/vscode.proposed.activeComment.d.ts +0 -23
- package/src/_internal/extension/vscode.proposed.aiRelatedInformation.d.ts +0 -49
- package/src/_internal/extension/vscode.proposed.aiSettingsSearch.d.ts +0 -31
- package/src/_internal/extension/vscode.proposed.aiTextSearchProvider.d.ts +0 -41
- package/src/_internal/extension/vscode.proposed.authLearnMore.d.ts +0 -16
- package/src/_internal/extension/vscode.proposed.chatBinaryReferenceData.d.ts +0 -41
- package/src/_internal/extension/vscode.proposed.chatEditing.d.ts +0 -29
- package/src/_internal/extension/vscode.proposed.chatParticipantAdditions.d.ts +0 -636
- package/src/_internal/extension/vscode.proposed.chatParticipantPrivate.d.ts +0 -276
- package/src/_internal/extension/vscode.proposed.chatProvider.d.ts +0 -62
- package/src/_internal/extension/vscode.proposed.chatReadonlyPromptReference.d.ts +0 -17
- package/src/_internal/extension/vscode.proposed.chatReferenceDiagnostic.d.ts +0 -23
- package/src/_internal/extension/vscode.proposed.chatSessionsProvider.d.ts +0 -218
- package/src/_internal/extension/vscode.proposed.chatStatusItem.d.ts +0 -61
- package/src/_internal/extension/vscode.proposed.codeActionAI.d.ts +0 -16
- package/src/_internal/extension/vscode.proposed.commentReveal.d.ts +0 -32
- package/src/_internal/extension/vscode.proposed.contribCommentThreadAdditionalMenu.d.ts +0 -8
- package/src/_internal/extension/vscode.proposed.contribCommentsViewThreadMenus.d.ts +0 -6
- package/src/_internal/extension/vscode.proposed.contribSourceControlInputBoxMenu.d.ts +0 -7
- package/src/_internal/extension/vscode.proposed.dataChannels.d.ts +0 -19
- package/src/_internal/extension/vscode.proposed.defaultChatParticipant.d.ts +0 -52
- package/src/_internal/extension/vscode.proposed.documentFiltersExclusive.d.ts +0 -13
- package/src/_internal/extension/vscode.proposed.embeddings.d.ts +0 -33
- package/src/_internal/extension/vscode.proposed.extensionsAny.d.ts +0 -40
- package/src/_internal/extension/vscode.proposed.findFiles2.d.ts +0 -125
- package/src/_internal/extension/vscode.proposed.findTextInFiles.d.ts +0 -104
- package/src/_internal/extension/vscode.proposed.findTextInFiles2.d.ts +0 -144
- package/src/_internal/extension/vscode.proposed.inlineCompletionsAdditions.d.ts +0 -202
- package/src/_internal/extension/vscode.proposed.interactive.d.ts +0 -11
- package/src/_internal/extension/vscode.proposed.languageModelCapabilities.d.ts +0 -25
- package/src/_internal/extension/vscode.proposed.languageModelDataPart.d.ts +0 -163
- package/src/_internal/extension/vscode.proposed.languageModelSystem.d.ts +0 -17
- package/src/_internal/extension/vscode.proposed.languageModelThinkingPart.d.ts +0 -49
- package/src/_internal/extension/vscode.proposed.languageModelToolResultAudience.d.ts +0 -36
- package/src/_internal/extension/vscode.proposed.mappedEditsProvider.d.ts +0 -110
- package/src/_internal/extension/vscode.proposed.newSymbolNamesProvider.d.ts +0 -47
- package/src/_internal/extension/vscode.proposed.readonlyMessage.d.ts +0 -14
- package/src/_internal/extension/vscode.proposed.resolvers.d.ts +0 -475
- package/src/_internal/extension/vscode.proposed.scmInputBoxValueProvider.d.ts +0 -25
- package/src/_internal/extension/vscode.proposed.taskProblemMatcherStatus.d.ts +0 -42
- package/src/_internal/extension/vscode.proposed.terminalDataWriteEvent.d.ts +0 -32
- package/src/_internal/extension/vscode.proposed.terminalExecuteCommandEvent.d.ts +0 -48
- package/src/_internal/extension/vscode.proposed.terminalQuickFixProvider.d.ts +0 -87
- package/src/_internal/extension/vscode.proposed.terminalSelection.d.ts +0 -16
- package/src/_internal/extension/vscode.proposed.testObserver.d.ts +0 -199
- package/src/_internal/extension/vscode.proposed.textDocumentChangeReason.d.ts +0 -30
- package/src/_internal/extension/vscode.proposed.textSearchProvider.d.ts +0 -281
- package/src/_internal/extension/vscode.proposed.textSearchProvider2.d.ts +0 -297
- package/src/_internal/extension/xtab/common/promptCrafting.ts +0 -670
- package/src/_internal/extension/xtab/node/xtabEndpoint.ts +0 -102
- package/src/_internal/extension/xtab/node/xtabProvider.ts +0 -976
- package/src/_internal/extension/xtab/node/xtabUtils.ts +0 -62
- package/src/_internal/platform/authentication/common/authentication.ts +0 -309
- package/src/_internal/platform/authentication/common/copilotToken.ts +0 -300
- package/src/_internal/platform/authentication/common/copilotTokenManager.ts +0 -59
- package/src/_internal/platform/authentication/common/copilotTokenStore.ts +0 -40
- package/src/_internal/platform/authentication/common/staticGitHubAuthenticationService.ts +0 -96
- package/src/_internal/platform/authentication/node/copilotTokenManager.ts +0 -303
- package/src/_internal/platform/chat/common/chatMLFetcher.ts +0 -124
- package/src/_internal/platform/chat/common/chatQuotaService.ts +0 -63
- package/src/_internal/platform/chat/common/chatQuotaServiceImpl.ts +0 -96
- package/src/_internal/platform/chat/common/commonTypes.ts +0 -353
- package/src/_internal/platform/chat/common/conversationOptions.ts +0 -16
- package/src/_internal/platform/chat/common/globalStringUtils.ts +0 -54
- package/src/_internal/platform/chat/common/interactionService.ts +0 -35
- package/src/_internal/platform/configuration/common/configurationService.ts +0 -803
- package/src/_internal/platform/configuration/common/defaultsOnlyConfigurationService.ts +0 -39
- package/src/_internal/platform/configuration/common/jsonSchema.ts +0 -139
- package/src/_internal/platform/configuration/common/validator.ts +0 -242
- package/src/_internal/platform/diff/common/diffService.ts +0 -41
- package/src/_internal/platform/diff/common/diffWorker.ts +0 -83
- package/src/_internal/platform/diff/node/diffServiceImpl.ts +0 -85
- package/src/_internal/platform/editing/common/abstractText.ts +0 -177
- package/src/_internal/platform/editing/common/notebookDocumentSnapshot.ts +0 -122
- package/src/_internal/platform/editing/common/positionOffsetTransformer.ts +0 -202
- package/src/_internal/platform/editing/common/textDocumentSnapshot.ts +0 -274
- package/src/_internal/platform/endpoint/common/capiClient.ts +0 -37
- package/src/_internal/platform/endpoint/common/chatModelCapabilities.ts +0 -115
- package/src/_internal/platform/endpoint/common/domainService.ts +0 -27
- package/src/_internal/platform/endpoint/common/endpointProvider.ts +0 -104
- package/src/_internal/platform/endpoint/common/endpointTypes.ts +0 -12
- package/src/_internal/platform/endpoint/common/licenseAgreement.ts +0 -11
- package/src/_internal/platform/endpoint/common/statefulMarkerContainer.tsx +0 -85
- package/src/_internal/platform/endpoint/common/thinkingDataContainer.tsx +0 -44
- package/src/_internal/platform/endpoint/node/capiClientImpl.ts +0 -18
- package/src/_internal/platform/endpoint/node/chatEndpoint.ts +0 -435
- package/src/_internal/platform/endpoint/node/domainServiceImpl.ts +0 -80
- package/src/_internal/platform/endpoint/node/proxyXtabEndpoint.ts +0 -43
- package/src/_internal/platform/endpoint/node/responsesApi.ts +0 -326
- package/src/_internal/platform/env/common/envService.ts +0 -134
- package/src/_internal/platform/env/common/nullEnvService.ts +0 -68
- package/src/_internal/platform/env/common/packagejson.ts +0 -49
- package/src/_internal/platform/git/common/gitExtensionService.ts +0 -21
- package/src/_internal/platform/git/common/nullGitExtensionService.ts +0 -20
- package/src/_internal/platform/git/vscode/git.d.ts +0 -414
- package/src/_internal/platform/github/common/githubAPI.ts +0 -44
- package/src/_internal/platform/github/common/githubService.ts +0 -87
- package/src/_internal/platform/github/common/nullOctokitServiceImpl.ts +0 -21
- package/src/_internal/platform/ignore/common/ignoreService.ts +0 -72
- package/src/_internal/platform/inlineCompletions/common/api.ts +0 -198
- package/src/_internal/platform/inlineEdits/common/dataTypes/diagnosticData.ts +0 -32
- package/src/_internal/platform/inlineEdits/common/dataTypes/documentId.ts +0 -52
- package/src/_internal/platform/inlineEdits/common/dataTypes/edit.ts +0 -165
- package/src/_internal/platform/inlineEdits/common/dataTypes/editUtils.ts +0 -74
- package/src/_internal/platform/inlineEdits/common/dataTypes/fetchCancellationError.ts +0 -14
- package/src/_internal/platform/inlineEdits/common/dataTypes/languageContext.ts +0 -107
- package/src/_internal/platform/inlineEdits/common/dataTypes/languageId.ts +0 -14
- package/src/_internal/platform/inlineEdits/common/dataTypes/permutation.ts +0 -69
- package/src/_internal/platform/inlineEdits/common/dataTypes/rootedLineEdit.ts +0 -49
- package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLength.ts +0 -74
- package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/combineTextEditInfos.ts +0 -132
- package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/length.ts +0 -184
- package/src/_internal/platform/inlineEdits/common/dataTypes/textEditLengthHelper/textEditInfo.ts +0 -32
- package/src/_internal/platform/inlineEdits/common/dataTypes/xtabPromptOptions.ts +0 -89
- package/src/_internal/platform/inlineEdits/common/debugRecorderBookmark.ts +0 -10
- package/src/_internal/platform/inlineEdits/common/editReason.ts +0 -134
- package/src/_internal/platform/inlineEdits/common/inlineEditLogContext.ts +0 -490
- package/src/_internal/platform/inlineEdits/common/observableGit.ts +0 -49
- package/src/_internal/platform/inlineEdits/common/observableWorkspace.ts +0 -239
- package/src/_internal/platform/inlineEdits/common/responseProcessor.ts +0 -249
- package/src/_internal/platform/inlineEdits/common/statelessNextEditProvider.ts +0 -468
- package/src/_internal/platform/inlineEdits/common/statelessNextEditProviders.ts +0 -59
- package/src/_internal/platform/inlineEdits/common/utils/observable.ts +0 -54
- package/src/_internal/platform/inlineEdits/common/utils/stringifyChatMessages.ts +0 -29
- package/src/_internal/platform/inlineEdits/common/utils/utils.ts +0 -56
- package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/historyContextProvider.ts +0 -60
- package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/nesHistoryContextProvider.ts +0 -353
- package/src/_internal/platform/inlineEdits/common/workspaceEditTracker/nesXtabHistoryTracker.ts +0 -176
- package/src/_internal/platform/languageContextProvider/common/languageContextProviderService.ts +0 -25
- package/src/_internal/platform/languageContextProvider/common/nullLanguageContextProviderService.ts +0 -38
- package/src/_internal/platform/languageServer/common/languageContextService.ts +0 -186
- package/src/_internal/platform/languages/common/languageDiagnosticsService.ts +0 -67
- package/src/_internal/platform/languages/common/testLanguageDiagnosticsService.ts +0 -28
- package/src/_internal/platform/log/common/logService.ts +0 -232
- package/src/_internal/platform/nesFetch/common/completionsAPI.ts +0 -78
- package/src/_internal/platform/nesFetch/common/completionsFetchService.ts +0 -118
- package/src/_internal/platform/nesFetch/common/responseStream.ts +0 -151
- package/src/_internal/platform/nesFetch/node/completionsFetchServiceImpl.ts +0 -236
- package/src/_internal/platform/nesFetch/node/streamTransformer.ts +0 -95
- package/src/_internal/platform/networking/common/fetch.ts +0 -349
- package/src/_internal/platform/networking/common/fetcherService.ts +0 -84
- package/src/_internal/platform/networking/common/networking.ts +0 -442
- package/src/_internal/platform/networking/common/openai.ts +0 -273
- package/src/_internal/platform/networking/node/chatStream.ts +0 -137
- package/src/_internal/platform/networking/node/stream.ts +0 -749
- package/src/_internal/platform/notebook/common/alternativeContent.ts +0 -89
- package/src/_internal/platform/notebook/common/alternativeContentFormat.ts +0 -10
- package/src/_internal/platform/notebook/common/alternativeContentProvider.json.ts +0 -262
- package/src/_internal/platform/notebook/common/alternativeContentProvider.text.ts +0 -243
- package/src/_internal/platform/notebook/common/alternativeContentProvider.ts +0 -41
- package/src/_internal/platform/notebook/common/alternativeContentProvider.xml.ts +0 -205
- package/src/_internal/platform/notebook/common/alternativeNotebookDocument.ts +0 -155
- package/src/_internal/platform/notebook/common/helpers.ts +0 -212
- package/src/_internal/platform/notebook/common/notebookService.ts +0 -43
- package/src/_internal/platform/openai/node/fetch.ts +0 -596
- package/src/_internal/platform/parser/node/nodes.ts +0 -190
- package/src/_internal/platform/requestLogger/node/nullRequestLogger.ts +0 -26
- package/src/_internal/platform/requestLogger/node/requestLogger.ts +0 -383
- package/src/_internal/platform/simulationTestContext/common/simulationTestContext.ts +0 -29
- package/src/_internal/platform/snippy/common/snippyService.ts +0 -25
- package/src/_internal/platform/telemetry/common/nullExperimentationService.ts +0 -64
- package/src/_internal/platform/telemetry/common/nullTelemetryService.ts +0 -53
- package/src/_internal/platform/telemetry/common/telemetry.ts +0 -215
- package/src/_internal/platform/telemetry/common/telemetryData.ts +0 -205
- package/src/_internal/platform/thinking/common/thinking.ts +0 -61
- package/src/_internal/platform/thinking/common/thinkingUtils.ts +0 -57
- package/src/_internal/platform/tokenizer/node/parseTikTokens.ts +0 -23
- package/src/_internal/platform/tokenizer/node/tikTokenizerImpl.ts +0 -74
- package/src/_internal/platform/tokenizer/node/tikTokenizerWorker.ts +0 -24
- package/src/_internal/platform/tokenizer/node/tokenizer.ts +0 -357
- package/src/_internal/platform/workspace/common/workspaceService.ts +0 -226
- package/src/_internal/platform/workspaceRecorder/common/workspaceLog.ts +0 -118
- package/src/_internal/util/common/anomalyDetection.ts +0 -112
- package/src/_internal/util/common/arrays.ts +0 -81
- package/src/_internal/util/common/async.ts +0 -155
- package/src/_internal/util/common/cache.ts +0 -183
- package/src/_internal/util/common/crypto.ts +0 -41
- package/src/_internal/util/common/errors.ts +0 -22
- package/src/_internal/util/common/globals.d.ts +0 -12
- package/src/_internal/util/common/imageUtils.ts +0 -154
- package/src/_internal/util/common/languages.ts +0 -940
- package/src/_internal/util/common/notebooks.ts +0 -286
- package/src/_internal/util/common/result.ts +0 -71
- package/src/_internal/util/common/services.ts +0 -43
- package/src/_internal/util/common/test/shims/chatTypes.ts +0 -448
- package/src/_internal/util/common/test/shims/editing.ts +0 -233
- package/src/_internal/util/common/test/shims/enums.ts +0 -61
- package/src/_internal/util/common/test/shims/l10n.ts +0 -37
- package/src/_internal/util/common/test/shims/newSymbolName.ts +0 -23
- package/src/_internal/util/common/test/shims/terminal.ts +0 -33
- package/src/_internal/util/common/test/shims/vscodeTypesShim.ts +0 -115
- package/src/_internal/util/common/time.ts +0 -31
- package/src/_internal/util/common/tokenizer.ts +0 -30
- package/src/_internal/util/common/tracing.ts +0 -52
- package/src/_internal/util/common/types.ts +0 -33
- package/src/_internal/util/common/variableLengthQuantity.ts +0 -40
- package/src/_internal/util/node/worker.ts +0 -130
- package/src/_internal/util/vs/base/common/arrays.ts +0 -926
- package/src/_internal/util/vs/base/common/arraysFind.ts +0 -206
- package/src/_internal/util/vs/base/common/assert.ts +0 -89
- package/src/_internal/util/vs/base/common/async.ts +0 -2582
- package/src/_internal/util/vs/base/common/buffer.ts +0 -501
- package/src/_internal/util/vs/base/common/cache.ts +0 -122
- package/src/_internal/util/vs/base/common/cancellation.ts +0 -150
- package/src/_internal/util/vs/base/common/charCode.ts +0 -452
- package/src/_internal/util/vs/base/common/codicons.ts +0 -66
- package/src/_internal/util/vs/base/common/codiconsLibrary.ts +0 -618
- package/src/_internal/util/vs/base/common/codiconsUtil.ts +0 -30
- package/src/_internal/util/vs/base/common/collections.ts +0 -156
- package/src/_internal/util/vs/base/common/diff/diff.ts +0 -1317
- package/src/_internal/util/vs/base/common/diff/diffChange.ts +0 -62
- package/src/_internal/util/vs/base/common/equals.ts +0 -148
- package/src/_internal/util/vs/base/common/errors.ts +0 -342
- package/src/_internal/util/vs/base/common/event.ts +0 -1782
- package/src/_internal/util/vs/base/common/extpath.ts +0 -425
- package/src/_internal/util/vs/base/common/filters.ts +0 -928
- package/src/_internal/util/vs/base/common/functional.ts +0 -34
- package/src/_internal/util/vs/base/common/glob.ts +0 -839
- package/src/_internal/util/vs/base/common/hash.ts +0 -326
- package/src/_internal/util/vs/base/common/htmlContent.ts +0 -212
- package/src/_internal/util/vs/base/common/iconLabels.ts +0 -118
- package/src/_internal/util/vs/base/common/iterator.ts +0 -196
- package/src/_internal/util/vs/base/common/lazy.ts +0 -59
- package/src/_internal/util/vs/base/common/lifecycle.ts +0 -845
- package/src/_internal/util/vs/base/common/linkedList.ts +0 -144
- package/src/_internal/util/vs/base/common/map.ts +0 -954
- package/src/_internal/util/vs/base/common/marshallingIds.ts +0 -35
- package/src/_internal/util/vs/base/common/mime.ts +0 -136
- package/src/_internal/util/vs/base/common/naturalLanguage/korean.ts +0 -425
- package/src/_internal/util/vs/base/common/network.ts +0 -429
- package/src/_internal/util/vs/base/common/numbers.ts +0 -166
- package/src/_internal/util/vs/base/common/objects.ts +0 -242
- package/src/_internal/util/vs/base/common/observable.ts +0 -10
- package/src/_internal/util/vs/base/common/observableInternal/base.ts +0 -208
- package/src/_internal/util/vs/base/common/observableInternal/changeTracker.ts +0 -96
- package/src/_internal/util/vs/base/common/observableInternal/commonFacade/cancellation.ts +0 -9
- package/src/_internal/util/vs/base/common/observableInternal/commonFacade/deps.ts +0 -12
- package/src/_internal/util/vs/base/common/observableInternal/debugLocation.ts +0 -88
- package/src/_internal/util/vs/base/common/observableInternal/debugName.ts +0 -150
- package/src/_internal/util/vs/base/common/observableInternal/experimental/utils.ts +0 -62
- package/src/_internal/util/vs/base/common/observableInternal/index.ts +0 -61
- package/src/_internal/util/vs/base/common/observableInternal/logging/consoleObservableLogger.ts +0 -388
- package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/debuggerApi.d.ts +0 -154
- package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/debuggerRpc.ts +0 -80
- package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/devToolsLogger.ts +0 -485
- package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/rpc.ts +0 -103
- package/src/_internal/util/vs/base/common/observableInternal/logging/debugger/utils.ts +0 -69
- package/src/_internal/util/vs/base/common/observableInternal/logging/logging.ts +0 -133
- package/src/_internal/util/vs/base/common/observableInternal/map.ts +0 -81
- package/src/_internal/util/vs/base/common/observableInternal/observables/baseObservable.ts +0 -172
- package/src/_internal/util/vs/base/common/observableInternal/observables/constObservable.ts +0 -44
- package/src/_internal/util/vs/base/common/observableInternal/observables/derived.ts +0 -190
- package/src/_internal/util/vs/base/common/observableInternal/observables/derivedImpl.ts +0 -445
- package/src/_internal/util/vs/base/common/observableInternal/observables/lazyObservableValue.ts +0 -154
- package/src/_internal/util/vs/base/common/observableInternal/observables/observableFromEvent.ts +0 -174
- package/src/_internal/util/vs/base/common/observableInternal/observables/observableSignal.ts +0 -67
- package/src/_internal/util/vs/base/common/observableInternal/observables/observableSignalFromEvent.ts +0 -62
- package/src/_internal/util/vs/base/common/observableInternal/observables/observableValue.ts +0 -131
- package/src/_internal/util/vs/base/common/observableInternal/observables/observableValueOpts.ts +0 -37
- package/src/_internal/util/vs/base/common/observableInternal/reactions/autorun.ts +0 -188
- package/src/_internal/util/vs/base/common/observableInternal/reactions/autorunImpl.ts +0 -256
- package/src/_internal/util/vs/base/common/observableInternal/set.ts +0 -78
- package/src/_internal/util/vs/base/common/observableInternal/transaction.ts +0 -115
- package/src/_internal/util/vs/base/common/observableInternal/utils/promise.ts +0 -129
- package/src/_internal/util/vs/base/common/observableInternal/utils/runOnChange.ts +0 -65
- package/src/_internal/util/vs/base/common/observableInternal/utils/utils.ts +0 -281
- package/src/_internal/util/vs/base/common/observableInternal/utils/utilsCancellation.ts +0 -101
- package/src/_internal/util/vs/base/common/observableInternal/utils/valueWithChangeEvent.ts +0 -31
- package/src/_internal/util/vs/base/common/path.ts +0 -1591
- package/src/_internal/util/vs/base/common/platform.ts +0 -282
- package/src/_internal/util/vs/base/common/process.ts +0 -78
- package/src/_internal/util/vs/base/common/resources.ts +0 -446
- package/src/_internal/util/vs/base/common/sequence.ts +0 -36
- package/src/_internal/util/vs/base/common/sseParser.ts +0 -247
- package/src/_internal/util/vs/base/common/stopwatch.ts +0 -43
- package/src/_internal/util/vs/base/common/stream.ts +0 -792
- package/src/_internal/util/vs/base/common/strings.ts +0 -1364
- package/src/_internal/util/vs/base/common/symbols.ts +0 -11
- package/src/_internal/util/vs/base/common/themables.ts +0 -106
- package/src/_internal/util/vs/base/common/types.ts +0 -345
- package/src/_internal/util/vs/base/common/uint.ts +0 -61
- package/src/_internal/util/vs/base/common/uri.ts +0 -752
- package/src/_internal/util/vs/base/common/uuid.ts +0 -72
- package/src/_internal/util/vs/base-common.d.ts +0 -42
- package/src/_internal/util/vs/editor/common/core/editOperation.ts +0 -62
- package/src/_internal/util/vs/editor/common/core/edits/edit.ts +0 -399
- package/src/_internal/util/vs/editor/common/core/edits/lineEdit.ts +0 -414
- package/src/_internal/util/vs/editor/common/core/edits/stringEdit.ts +0 -568
- package/src/_internal/util/vs/editor/common/core/edits/textEdit.ts +0 -411
- package/src/_internal/util/vs/editor/common/core/position.ts +0 -186
- package/src/_internal/util/vs/editor/common/core/range.ts +0 -519
- package/src/_internal/util/vs/editor/common/core/ranges/lineRange.ts +0 -416
- package/src/_internal/util/vs/editor/common/core/ranges/offsetRange.ts +0 -275
- package/src/_internal/util/vs/editor/common/core/text/abstractText.ts +0 -127
- package/src/_internal/util/vs/editor/common/core/text/positionToOffset.ts +0 -26
- package/src/_internal/util/vs/editor/common/core/text/positionToOffsetImpl.ts +0 -144
- package/src/_internal/util/vs/editor/common/core/text/textLength.ts +0 -150
- package/src/_internal/util/vs/editor/common/core/wordHelper.ts +0 -177
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/diffAlgorithm.ts +0 -210
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/dynamicProgrammingDiffing.ts +0 -109
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/algorithms/myersDiffAlgorithm.ts +0 -178
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/computeMovedLines.ts +0 -331
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/defaultLinesDiffComputer.ts +0 -273
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/heuristicSequenceOptimizations.ts +0 -475
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/lineSequence.ts +0 -47
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/linesSliceCharSequence.ts +0 -248
- package/src/_internal/util/vs/editor/common/diff/defaultLinesDiffComputer/utils.ts +0 -76
- package/src/_internal/util/vs/editor/common/diff/legacyLinesDiffComputer.ts +0 -693
- package/src/_internal/util/vs/editor/common/diff/linesDiffComputer.ts +0 -61
- package/src/_internal/util/vs/editor/common/diff/rangeMapping.ts +0 -418
- package/src/_internal/util/vs/editor/common/model/prefixSumComputer.ts +0 -304
- package/src/_internal/util/vs/nls.messages.ts +0 -21
- package/src/_internal/util/vs/nls.ts +0 -243
- package/src/_internal/util/vs/platform/instantiation/common/descriptors.ts +0 -23
- package/src/_internal/util/vs/platform/instantiation/common/graph.ts +0 -113
- package/src/_internal/util/vs/platform/instantiation/common/instantiation.ts +0 -127
- package/src/_internal/util/vs/platform/instantiation/common/instantiationService.ts +0 -483
- package/src/_internal/util/vs/platform/instantiation/common/serviceCollection.ts +0 -34
- package/src/_internal/util/vs/vscode-globals-nls.d.ts +0 -42
- package/src/_internal/util/vs/vscode-globals-product.d.ts +0 -35
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/diagnostic.ts +0 -109
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/es5ClassCompat.ts +0 -34
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/location.ts +0 -51
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/markdownString.ts +0 -83
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/notebooks.ts +0 -296
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/position.ts +0 -195
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/range.ts +0 -167
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/selection.ts +0 -94
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/snippetString.ts +0 -103
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/snippetTextEdit.ts +0 -44
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/symbolInformation.ts +0 -89
- package/src/_internal/util/vs/workbench/api/common/extHostTypes/textEdit.ts +0 -99
- package/src/_internal/vscodeTypes.ts +0 -100
- package/src/main.ts +0 -207
- package/src/package.json +0 -4063
|
@@ -1,89 +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 type { LanguageModelChat, NotebookDocument, Uri } from 'vscode';
|
|
7
|
-
import { findCell } from '../../../util/common/notebooks';
|
|
8
|
-
import { createServiceIdentifier } from '../../../util/common/services';
|
|
9
|
-
import { Range } from '../../../util/common/test/shims/vscodeTypesShim';
|
|
10
|
-
import { ConfigKey, IConfigurationService } from '../../configuration/common/configurationService';
|
|
11
|
-
import { modelPrefersJsonNotebookRepresentation } from '../../endpoint/common/chatModelCapabilities';
|
|
12
|
-
import { IChatEndpoint } from '../../networking/common/networking';
|
|
13
|
-
import { IExperimentationService } from '../../telemetry/common/nullExperimentationService';
|
|
14
|
-
import { BaseAlternativeNotebookContentProvider } from './alternativeContentProvider';
|
|
15
|
-
import { AlternativeJsonNotebookContentProvider, isJsonContent } from './alternativeContentProvider.json';
|
|
16
|
-
import { AlternativeTextNotebookContentProvider } from './alternativeContentProvider.text';
|
|
17
|
-
import { AlternativeXmlNotebookContentProvider, isXmlContent } from './alternativeContentProvider.xml';
|
|
18
|
-
|
|
19
|
-
export type AlternativeContentFormat = 'xml' | 'text' | 'json';
|
|
20
|
-
|
|
21
|
-
export function getAlternativeNotebookDocumentProvider(kind: 'xml' | 'text' | 'json'): BaseAlternativeNotebookContentProvider {
|
|
22
|
-
switch (kind) {
|
|
23
|
-
case 'xml':
|
|
24
|
-
return new AlternativeXmlNotebookContentProvider();
|
|
25
|
-
case 'text':
|
|
26
|
-
return new AlternativeTextNotebookContentProvider();
|
|
27
|
-
case 'json':
|
|
28
|
-
return new AlternativeJsonNotebookContentProvider();
|
|
29
|
-
default:
|
|
30
|
-
throw new Error(`Unsupported kind '${kind}'`);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Given the content, determine the format of the content.
|
|
36
|
-
*/
|
|
37
|
-
export function inferAlternativeNotebookContentFormat(content: string): AlternativeContentFormat {
|
|
38
|
-
if (isXmlContent(content)) {
|
|
39
|
-
return 'xml';
|
|
40
|
-
}
|
|
41
|
-
if (isJsonContent(content)) {
|
|
42
|
-
return 'json';
|
|
43
|
-
}
|
|
44
|
-
return 'text';
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
export const IAlternativeNotebookContentService = createServiceIdentifier<IAlternativeNotebookContentService>('IAlternativeNotebookContentService');
|
|
49
|
-
|
|
50
|
-
export interface IAlternativeNotebookContentService {
|
|
51
|
-
readonly _serviceBrand: undefined;
|
|
52
|
-
getFormat(options: LanguageModelChat | IChatEndpoint | undefined): AlternativeContentFormat;
|
|
53
|
-
create(format: AlternativeContentFormat): BaseAlternativeNotebookContentProvider;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export class AlternativeNotebookContentService implements IAlternativeNotebookContentService {
|
|
57
|
-
declare readonly _serviceBrand: undefined;
|
|
58
|
-
constructor(
|
|
59
|
-
@IConfigurationService private readonly configurationService: IConfigurationService,
|
|
60
|
-
@IExperimentationService private readonly experimentationService: IExperimentationService,
|
|
61
|
-
) {
|
|
62
|
-
//
|
|
63
|
-
}
|
|
64
|
-
getFormat(options: LanguageModelChat | IChatEndpoint | undefined): AlternativeContentFormat {
|
|
65
|
-
// GPT 4.1 supports apply_patch, such models work best with JSON format (doesn't have great support for XML yet, thats being worked on).
|
|
66
|
-
if (options && modelPrefersJsonNotebookRepresentation(options)) {
|
|
67
|
-
return 'json';
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return this.configurationService.getExperimentBasedConfig(ConfigKey.Internal.NotebookAlternativeDocumentFormat, this.experimentationService);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
create(format: AlternativeContentFormat): BaseAlternativeNotebookContentProvider {
|
|
74
|
-
return getAlternativeNotebookDocumentProvider(format);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
export function getAltNotebookRange(range: Range, cellUri: Uri, notebook: NotebookDocument, format: AlternativeContentFormat) {
|
|
79
|
-
// If we have a range for cell, then translate that from notebook cell range to alternative range.
|
|
80
|
-
const cell = findCell(cellUri, notebook);
|
|
81
|
-
if (!cell) {
|
|
82
|
-
return undefined;
|
|
83
|
-
}
|
|
84
|
-
const doc = getAlternativeNotebookDocumentProvider(format).getAlternativeDocument(notebook);
|
|
85
|
-
return new Range(
|
|
86
|
-
doc.fromCellPosition(cell, range.start),
|
|
87
|
-
doc.fromCellPosition(cell, range.end),
|
|
88
|
-
);
|
|
89
|
-
}
|
|
@@ -1,10 +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
|
-
export enum AlternativeNotebookFormat {
|
|
7
|
-
json = 'json',
|
|
8
|
-
xml = 'xml',
|
|
9
|
-
text = 'text'
|
|
10
|
-
}
|
|
@@ -1,262 +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
|
-
import { visit } from 'jsonc-parser';
|
|
6
|
-
import type { CancellationToken, NotebookCell, NotebookDocument, TextDocument } from 'vscode';
|
|
7
|
-
import { AsyncIterableObject } from '../../../util/vs/base/common/async';
|
|
8
|
-
import { URI } from '../../../util/vs/base/common/uri';
|
|
9
|
-
import { NotebookCellKind, Position, Range, Uri } from '../../../util/common/test/shims/vscodeTypesShim';
|
|
10
|
-
import { BaseAlternativeNotebookContentProvider } from './alternativeContentProvider';
|
|
11
|
-
import { AlternativeNotebookDocument } from './alternativeNotebookDocument';
|
|
12
|
-
import { EOL, getCellId, getCellIdMap, getDefaultLanguage, LineOfCellText, LineOfText, summarize } from './helpers';
|
|
13
|
-
|
|
14
|
-
const IndentSize = 4;
|
|
15
|
-
|
|
16
|
-
export function isJsonContent(text: string): boolean {
|
|
17
|
-
if (text.startsWith('{') || text.trim().startsWith('{')) {
|
|
18
|
-
return true;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if ((text.includes('{') || text.includes('}')) && text.includes('"source":') && text.includes('"cell_type":')) {
|
|
22
|
-
return true;
|
|
23
|
-
}
|
|
24
|
-
return false;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
class AlternativeJsonDocument extends AlternativeNotebookDocument {
|
|
28
|
-
override fromCellPosition(cell: NotebookCell, position: Position): Position {
|
|
29
|
-
const cellId = getCellId(cell);
|
|
30
|
-
|
|
31
|
-
const alternativeContentText = this.getText();
|
|
32
|
-
const sourcePrefix = ` `; // we know we're indented by 4 spaces and source is 3 levels deep
|
|
33
|
-
const cellMarker = `"id": "${cellId}",`;
|
|
34
|
-
const positionOfSource = alternativeContentText.indexOf(`"source": [`, alternativeContentText.indexOf(cellMarker));
|
|
35
|
-
|
|
36
|
-
// Assume the text in the line is `print("Hello World")`
|
|
37
|
-
// & the position is the white space before `World`
|
|
38
|
-
// Position = line = n, character = 12
|
|
39
|
-
// In Json this would be ` "print(\"Hello World\")"`
|
|
40
|
-
// That would be translated as character position in translated = ` "print(\"Hello`.length;
|
|
41
|
-
const firstLineIndexOfCellSource = this.positionAt(positionOfSource).line + 1;
|
|
42
|
-
const leadingCharacters = cell.document.getText(new Range(position.line, 0, position.line, position.character));
|
|
43
|
-
// -1 to exclude to trailing `"`
|
|
44
|
-
const characterPositionInAltContent = `${sourcePrefix}${JSON.stringify(leadingCharacters).slice(0, -1)}`;
|
|
45
|
-
const linePositionInAltContent = position.line + firstLineIndexOfCellSource;
|
|
46
|
-
// -1 to exclude to trailing `"`
|
|
47
|
-
return new Position(linePositionInAltContent, characterPositionInAltContent.length);
|
|
48
|
-
}
|
|
49
|
-
override toCellPosition(position: Position): { cell: NotebookCell; position: Position } | undefined {
|
|
50
|
-
throw new Error('Method not implemented.');
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
export class AlternativeJsonNotebookContentProvider extends BaseAlternativeNotebookContentProvider {
|
|
55
|
-
constructor() {
|
|
56
|
-
super('json');
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
public stripCellMarkers(text: string): string {
|
|
60
|
-
return text;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
public override parseAlternateContent(notebookOrUri: NotebookDocument | Uri, inputStream: AsyncIterable<LineOfText>, token: CancellationToken): AsyncIterable<LineOfCellText> {
|
|
64
|
-
return this.parseAlternateContentImpl(notebookOrUri, inputStream, token);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
public override getAlternativeDocument(notebook: NotebookDocument, excludeMarkdownCells?: boolean): AlternativeNotebookDocument {
|
|
68
|
-
const cells = notebook.getCells().filter(cell => excludeMarkdownCells ? cell.kind !== NotebookCellKind.Markup : true).map(cell => {
|
|
69
|
-
const summary = summarize(cell);
|
|
70
|
-
const source = getCellCode(cell.document);
|
|
71
|
-
|
|
72
|
-
return {
|
|
73
|
-
cell_type: summary.cell_type,
|
|
74
|
-
id: summary.id,
|
|
75
|
-
metadata: {
|
|
76
|
-
language: summary.language
|
|
77
|
-
},
|
|
78
|
-
source,
|
|
79
|
-
} satisfies SummaryCell;
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
const json: Notebook = { cells };
|
|
83
|
-
const text = JSON.stringify(json, undefined, IndentSize);
|
|
84
|
-
|
|
85
|
-
return new AlternativeJsonDocument(text, notebook);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
public override getSummaryOfStructure(notebook: NotebookDocument, cellsToInclude: NotebookCell[], existingCodeMarker: string): string {
|
|
89
|
-
const lines = ['{', ' "cells: ['];
|
|
90
|
-
const existingCodeMarkerWithComment = `// ${existingCodeMarker}`;
|
|
91
|
-
notebook.getCells().forEach((cell) => {
|
|
92
|
-
if (cellsToInclude.includes(cell)) {
|
|
93
|
-
const cellSummary = summarize(cell);
|
|
94
|
-
if (cellSummary.source.length && cellSummary.source[0].trim().length) {
|
|
95
|
-
cellSummary.source = [cellSummary.source[0], existingCodeMarkerWithComment];
|
|
96
|
-
} else if (cellSummary.source.length && cellSummary.source.some(line => line.trim().length)) {
|
|
97
|
-
cellSummary.source = [existingCodeMarkerWithComment, cellSummary.source.filter(line => line.trim().length)[0], existingCodeMarkerWithComment];
|
|
98
|
-
} else {
|
|
99
|
-
cellSummary.source = [existingCodeMarkerWithComment];
|
|
100
|
-
}
|
|
101
|
-
const summary = JSON.stringify(cellSummary, undefined, IndentSize).split(/\r?\n/).map(line => ` ${line}`);
|
|
102
|
-
lines.push(...summary);
|
|
103
|
-
lines.push(',');
|
|
104
|
-
} else if (!lines.length || lines[lines.length - 1] !== existingCodeMarkerWithComment) {
|
|
105
|
-
lines.push(existingCodeMarkerWithComment);
|
|
106
|
-
}
|
|
107
|
-
});
|
|
108
|
-
lines.push(` ]`);
|
|
109
|
-
lines.push(`}`);
|
|
110
|
-
return lines.join(EOL);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
private parseAlternateContentImpl(notebookOrUri: NotebookDocument | URI, inputStream: AsyncIterable<LineOfText>, token: CancellationToken): AsyncIterable<LineOfCellText> {
|
|
114
|
-
return new AsyncIterableObject<LineOfCellText>(async (emitter) => {
|
|
115
|
-
const cellIdMap = URI.isUri(notebookOrUri) ? new Map<string, NotebookCell>() : getCellIdMap(notebookOrUri);
|
|
116
|
-
const cellIdsSeen = new Set<string>();
|
|
117
|
-
let jsonText = '';
|
|
118
|
-
let lastSeenOffset = -1;
|
|
119
|
-
const cellInfo: { id?: string; index: number; kind: NotebookCellKind; source: string[]; uri?: Uri; language?: string; startOffset: number; endOffset: number } = {
|
|
120
|
-
index: -1,
|
|
121
|
-
startOffset: -1,
|
|
122
|
-
endOffset: -1,
|
|
123
|
-
kind: NotebookCellKind.Code,
|
|
124
|
-
source: [],
|
|
125
|
-
};
|
|
126
|
-
const defaultLanguage = URI.isUri(notebookOrUri) ? 'python' : getDefaultLanguage(notebookOrUri);
|
|
127
|
-
|
|
128
|
-
const emitCell = (endOffset: number) => {
|
|
129
|
-
// LLM can return duplicate cell with the same id.
|
|
130
|
-
cellInfo.language = cellInfo.language || defaultLanguage;
|
|
131
|
-
if (cellInfo.id && cellIdMap.get(cellInfo.id)?.document.languageId === cellInfo.language) {
|
|
132
|
-
if (cellIdsSeen.has(cellInfo.id)) {
|
|
133
|
-
cellInfo.id = '';
|
|
134
|
-
} else {
|
|
135
|
-
cellIdsSeen.add(cellInfo.id);
|
|
136
|
-
}
|
|
137
|
-
} else {
|
|
138
|
-
// Possible duplicate cell with the same id but different language.
|
|
139
|
-
// In such cases, treat them as new cells.
|
|
140
|
-
cellInfo.id = '';
|
|
141
|
-
}
|
|
142
|
-
const cell = cellIdMap.get(cellInfo.id);
|
|
143
|
-
cellInfo.uri = cell?.document.uri;
|
|
144
|
-
cellInfo.kind = cell?.kind || (cellInfo.language === 'markdown' ? NotebookCellKind.Markup : NotebookCellKind.Code);
|
|
145
|
-
|
|
146
|
-
emitter.emitOne({ index: cellInfo.index, type: 'start', kind: cellInfo.kind, language: cellInfo.language, uri: cellInfo.uri, id: cellInfo.id });
|
|
147
|
-
cellInfo.source.forEach(cellLine => emitter.emitOne({ index: cellInfo.index, type: 'line', line: cellLine }));
|
|
148
|
-
emitter.emitOne({ index: cellInfo.index, type: 'end' });
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
let finalOffset = 0;
|
|
152
|
-
for await (const lineOfText of inputStream) {
|
|
153
|
-
if (token.isCancellationRequested) {
|
|
154
|
-
break;
|
|
155
|
-
}
|
|
156
|
-
const line = lineOfText.value;
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
jsonText += line;
|
|
160
|
-
|
|
161
|
-
visit(jsonText, {
|
|
162
|
-
onObjectEnd(offset, _length, _startLine, _startCharacter) {
|
|
163
|
-
finalOffset = offset;
|
|
164
|
-
},
|
|
165
|
-
onLiteralValue: (value, offset, _length, _startLine, _startCharacter, pathSupplier) => {
|
|
166
|
-
if (lastSeenOffset >= offset) {
|
|
167
|
-
return;
|
|
168
|
-
}
|
|
169
|
-
const segments = pathSupplier();
|
|
170
|
-
if (segments.length < 2) {
|
|
171
|
-
return;
|
|
172
|
-
}
|
|
173
|
-
if (segments.shift() !== 'cells') {
|
|
174
|
-
return;
|
|
175
|
-
}
|
|
176
|
-
const cellIndex = segments.shift();
|
|
177
|
-
if (typeof cellIndex !== 'number') {
|
|
178
|
-
return;
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
const property = segments.shift()! as string;
|
|
182
|
-
lastSeenOffset = offset;
|
|
183
|
-
|
|
184
|
-
if (cellInfo.index !== -1 && cellInfo.index !== cellIndex) {
|
|
185
|
-
emitCell(offset);
|
|
186
|
-
|
|
187
|
-
cellInfo.startOffset = offset;
|
|
188
|
-
cellInfo.id = undefined;
|
|
189
|
-
cellInfo.kind = NotebookCellKind.Code;
|
|
190
|
-
cellInfo.source = [];
|
|
191
|
-
cellInfo.uri = undefined;
|
|
192
|
-
cellInfo.language = undefined;
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
cellInfo.index = cellIndex;
|
|
196
|
-
|
|
197
|
-
if (property === 'cell_type') {
|
|
198
|
-
cellInfo.kind = value === 'code' ? NotebookCellKind.Code : NotebookCellKind.Markup;
|
|
199
|
-
if (cellInfo.kind === NotebookCellKind.Markup) {
|
|
200
|
-
cellInfo.language = 'markdown';
|
|
201
|
-
}
|
|
202
|
-
} else if (property === 'id') {
|
|
203
|
-
// This is for scenarios when LLM sends the id as part of the cell instead of metdata.
|
|
204
|
-
cellInfo.id = value;
|
|
205
|
-
} else if (property === 'metadata' && segments[0] === 'id') {
|
|
206
|
-
cellInfo.id = value;
|
|
207
|
-
} else if (property === 'metadata' && segments[0] === 'language') {
|
|
208
|
-
cellInfo.language = value;
|
|
209
|
-
if (cellInfo.language === 'markdown') {
|
|
210
|
-
cellInfo.kind = NotebookCellKind.Markup;
|
|
211
|
-
}
|
|
212
|
-
} else if (property === 'source' && segments.length && typeof segments[0] === 'number') {
|
|
213
|
-
if (segments[0] === 0) {
|
|
214
|
-
cellInfo.startOffset = offset;
|
|
215
|
-
}
|
|
216
|
-
let code = typeof value === 'string' ? value : `${value || ''}`;
|
|
217
|
-
// Generally code in jupyter cells always end with `\n` when persisted in JSON file.
|
|
218
|
-
// However we do not want to deal with the \n as we're only interested in the lines of code.
|
|
219
|
-
// This is because we're going to edit a line at a time, new line means we have two lines to edit, but thats not possible.
|
|
220
|
-
// A line cannot contain new line in editor (then its just two lines in editor).
|
|
221
|
-
if (code.endsWith('\n')) {
|
|
222
|
-
code = code.substr(0, code.length - 1);
|
|
223
|
-
}
|
|
224
|
-
cellInfo.source.push(code);
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
});
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
if (cellInfo.index !== -1) {
|
|
231
|
-
emitCell(finalOffset);
|
|
232
|
-
}
|
|
233
|
-
});
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
function getCellCode(document: TextDocument): string[] {
|
|
238
|
-
if (document.lineCount === 0) {
|
|
239
|
-
return [];
|
|
240
|
-
}
|
|
241
|
-
if (document.lineCount === 1) {
|
|
242
|
-
return [document.lineAt(0).text];
|
|
243
|
-
}
|
|
244
|
-
const lineCount = document.lineCount;
|
|
245
|
-
return new Array(lineCount).fill('').map((_, i) => document.lineAt(i).text);
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
type Notebook = {
|
|
249
|
-
cells: SummaryCell[];
|
|
250
|
-
};
|
|
251
|
-
|
|
252
|
-
/**
|
|
253
|
-
* Shortend version of a Jupyter cell JSON.
|
|
254
|
-
*/
|
|
255
|
-
type SummaryCell = {
|
|
256
|
-
cell_type: 'code' | 'markdown';
|
|
257
|
-
source: string[];
|
|
258
|
-
id: string;
|
|
259
|
-
metadata: {
|
|
260
|
-
language: string;
|
|
261
|
-
};
|
|
262
|
-
};
|
|
@@ -1,243 +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
|
-
import type { CancellationToken, NotebookCell, NotebookDocument, Position, Uri } from 'vscode';
|
|
6
|
-
import { getLanguage } from '../../../util/common/languages';
|
|
7
|
-
import { isUri } from '../../../util/common/types';
|
|
8
|
-
import { EndOfLine, NotebookCellKind } from '../../../util/common/test/shims/vscodeTypesShim';
|
|
9
|
-
import { BaseAlternativeNotebookContentProvider } from './alternativeContentProvider';
|
|
10
|
-
import { AlternativeNotebookDocument } from './alternativeNotebookDocument';
|
|
11
|
-
import { EOL, getCellIdMap, getDefaultLanguage, LineOfCellText, LineOfText, summarize, SummaryCell } from './helpers';
|
|
12
|
-
import { findLast } from '../../../util/vs/base/common/arraysFind';
|
|
13
|
-
|
|
14
|
-
export function generateCellTextMarker(cell: SummaryCell, lineComment: string): string {
|
|
15
|
-
const cellIdStr = cell.id ? `[id=${cell.id}] ` : '';
|
|
16
|
-
return `${lineComment}%% vscode.cell ${cellIdStr}[language=${cell.language}]`;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export function lineMightHaveCellMarker(line: string) {
|
|
20
|
-
return line.toLowerCase().includes('vscode.cell');
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
class AlternativeTextDocument extends AlternativeNotebookDocument {
|
|
24
|
-
constructor(text: string, private readonly cellOffsetMap: { offset: number; sourceOffset: number; cell: NotebookCell }[], notebook: NotebookDocument) {
|
|
25
|
-
super(text, notebook);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
override fromCellPosition(cell: NotebookCell, position: Position): Position {
|
|
29
|
-
const cellSummary = summarize(cell);
|
|
30
|
-
const lineCommentStart = getLineCommentStart(this.notebook);
|
|
31
|
-
const cellMarker = generateCellTextMarker(cellSummary, lineCommentStart);
|
|
32
|
-
|
|
33
|
-
const eolLength = cell.document.eol === EndOfLine.LF ? 1 : 2;
|
|
34
|
-
const blockComment = getBlockComment(this.notebook);
|
|
35
|
-
const alternativeContentText = this.getText();
|
|
36
|
-
const offsetInCell = cell.document.offsetAt(position);
|
|
37
|
-
const markdownOffset = cell.kind === NotebookCellKind.Markup ? blockComment[0].length + eolLength : 0;
|
|
38
|
-
const offset = alternativeContentText.indexOf(cellMarker) + cellMarker.length + eolLength + markdownOffset + offsetInCell;
|
|
39
|
-
return this.positionAt(offset);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
override toCellPosition(position: Position): { cell: NotebookCell; position: Position } | undefined {
|
|
43
|
-
const offset = this.offsetAt(position);
|
|
44
|
-
const cell = findLast(this.cellOffsetMap, (cell) => cell.sourceOffset <= offset);
|
|
45
|
-
if (!cell) {
|
|
46
|
-
return undefined;
|
|
47
|
-
}
|
|
48
|
-
const cellPosition = cell.cell.document.positionAt(offset - cell.sourceOffset);
|
|
49
|
-
return { cell: cell.cell, position: cellPosition };
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
export class AlternativeTextNotebookContentProvider extends BaseAlternativeNotebookContentProvider {
|
|
55
|
-
constructor() {
|
|
56
|
-
super('text');
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
public stripCellMarkers(text: string): string {
|
|
60
|
-
const lines = text.split(EOL);
|
|
61
|
-
if (lines.length && lineMightHaveCellMarker(lines[0])) {
|
|
62
|
-
lines.shift();
|
|
63
|
-
return lines.join(EOL);
|
|
64
|
-
} else {
|
|
65
|
-
return text;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
public override getSummaryOfStructure(notebook: NotebookDocument, cellsToInclude: NotebookCell[], existingCodeMarker: string): string {
|
|
70
|
-
const blockComment = getBlockComment(notebook);
|
|
71
|
-
const lineCommentStart = getLineCommentStart(notebook);
|
|
72
|
-
const existingCodeMarkerWithComment = `${lineCommentStart} ${existingCodeMarker}`;
|
|
73
|
-
const lines: string[] = [];
|
|
74
|
-
notebook.getCells().forEach((cell) => {
|
|
75
|
-
if (cellsToInclude.includes(cell)) {
|
|
76
|
-
const cellSummary = summarize(cell);
|
|
77
|
-
if (cellSummary.source.length && cellSummary.source[0].trim().length) {
|
|
78
|
-
cellSummary.source = [cellSummary.source[0], existingCodeMarkerWithComment];
|
|
79
|
-
} else if (cellSummary.source.length && cellSummary.source.some(line => line.trim().length)) {
|
|
80
|
-
cellSummary.source = [existingCodeMarkerWithComment, cellSummary.source.filter(line => line.trim().length)[0], existingCodeMarkerWithComment];
|
|
81
|
-
} else {
|
|
82
|
-
cellSummary.source = [existingCodeMarkerWithComment];
|
|
83
|
-
}
|
|
84
|
-
lines.push(generateAlternativeCellTextContent(cellSummary, lineCommentStart, blockComment).content);
|
|
85
|
-
} else if (!lines.length || lines[lines.length - 1] !== existingCodeMarkerWithComment) {
|
|
86
|
-
lines.push(existingCodeMarkerWithComment);
|
|
87
|
-
}
|
|
88
|
-
});
|
|
89
|
-
return lines.join(EOL);
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
public override async *parseAlternateContent(notebookOrUri: NotebookDocument | Uri, inputStream: AsyncIterable<LineOfText>, token: CancellationToken): AsyncIterable<LineOfCellText> {
|
|
94
|
-
const isNotebook = !isUri(notebookOrUri);
|
|
95
|
-
const cellIdMap = isNotebook ? getCellIdMap(notebookOrUri) : new Map<string, NotebookCell>();
|
|
96
|
-
|
|
97
|
-
let inMarkdownCell = false;
|
|
98
|
-
let isInTripleQuotes = false;
|
|
99
|
-
let pendingTripleQuotes = false;
|
|
100
|
-
let emittedStart = false;
|
|
101
|
-
let cellIndex = -1;
|
|
102
|
-
|
|
103
|
-
const lineCommentStart = getLineCommentStart(isNotebook ? notebookOrUri : undefined);
|
|
104
|
-
const blockComment = getBlockComment(isNotebook ? notebookOrUri : undefined);
|
|
105
|
-
const defaultLanguage = isNotebook ? getLanguage(getDefaultLanguage(notebookOrUri)).languageId : undefined;
|
|
106
|
-
const cellIdsSeen = new Set<string>();
|
|
107
|
-
for await (const lineOfText of inputStream) {
|
|
108
|
-
if (token.isCancellationRequested) {
|
|
109
|
-
break;
|
|
110
|
-
}
|
|
111
|
-
const line = lineOfText.value;
|
|
112
|
-
|
|
113
|
-
// Check for new cell delimiter
|
|
114
|
-
// Sometimes LLM returns cells without the `vscode.cell` marker such as .
|
|
115
|
-
const isLineCommentForEmptyCellWithoutCellMarker = line.startsWith(`${lineCommentStart}%% [`) && line.trimEnd().endsWith(']');
|
|
116
|
-
const isLineCommentWithCellMarker = line.startsWith(`${lineCommentStart}%% vscode.cell`);
|
|
117
|
-
// Attempt to extract only if we think we have a cell marker, else we end up doing this for every single line and thats expensive.
|
|
118
|
-
const cellParts = (isLineCommentWithCellMarker || isLineCommentForEmptyCellWithoutCellMarker) ? extractCellParts(line, defaultLanguage) : undefined;
|
|
119
|
-
if ((isLineCommentWithCellMarker || isLineCommentForEmptyCellWithoutCellMarker) && cellParts?.language) {
|
|
120
|
-
if (pendingTripleQuotes) {
|
|
121
|
-
pendingTripleQuotes = false;
|
|
122
|
-
}
|
|
123
|
-
const lineOfCellText: LineOfCellText & { emitted: Boolean } = { index: -1, uri: undefined, language: undefined, kind: NotebookCellKind.Code, emitted: false, type: 'start' };
|
|
124
|
-
lineOfCellText.index = cellIndex += 1;
|
|
125
|
-
lineOfCellText.emitted = false;
|
|
126
|
-
// LLM returns duplicate cell with the same id.
|
|
127
|
-
if (cellParts.id && cellIdMap.get(cellParts.id)?.document.languageId === cellParts.language) {
|
|
128
|
-
if (cellIdsSeen.has(cellParts.id)) {
|
|
129
|
-
cellParts.id = '';
|
|
130
|
-
} else {
|
|
131
|
-
cellIdsSeen.add(cellParts.id);
|
|
132
|
-
}
|
|
133
|
-
} else {
|
|
134
|
-
// Possible duplicate cell with the same id but different language.
|
|
135
|
-
// In such cases, treat them as new cells.
|
|
136
|
-
cellParts.id = '';
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
const cell = cellIdMap.get(cellParts.id);
|
|
140
|
-
lineOfCellText.id = cellParts.id;
|
|
141
|
-
lineOfCellText.language = cellParts.language;
|
|
142
|
-
lineOfCellText.uri = cell?.document.uri;
|
|
143
|
-
lineOfCellText.kind = cell?.kind || (lineOfCellText.language === 'markdown' ? NotebookCellKind.Markup : NotebookCellKind.Code);
|
|
144
|
-
inMarkdownCell = lineOfCellText.language === 'markdown';
|
|
145
|
-
isInTripleQuotes = false;
|
|
146
|
-
|
|
147
|
-
if (emittedStart) {
|
|
148
|
-
yield { index: cellIndex - 1, type: 'end' };
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
emittedStart = true;
|
|
152
|
-
yield lineOfCellText;
|
|
153
|
-
continue;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
if (!emittedStart) {
|
|
157
|
-
continue;
|
|
158
|
-
}
|
|
159
|
-
if (inMarkdownCell) {
|
|
160
|
-
if (!isInTripleQuotes) {
|
|
161
|
-
// Look for the opening triple quotes
|
|
162
|
-
if (line === blockComment[0]) {
|
|
163
|
-
isInTripleQuotes = true;
|
|
164
|
-
} else {
|
|
165
|
-
// lineEmitted = true;
|
|
166
|
-
yield { index: cellIndex, line, type: 'line' };
|
|
167
|
-
}
|
|
168
|
-
} else {
|
|
169
|
-
// We are in triple quotes
|
|
170
|
-
if (line === blockComment[1]) {
|
|
171
|
-
// Closing triple quotes found
|
|
172
|
-
isInTripleQuotes = false;
|
|
173
|
-
pendingTripleQuotes = true;
|
|
174
|
-
} else {
|
|
175
|
-
yield { index: cellIndex, line, type: 'line' };
|
|
176
|
-
}
|
|
177
|
-
}
|
|
178
|
-
} else {
|
|
179
|
-
// Non-markdown cell or default
|
|
180
|
-
yield { index: cellIndex, line, type: 'line' };
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
if (emittedStart) {
|
|
185
|
-
yield { index: cellIndex, type: 'end' };
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
public override getAlternativeDocument(notebook: NotebookDocument, excludeMarkdownCells?: boolean): AlternativeNotebookDocument {
|
|
190
|
-
const cells = notebook.getCells().filter(cell => excludeMarkdownCells ? cell.kind !== NotebookCellKind.Markup : true).map(cell => summarize(cell));
|
|
191
|
-
const blockComment = getBlockComment(notebook);
|
|
192
|
-
const lineCommentStart = getLineCommentStart(notebook);
|
|
193
|
-
const cellContent = cells.map(cell => ({ ...generateAlternativeCellTextContent(cell, lineCommentStart, blockComment), cell: notebook.cellAt(cell.index) }));
|
|
194
|
-
const content = cellContent.map(cell => cell.content).join(EOL);
|
|
195
|
-
const cellOffsetMap = cellContent.map(cellContent => {
|
|
196
|
-
const offset = content.indexOf(cellContent.content);
|
|
197
|
-
const sourceOffset = offset + cellContent.prefix.length;
|
|
198
|
-
return { offset, sourceOffset, cell: notebook.cellAt(cellContent.cell.index) };
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
return new AlternativeTextDocument(content, cellOffsetMap, notebook);
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
function generateAlternativeCellTextContent(cell: SummaryCell, lineCommentStart: string, blockComment: [string, string]): { content: string; prefix: string } {
|
|
207
|
-
const cellMarker = generateCellTextMarker(cell, lineCommentStart);
|
|
208
|
-
const src = cell.source.join(EOL);
|
|
209
|
-
const prefix = cell.language === 'markdown' ? `${cellMarker}${EOL}${blockComment[0]}${EOL}` : `${cellMarker}${EOL}`;
|
|
210
|
-
const content = cell.language === 'markdown'
|
|
211
|
-
? `${prefix}${src}${EOL}${blockComment[1]}`
|
|
212
|
-
: `${prefix}${src}`;
|
|
213
|
-
return { content, prefix };
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
export function getBlockComment(notebook?: NotebookDocument): [string, string] {
|
|
217
|
-
if (!notebook) {
|
|
218
|
-
return ['"""', '"""'];
|
|
219
|
-
}
|
|
220
|
-
const language = getLanguage(getDefaultLanguage(notebook));
|
|
221
|
-
return language.blockComment ?? ['```', '```'];
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
export function getLineCommentStart(notebook?: NotebookDocument): string {
|
|
225
|
-
if (!notebook) {
|
|
226
|
-
return '#';
|
|
227
|
-
}
|
|
228
|
-
const language = getLanguage(getDefaultLanguage(notebook));
|
|
229
|
-
return language.lineComment.start || '#';
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
function extractCellParts(line: string, defaultLanguage: string | undefined): { id: string; language: string } | undefined {
|
|
233
|
-
const idMatch = line.match(/\[id=(.+?)\]/);
|
|
234
|
-
const languageMatch = line.match(/\[language=(.+?)\]/);
|
|
235
|
-
if (!languageMatch) {
|
|
236
|
-
if (lineMightHaveCellMarker(line) && typeof defaultLanguage === 'string') {
|
|
237
|
-
// If we have a cell marker but no language, we assume the default language.
|
|
238
|
-
return { id: idMatch ? idMatch[1].trim() : '', language: defaultLanguage };
|
|
239
|
-
}
|
|
240
|
-
return;
|
|
241
|
-
}
|
|
242
|
-
return { id: idMatch ? idMatch[1].trim() : '', language: languageMatch[1].trim() };
|
|
243
|
-
}
|
|
@@ -1,41 +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 type { CancellationToken, NotebookCell, NotebookDocument } from 'vscode';
|
|
7
|
-
import { Uri } from '../../../util/common/test/shims/vscodeTypesShim';
|
|
8
|
-
import { AlternativeNotebookDocument } from './alternativeNotebookDocument';
|
|
9
|
-
import { LineOfCellText, LineOfText } from './helpers';
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
export abstract class BaseAlternativeNotebookContentProvider {
|
|
13
|
-
constructor(public readonly kind: 'xml' | 'text' | 'json') { }
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Give the code for a cell, strips the cell markers and returns the code.
|
|
17
|
-
* XML and Jupytext formats have cell markers and this allows stripped those markers.
|
|
18
|
-
*/
|
|
19
|
-
public abstract stripCellMarkers(text: string): string;
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Generate the Document of the notebook document that is LLM friendly.
|
|
23
|
-
*/
|
|
24
|
-
public abstract getAlternativeDocument(notebook: NotebookDocument, excludeMarkdownCells?: boolean): AlternativeNotebookDocument;
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Generate the summary of the structure of the notebook document that is LLM friendly.
|
|
28
|
-
* & includes just the cells that are passed in.
|
|
29
|
-
* This is used to help the LLM understand the structure of the notebook, without including the entire code of all cells.
|
|
30
|
-
*/
|
|
31
|
-
public abstract getSummaryOfStructure(notebook: NotebookDocument, cellsToInclude: NotebookCell[], existingCodeMarker: string): string;
|
|
32
|
-
|
|
33
|
-
/**
|
|
34
|
-
* Given the input stream of response parts, parse the response and return an async iterable of lines of text for a given cell.
|
|
35
|
-
* We accept a NotebookDocument or a Uri.
|
|
36
|
-
* This is because its possible the Notebook may not have been created/loaded as of yet.
|
|
37
|
-
* I.e. for new Notebooks, we can emity the Insert Cell Edits without the notebook being created.
|
|
38
|
-
*/
|
|
39
|
-
public abstract parseAlternateContent(notebookOrUri: NotebookDocument | Uri, inputStream: AsyncIterable<LineOfText>, token: CancellationToken): AsyncIterable<LineOfCellText>;
|
|
40
|
-
|
|
41
|
-
}
|