mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-19 06:45:50 +00:00
feat: 工具层及 mcp 大重构 (#252)
* feat: 第一版大重构 * fix: 修复类型问题 * chore: 更新版本到 1.3.2 * Add brave as alternative WebSearchTool * fix: 修正顺序 * fix: 修复对穷鬼模式的 auto dream 和 session memory 越过 * feat: 穷鬼模式去除 session-summary * feat: 创建 builtin-tools 包,搬运所有工具实现 将 src/tools/ 下的全部 60 个工具目录迁移至 packages/builtin-tools/src/tools/, 内部导入路径已更新为 src/ alias 模式。 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * refactor: 更新 src/ 中所有工具引用至 builtin-tools 包,删除 src/tools/ - src/tools.ts 及 178 个 src/ 文件的 import 路径从 ./tools/ 改为 builtin-tools/tools/ - 删除 src/tools/ 整个目录(已迁移至 packages/builtin-tools/) Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * chore: 添加 builtin-tools 路径别名至 tsconfig,更新 bun.lock - tsconfig.json 新增 builtin-tools/* 和 builtin-tools 路径映射 - 新增 packages/builtin-tools/src 至 include Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * refactor: 为 builtin-tools、mcp-client、agent-tools 添加 @claude-code-best 作用域前缀 所有包名及 import 路径统一添加 @claude-code-best/ 前缀: - builtin-tools → @claude-code-best/builtin-tools - mcp-client → @claude-code-best/mcp-client - agent-tools → @claude-code-best/agent-tools Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: 修复 node 环境没有 bun 的问题 --------- Co-authored-by: Eric-Guo <eric.guocz@gmail.com> Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -14,7 +14,7 @@ import {
|
||||
MaxFileReadTokenExceededError,
|
||||
type Output as FileReadToolOutput,
|
||||
readImageWithTokenBudget,
|
||||
} from '../tools/FileReadTool/FileReadTool.js'
|
||||
} from '@claude-code-best/builtin-tools/tools/FileReadTool/FileReadTool.js'
|
||||
import { FileTooLargeError, readFileInRange } from './readFileInRange.js'
|
||||
import { expandPath } from './path.js'
|
||||
import { countCharInString } from './stringUtils.js'
|
||||
@@ -22,11 +22,11 @@ import { count, uniq } from './array.js'
|
||||
import { getFsImplementation } from './fsOperations.js'
|
||||
import { readdir, stat } from 'fs/promises'
|
||||
import type { IDESelection } from '../hooks/useIdeSelection.js'
|
||||
import { TODO_WRITE_TOOL_NAME } from '../tools/TodoWriteTool/constants.js'
|
||||
import { TASK_CREATE_TOOL_NAME } from '../tools/TaskCreateTool/constants.js'
|
||||
import { TASK_UPDATE_TOOL_NAME } from '../tools/TaskUpdateTool/constants.js'
|
||||
import { BASH_TOOL_NAME } from '../tools/BashTool/toolName.js'
|
||||
import { SKILL_TOOL_NAME } from '../tools/SkillTool/constants.js'
|
||||
import { TODO_WRITE_TOOL_NAME } from '@claude-code-best/builtin-tools/tools/TodoWriteTool/constants.js'
|
||||
import { TASK_CREATE_TOOL_NAME } from '@claude-code-best/builtin-tools/tools/TaskCreateTool/constants.js'
|
||||
import { TASK_UPDATE_TOOL_NAME } from '@claude-code-best/builtin-tools/tools/TaskUpdateTool/constants.js'
|
||||
import { BASH_TOOL_NAME } from '@claude-code-best/builtin-tools/tools/BashTool/toolName.js'
|
||||
import { SKILL_TOOL_NAME } from '@claude-code-best/builtin-tools/tools/SkillTool/constants.js'
|
||||
import type { TodoList } from './todo/types.js'
|
||||
import {
|
||||
type Task,
|
||||
@@ -64,7 +64,7 @@ import {
|
||||
} from 'src/types/textInputTypes.js'
|
||||
import { randomUUID, type UUID } from 'crypto'
|
||||
import { getSettings_DEPRECATED } from './settings/settings.js'
|
||||
import { getSnippetForTwoFileDiff } from 'src/tools/FileEditTool/utils.js'
|
||||
import { getSnippetForTwoFileDiff } from '@claude-code-best/builtin-tools/tools/FileEditTool/utils.js'
|
||||
import type {
|
||||
ContentBlockParam,
|
||||
ImageBlockParam,
|
||||
@@ -83,7 +83,7 @@ import { getSkillToolCommands, getMcpSkillCommands } from '../commands.js'
|
||||
import type { Command } from '../types/command.js'
|
||||
import uniqBy from 'lodash-es/uniqBy.js'
|
||||
import { getProjectRoot } from '../bootstrap/state.js'
|
||||
import { formatCommandsWithinBudget } from '../tools/SkillTool/prompt.js'
|
||||
import { formatCommandsWithinBudget } from '@claude-code-best/builtin-tools/tools/SkillTool/prompt.js'
|
||||
import { getContextWindowForModel } from './context.js'
|
||||
import type { DiscoverySignal } from '../services/skillSearch/signals.js'
|
||||
// Conditional require for DCE. All skill-search string literals that would
|
||||
@@ -107,8 +107,8 @@ const autoModeStateModule = feature('TRANSCRIPT_CLASSIFIER')
|
||||
import {
|
||||
MAX_LINES_TO_READ,
|
||||
FILE_READ_TOOL_NAME,
|
||||
} from 'src/tools/FileReadTool/prompt.js'
|
||||
import { getDefaultFileReadingLimits } from 'src/tools/FileReadTool/limits.js'
|
||||
} from '@claude-code-best/builtin-tools/tools/FileReadTool/prompt.js'
|
||||
import { getDefaultFileReadingLimits } from '@claude-code-best/builtin-tools/tools/FileReadTool/limits.js'
|
||||
import { cacheKeys, type FileStateCache } from './fileStateCache.js'
|
||||
import {
|
||||
createAbortController,
|
||||
@@ -119,13 +119,13 @@ import {
|
||||
getFileModificationTimeAsync,
|
||||
isFileWithinReadSizeLimit,
|
||||
} from './file.js'
|
||||
import type { AgentDefinition } from '../tools/AgentTool/loadAgentsDir.js'
|
||||
import { filterAgentsByMcpRequirements } from '../tools/AgentTool/loadAgentsDir.js'
|
||||
import { AGENT_TOOL_NAME } from '../tools/AgentTool/constants.js'
|
||||
import type { AgentDefinition } from '@claude-code-best/builtin-tools/tools/AgentTool/loadAgentsDir.js'
|
||||
import { filterAgentsByMcpRequirements } from '@claude-code-best/builtin-tools/tools/AgentTool/loadAgentsDir.js'
|
||||
import { AGENT_TOOL_NAME } from '@claude-code-best/builtin-tools/tools/AgentTool/constants.js'
|
||||
import {
|
||||
formatAgentLine,
|
||||
shouldInjectAgentListInMessages,
|
||||
} from '../tools/AgentTool/prompt.js'
|
||||
} from '@claude-code-best/builtin-tools/tools/AgentTool/prompt.js'
|
||||
import { filterDeniedAgents } from './permissions/permissions.js'
|
||||
import { getSubscriptionType } from './auth.js'
|
||||
import { mcpInfoFromString } from '../services/mcp/mcpStringUtils.js'
|
||||
@@ -200,7 +200,7 @@ import { feature } from 'bun:bundle'
|
||||
const BRIEF_TOOL_NAME: string | null =
|
||||
feature('KAIROS') || feature('KAIROS_BRIEF')
|
||||
? (
|
||||
require('../tools/BriefTool/prompt.js') as typeof import('../tools/BriefTool/prompt.js')
|
||||
require('@claude-code-best/builtin-tools/tools/BriefTool/prompt.js') as typeof import('@claude-code-best/builtin-tools/tools/BriefTool/prompt.js')
|
||||
).BRIEF_TOOL_NAME
|
||||
: null
|
||||
const sessionTranscriptModule = feature('KAIROS')
|
||||
@@ -232,7 +232,7 @@ import { isAgentSwarmsEnabled } from './agentSwarmsEnabled.js'
|
||||
import { findRelevantMemories } from '../memdir/findRelevantMemories.js'
|
||||
import { memoryAge, memoryFreshnessText } from '../memdir/memoryAge.js'
|
||||
import { getAutoMemPath, isAutoMemoryEnabled } from '../memdir/paths.js'
|
||||
import { getAgentMemoryDir } from '../tools/AgentTool/agentMemory.js'
|
||||
import { getAgentMemoryDir } from '@claude-code-best/builtin-tools/tools/AgentTool/agentMemory.js'
|
||||
import {
|
||||
readUnreadMessages,
|
||||
markMessagesAsReadByPredicate,
|
||||
|
||||
Reference in New Issue
Block a user