mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-17 13:55:50 +00:00
* feat: 适配 zed acp 协议 * docs: 完善 acp 文档 * feat: integrate feature branches + daemon/job 命令层级化 + 跨平台后台引擎 Cherry-picked from origin/lint/preview (637c908), excluding lint-only changes. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: correct detectMimeFromBase64 to decode raw bytes from base64 Cherry-picked from origin/lint/preview (ee36954). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: daemon 子进程 spawn 跨平台修复 + CliLaunchSpec 集中化重构 Cherry-picked from origin/lint/preview (c5f52cd), excluding lint-only formatting changes. - 新建 src/utils/cliLaunch.ts: 集中化 CLI 子进程启动层 - 修复 --daemon-worker=kind 等号格式解析 - 修复 daemon/bg fast path 缺少 setShellIfWindows() - 修复 checkPathExists 用 existsSync 替代 execSync('dir') - 7 个 spawn 站点迁移到 CliLaunchSpec Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: merge tsconfig.base.json into tsconfig.json with full compiler options The cherry-pick from637c908dropped jsx/strict/etc settings when removing tsconfig.base.json. This commit restores them in a single tsconfig.json. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix: merge tsconfig.base.json into tsconfig.json with full compiler options The cherry-pick from637c908dropped jsx/strict/etc settings when removing tsconfig.base.json. This commit restores them in a single tsconfig.json. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
65 lines
1.8 KiB
TypeScript
65 lines
1.8 KiB
TypeScript
import { readFileSync } from 'fs'
|
|
import { join } from 'path'
|
|
import { getKairosActive } from '../bootstrap/state.js'
|
|
import { getClaudeConfigHomeDir } from '../utils/envUtils.js'
|
|
|
|
let _assistantForced = false
|
|
|
|
/**
|
|
* Whether the current session is in assistant (KAIROS) daemon mode.
|
|
* Wraps the bootstrap kairosActive state set by main.tsx after gate check.
|
|
*/
|
|
export function isAssistantMode(): boolean {
|
|
return getKairosActive()
|
|
}
|
|
|
|
/**
|
|
* Mark this session as forced assistant mode (--assistant flag).
|
|
* Skips the GrowthBook gate check — daemon is pre-entitled.
|
|
*/
|
|
export function markAssistantForced(): void {
|
|
_assistantForced = true
|
|
}
|
|
|
|
export function isAssistantForced(): boolean {
|
|
return _assistantForced
|
|
}
|
|
|
|
/**
|
|
* Pre-create an in-process team so Agent(name) can spawn teammates
|
|
* without TeamCreate.
|
|
*
|
|
* Phase 1: returns undefined so main.tsx's `assistantTeamContext ?? computeInitialTeamContext()`
|
|
* correctly falls back. Returning {} would bypass the ?? operator since {} is truthy.
|
|
*
|
|
* Phase 2: should return a full team context object matching AppState.teamContext shape.
|
|
*/
|
|
export async function initializeAssistantTeam(): Promise<undefined> {
|
|
return undefined
|
|
}
|
|
|
|
/**
|
|
* Assistant-specific system prompt addendum loaded from ~/.claude/agents/assistant.md.
|
|
* Returns empty string if the file doesn't exist.
|
|
*/
|
|
export function getAssistantSystemPromptAddendum(): string {
|
|
try {
|
|
return readFileSync(
|
|
join(getClaudeConfigHomeDir(), 'agents', 'assistant.md'),
|
|
'utf-8',
|
|
)
|
|
} catch {
|
|
return ''
|
|
}
|
|
}
|
|
|
|
/**
|
|
* How assistant mode was activated. Used for diagnostics/analytics.
|
|
* - 'daemon': via --assistant flag (Agent SDK daemon)
|
|
* - 'gate': via GrowthBook gate check
|
|
*/
|
|
export function getAssistantActivationPath(): string | undefined {
|
|
if (!isAssistantMode()) return undefined
|
|
return _assistantForced ? 'daemon' : 'gate'
|
|
}
|