@shareai-lab/kode 1.1.14 → 1.1.16-dev.1
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/cli.js +77 -82
- package/dist/entrypoints/cli.js +59 -38
- package/dist/entrypoints/cli.js.map +3 -3
- package/dist/index.js +5 -26
- package/dist/package.json +4 -1
- package/package.json +11 -104
- package/dist/test/testAdapters.js +0 -88
- package/dist/test/testAdapters.js.map +0 -1
- package/src/ProjectOnboarding.tsx +0 -198
- package/src/Tool.ts +0 -83
- package/src/commands/agents.tsx +0 -3416
- package/src/commands/approvedTools.ts +0 -53
- package/src/commands/bug.tsx +0 -20
- package/src/commands/clear.ts +0 -43
- package/src/commands/compact.ts +0 -120
- package/src/commands/config.tsx +0 -19
- package/src/commands/cost.ts +0 -18
- package/src/commands/ctx_viz.ts +0 -209
- package/src/commands/doctor.ts +0 -24
- package/src/commands/help.tsx +0 -19
- package/src/commands/init.ts +0 -37
- package/src/commands/listen.ts +0 -42
- package/src/commands/login.tsx +0 -51
- package/src/commands/logout.tsx +0 -40
- package/src/commands/mcp.ts +0 -41
- package/src/commands/model.tsx +0 -40
- package/src/commands/modelstatus.tsx +0 -20
- package/src/commands/onboarding.tsx +0 -34
- package/src/commands/pr_comments.ts +0 -59
- package/src/commands/refreshCommands.ts +0 -54
- package/src/commands/release-notes.ts +0 -34
- package/src/commands/resume.tsx +0 -31
- package/src/commands/review.ts +0 -49
- package/src/commands/terminalSetup.ts +0 -221
- package/src/commands.ts +0 -139
- package/src/components/ApproveApiKey.tsx +0 -93
- package/src/components/AsciiLogo.tsx +0 -13
- package/src/components/AutoUpdater.tsx +0 -148
- package/src/components/Bug.tsx +0 -367
- package/src/components/Config.tsx +0 -293
- package/src/components/ConsoleOAuthFlow.tsx +0 -327
- package/src/components/Cost.tsx +0 -23
- package/src/components/CostThresholdDialog.tsx +0 -46
- package/src/components/CustomSelect/option-map.ts +0 -42
- package/src/components/CustomSelect/select-option.tsx +0 -78
- package/src/components/CustomSelect/select.tsx +0 -152
- package/src/components/CustomSelect/theme.ts +0 -45
- package/src/components/CustomSelect/use-select-state.ts +0 -414
- package/src/components/CustomSelect/use-select.ts +0 -35
- package/src/components/FallbackToolUseRejectedMessage.tsx +0 -15
- package/src/components/FileEditToolUpdatedMessage.tsx +0 -66
- package/src/components/Help.tsx +0 -215
- package/src/components/HighlightedCode.tsx +0 -33
- package/src/components/InvalidConfigDialog.tsx +0 -113
- package/src/components/Link.tsx +0 -32
- package/src/components/LogSelector.tsx +0 -86
- package/src/components/Logo.tsx +0 -170
- package/src/components/MCPServerApprovalDialog.tsx +0 -100
- package/src/components/MCPServerDialogCopy.tsx +0 -25
- package/src/components/MCPServerMultiselectDialog.tsx +0 -109
- package/src/components/Message.tsx +0 -221
- package/src/components/MessageResponse.tsx +0 -15
- package/src/components/MessageSelector.tsx +0 -211
- package/src/components/ModeIndicator.tsx +0 -88
- package/src/components/ModelConfig.tsx +0 -301
- package/src/components/ModelListManager.tsx +0 -227
- package/src/components/ModelSelector.tsx +0 -3387
- package/src/components/ModelStatusDisplay.tsx +0 -230
- package/src/components/Onboarding.tsx +0 -274
- package/src/components/PressEnterToContinue.tsx +0 -11
- package/src/components/PromptInput.tsx +0 -760
- package/src/components/SentryErrorBoundary.ts +0 -39
- package/src/components/Spinner.tsx +0 -129
- package/src/components/StickerRequestForm.tsx +0 -16
- package/src/components/StructuredDiff.tsx +0 -191
- package/src/components/TextInput.tsx +0 -259
- package/src/components/TodoItem.tsx +0 -47
- package/src/components/TokenWarning.tsx +0 -31
- package/src/components/ToolUseLoader.tsx +0 -40
- package/src/components/TrustDialog.tsx +0 -106
- package/src/components/binary-feedback/BinaryFeedback.tsx +0 -63
- package/src/components/binary-feedback/BinaryFeedbackOption.tsx +0 -111
- package/src/components/binary-feedback/BinaryFeedbackView.tsx +0 -172
- package/src/components/binary-feedback/utils.ts +0 -220
- package/src/components/messages/AssistantBashOutputMessage.tsx +0 -22
- package/src/components/messages/AssistantLocalCommandOutputMessage.tsx +0 -49
- package/src/components/messages/AssistantRedactedThinkingMessage.tsx +0 -19
- package/src/components/messages/AssistantTextMessage.tsx +0 -144
- package/src/components/messages/AssistantThinkingMessage.tsx +0 -40
- package/src/components/messages/AssistantToolUseMessage.tsx +0 -132
- package/src/components/messages/TaskProgressMessage.tsx +0 -32
- package/src/components/messages/TaskToolMessage.tsx +0 -58
- package/src/components/messages/UserBashInputMessage.tsx +0 -28
- package/src/components/messages/UserCommandMessage.tsx +0 -30
- package/src/components/messages/UserKodingInputMessage.tsx +0 -28
- package/src/components/messages/UserPromptMessage.tsx +0 -35
- package/src/components/messages/UserTextMessage.tsx +0 -39
- package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +0 -12
- package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +0 -36
- package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +0 -31
- package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +0 -57
- package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +0 -35
- package/src/components/messages/UserToolResultMessage/utils.tsx +0 -56
- package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +0 -121
- package/src/components/permissions/FallbackPermissionRequest.tsx +0 -153
- package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +0 -182
- package/src/components/permissions/FileEditPermissionRequest/FileEditToolDiff.tsx +0 -77
- package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +0 -164
- package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +0 -83
- package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +0 -240
- package/src/components/permissions/PermissionRequest.tsx +0 -101
- package/src/components/permissions/PermissionRequestTitle.tsx +0 -69
- package/src/components/permissions/hooks.ts +0 -44
- package/src/components/permissions/toolUseOptions.ts +0 -59
- package/src/components/permissions/utils.ts +0 -23
- package/src/constants/betas.ts +0 -5
- package/src/constants/claude-asterisk-ascii-art.tsx +0 -238
- package/src/constants/figures.ts +0 -4
- package/src/constants/keys.ts +0 -3
- package/src/constants/macros.ts +0 -11
- package/src/constants/modelCapabilities.ts +0 -179
- package/src/constants/models.ts +0 -1025
- package/src/constants/oauth.ts +0 -18
- package/src/constants/product.ts +0 -17
- package/src/constants/prompts.ts +0 -168
- package/src/constants/releaseNotes.ts +0 -7
- package/src/context/PermissionContext.tsx +0 -149
- package/src/context.ts +0 -278
- package/src/cost-tracker.ts +0 -84
- package/src/entrypoints/cli.tsx +0 -1561
- package/src/entrypoints/mcp.ts +0 -175
- package/src/history.ts +0 -25
- package/src/hooks/useApiKeyVerification.ts +0 -59
- package/src/hooks/useArrowKeyHistory.ts +0 -55
- package/src/hooks/useCanUseTool.ts +0 -138
- package/src/hooks/useCancelRequest.ts +0 -39
- package/src/hooks/useDoublePress.ts +0 -41
- package/src/hooks/useExitOnCtrlCD.ts +0 -31
- package/src/hooks/useInterval.ts +0 -25
- package/src/hooks/useLogMessages.ts +0 -16
- package/src/hooks/useLogStartupTime.ts +0 -12
- package/src/hooks/useNotifyAfterTimeout.ts +0 -65
- package/src/hooks/usePermissionRequestLogging.ts +0 -44
- package/src/hooks/useTerminalSize.ts +0 -49
- package/src/hooks/useTextInput.ts +0 -317
- package/src/hooks/useUnifiedCompletion.ts +0 -1405
- package/src/index.ts +0 -34
- package/src/messages.ts +0 -38
- package/src/permissions.ts +0 -268
- package/src/query.ts +0 -720
- package/src/screens/ConfigureNpmPrefix.tsx +0 -197
- package/src/screens/Doctor.tsx +0 -219
- package/src/screens/LogList.tsx +0 -68
- package/src/screens/REPL.tsx +0 -813
- package/src/screens/ResumeConversation.tsx +0 -68
- package/src/services/adapters/base.ts +0 -38
- package/src/services/adapters/chatCompletions.ts +0 -90
- package/src/services/adapters/responsesAPI.ts +0 -170
- package/src/services/browserMocks.ts +0 -66
- package/src/services/claude.ts +0 -2197
- package/src/services/customCommands.ts +0 -704
- package/src/services/fileFreshness.ts +0 -377
- package/src/services/gpt5ConnectionTest.ts +0 -340
- package/src/services/mcpClient.ts +0 -564
- package/src/services/mcpServerApproval.tsx +0 -50
- package/src/services/mentionProcessor.ts +0 -273
- package/src/services/modelAdapterFactory.ts +0 -69
- package/src/services/notifier.ts +0 -40
- package/src/services/oauth.ts +0 -357
- package/src/services/openai.ts +0 -1359
- package/src/services/responseStateManager.ts +0 -90
- package/src/services/sentry.ts +0 -3
- package/src/services/statsig.ts +0 -172
- package/src/services/statsigStorage.ts +0 -86
- package/src/services/systemReminder.ts +0 -507
- package/src/services/vcr.ts +0 -161
- package/src/test/testAdapters.ts +0 -96
- package/src/tools/ArchitectTool/ArchitectTool.tsx +0 -135
- package/src/tools/ArchitectTool/prompt.ts +0 -15
- package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +0 -576
- package/src/tools/BashTool/BashTool.tsx +0 -243
- package/src/tools/BashTool/BashToolResultMessage.tsx +0 -38
- package/src/tools/BashTool/OutputLine.tsx +0 -49
- package/src/tools/BashTool/prompt.ts +0 -174
- package/src/tools/BashTool/utils.ts +0 -56
- package/src/tools/FileEditTool/FileEditTool.tsx +0 -319
- package/src/tools/FileEditTool/prompt.ts +0 -51
- package/src/tools/FileEditTool/utils.ts +0 -58
- package/src/tools/FileReadTool/FileReadTool.tsx +0 -404
- package/src/tools/FileReadTool/prompt.ts +0 -7
- package/src/tools/FileWriteTool/FileWriteTool.tsx +0 -301
- package/src/tools/FileWriteTool/prompt.ts +0 -10
- package/src/tools/GlobTool/GlobTool.tsx +0 -119
- package/src/tools/GlobTool/prompt.ts +0 -8
- package/src/tools/GrepTool/GrepTool.tsx +0 -147
- package/src/tools/GrepTool/prompt.ts +0 -11
- package/src/tools/MCPTool/MCPTool.tsx +0 -107
- package/src/tools/MCPTool/prompt.ts +0 -3
- package/src/tools/MemoryReadTool/MemoryReadTool.tsx +0 -127
- package/src/tools/MemoryReadTool/prompt.ts +0 -3
- package/src/tools/MemoryWriteTool/MemoryWriteTool.tsx +0 -89
- package/src/tools/MemoryWriteTool/prompt.ts +0 -3
- package/src/tools/MultiEditTool/MultiEditTool.tsx +0 -388
- package/src/tools/MultiEditTool/prompt.ts +0 -45
- package/src/tools/NotebookEditTool/NotebookEditTool.tsx +0 -298
- package/src/tools/NotebookEditTool/prompt.ts +0 -3
- package/src/tools/NotebookReadTool/NotebookReadTool.tsx +0 -258
- package/src/tools/NotebookReadTool/prompt.ts +0 -3
- package/src/tools/StickerRequestTool/StickerRequestTool.tsx +0 -107
- package/src/tools/StickerRequestTool/prompt.ts +0 -19
- package/src/tools/TaskTool/TaskTool.tsx +0 -438
- package/src/tools/TaskTool/constants.ts +0 -1
- package/src/tools/TaskTool/prompt.ts +0 -92
- package/src/tools/ThinkTool/ThinkTool.tsx +0 -54
- package/src/tools/ThinkTool/prompt.ts +0 -12
- package/src/tools/TodoWriteTool/TodoWriteTool.tsx +0 -313
- package/src/tools/TodoWriteTool/prompt.ts +0 -63
- package/src/tools/URLFetcherTool/URLFetcherTool.tsx +0 -178
- package/src/tools/URLFetcherTool/cache.ts +0 -55
- package/src/tools/URLFetcherTool/htmlToMarkdown.ts +0 -55
- package/src/tools/URLFetcherTool/prompt.ts +0 -17
- package/src/tools/WebSearchTool/WebSearchTool.tsx +0 -103
- package/src/tools/WebSearchTool/prompt.ts +0 -13
- package/src/tools/WebSearchTool/searchProviders.ts +0 -66
- package/src/tools/lsTool/lsTool.tsx +0 -272
- package/src/tools/lsTool/prompt.ts +0 -2
- package/src/tools.ts +0 -67
- package/src/types/PermissionMode.ts +0 -120
- package/src/types/RequestContext.ts +0 -72
- package/src/types/common.d.ts +0 -2
- package/src/types/conversation.ts +0 -51
- package/src/types/logs.ts +0 -58
- package/src/types/modelCapabilities.ts +0 -64
- package/src/types/notebook.ts +0 -87
- package/src/utils/Cursor.ts +0 -436
- package/src/utils/PersistentShell.ts +0 -552
- package/src/utils/advancedFuzzyMatcher.ts +0 -290
- package/src/utils/agentLoader.ts +0 -278
- package/src/utils/agentStorage.ts +0 -97
- package/src/utils/array.ts +0 -3
- package/src/utils/ask.tsx +0 -99
- package/src/utils/auth.ts +0 -13
- package/src/utils/autoCompactCore.ts +0 -223
- package/src/utils/autoUpdater.ts +0 -458
- package/src/utils/betas.ts +0 -20
- package/src/utils/browser.ts +0 -14
- package/src/utils/cleanup.ts +0 -72
- package/src/utils/commands.ts +0 -261
- package/src/utils/commonUnixCommands.ts +0 -161
- package/src/utils/config.ts +0 -945
- package/src/utils/conversationRecovery.ts +0 -55
- package/src/utils/debugLogger.ts +0 -1235
- package/src/utils/diff.ts +0 -42
- package/src/utils/env.ts +0 -57
- package/src/utils/errors.ts +0 -21
- package/src/utils/exampleCommands.ts +0 -109
- package/src/utils/execFileNoThrow.ts +0 -51
- package/src/utils/expertChatStorage.ts +0 -136
- package/src/utils/file.ts +0 -405
- package/src/utils/fileRecoveryCore.ts +0 -71
- package/src/utils/format.tsx +0 -44
- package/src/utils/fuzzyMatcher.ts +0 -328
- package/src/utils/generators.ts +0 -62
- package/src/utils/git.ts +0 -92
- package/src/utils/globalLogger.ts +0 -77
- package/src/utils/http.ts +0 -10
- package/src/utils/imagePaste.ts +0 -38
- package/src/utils/json.ts +0 -13
- package/src/utils/log.ts +0 -382
- package/src/utils/markdown.ts +0 -213
- package/src/utils/messageContextManager.ts +0 -294
- package/src/utils/messages.tsx +0 -945
- package/src/utils/model.ts +0 -914
- package/src/utils/permissions/filesystem.ts +0 -127
- package/src/utils/responseState.ts +0 -23
- package/src/utils/ripgrep.ts +0 -167
- package/src/utils/secureFile.ts +0 -564
- package/src/utils/sessionState.ts +0 -49
- package/src/utils/state.ts +0 -25
- package/src/utils/style.ts +0 -29
- package/src/utils/terminal.ts +0 -50
- package/src/utils/theme.ts +0 -127
- package/src/utils/thinking.ts +0 -144
- package/src/utils/todoStorage.ts +0 -431
- package/src/utils/tokens.ts +0 -43
- package/src/utils/toolExecutionController.ts +0 -163
- package/src/utils/unaryLogging.ts +0 -26
- package/src/utils/user.ts +0 -37
- package/src/utils/validate.ts +0 -165
package/src/utils/diff.ts
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { type Hunk, structuredPatch } from 'diff'
|
|
2
|
-
|
|
3
|
-
const CONTEXT_LINES = 3
|
|
4
|
-
|
|
5
|
-
// For some reason, & confuses the diff library, so we replace it with a token,
|
|
6
|
-
// then substitute it back in after the diff is computed.
|
|
7
|
-
const AMPERSAND_TOKEN = '<<:AMPERSAND_TOKEN:>>'
|
|
8
|
-
|
|
9
|
-
const DOLLAR_TOKEN = '<<:DOLLAR_TOKEN:>>'
|
|
10
|
-
|
|
11
|
-
export function getPatch({
|
|
12
|
-
filePath,
|
|
13
|
-
fileContents,
|
|
14
|
-
oldStr,
|
|
15
|
-
newStr,
|
|
16
|
-
}: {
|
|
17
|
-
filePath: string
|
|
18
|
-
fileContents: string
|
|
19
|
-
oldStr: string
|
|
20
|
-
newStr: string
|
|
21
|
-
}): Hunk[] {
|
|
22
|
-
return structuredPatch(
|
|
23
|
-
filePath,
|
|
24
|
-
filePath,
|
|
25
|
-
fileContents.replaceAll('&', AMPERSAND_TOKEN).replaceAll('$', DOLLAR_TOKEN),
|
|
26
|
-
fileContents
|
|
27
|
-
.replaceAll('&', AMPERSAND_TOKEN)
|
|
28
|
-
.replaceAll('$', DOLLAR_TOKEN)
|
|
29
|
-
.replace(
|
|
30
|
-
oldStr.replaceAll('&', AMPERSAND_TOKEN).replaceAll('$', DOLLAR_TOKEN),
|
|
31
|
-
newStr.replaceAll('&', AMPERSAND_TOKEN).replaceAll('$', DOLLAR_TOKEN),
|
|
32
|
-
),
|
|
33
|
-
undefined,
|
|
34
|
-
undefined,
|
|
35
|
-
{ context: CONTEXT_LINES },
|
|
36
|
-
).hunks.map(_ => ({
|
|
37
|
-
..._,
|
|
38
|
-
lines: _.lines.map(_ =>
|
|
39
|
-
_.replaceAll(AMPERSAND_TOKEN, '&').replaceAll(DOLLAR_TOKEN, '$'),
|
|
40
|
-
),
|
|
41
|
-
}))
|
|
42
|
-
}
|
package/src/utils/env.ts
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { execFileNoThrow } from './execFileNoThrow'
|
|
2
|
-
import { memoize } from 'lodash-es'
|
|
3
|
-
import { join } from 'path'
|
|
4
|
-
import { homedir } from 'os'
|
|
5
|
-
import { CONFIG_BASE_DIR, CONFIG_FILE } from '../constants/product'
|
|
6
|
-
// Base directory for all Any kode data files (except config.json for backwards compatibility)
|
|
7
|
-
// Support both KODE_CONFIG_DIR and CLAUDE_CONFIG_DIR for compatibility
|
|
8
|
-
export const CLAUDE_BASE_DIR =
|
|
9
|
-
process.env.KODE_CONFIG_DIR ?? process.env.CLAUDE_CONFIG_DIR ?? join(homedir(), CONFIG_BASE_DIR)
|
|
10
|
-
|
|
11
|
-
// Config and data paths
|
|
12
|
-
// Support both KODE_CONFIG_DIR and CLAUDE_CONFIG_DIR environment variables
|
|
13
|
-
export const GLOBAL_CLAUDE_FILE = (process.env.KODE_CONFIG_DIR || process.env.CLAUDE_CONFIG_DIR)
|
|
14
|
-
? join(CLAUDE_BASE_DIR, 'config.json')
|
|
15
|
-
: join(homedir(), CONFIG_FILE)
|
|
16
|
-
export const MEMORY_DIR = join(CLAUDE_BASE_DIR, 'memory')
|
|
17
|
-
|
|
18
|
-
const getIsDocker = memoize(async (): Promise<boolean> => {
|
|
19
|
-
// Check for .dockerenv file
|
|
20
|
-
const { code } = await execFileNoThrow('test', ['-f', '/.dockerenv'])
|
|
21
|
-
if (code !== 0) {
|
|
22
|
-
return false
|
|
23
|
-
}
|
|
24
|
-
return process.platform === 'linux'
|
|
25
|
-
})
|
|
26
|
-
|
|
27
|
-
const hasInternetAccess = memoize(async (): Promise<boolean> => {
|
|
28
|
-
try {
|
|
29
|
-
const controller = new AbortController()
|
|
30
|
-
const timeout = setTimeout(() => controller.abort(), 1000)
|
|
31
|
-
|
|
32
|
-
await fetch('http://1.1.1.1', {
|
|
33
|
-
method: 'HEAD',
|
|
34
|
-
signal: controller.signal,
|
|
35
|
-
})
|
|
36
|
-
|
|
37
|
-
clearTimeout(timeout)
|
|
38
|
-
return true
|
|
39
|
-
} catch {
|
|
40
|
-
return false
|
|
41
|
-
}
|
|
42
|
-
})
|
|
43
|
-
|
|
44
|
-
// all of these should be immutable
|
|
45
|
-
export const env = {
|
|
46
|
-
getIsDocker,
|
|
47
|
-
hasInternetAccess,
|
|
48
|
-
isCI: Boolean(process.env.CI),
|
|
49
|
-
platform:
|
|
50
|
-
process.platform === 'win32'
|
|
51
|
-
? 'windows'
|
|
52
|
-
: process.platform === 'darwin'
|
|
53
|
-
? 'macos'
|
|
54
|
-
: 'linux',
|
|
55
|
-
nodeVersion: process.version,
|
|
56
|
-
terminal: process.env.TERM_PROGRAM,
|
|
57
|
-
}
|
package/src/utils/errors.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
export class MalformedCommandError extends TypeError {}
|
|
2
|
-
|
|
3
|
-
export class DeprecatedCommandError extends Error {}
|
|
4
|
-
|
|
5
|
-
export class AbortError extends Error {}
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Custom error class for configuration file parsing errors
|
|
9
|
-
* Includes the file path and the default configuration that should be used
|
|
10
|
-
*/
|
|
11
|
-
export class ConfigParseError extends Error {
|
|
12
|
-
filePath: string
|
|
13
|
-
defaultConfig: unknown
|
|
14
|
-
|
|
15
|
-
constructor(message: string, filePath: string, defaultConfig: unknown) {
|
|
16
|
-
super(message)
|
|
17
|
-
this.name = 'ConfigParseError'
|
|
18
|
-
this.filePath = filePath
|
|
19
|
-
this.defaultConfig = defaultConfig
|
|
20
|
-
}
|
|
21
|
-
}
|
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
getGlobalConfig,
|
|
3
|
-
saveGlobalConfig,
|
|
4
|
-
getCurrentProjectConfig,
|
|
5
|
-
saveCurrentProjectConfig,
|
|
6
|
-
} from './config.js'
|
|
7
|
-
import { env } from './env'
|
|
8
|
-
import { getCwd } from './state'
|
|
9
|
-
import { exec } from 'child_process'
|
|
10
|
-
import { logError } from './log'
|
|
11
|
-
import { memoize, sample } from 'lodash-es'
|
|
12
|
-
import { promisify } from 'util'
|
|
13
|
-
import { getIsGit } from './git'
|
|
14
|
-
import { queryQuick } from '../services/claude'
|
|
15
|
-
|
|
16
|
-
const execPromise = promisify(exec)
|
|
17
|
-
|
|
18
|
-
async function getFrequentlyModifiedFiles(): Promise<string[]> {
|
|
19
|
-
if (process.env.NODE_ENV === 'test') return []
|
|
20
|
-
if (env.platform === 'windows') return []
|
|
21
|
-
if (!(await getIsGit())) return []
|
|
22
|
-
|
|
23
|
-
try {
|
|
24
|
-
let filenames = ''
|
|
25
|
-
// Look up files modified by the user's recent commits
|
|
26
|
-
// Be careful to do it async, so it doesn't block the main thread
|
|
27
|
-
const { stdout: userFilenames } = await execPromise(
|
|
28
|
-
'git log -n 1000 --pretty=format: --name-only --diff-filter=M --author=$(git config user.email) | sort | uniq -c | sort -nr | head -n 20',
|
|
29
|
-
{ cwd: getCwd(), encoding: 'utf8' },
|
|
30
|
-
)
|
|
31
|
-
|
|
32
|
-
filenames = 'Files modified by user:\n' + userFilenames
|
|
33
|
-
|
|
34
|
-
// Look at other users' commits if we don't have enough files
|
|
35
|
-
if (userFilenames.split('\n').length < 10) {
|
|
36
|
-
const { stdout: allFilenames } = await execPromise(
|
|
37
|
-
'git log -n 1000 --pretty=format: --name-only --diff-filter=M | sort | uniq -c | sort -nr | head -n 20',
|
|
38
|
-
{ cwd: getCwd(), encoding: 'utf8' },
|
|
39
|
-
)
|
|
40
|
-
filenames += '\n\nFiles modified by other users:\n' + allFilenames
|
|
41
|
-
}
|
|
42
|
-
const response = await queryQuick({
|
|
43
|
-
systemPrompt: [
|
|
44
|
-
"You are an expert at analyzing git history. Given a list of files and their modification counts, return exactly five filenames that are frequently modified and represent core application logic (not auto-generated files, dependencies, or configuration). Make sure filenames are diverse, not all in the same folder, and are a mix of user and other users. Return only the filenames' basenames (without the path) separated by newlines with no explanation.",
|
|
45
|
-
],
|
|
46
|
-
userPrompt: filenames,
|
|
47
|
-
})
|
|
48
|
-
|
|
49
|
-
const content = response.message.content[0]
|
|
50
|
-
if (!content || content.type !== 'text') return []
|
|
51
|
-
const chosenFilenames = content.text.trim().split('\n')
|
|
52
|
-
if (chosenFilenames.length < 5) {
|
|
53
|
-
// Likely error
|
|
54
|
-
return []
|
|
55
|
-
}
|
|
56
|
-
return chosenFilenames
|
|
57
|
-
} catch (err) {
|
|
58
|
-
logError(err)
|
|
59
|
-
return []
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
export const getExampleCommands = memoize(async (): Promise<string[]> => {
|
|
64
|
-
const globalConfig = getGlobalConfig()
|
|
65
|
-
const projectConfig = getCurrentProjectConfig()
|
|
66
|
-
const now = Date.now()
|
|
67
|
-
const lastGenerated = projectConfig.exampleFilesGeneratedAt ?? 0
|
|
68
|
-
const oneWeek = 7 * 24 * 60 * 60 * 1000
|
|
69
|
-
|
|
70
|
-
// Regenerate examples if they're over a week old
|
|
71
|
-
if (now - lastGenerated > oneWeek) {
|
|
72
|
-
projectConfig.exampleFiles = []
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// Update global startup count
|
|
76
|
-
const newGlobalConfig = {
|
|
77
|
-
...globalConfig,
|
|
78
|
-
numStartups: (globalConfig.numStartups ?? 0) + 1,
|
|
79
|
-
}
|
|
80
|
-
saveGlobalConfig(newGlobalConfig)
|
|
81
|
-
|
|
82
|
-
// // If no example files cached, kickstart fetch in background
|
|
83
|
-
// if (!projectConfig.exampleFiles?.length) {
|
|
84
|
-
// getFrequentlyModifiedFiles().then(files => {
|
|
85
|
-
// if (files.length) {
|
|
86
|
-
// saveCurrentProjectConfig({
|
|
87
|
-
// ...getCurrentProjectConfig(),
|
|
88
|
-
// exampleFiles: files,
|
|
89
|
-
// exampleFilesGeneratedAt: Date.now(),
|
|
90
|
-
// })
|
|
91
|
-
// }
|
|
92
|
-
// })
|
|
93
|
-
// }
|
|
94
|
-
|
|
95
|
-
const frequentFile = projectConfig.exampleFiles?.length
|
|
96
|
-
? sample(projectConfig.exampleFiles)
|
|
97
|
-
: '<filepath>'
|
|
98
|
-
|
|
99
|
-
return [
|
|
100
|
-
'fix lint errors',
|
|
101
|
-
'fix typecheck errors',
|
|
102
|
-
`how does ${frequentFile} work?`,
|
|
103
|
-
`refactor ${frequentFile}`,
|
|
104
|
-
'how do I log an error?',
|
|
105
|
-
`edit ${frequentFile} to...`,
|
|
106
|
-
`write a test for ${frequentFile}`,
|
|
107
|
-
'create a util logging.py that...',
|
|
108
|
-
]
|
|
109
|
-
})
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { execFile } from 'child_process'
|
|
2
|
-
import { getCwd } from './state'
|
|
3
|
-
import { logError } from './log'
|
|
4
|
-
|
|
5
|
-
const MS_IN_SECOND = 1000
|
|
6
|
-
const SECONDS_IN_MINUTE = 60
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* execFile, but always resolves (never throws)
|
|
10
|
-
*/
|
|
11
|
-
export function execFileNoThrow(
|
|
12
|
-
file: string,
|
|
13
|
-
args: string[],
|
|
14
|
-
abortSignal?: AbortSignal,
|
|
15
|
-
timeout = 10 * SECONDS_IN_MINUTE * MS_IN_SECOND,
|
|
16
|
-
preserveOutputOnError = true,
|
|
17
|
-
): Promise<{ stdout: string; stderr: string; code: number }> {
|
|
18
|
-
return new Promise(resolve => {
|
|
19
|
-
try {
|
|
20
|
-
execFile(
|
|
21
|
-
file,
|
|
22
|
-
args,
|
|
23
|
-
{
|
|
24
|
-
maxBuffer: 1_000_000,
|
|
25
|
-
signal: abortSignal,
|
|
26
|
-
timeout,
|
|
27
|
-
cwd: getCwd(),
|
|
28
|
-
},
|
|
29
|
-
(error, stdout, stderr) => {
|
|
30
|
-
if (error) {
|
|
31
|
-
if (preserveOutputOnError) {
|
|
32
|
-
const errorCode = typeof error.code === 'number' ? error.code : 1
|
|
33
|
-
resolve({
|
|
34
|
-
stdout: stdout || '',
|
|
35
|
-
stderr: stderr || '',
|
|
36
|
-
code: errorCode,
|
|
37
|
-
})
|
|
38
|
-
} else {
|
|
39
|
-
resolve({ stdout: '', stderr: '', code: 1 })
|
|
40
|
-
}
|
|
41
|
-
} else {
|
|
42
|
-
resolve({ stdout, stderr, code: 0 })
|
|
43
|
-
}
|
|
44
|
-
},
|
|
45
|
-
)
|
|
46
|
-
} catch (error) {
|
|
47
|
-
logError(error)
|
|
48
|
-
resolve({ stdout: '', stderr: '', code: 1 })
|
|
49
|
-
}
|
|
50
|
-
})
|
|
51
|
-
}
|
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'fs'
|
|
2
|
-
import { join } from 'path'
|
|
3
|
-
import { homedir } from 'os'
|
|
4
|
-
import { randomUUID } from 'crypto'
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Expert Chat Session Storage - 极简版
|
|
8
|
-
* 存储符合OpenAI格式的messages历史
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
export interface ChatMessage {
|
|
12
|
-
role: 'user' | 'assistant'
|
|
13
|
-
content: string
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export interface ExpertChatSession {
|
|
17
|
-
sessionId: string
|
|
18
|
-
expertModel: string
|
|
19
|
-
messages: ChatMessage[]
|
|
20
|
-
createdAt: number
|
|
21
|
-
lastUpdated: number
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* 获取专家聊天存储目录
|
|
26
|
-
*/
|
|
27
|
-
function getExpertChatDirectory(): string {
|
|
28
|
-
const configDir =
|
|
29
|
-
process.env.KODE_CONFIG_DIR ?? process.env.ANYKODE_CONFIG_DIR ?? join(homedir(), '.kode')
|
|
30
|
-
const expertChatDir = join(configDir, 'expert-chats')
|
|
31
|
-
|
|
32
|
-
if (!existsSync(expertChatDir)) {
|
|
33
|
-
mkdirSync(expertChatDir, { recursive: true })
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
return expertChatDir
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* 获取会话文件路径 - 使用 sessionId.json 格式
|
|
41
|
-
*/
|
|
42
|
-
function getSessionFilePath(sessionId: string): string {
|
|
43
|
-
return join(getExpertChatDirectory(), `${sessionId}.json`)
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* 创建新的专家聊天会话
|
|
48
|
-
*/
|
|
49
|
-
export function createExpertChatSession(
|
|
50
|
-
expertModel: string,
|
|
51
|
-
): ExpertChatSession {
|
|
52
|
-
const sessionId = randomUUID().slice(0, 5)
|
|
53
|
-
const session: ExpertChatSession = {
|
|
54
|
-
sessionId,
|
|
55
|
-
expertModel,
|
|
56
|
-
messages: [],
|
|
57
|
-
createdAt: Date.now(),
|
|
58
|
-
lastUpdated: Date.now(),
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
saveExpertChatSession(session)
|
|
62
|
-
return session
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* 加载现有专家聊天会话
|
|
67
|
-
*/
|
|
68
|
-
export function loadExpertChatSession(
|
|
69
|
-
sessionId: string,
|
|
70
|
-
): ExpertChatSession | null {
|
|
71
|
-
const filePath = getSessionFilePath(sessionId)
|
|
72
|
-
|
|
73
|
-
if (!existsSync(filePath)) {
|
|
74
|
-
return null
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
try {
|
|
78
|
-
const content = readFileSync(filePath, 'utf-8')
|
|
79
|
-
return JSON.parse(content) as ExpertChatSession
|
|
80
|
-
} catch (error) {
|
|
81
|
-
console.error(`Failed to load expert chat session ${sessionId}:`, error)
|
|
82
|
-
return null
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* 保存专家聊天会话
|
|
88
|
-
*/
|
|
89
|
-
export function saveExpertChatSession(session: ExpertChatSession): void {
|
|
90
|
-
const filePath = getSessionFilePath(session.sessionId)
|
|
91
|
-
|
|
92
|
-
try {
|
|
93
|
-
session.lastUpdated = Date.now()
|
|
94
|
-
writeFileSync(filePath, JSON.stringify(session, null, 2), 'utf-8')
|
|
95
|
-
} catch (error) {
|
|
96
|
-
console.error(
|
|
97
|
-
`Failed to save expert chat session ${session.sessionId}:`,
|
|
98
|
-
error,
|
|
99
|
-
)
|
|
100
|
-
throw error
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
/**
|
|
105
|
-
* 添加消息到会话
|
|
106
|
-
*/
|
|
107
|
-
export function addMessageToSession(
|
|
108
|
-
sessionId: string,
|
|
109
|
-
role: 'user' | 'assistant',
|
|
110
|
-
content: string,
|
|
111
|
-
): ExpertChatSession | null {
|
|
112
|
-
const session = loadExpertChatSession(sessionId)
|
|
113
|
-
if (!session) {
|
|
114
|
-
return null
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
session.messages.push({ role, content })
|
|
118
|
-
saveExpertChatSession(session)
|
|
119
|
-
|
|
120
|
-
return session
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* 获取会话的消息历史 - 返回OpenAI格式
|
|
125
|
-
*/
|
|
126
|
-
export function getSessionMessages(sessionId: string): ChatMessage[] {
|
|
127
|
-
const session = loadExpertChatSession(sessionId)
|
|
128
|
-
return session?.messages || []
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* 生成新的会话ID
|
|
133
|
-
*/
|
|
134
|
-
export function generateSessionId(): string {
|
|
135
|
-
return randomUUID().slice(0, 5)
|
|
136
|
-
}
|