mirror of
https://github.com/claude-code-best/claude-code.git
synced 2026-06-15 21:05:51 +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>
49 lines
1.2 KiB
TypeScript
49 lines
1.2 KiB
TypeScript
import { mkdir, writeFile } from 'fs/promises'
|
|
import { join, resolve } from 'path'
|
|
import { lock } from './lockfile.js'
|
|
|
|
const persistenceLocks = new Map<string, Promise<void>>()
|
|
|
|
export async function withAutonomyPersistenceLock<T>(
|
|
rootDir: string,
|
|
fn: () => Promise<T>,
|
|
): Promise<T> {
|
|
const key = resolve(rootDir)
|
|
const lockPath = join(key, '.claude', 'autonomy', '.lock')
|
|
const previous = persistenceLocks.get(key) ?? Promise.resolve()
|
|
|
|
let release!: () => void
|
|
const current = new Promise<void>(resolve => {
|
|
release = resolve
|
|
})
|
|
persistenceLocks.set(
|
|
key,
|
|
previous.then(() => current),
|
|
)
|
|
|
|
await previous
|
|
try {
|
|
await mkdir(join(key, '.claude', 'autonomy'), { recursive: true })
|
|
await writeFile(lockPath, '', { flag: 'a' })
|
|
const unlock = await lock(lockPath, {
|
|
lockfilePath: `${lockPath}.lock`,
|
|
retries: {
|
|
retries: 10,
|
|
factor: 1.2,
|
|
minTimeout: 10,
|
|
maxTimeout: 100,
|
|
},
|
|
})
|
|
try {
|
|
return await fn()
|
|
} finally {
|
|
await unlock().catch(() => {})
|
|
}
|
|
} finally {
|
|
release()
|
|
if (persistenceLocks.get(key) === current) {
|
|
persistenceLocks.delete(key)
|
|
}
|
|
}
|
|
}
|