@gguf/coder 0.3.1 → 0.3.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/package.json +2 -2
- package/pnpm-workspace.yaml +15 -0
- package/color_picker.html +0 -36
- package/scripts/extract-changelog.js +0 -73
- package/scripts/fetch-models.js +0 -143
- package/scripts/test.sh +0 -40
- package/scripts/update-homebrew-formula.sh +0 -125
- package/scripts/update-nix-version.sh +0 -157
- package/source/ai-sdk-client/AISDKClient.spec.ts +0 -117
- package/source/ai-sdk-client/AISDKClient.ts +0 -155
- package/source/ai-sdk-client/chat/chat-handler.spec.ts +0 -121
- package/source/ai-sdk-client/chat/chat-handler.ts +0 -276
- package/source/ai-sdk-client/chat/streaming-handler.spec.ts +0 -173
- package/source/ai-sdk-client/chat/streaming-handler.ts +0 -110
- package/source/ai-sdk-client/chat/tool-processor.spec.ts +0 -92
- package/source/ai-sdk-client/chat/tool-processor.ts +0 -70
- package/source/ai-sdk-client/converters/message-converter.spec.ts +0 -220
- package/source/ai-sdk-client/converters/message-converter.ts +0 -113
- package/source/ai-sdk-client/converters/tool-converter.spec.ts +0 -90
- package/source/ai-sdk-client/converters/tool-converter.ts +0 -46
- package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +0 -55
- package/source/ai-sdk-client/error-handling/error-extractor.ts +0 -15
- package/source/ai-sdk-client/error-handling/error-parser.spec.ts +0 -169
- package/source/ai-sdk-client/error-handling/error-parser.ts +0 -161
- package/source/ai-sdk-client/index.ts +0 -7
- package/source/ai-sdk-client/providers/provider-factory.spec.ts +0 -71
- package/source/ai-sdk-client/providers/provider-factory.ts +0 -41
- package/source/ai-sdk-client/types.ts +0 -9
- package/source/ai-sdk-client-empty-message.spec.ts +0 -141
- package/source/ai-sdk-client-error-handling.spec.ts +0 -186
- package/source/ai-sdk-client-maxretries.spec.ts +0 -114
- package/source/ai-sdk-client-preparestep.spec.ts +0 -279
- package/source/app/App.spec.tsx +0 -32
- package/source/app/App.tsx +0 -480
- package/source/app/components/AppContainer.spec.tsx +0 -96
- package/source/app/components/AppContainer.tsx +0 -56
- package/source/app/components/ChatInterface.spec.tsx +0 -163
- package/source/app/components/ChatInterface.tsx +0 -144
- package/source/app/components/ModalSelectors.spec.tsx +0 -141
- package/source/app/components/ModalSelectors.tsx +0 -135
- package/source/app/helpers.spec.ts +0 -97
- package/source/app/helpers.ts +0 -63
- package/source/app/index.ts +0 -4
- package/source/app/types.ts +0 -39
- package/source/app/utils/appUtils.ts +0 -294
- package/source/app/utils/conversationState.ts +0 -310
- package/source/app.spec.tsx +0 -244
- package/source/cli.spec.ts +0 -73
- package/source/cli.tsx +0 -51
- package/source/client-factory.spec.ts +0 -48
- package/source/client-factory.ts +0 -178
- package/source/command-parser.spec.ts +0 -127
- package/source/command-parser.ts +0 -36
- package/source/commands/checkpoint.spec.tsx +0 -277
- package/source/commands/checkpoint.tsx +0 -366
- package/source/commands/clear.tsx +0 -22
- package/source/commands/custom-commands.tsx +0 -121
- package/source/commands/exit.ts +0 -21
- package/source/commands/export.spec.tsx +0 -131
- package/source/commands/export.tsx +0 -79
- package/source/commands/help.tsx +0 -120
- package/source/commands/index.ts +0 -17
- package/source/commands/init.tsx +0 -339
- package/source/commands/lsp-command.spec.tsx +0 -281
- package/source/commands/lsp.tsx +0 -120
- package/source/commands/mcp-command.spec.tsx +0 -313
- package/source/commands/mcp.tsx +0 -162
- package/source/commands/model-database.spec.tsx +0 -758
- package/source/commands/model-database.tsx +0 -418
- package/source/commands/model.ts +0 -12
- package/source/commands/provider.ts +0 -12
- package/source/commands/setup-config.tsx +0 -16
- package/source/commands/simple-commands.spec.tsx +0 -175
- package/source/commands/status.ts +0 -12
- package/source/commands/theme.ts +0 -12
- package/source/commands/update.spec.tsx +0 -261
- package/source/commands/update.tsx +0 -201
- package/source/commands/usage.spec.tsx +0 -495
- package/source/commands/usage.tsx +0 -100
- package/source/commands.spec.ts +0 -436
- package/source/commands.ts +0 -83
- package/source/components/assistant-message.spec.tsx +0 -796
- package/source/components/assistant-message.tsx +0 -34
- package/source/components/bash-execution-indicator.tsx +0 -21
- package/source/components/cancelling-indicator.tsx +0 -16
- package/source/components/chat-queue.spec.tsx +0 -83
- package/source/components/chat-queue.tsx +0 -36
- package/source/components/checkpoint-display.spec.tsx +0 -219
- package/source/components/checkpoint-display.tsx +0 -126
- package/source/components/checkpoint-selector.spec.tsx +0 -173
- package/source/components/checkpoint-selector.tsx +0 -173
- package/source/components/development-mode-indicator.spec.tsx +0 -268
- package/source/components/development-mode-indicator.tsx +0 -38
- package/source/components/message-box.spec.tsx +0 -427
- package/source/components/message-box.tsx +0 -87
- package/source/components/model-selector.tsx +0 -132
- package/source/components/provider-selector.tsx +0 -75
- package/source/components/random-spinner.tsx +0 -19
- package/source/components/security-disclaimer.tsx +0 -73
- package/source/components/status-connection-display.spec.tsx +0 -133
- package/source/components/status.tsx +0 -267
- package/source/components/theme-selector.tsx +0 -126
- package/source/components/tool-confirmation.tsx +0 -190
- package/source/components/tool-execution-indicator.tsx +0 -33
- package/source/components/tool-message.tsx +0 -85
- package/source/components/ui/titled-box.spec.tsx +0 -207
- package/source/components/ui/titled-box.tsx +0 -57
- package/source/components/usage/progress-bar.spec.tsx +0 -398
- package/source/components/usage/progress-bar.tsx +0 -30
- package/source/components/usage/usage-display.spec.tsx +0 -780
- package/source/components/usage/usage-display.tsx +0 -291
- package/source/components/user-input.spec.tsx +0 -327
- package/source/components/user-input.tsx +0 -533
- package/source/components/user-message.spec.tsx +0 -230
- package/source/components/user-message.tsx +0 -84
- package/source/components/welcome-message.tsx +0 -76
- package/source/config/env-substitution.ts +0 -65
- package/source/config/index.spec.ts +0 -171
- package/source/config/index.ts +0 -154
- package/source/config/paths.spec.ts +0 -241
- package/source/config/paths.ts +0 -55
- package/source/config/preferences.ts +0 -51
- package/source/config/themes.ts +0 -315
- package/source/constants.ts +0 -130
- package/source/context/mode-context.spec.ts +0 -79
- package/source/context/mode-context.ts +0 -24
- package/source/custom-commands/executor.spec.ts +0 -142
- package/source/custom-commands/executor.ts +0 -64
- package/source/custom-commands/loader.spec.ts +0 -314
- package/source/custom-commands/loader.ts +0 -153
- package/source/custom-commands/parser.ts +0 -196
- package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +0 -39
- package/source/hooks/chat-handler/conversation/conversation-loop.tsx +0 -511
- package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +0 -50
- package/source/hooks/chat-handler/conversation/tool-executor.tsx +0 -109
- package/source/hooks/chat-handler/index.ts +0 -12
- package/source/hooks/chat-handler/state/streaming-state.spec.ts +0 -26
- package/source/hooks/chat-handler/state/streaming-state.ts +0 -19
- package/source/hooks/chat-handler/types.ts +0 -38
- package/source/hooks/chat-handler/useChatHandler.spec.tsx +0 -321
- package/source/hooks/chat-handler/useChatHandler.tsx +0 -194
- package/source/hooks/chat-handler/utils/context-checker.spec.ts +0 -60
- package/source/hooks/chat-handler/utils/context-checker.tsx +0 -73
- package/source/hooks/chat-handler/utils/message-helpers.spec.ts +0 -42
- package/source/hooks/chat-handler/utils/message-helpers.tsx +0 -36
- package/source/hooks/chat-handler/utils/tool-filters.spec.ts +0 -109
- package/source/hooks/chat-handler/utils/tool-filters.ts +0 -64
- package/source/hooks/useAppHandlers.tsx +0 -291
- package/source/hooks/useAppInitialization.tsx +0 -422
- package/source/hooks/useAppState.tsx +0 -311
- package/source/hooks/useDirectoryTrust.tsx +0 -98
- package/source/hooks/useInputState.ts +0 -414
- package/source/hooks/useModeHandlers.tsx +0 -302
- package/source/hooks/useNonInteractiveMode.ts +0 -140
- package/source/hooks/useTerminalWidth.tsx +0 -81
- package/source/hooks/useTheme.ts +0 -18
- package/source/hooks/useToolHandler.tsx +0 -349
- package/source/hooks/useUIState.ts +0 -61
- package/source/init/agents-template-generator.ts +0 -421
- package/source/init/existing-rules-extractor.ts +0 -319
- package/source/init/file-scanner.spec.ts +0 -227
- package/source/init/file-scanner.ts +0 -238
- package/source/init/framework-detector.ts +0 -382
- package/source/init/language-detector.ts +0 -269
- package/source/init/project-analyzer.spec.ts +0 -231
- package/source/init/project-analyzer.ts +0 -458
- package/source/lsp/index.ts +0 -31
- package/source/lsp/lsp-client.spec.ts +0 -508
- package/source/lsp/lsp-client.ts +0 -487
- package/source/lsp/lsp-manager.spec.ts +0 -477
- package/source/lsp/lsp-manager.ts +0 -419
- package/source/lsp/protocol.spec.ts +0 -502
- package/source/lsp/protocol.ts +0 -360
- package/source/lsp/server-discovery.spec.ts +0 -654
- package/source/lsp/server-discovery.ts +0 -515
- package/source/markdown-parser/html-entities.spec.ts +0 -88
- package/source/markdown-parser/html-entities.ts +0 -45
- package/source/markdown-parser/index.spec.ts +0 -281
- package/source/markdown-parser/index.ts +0 -126
- package/source/markdown-parser/table-parser.spec.ts +0 -133
- package/source/markdown-parser/table-parser.ts +0 -114
- package/source/markdown-parser/utils.spec.ts +0 -70
- package/source/markdown-parser/utils.ts +0 -13
- package/source/mcp/mcp-client.spec.ts +0 -81
- package/source/mcp/mcp-client.ts +0 -625
- package/source/mcp/transport-factory.spec.ts +0 -406
- package/source/mcp/transport-factory.ts +0 -312
- package/source/message-handler.ts +0 -67
- package/source/model-database/database-engine.spec.ts +0 -494
- package/source/model-database/database-engine.ts +0 -50
- package/source/model-database/model-database.spec.ts +0 -363
- package/source/model-database/model-database.ts +0 -91
- package/source/model-database/model-engine.spec.ts +0 -447
- package/source/model-database/model-engine.ts +0 -65
- package/source/model-database/model-fetcher.spec.ts +0 -583
- package/source/model-database/model-fetcher.ts +0 -330
- package/source/models/index.ts +0 -1
- package/source/models/models-cache.spec.ts +0 -214
- package/source/models/models-cache.ts +0 -78
- package/source/models/models-dev-client.spec.ts +0 -379
- package/source/models/models-dev-client.ts +0 -329
- package/source/models/models-types.ts +0 -68
- package/source/prompt-history.ts +0 -155
- package/source/security/command-injection.spec.ts +0 -240
- package/source/services/checkpoint-manager.spec.ts +0 -523
- package/source/services/checkpoint-manager.ts +0 -466
- package/source/services/file-snapshot.spec.ts +0 -569
- package/source/services/file-snapshot.ts +0 -220
- package/source/test-utils/render-with-theme.tsx +0 -48
- package/source/tokenization/index.ts +0 -1
- package/source/tokenization/tokenizer-factory.spec.ts +0 -170
- package/source/tokenization/tokenizer-factory.ts +0 -125
- package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +0 -200
- package/source/tokenization/tokenizers/anthropic-tokenizer.ts +0 -43
- package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +0 -236
- package/source/tokenization/tokenizers/fallback-tokenizer.ts +0 -26
- package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +0 -224
- package/source/tokenization/tokenizers/llama-tokenizer.ts +0 -41
- package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +0 -184
- package/source/tokenization/tokenizers/openai-tokenizer.ts +0 -57
- package/source/tool-calling/index.ts +0 -5
- package/source/tool-calling/json-parser.spec.ts +0 -639
- package/source/tool-calling/json-parser.ts +0 -247
- package/source/tool-calling/tool-parser.spec.ts +0 -395
- package/source/tool-calling/tool-parser.ts +0 -120
- package/source/tool-calling/xml-parser.spec.ts +0 -662
- package/source/tool-calling/xml-parser.ts +0 -289
- package/source/tools/execute-bash.spec.tsx +0 -353
- package/source/tools/execute-bash.tsx +0 -219
- package/source/tools/execute-function.spec.ts +0 -130
- package/source/tools/fetch-url.spec.tsx +0 -342
- package/source/tools/fetch-url.tsx +0 -172
- package/source/tools/find-files.spec.tsx +0 -924
- package/source/tools/find-files.tsx +0 -293
- package/source/tools/index.ts +0 -102
- package/source/tools/lsp-get-diagnostics.tsx +0 -192
- package/source/tools/needs-approval.spec.ts +0 -282
- package/source/tools/read-file.spec.tsx +0 -801
- package/source/tools/read-file.tsx +0 -387
- package/source/tools/search-file-contents.spec.tsx +0 -1273
- package/source/tools/search-file-contents.tsx +0 -293
- package/source/tools/string-replace.spec.tsx +0 -730
- package/source/tools/string-replace.tsx +0 -548
- package/source/tools/tool-manager.ts +0 -210
- package/source/tools/tool-registry.spec.ts +0 -415
- package/source/tools/tool-registry.ts +0 -228
- package/source/tools/web-search.tsx +0 -223
- package/source/tools/write-file.spec.tsx +0 -559
- package/source/tools/write-file.tsx +0 -228
- package/source/types/app.ts +0 -37
- package/source/types/checkpoint.ts +0 -48
- package/source/types/commands.ts +0 -46
- package/source/types/components.ts +0 -27
- package/source/types/config.ts +0 -103
- package/source/types/core-connection-status.spec.ts +0 -67
- package/source/types/core.ts +0 -181
- package/source/types/hooks.ts +0 -50
- package/source/types/index.ts +0 -12
- package/source/types/markdown-parser.ts +0 -11
- package/source/types/mcp.ts +0 -52
- package/source/types/system.ts +0 -16
- package/source/types/tokenization.ts +0 -41
- package/source/types/ui.ts +0 -40
- package/source/types/usage.ts +0 -58
- package/source/types/utils.ts +0 -16
- package/source/usage/calculator.spec.ts +0 -385
- package/source/usage/calculator.ts +0 -104
- package/source/usage/storage.spec.ts +0 -703
- package/source/usage/storage.ts +0 -238
- package/source/usage/tracker.spec.ts +0 -456
- package/source/usage/tracker.ts +0 -102
- package/source/utils/atomic-deletion.spec.ts +0 -194
- package/source/utils/atomic-deletion.ts +0 -127
- package/source/utils/bounded-map.spec.ts +0 -300
- package/source/utils/bounded-map.ts +0 -193
- package/source/utils/checkpoint-utils.spec.ts +0 -222
- package/source/utils/checkpoint-utils.ts +0 -92
- package/source/utils/error-formatter.spec.ts +0 -169
- package/source/utils/error-formatter.ts +0 -194
- package/source/utils/file-autocomplete.spec.ts +0 -173
- package/source/utils/file-autocomplete.ts +0 -196
- package/source/utils/file-cache.spec.ts +0 -309
- package/source/utils/file-cache.ts +0 -195
- package/source/utils/file-content-loader.spec.ts +0 -180
- package/source/utils/file-content-loader.ts +0 -179
- package/source/utils/file-mention-handler.spec.ts +0 -261
- package/source/utils/file-mention-handler.ts +0 -84
- package/source/utils/file-mention-parser.spec.ts +0 -182
- package/source/utils/file-mention-parser.ts +0 -170
- package/source/utils/fuzzy-matching.spec.ts +0 -149
- package/source/utils/fuzzy-matching.ts +0 -146
- package/source/utils/indentation-normalizer.spec.ts +0 -216
- package/source/utils/indentation-normalizer.ts +0 -76
- package/source/utils/installation-detector.spec.ts +0 -178
- package/source/utils/installation-detector.ts +0 -153
- package/source/utils/logging/config.spec.ts +0 -311
- package/source/utils/logging/config.ts +0 -210
- package/source/utils/logging/console-facade.spec.ts +0 -184
- package/source/utils/logging/console-facade.ts +0 -384
- package/source/utils/logging/correlation.spec.ts +0 -679
- package/source/utils/logging/correlation.ts +0 -474
- package/source/utils/logging/formatters.spec.ts +0 -464
- package/source/utils/logging/formatters.ts +0 -207
- package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +0 -93
- package/source/utils/logging/health-monitor/alerts/alert-manager.ts +0 -79
- package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/configuration-check.ts +0 -43
- package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/logging-check.ts +0 -58
- package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +0 -100
- package/source/utils/logging/health-monitor/checks/memory-check.ts +0 -78
- package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/performance-check.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.spec.ts +0 -56
- package/source/utils/logging/health-monitor/checks/request-check.ts +0 -76
- package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +0 -70
- package/source/utils/logging/health-monitor/core/health-check-runner.ts +0 -138
- package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +0 -58
- package/source/utils/logging/health-monitor/core/health-monitor.ts +0 -344
- package/source/utils/logging/health-monitor/core/scoring.spec.ts +0 -65
- package/source/utils/logging/health-monitor/core/scoring.ts +0 -91
- package/source/utils/logging/health-monitor/index.ts +0 -15
- package/source/utils/logging/health-monitor/instances.ts +0 -48
- package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +0 -141
- package/source/utils/logging/health-monitor/middleware/http-middleware.ts +0 -75
- package/source/utils/logging/health-monitor/types.ts +0 -126
- package/source/utils/logging/index.spec.ts +0 -284
- package/source/utils/logging/index.ts +0 -236
- package/source/utils/logging/integration.spec.ts +0 -441
- package/source/utils/logging/log-method-factory.spec.ts +0 -573
- package/source/utils/logging/log-method-factory.ts +0 -233
- package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +0 -277
- package/source/utils/logging/log-query/aggregation/aggregator.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +0 -159
- package/source/utils/logging/log-query/aggregation/facet-generator.ts +0 -47
- package/source/utils/logging/log-query/index.ts +0 -23
- package/source/utils/logging/log-query/query/filter-predicates.spec.ts +0 -247
- package/source/utils/logging/log-query/query/filter-predicates.ts +0 -154
- package/source/utils/logging/log-query/query/query-builder.spec.ts +0 -182
- package/source/utils/logging/log-query/query/query-builder.ts +0 -151
- package/source/utils/logging/log-query/query/query-engine.spec.ts +0 -214
- package/source/utils/logging/log-query/query/query-engine.ts +0 -45
- package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +0 -143
- package/source/utils/logging/log-query/storage/circular-buffer.ts +0 -75
- package/source/utils/logging/log-query/storage/index-manager.spec.ts +0 -150
- package/source/utils/logging/log-query/storage/index-manager.ts +0 -71
- package/source/utils/logging/log-query/storage/log-storage.spec.ts +0 -257
- package/source/utils/logging/log-query/storage/log-storage.ts +0 -80
- package/source/utils/logging/log-query/types.ts +0 -163
- package/source/utils/logging/log-query/utils/helpers.spec.ts +0 -263
- package/source/utils/logging/log-query/utils/helpers.ts +0 -72
- package/source/utils/logging/log-query/utils/sorting.spec.ts +0 -182
- package/source/utils/logging/log-query/utils/sorting.ts +0 -61
- package/source/utils/logging/logger-provider.spec.ts +0 -262
- package/source/utils/logging/logger-provider.ts +0 -362
- package/source/utils/logging/performance.spec.ts +0 -209
- package/source/utils/logging/performance.ts +0 -757
- package/source/utils/logging/pino-logger.spec.ts +0 -425
- package/source/utils/logging/pino-logger.ts +0 -514
- package/source/utils/logging/redaction.spec.ts +0 -490
- package/source/utils/logging/redaction.ts +0 -267
- package/source/utils/logging/request-tracker.spec.ts +0 -1198
- package/source/utils/logging/request-tracker.ts +0 -803
- package/source/utils/logging/transports.spec.ts +0 -505
- package/source/utils/logging/transports.ts +0 -305
- package/source/utils/logging/types.ts +0 -216
- package/source/utils/message-builder.spec.ts +0 -179
- package/source/utils/message-builder.ts +0 -101
- package/source/utils/message-queue.tsx +0 -486
- package/source/utils/paste-detection.spec.ts +0 -69
- package/source/utils/paste-detection.ts +0 -124
- package/source/utils/paste-roundtrip.spec.ts +0 -442
- package/source/utils/paste-utils.spec.ts +0 -128
- package/source/utils/paste-utils.ts +0 -52
- package/source/utils/programming-language-helper.spec.ts +0 -74
- package/source/utils/programming-language-helper.ts +0 -32
- package/source/utils/prompt-assembly.spec.ts +0 -221
- package/source/utils/prompt-processor.ts +0 -173
- package/source/utils/tool-args-parser.spec.ts +0 -136
- package/source/utils/tool-args-parser.ts +0 -54
- package/source/utils/tool-cancellation.spec.ts +0 -230
- package/source/utils/tool-cancellation.ts +0 -28
- package/source/utils/tool-result-display.spec.tsx +0 -469
- package/source/utils/tool-result-display.tsx +0 -90
- package/source/utils/update-checker.spec.ts +0 -383
- package/source/utils/update-checker.ts +0 -183
- package/source/wizard/config-wizard.spec.tsx +0 -103
- package/source/wizard/config-wizard.tsx +0 -382
- package/source/wizard/steps/location-step.spec.tsx +0 -186
- package/source/wizard/steps/location-step.tsx +0 -147
- package/source/wizard/steps/mcp-step.spec.tsx +0 -607
- package/source/wizard/steps/mcp-step.tsx +0 -632
- package/source/wizard/steps/provider-step.spec.tsx +0 -342
- package/source/wizard/steps/provider-step.tsx +0 -957
- package/source/wizard/steps/summary-step.spec.tsx +0 -749
- package/source/wizard/steps/summary-step.tsx +0 -228
- package/source/wizard/templates/mcp-templates.spec.ts +0 -613
- package/source/wizard/templates/mcp-templates.ts +0 -570
- package/source/wizard/templates/provider-templates.spec.ts +0 -152
- package/source/wizard/templates/provider-templates.ts +0 -485
- package/source/wizard/utils/fetch-cloud-models.spec.ts +0 -428
- package/source/wizard/utils/fetch-cloud-models.ts +0 -223
- package/source/wizard/utils/fetch-local-models.spec.ts +0 -297
- package/source/wizard/utils/fetch-local-models.ts +0 -192
- package/source/wizard/validation-array.spec.ts +0 -264
- package/source/wizard/validation.spec.ts +0 -373
- package/source/wizard/validation.ts +0 -232
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
// CLI Paste Detection Utilities
|
|
2
|
-
// Since CLI applications don't receive direct paste events, we use heuristics
|
|
3
|
-
|
|
4
|
-
interface PasteDetectionOptions {
|
|
5
|
-
// Time threshold for rapid input (milliseconds)
|
|
6
|
-
timeThreshold: number;
|
|
7
|
-
// Character count threshold for single input change
|
|
8
|
-
charThreshold: number;
|
|
9
|
-
// Line count threshold for multi-line detection
|
|
10
|
-
lineThreshold: number;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
const DEFAULT_PASTE_OPTIONS: PasteDetectionOptions = {
|
|
14
|
-
timeThreshold: 50, // Increased to 50ms to be more forgiving of fast typing
|
|
15
|
-
charThreshold: 5, // Lower threshold - detect pastes of 5+ chars (size method needs 10+ chars)
|
|
16
|
-
lineThreshold: 2, // Multiple lines added instantly
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
export class PasteDetector {
|
|
20
|
-
private lastInputTime = 0;
|
|
21
|
-
private lastInputLength = 0;
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Detect if a text change is likely a paste operation
|
|
25
|
-
* @param newText The new text content
|
|
26
|
-
* @param options Detection thresholds
|
|
27
|
-
* @returns Object with detection result and details
|
|
28
|
-
*/
|
|
29
|
-
detectPaste(
|
|
30
|
-
newText: string,
|
|
31
|
-
options: PasteDetectionOptions = DEFAULT_PASTE_OPTIONS,
|
|
32
|
-
): {
|
|
33
|
-
isPaste: boolean;
|
|
34
|
-
method: 'rate' | 'size' | 'lines' | 'none';
|
|
35
|
-
addedText: string;
|
|
36
|
-
details: {
|
|
37
|
-
timeElapsed: number;
|
|
38
|
-
charsAdded: number;
|
|
39
|
-
linesAdded: number;
|
|
40
|
-
};
|
|
41
|
-
} {
|
|
42
|
-
const currentTime = Date.now();
|
|
43
|
-
const timeElapsed = currentTime - this.lastInputTime;
|
|
44
|
-
const charsAdded = newText.length - this.lastInputLength;
|
|
45
|
-
|
|
46
|
-
// Calculate lines added in THIS change, not total lines in text
|
|
47
|
-
const previousLineCount =
|
|
48
|
-
this.lastInputLength > 0
|
|
49
|
-
? newText.slice(0, this.lastInputLength).split('\n').length
|
|
50
|
-
: 1;
|
|
51
|
-
const currentLineCount = newText.split('\n').length;
|
|
52
|
-
const linesAdded = currentLineCount - previousLineCount;
|
|
53
|
-
|
|
54
|
-
// Get the added text (assuming it's at the end)
|
|
55
|
-
const addedText = newText.slice(this.lastInputLength);
|
|
56
|
-
|
|
57
|
-
// Update tracking
|
|
58
|
-
this.lastInputTime = currentTime;
|
|
59
|
-
this.lastInputLength = newText.length;
|
|
60
|
-
|
|
61
|
-
const details = {
|
|
62
|
-
timeElapsed,
|
|
63
|
-
charsAdded,
|
|
64
|
-
linesAdded,
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
// Method 1: Rate-based detection (fast input)
|
|
68
|
-
if (
|
|
69
|
-
timeElapsed < options.timeThreshold &&
|
|
70
|
-
charsAdded > options.charThreshold
|
|
71
|
-
) {
|
|
72
|
-
return {
|
|
73
|
-
isPaste: true,
|
|
74
|
-
method: 'rate',
|
|
75
|
-
addedText,
|
|
76
|
-
details,
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
// Method 2: Size-based detection (large single input)
|
|
81
|
-
if (charsAdded > options.charThreshold * 2) {
|
|
82
|
-
return {
|
|
83
|
-
isPaste: true,
|
|
84
|
-
method: 'size',
|
|
85
|
-
addedText,
|
|
86
|
-
details,
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
// Method 3: Multi-line detection
|
|
91
|
-
if (linesAdded >= options.lineThreshold) {
|
|
92
|
-
return {
|
|
93
|
-
isPaste: true,
|
|
94
|
-
method: 'lines',
|
|
95
|
-
addedText,
|
|
96
|
-
details,
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return {
|
|
101
|
-
isPaste: false,
|
|
102
|
-
method: 'none',
|
|
103
|
-
addedText,
|
|
104
|
-
details,
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* Reset the detector state (call when input is cleared or submitted)
|
|
110
|
-
*/
|
|
111
|
-
reset(): void {
|
|
112
|
-
this.lastInputTime = 0;
|
|
113
|
-
this.lastInputLength = 0;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* Update detector state without triggering detection
|
|
118
|
-
* Useful for manual input changes that shouldn't be considered pastes
|
|
119
|
-
*/
|
|
120
|
-
updateState(text: string): void {
|
|
121
|
-
this.lastInputTime = Date.now();
|
|
122
|
-
this.lastInputLength = text.length;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
@@ -1,442 +0,0 @@
|
|
|
1
|
-
import test from 'ava';
|
|
2
|
-
import type {
|
|
3
|
-
InputState,
|
|
4
|
-
PastePlaceholderContent,
|
|
5
|
-
PlaceholderContent,
|
|
6
|
-
} from '../types/hooks';
|
|
7
|
-
import {PlaceholderType} from '../types/hooks';
|
|
8
|
-
|
|
9
|
-
console.log(`\npaste-roundtrip.spec.ts`);
|
|
10
|
-
|
|
11
|
-
// Self-contained implementations for integration testing
|
|
12
|
-
class PasteDetector {
|
|
13
|
-
private lastInput = '';
|
|
14
|
-
private lastTimestamp = 0;
|
|
15
|
-
|
|
16
|
-
detectPaste(newInput: string): {
|
|
17
|
-
isPaste: boolean;
|
|
18
|
-
addedText: string;
|
|
19
|
-
method?: string;
|
|
20
|
-
} {
|
|
21
|
-
const now = Date.now();
|
|
22
|
-
const deltaTime = now - this.lastTimestamp;
|
|
23
|
-
const addedText = newInput.slice(this.lastInput.length);
|
|
24
|
-
|
|
25
|
-
// Update state for next call
|
|
26
|
-
const result = {
|
|
27
|
-
isPaste: false,
|
|
28
|
-
addedText,
|
|
29
|
-
method: undefined as string | undefined,
|
|
30
|
-
};
|
|
31
|
-
|
|
32
|
-
// Rate-based detection: >50 chars in <16ms
|
|
33
|
-
if (addedText.length > 50 && deltaTime < 16) {
|
|
34
|
-
result.isPaste = true;
|
|
35
|
-
result.method = 'rate';
|
|
36
|
-
}
|
|
37
|
-
// Size-based detection: >100 chars at once
|
|
38
|
-
else if (addedText.length > 100) {
|
|
39
|
-
result.isPaste = true;
|
|
40
|
-
result.method = 'size';
|
|
41
|
-
}
|
|
42
|
-
// Multi-line detection: >=2 lines
|
|
43
|
-
else if (addedText.split(/\r\n|\r|\n/).length >= 2) {
|
|
44
|
-
result.isPaste = true;
|
|
45
|
-
result.method = 'multiline';
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
this.lastInput = newInput;
|
|
49
|
-
this.lastTimestamp = now;
|
|
50
|
-
|
|
51
|
-
return result;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
reset() {
|
|
55
|
-
this.lastInput = '';
|
|
56
|
-
this.lastTimestamp = 0;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
updateState(newInput: string) {
|
|
60
|
-
this.lastInput = newInput;
|
|
61
|
-
this.lastTimestamp = Date.now();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
function handlePaste(
|
|
66
|
-
pastedText: string,
|
|
67
|
-
currentDisplayValue: string,
|
|
68
|
-
currentPlaceholderContent: Record<string, PlaceholderContent>,
|
|
69
|
-
): InputState | null {
|
|
70
|
-
// Only create placeholder for large pastes (>80 chars)
|
|
71
|
-
if (pastedText.length <= 80) {
|
|
72
|
-
return null; // Small paste, insert as normal text
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// Generate simple incrementing ID based on existing paste placeholders
|
|
76
|
-
const existingPasteCount = Object.values(currentPlaceholderContent).filter(
|
|
77
|
-
content => content.type === PlaceholderType.PASTE,
|
|
78
|
-
).length;
|
|
79
|
-
const pasteId = (existingPasteCount + 1).toString();
|
|
80
|
-
const placeholder = `[Paste #${pasteId}: ${pastedText.length} chars]`;
|
|
81
|
-
|
|
82
|
-
const pasteContent: PastePlaceholderContent = {
|
|
83
|
-
type: PlaceholderType.PASTE,
|
|
84
|
-
displayText: placeholder,
|
|
85
|
-
content: pastedText,
|
|
86
|
-
originalSize: pastedText.length,
|
|
87
|
-
timestamp: Date.now(),
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
const newPlaceholderContent = {
|
|
91
|
-
...currentPlaceholderContent,
|
|
92
|
-
[pasteId]: pasteContent,
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
// For CLI paste detection, we need to replace the pasted text in the display value
|
|
96
|
-
// If the pasted text is at the end, replace it. Otherwise append the placeholder.
|
|
97
|
-
const newDisplayValue = currentDisplayValue.includes(pastedText)
|
|
98
|
-
? currentDisplayValue.replace(pastedText, placeholder)
|
|
99
|
-
: currentDisplayValue + placeholder;
|
|
100
|
-
|
|
101
|
-
return {
|
|
102
|
-
displayValue: newDisplayValue,
|
|
103
|
-
placeholderContent: newPlaceholderContent,
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
function assemblePrompt(inputState: InputState): string {
|
|
108
|
-
let assembledPrompt = inputState.displayValue;
|
|
109
|
-
|
|
110
|
-
Object.entries(inputState.placeholderContent).forEach(
|
|
111
|
-
([pasteId, placeholderContent]) => {
|
|
112
|
-
if (placeholderContent.type === 'paste') {
|
|
113
|
-
const pasteContent = placeholderContent as PastePlaceholderContent;
|
|
114
|
-
assembledPrompt = assembledPrompt.replace(
|
|
115
|
-
pasteContent.displayText,
|
|
116
|
-
pasteContent.content,
|
|
117
|
-
);
|
|
118
|
-
}
|
|
119
|
-
},
|
|
120
|
-
);
|
|
121
|
-
|
|
122
|
-
return assembledPrompt;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
function handleAtomicDeletion(
|
|
126
|
-
previousState: InputState,
|
|
127
|
-
newText: string,
|
|
128
|
-
): InputState | null {
|
|
129
|
-
const previousText = previousState.displayValue;
|
|
130
|
-
|
|
131
|
-
// Only handle deletions (text getting shorter)
|
|
132
|
-
if (newText.length >= previousText.length) {
|
|
133
|
-
return null;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
// Find what was deleted
|
|
137
|
-
const deletedChars = previousText.length - newText.length;
|
|
138
|
-
|
|
139
|
-
// Find where the deletion occurred
|
|
140
|
-
let deletionStart = -1;
|
|
141
|
-
for (let i = 0; i < Math.min(previousText.length, newText.length); i++) {
|
|
142
|
-
if (previousText[i] !== newText[i]) {
|
|
143
|
-
deletionStart = i;
|
|
144
|
-
break;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
// If no difference found in common part, deletion was at the end
|
|
149
|
-
if (deletionStart === -1) {
|
|
150
|
-
deletionStart = newText.length;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
// Check if any placeholder was affected by this deletion
|
|
154
|
-
const placeholderRegex = /\[Paste #(\d+): \d+ chars\]/g;
|
|
155
|
-
let match;
|
|
156
|
-
|
|
157
|
-
while ((match = placeholderRegex.exec(previousText)) !== null) {
|
|
158
|
-
const placeholderStart = match.index;
|
|
159
|
-
const placeholderEnd = placeholderStart + match[0].length;
|
|
160
|
-
const placeholderId = match[1];
|
|
161
|
-
|
|
162
|
-
// Check if deletion overlaps with this placeholder
|
|
163
|
-
const deletionEnd = deletionStart + deletedChars;
|
|
164
|
-
|
|
165
|
-
if (
|
|
166
|
-
(deletionStart >= placeholderStart && deletionStart < placeholderEnd) ||
|
|
167
|
-
(deletionEnd > placeholderStart && deletionEnd <= placeholderEnd) ||
|
|
168
|
-
(deletionStart <= placeholderStart && deletionEnd >= placeholderEnd)
|
|
169
|
-
) {
|
|
170
|
-
// Deletion affects this placeholder - remove it atomically
|
|
171
|
-
const newDisplayValue = previousText.replace(match[0], '');
|
|
172
|
-
const newPlaceholderContent = {...previousState.placeholderContent};
|
|
173
|
-
delete newPlaceholderContent[placeholderId];
|
|
174
|
-
|
|
175
|
-
return {
|
|
176
|
-
displayValue: newDisplayValue,
|
|
177
|
-
placeholderContent: newPlaceholderContent,
|
|
178
|
-
};
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
return null;
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
// Full round-trip integration test for paste handling system
|
|
186
|
-
test('complete paste handling round-trip workflow', t => {
|
|
187
|
-
// Step 1: Simulate user typing some text
|
|
188
|
-
let currentState: InputState = {
|
|
189
|
-
displayValue: 'Analyze this code: ',
|
|
190
|
-
placeholderContent: {},
|
|
191
|
-
};
|
|
192
|
-
|
|
193
|
-
// Step 2: Simulate a large paste being detected
|
|
194
|
-
const detector = new PasteDetector();
|
|
195
|
-
// Initialize detector with current state
|
|
196
|
-
detector.updateState(currentState.displayValue);
|
|
197
|
-
|
|
198
|
-
const largeCodeSnippet = `function fibonacci(n) {
|
|
199
|
-
if (n <= 1) return n;
|
|
200
|
-
return fibonacci(n - 1) + fibonacci(n - 2);
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
const result = fibonacci(10);
|
|
204
|
-
console.log('Fibonacci result:', result);
|
|
205
|
-
|
|
206
|
-
// Additional complex logic
|
|
207
|
-
class Calculator {
|
|
208
|
-
constructor() {
|
|
209
|
-
this.history = [];
|
|
210
|
-
this.operations = ['add', 'subtract', 'multiply', 'divide'];
|
|
211
|
-
this.precision = 2;
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
add(a, b) {
|
|
215
|
-
const result = a + b;
|
|
216
|
-
this.history.push(\`\${a} + \${b} = \${result}\`);
|
|
217
|
-
return result;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
subtract(a, b) {
|
|
221
|
-
const result = a - b;
|
|
222
|
-
this.history.push(\`\${a} - \${b} = \${result}\`);
|
|
223
|
-
return result;
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
multiply(a, b) {
|
|
227
|
-
const result = a * b;
|
|
228
|
-
this.history.push(\`\${a} * \${b} = \${result}\`);
|
|
229
|
-
return result;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
divide(a, b) {
|
|
233
|
-
if (b === 0) throw new Error('Division by zero');
|
|
234
|
-
const result = a / b;
|
|
235
|
-
this.history.push(\`\${a} / \${b} = \${result}\`);
|
|
236
|
-
return result;
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
getHistory() {
|
|
240
|
-
return this.history.slice();
|
|
241
|
-
}
|
|
242
|
-
|
|
243
|
-
clearHistory() {
|
|
244
|
-
this.history = [];
|
|
245
|
-
}
|
|
246
|
-
}`;
|
|
247
|
-
|
|
248
|
-
// Simulate paste detection
|
|
249
|
-
const newInputWithPaste = currentState.displayValue + largeCodeSnippet;
|
|
250
|
-
const detection = detector.detectPaste(newInputWithPaste);
|
|
251
|
-
|
|
252
|
-
// Verify paste was detected
|
|
253
|
-
t.true(detection.isPaste);
|
|
254
|
-
// Method could be 'rate' or 'size' depending on timing - both are valid for large pastes
|
|
255
|
-
|
|
256
|
-
// Step 3: Handle the paste by creating placeholder
|
|
257
|
-
const pasteResult = handlePaste(
|
|
258
|
-
detection.addedText,
|
|
259
|
-
currentState.displayValue,
|
|
260
|
-
currentState.placeholderContent,
|
|
261
|
-
);
|
|
262
|
-
|
|
263
|
-
t.truthy(pasteResult);
|
|
264
|
-
currentState = pasteResult!;
|
|
265
|
-
|
|
266
|
-
// Verify placeholder was created correctly
|
|
267
|
-
t.true(currentState.displayValue.includes('[Paste #'));
|
|
268
|
-
t.true(currentState.displayValue.includes('chars]'));
|
|
269
|
-
|
|
270
|
-
// Debug: Check actual vs expected length
|
|
271
|
-
const pasteId = Object.keys(currentState.placeholderContent)[0];
|
|
272
|
-
const pasteContent = currentState.placeholderContent[
|
|
273
|
-
pasteId
|
|
274
|
-
] as PastePlaceholderContent;
|
|
275
|
-
const actualLength = pasteContent.content.length;
|
|
276
|
-
|
|
277
|
-
// Use the actual length from the stored content
|
|
278
|
-
t.is(
|
|
279
|
-
currentState.displayValue,
|
|
280
|
-
`Analyze this code: [Paste #${pasteId}: ${actualLength} chars]`,
|
|
281
|
-
);
|
|
282
|
-
|
|
283
|
-
// Verify full content is preserved
|
|
284
|
-
t.is(pasteContent.content, largeCodeSnippet);
|
|
285
|
-
|
|
286
|
-
// Step 4: Simulate adding more text after the paste
|
|
287
|
-
currentState = {
|
|
288
|
-
displayValue: currentState.displayValue + ' and explain the algorithm',
|
|
289
|
-
placeholderContent: currentState.placeholderContent,
|
|
290
|
-
};
|
|
291
|
-
|
|
292
|
-
// Step 5: Simulate a second paste in the same command
|
|
293
|
-
const secondSnippet = 'const testData = [1, 2, 3, 4, 5];';
|
|
294
|
-
const secondPasteResult = handlePaste(
|
|
295
|
-
secondSnippet,
|
|
296
|
-
currentState.displayValue,
|
|
297
|
-
currentState.placeholderContent,
|
|
298
|
-
);
|
|
299
|
-
|
|
300
|
-
// Second paste is small, should return null (inserted as plain text)
|
|
301
|
-
t.is(secondPasteResult, null);
|
|
302
|
-
|
|
303
|
-
// Add the small paste manually (simulating normal insertion)
|
|
304
|
-
currentState = {
|
|
305
|
-
displayValue: currentState.displayValue + ' Compare with: ' + secondSnippet,
|
|
306
|
-
placeholderContent: currentState.placeholderContent,
|
|
307
|
-
};
|
|
308
|
-
|
|
309
|
-
// Step 6: Test atomic deletion - simulate user deleting part of the first placeholder
|
|
310
|
-
// Create a text where we delete from inside the placeholder (simulating backspace)
|
|
311
|
-
const fullPlaceholder = `[Paste #${pasteId}: ${actualLength} chars]`;
|
|
312
|
-
const placeholderIndex = currentState.displayValue.indexOf(fullPlaceholder);
|
|
313
|
-
// Delete 2 characters from the middle of the placeholder (remove "te" from "Paste")
|
|
314
|
-
const partiallyDeletedText =
|
|
315
|
-
currentState.displayValue.slice(0, placeholderIndex + 4) + // "[Pas"
|
|
316
|
-
currentState.displayValue.slice(placeholderIndex + 6); // skip "te", continue from " #..."
|
|
317
|
-
const atomicDeletionResult = handleAtomicDeletion(
|
|
318
|
-
currentState,
|
|
319
|
-
partiallyDeletedText,
|
|
320
|
-
);
|
|
321
|
-
|
|
322
|
-
t.truthy(atomicDeletionResult);
|
|
323
|
-
|
|
324
|
-
// After atomic deletion, placeholder and content should be gone
|
|
325
|
-
t.false(atomicDeletionResult!.displayValue.includes('[Paste #'));
|
|
326
|
-
t.deepEqual(atomicDeletionResult!.placeholderContent, {});
|
|
327
|
-
|
|
328
|
-
// Step 7: Restore state and test prompt assembly for submission
|
|
329
|
-
// (Simulate the state before deletion for final assembly test)
|
|
330
|
-
const finalState: InputState = {
|
|
331
|
-
displayValue: `Analyze this code: [Paste #${pasteId}: ${actualLength} chars] and explain the algorithm Compare with: ${secondSnippet}`,
|
|
332
|
-
placeholderContent: {
|
|
333
|
-
[pasteId]: {
|
|
334
|
-
type: PlaceholderType.PASTE,
|
|
335
|
-
displayText: `[Paste #${pasteId}: ${actualLength} chars]`,
|
|
336
|
-
content: largeCodeSnippet,
|
|
337
|
-
originalSize: actualLength,
|
|
338
|
-
} as PastePlaceholderContent,
|
|
339
|
-
},
|
|
340
|
-
};
|
|
341
|
-
|
|
342
|
-
// Step 8: Test prompt assembly (what gets sent to AI)
|
|
343
|
-
const assembledPrompt = assemblePrompt(finalState);
|
|
344
|
-
|
|
345
|
-
// Verify placeholders are replaced with full content
|
|
346
|
-
t.false(assembledPrompt.includes('[Paste #'));
|
|
347
|
-
t.true(assembledPrompt.includes('function fibonacci(n)'));
|
|
348
|
-
t.true(assembledPrompt.includes('class Calculator'));
|
|
349
|
-
t.true(assembledPrompt.includes('and explain the algorithm'));
|
|
350
|
-
t.true(assembledPrompt.includes('Compare with: const testData'));
|
|
351
|
-
|
|
352
|
-
// Verify complete reconstruction
|
|
353
|
-
const expectedFinalPrompt = `Analyze this code: ${largeCodeSnippet} and explain the algorithm Compare with: ${secondSnippet}`;
|
|
354
|
-
t.is(assembledPrompt, expectedFinalPrompt);
|
|
355
|
-
|
|
356
|
-
// Step 9: Test history preservation (what gets saved)
|
|
357
|
-
// Verify that the InputState can be serialized and deserialized
|
|
358
|
-
const serialized = JSON.stringify(finalState);
|
|
359
|
-
const deserialized: InputState = JSON.parse(serialized);
|
|
360
|
-
|
|
361
|
-
t.deepEqual(deserialized, finalState);
|
|
362
|
-
t.is(assemblePrompt(deserialized), expectedFinalPrompt);
|
|
363
|
-
});
|
|
364
|
-
|
|
365
|
-
// Test multiple placeholders in single command
|
|
366
|
-
test('multiple placeholders in single command workflow', t => {
|
|
367
|
-
const detector = new PasteDetector();
|
|
368
|
-
let currentState: InputState = {
|
|
369
|
-
displayValue: 'Compare ',
|
|
370
|
-
placeholderContent: {},
|
|
371
|
-
};
|
|
372
|
-
|
|
373
|
-
// First large paste - simulate by creating full input
|
|
374
|
-
const firstCode = 'x'.repeat(600); // Large enough to trigger placeholder
|
|
375
|
-
const firstFullInput = currentState.displayValue + firstCode;
|
|
376
|
-
const firstDetection = detector.detectPaste(firstFullInput);
|
|
377
|
-
t.true(firstDetection.isPaste);
|
|
378
|
-
|
|
379
|
-
const firstPasteResult = handlePaste(
|
|
380
|
-
firstCode, // Pass the actual pasted code, not the added text which includes existing text
|
|
381
|
-
currentState.displayValue,
|
|
382
|
-
currentState.placeholderContent,
|
|
383
|
-
);
|
|
384
|
-
t.truthy(firstPasteResult);
|
|
385
|
-
currentState = firstPasteResult!;
|
|
386
|
-
|
|
387
|
-
// Add text between pastes
|
|
388
|
-
currentState = {
|
|
389
|
-
displayValue: currentState.displayValue + ' with ',
|
|
390
|
-
placeholderContent: currentState.placeholderContent,
|
|
391
|
-
};
|
|
392
|
-
|
|
393
|
-
// Update detector state to current state
|
|
394
|
-
detector.updateState(currentState.displayValue);
|
|
395
|
-
|
|
396
|
-
// Second large paste - simulate by creating new full input
|
|
397
|
-
const secondCode = 'y'.repeat(700);
|
|
398
|
-
const secondFullInput = currentState.displayValue + secondCode;
|
|
399
|
-
const secondDetection = detector.detectPaste(secondFullInput);
|
|
400
|
-
t.true(secondDetection.isPaste);
|
|
401
|
-
|
|
402
|
-
const secondPasteResult = handlePaste(
|
|
403
|
-
secondCode, // Pass the actual pasted code, not the added text
|
|
404
|
-
currentState.displayValue,
|
|
405
|
-
currentState.placeholderContent,
|
|
406
|
-
);
|
|
407
|
-
t.truthy(secondPasteResult);
|
|
408
|
-
currentState = secondPasteResult!;
|
|
409
|
-
|
|
410
|
-
// Verify two placeholders exist
|
|
411
|
-
const placeholderMatches = currentState.displayValue.match(
|
|
412
|
-
/\[Paste #\d+: \d+ chars\]/g,
|
|
413
|
-
);
|
|
414
|
-
t.is(placeholderMatches?.length, 2);
|
|
415
|
-
|
|
416
|
-
// Verify both pieces of content are preserved
|
|
417
|
-
t.is(Object.keys(currentState.placeholderContent).length, 2);
|
|
418
|
-
|
|
419
|
-
// Test assembly replaces both placeholders
|
|
420
|
-
const assembled = assemblePrompt(currentState);
|
|
421
|
-
t.false(assembled.includes('[Paste #'));
|
|
422
|
-
t.true(assembled.includes(firstCode));
|
|
423
|
-
t.true(assembled.includes(secondCode));
|
|
424
|
-
t.is(assembled, `Compare ${firstCode} with ${secondCode}`);
|
|
425
|
-
});
|
|
426
|
-
|
|
427
|
-
// Test edge cases and error conditions
|
|
428
|
-
test('paste handling edge cases', t => {
|
|
429
|
-
// Test with empty state
|
|
430
|
-
const emptyState: InputState = {displayValue: '', placeholderContent: {}};
|
|
431
|
-
const assembled = assemblePrompt(emptyState);
|
|
432
|
-
t.is(assembled, '');
|
|
433
|
-
|
|
434
|
-
// Test with placeholder but missing content (error recovery)
|
|
435
|
-
const corruptState: InputState = {
|
|
436
|
-
displayValue: 'Test [Paste #123: 100 chars] here',
|
|
437
|
-
placeholderContent: {}, // Missing content for placeholder
|
|
438
|
-
};
|
|
439
|
-
const assembledCorrupt = assemblePrompt(corruptState);
|
|
440
|
-
// Should leave placeholder intact if content is missing
|
|
441
|
-
t.true(assembledCorrupt.includes('[Paste #123: 100 chars]'));
|
|
442
|
-
});
|
|
@@ -1,128 +0,0 @@
|
|
|
1
|
-
import type {PastePlaceholderContent, PlaceholderContent} from '@/types/hooks';
|
|
2
|
-
import {PlaceholderType} from '@/types/hooks';
|
|
3
|
-
import test from 'ava';
|
|
4
|
-
import {handlePaste} from './paste-utils';
|
|
5
|
-
|
|
6
|
-
// Tests for handlePaste utility function
|
|
7
|
-
// Validates paste handling logic and placeholder creation
|
|
8
|
-
|
|
9
|
-
console.log(`\npaste-utils.spec.ts`);
|
|
10
|
-
|
|
11
|
-
test('handlePaste returns null for empty pastes', t => {
|
|
12
|
-
const pastedText = '';
|
|
13
|
-
const currentDisplayValue = 'existing content';
|
|
14
|
-
const currentPlaceholderContent: Record<string, PlaceholderContent> = {};
|
|
15
|
-
|
|
16
|
-
const result = handlePaste(
|
|
17
|
-
pastedText,
|
|
18
|
-
currentDisplayValue,
|
|
19
|
-
currentPlaceholderContent,
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
t.is(result, null);
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
test('handlePaste creates placeholder for small pastes', t => {
|
|
26
|
-
const pastedText = 'small text';
|
|
27
|
-
const currentDisplayValue = 'existing content';
|
|
28
|
-
const currentPlaceholderContent: Record<string, PlaceholderContent> = {};
|
|
29
|
-
|
|
30
|
-
const result = handlePaste(
|
|
31
|
-
pastedText,
|
|
32
|
-
currentDisplayValue,
|
|
33
|
-
currentPlaceholderContent,
|
|
34
|
-
);
|
|
35
|
-
|
|
36
|
-
t.truthy(result);
|
|
37
|
-
t.is(typeof result!.displayValue, 'string');
|
|
38
|
-
t.true(result!.displayValue.includes('[Paste #'));
|
|
39
|
-
t.true(result!.displayValue.includes('10 chars]'));
|
|
40
|
-
|
|
41
|
-
// Should contain the pasted content in the map
|
|
42
|
-
const pasteIds = Object.keys(result!.placeholderContent);
|
|
43
|
-
t.is(pasteIds.length, 1);
|
|
44
|
-
const pasteContent = result!.placeholderContent[
|
|
45
|
-
pasteIds[0]
|
|
46
|
-
] as PastePlaceholderContent;
|
|
47
|
-
t.is(pasteContent.content, pastedText);
|
|
48
|
-
t.is(pasteContent.type, PlaceholderType.PASTE);
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
test('handlePaste creates placeholder for large pastes', t => {
|
|
52
|
-
const pastedText = 'a'.repeat(600);
|
|
53
|
-
const currentDisplayValue = 'existing content';
|
|
54
|
-
const currentPlaceholderContent: Record<string, PlaceholderContent> = {};
|
|
55
|
-
|
|
56
|
-
const result = handlePaste(
|
|
57
|
-
pastedText,
|
|
58
|
-
currentDisplayValue,
|
|
59
|
-
currentPlaceholderContent,
|
|
60
|
-
);
|
|
61
|
-
|
|
62
|
-
t.truthy(result);
|
|
63
|
-
t.is(typeof result!.displayValue, 'string');
|
|
64
|
-
t.true(result!.displayValue.includes('[Paste #'));
|
|
65
|
-
t.true(result!.displayValue.includes('600 chars]'));
|
|
66
|
-
|
|
67
|
-
// Should contain the pasted content in the map
|
|
68
|
-
const pasteIds = Object.keys(result!.placeholderContent);
|
|
69
|
-
t.is(pasteIds.length, 1);
|
|
70
|
-
const pasteContent = result!.placeholderContent[
|
|
71
|
-
pasteIds[0]
|
|
72
|
-
] as PastePlaceholderContent;
|
|
73
|
-
t.is(pasteContent.content, pastedText);
|
|
74
|
-
t.is(pasteContent.type, PlaceholderType.PASTE);
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
test('handlePaste replaces pasted text with placeholder in display value', t => {
|
|
78
|
-
const pastedText = 'x'.repeat(700);
|
|
79
|
-
const currentDisplayValue = `prefix ${pastedText} suffix`;
|
|
80
|
-
const currentPlaceholderContent: Record<string, PlaceholderContent> = {};
|
|
81
|
-
|
|
82
|
-
const result = handlePaste(
|
|
83
|
-
pastedText,
|
|
84
|
-
currentDisplayValue,
|
|
85
|
-
currentPlaceholderContent,
|
|
86
|
-
);
|
|
87
|
-
|
|
88
|
-
t.truthy(result);
|
|
89
|
-
t.true(result!.displayValue.startsWith('prefix [Paste #'));
|
|
90
|
-
t.true(result!.displayValue.endsWith('700 chars] suffix'));
|
|
91
|
-
t.false(result!.displayValue.includes('x'.repeat(10))); // Original text should be gone
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
test('handlePaste preserves existing pasted content', t => {
|
|
95
|
-
const existingPlaceholderContent: Record<string, PlaceholderContent> = {
|
|
96
|
-
'123': {
|
|
97
|
-
type: PlaceholderType.PASTE,
|
|
98
|
-
displayText: '[Paste #123: 24 chars]',
|
|
99
|
-
content: 'previous paste content',
|
|
100
|
-
originalSize: 24,
|
|
101
|
-
} as PastePlaceholderContent,
|
|
102
|
-
};
|
|
103
|
-
const pastedText = 'b'.repeat(800);
|
|
104
|
-
const currentDisplayValue = 'some text';
|
|
105
|
-
|
|
106
|
-
const result = handlePaste(
|
|
107
|
-
pastedText,
|
|
108
|
-
currentDisplayValue,
|
|
109
|
-
existingPlaceholderContent,
|
|
110
|
-
);
|
|
111
|
-
|
|
112
|
-
t.truthy(result);
|
|
113
|
-
t.is(Object.keys(result!.placeholderContent).length, 2);
|
|
114
|
-
const existingContent = result!.placeholderContent[
|
|
115
|
-
'123'
|
|
116
|
-
] as PastePlaceholderContent;
|
|
117
|
-
t.is(existingContent.content, 'previous paste content');
|
|
118
|
-
|
|
119
|
-
// Find the new paste ID
|
|
120
|
-
const newPasteId = Object.keys(result!.placeholderContent).find(
|
|
121
|
-
id => id !== '123',
|
|
122
|
-
);
|
|
123
|
-
t.truthy(newPasteId);
|
|
124
|
-
const newContent = result!.placeholderContent[
|
|
125
|
-
newPasteId!
|
|
126
|
-
] as PastePlaceholderContent;
|
|
127
|
-
t.is(newContent.content, pastedText);
|
|
128
|
-
});
|