← 返回 Skills 市场
iliaal

ia-git-worktree

作者 Ilia Alshanetsky · GitHub ↗ · v3.0.4 · MIT-0
cross-platform ⚠ suspicious
261
总下载
0
收藏
0
当前安装
11
版本数
在 OpenClaw 中安装
/install compound-eng-git-worktree
功能描述
Manage Git worktrees for isolated parallel development. Use when creating, listing, switching, or cleaning up git worktrees, or when needing isolated branche...
使用说明 (SKILL.md)

Git worktree manager

Always use the manager script

Never call git worktree add directly -- always use the worktree-manager.sh script.

The script handles critical setup that raw git commands don't:

  1. Copies .env, .env.local, .env.test, etc. from main repo
  2. Ensures .worktrees is in .gitignore
  3. Creates consistent directory structure
  4. After creation, install dependencies if detected: package.jsonnpm install, composer.jsoncomposer install, pyproject.tomlpip install -e ., go.modgo mod download

Safety Verification

Before creating a worktree, verify the worktree directory is gitignored:

# Verify .worktrees is ignored (should output ".worktrees")
git check-ignore .worktrees || echo "WARNING: .worktrees not in .gitignore"

If not ignored, add it to .gitignore before proceeding. The manager script handles this, but verify when troubleshooting.

After creating a worktree, run the project's test suite to establish a clean baseline. Pre-existing failures in the worktree should be caught before starting new work -- not discovered mid-implementation.

# CORRECT - Always use the script
bash ${CLAUDE_PLUGIN_ROOT}/skills/ia-git-worktree/scripts/worktree-manager.sh create feature-name

# WRONG - Never do this directly
git worktree add .worktrees/feature-name -b feature-name main

Commands

Command Description Example
create \x3Cbranch> [from] Create worktree + branch (default: from main) ...worktree-manager.sh create feature-login
list / ls List all worktrees with status ...worktree-manager.sh list
switch \x3Cname> / go Switch to existing worktree ...worktree-manager.sh switch feature-login
copy-env \x3Cname> Copy .env files to existing worktree ...worktree-manager.sh copy-env feature-login
cleanup / clean Interactively remove inactive worktrees ...worktree-manager.sh cleanup

After cleanup, run git worktree prune to remove any orphaned worktree metadata from manually deleted directories.

All commands use: bash ${CLAUDE_PLUGIN_ROOT}/skills/ia-git-worktree/scripts/worktree-manager.sh \x3Ccommand>

Environment Detection

Before creating worktrees, detect the execution context:

  1. Already in a worktree? Check git rev-parse --show-toplevel against git worktree list. If the current directory is already a linked worktree, skip creation -- work directly in the existing worktree.
  2. Codex/sandbox environment? If $CODEX_SANDBOX is set or the repo is at a non-standard path (e.g., /tmp/, /workspace/), worktrees may not be supported. Fall back to regular branch switching.
  3. Bare repo? If git rev-parse --is-bare-repository returns true, worktrees are the only way to have a working directory. Adjust paths accordingly.

Adapt the workflow to the detected context rather than failing with a generic error.

Integration with Workflows

/ia-review

  1. Check current branch
  2. If ALREADY on target branch -> stay there, no worktree needed
  3. If DIFFERENT branch -> offer worktree: "Use worktree for isolated review? (y/n)"

/ia-work

Always offer choice:

  1. New branch on current worktree (live work)
  2. Worktree (parallel work)

Branch Completion

When work in a worktree is done, verify tests pass, then present exactly 4 options:

  1. Merge locally -- merge into base branch, delete worktree branch, clean up worktree
  2. Push + PR -- push branch, create PR with gh pr create, keep worktree until merged
  3. Keep as-is -- leave branch and worktree for later
  4. Discard -- requires typing "discard" to confirm. Deletes branch and worktree. No silent discards.

Clean up the worktree directory only for options 1 and 4. For option 2, the worktree stays until the PR merges.

Change Summary

When completing work in a worktree (before merge or PR), output a structured summary:

CHANGES MADE:
- src/routes/tasks.ts: Added validation middleware

THINGS I DIDN'T TOUCH (intentionally):
- src/routes/auth.ts: Has similar validation gap but out of scope

POTENTIAL CONCERNS:
- The Zod schema is strict -- rejects extra fields. Confirm this is desired.

The "DIDN'T TOUCH" section prevents reviewers from wondering whether adjacent issues were missed or intentionally deferred.

Hook Safety Under Husky

Installing hooks into .git/hooks/ silently fails on any repo that uses Husky. Husky sets core.hooksPath (typically to .husky/_) and git ignores .git/hooks/ entirely when that config is non-empty. The hook file lands on disk, is executable, is correct, and is dead. Invisible failure until someone asks why the post-merge behavior isn't running.

Detection rule before writing any hook

hooks_path=$(git -C "$repo" config --get core.hooksPath)
  • Empty output: write to $(git rev-parse --git-common-dir)/hooks/\x3Cname> as usual.
  • .husky/_ (or any path containing husky.sh / h trampoline): Husky v9 setup. Write to .husky/\x3Cname>; do NOT include the v8-era . "$(dirname "$0")/_/husky.sh" line (v9 prints a deprecation warning if you do).
  • Unrecognized non-empty value: refuse to write the hook and surface the path to the user. Silent writes to the wrong location waste debug cycles later.

Worktree-safe hook body

.git/hooks/ lives in the common git dir and runs for every worktree of the clone. A hook installed once fires across all trees. Two rules to stay safe:

  1. Resolve the invoking worktree's root inside the hook body with git rev-parse --show-toplevel, not a hardcoded path. Hardcoding means the last install-hooks invocation wins for every worktree.
  2. Guard the tool invocation with an existence check on the tool's per-tree state dir. Siblings without your tool's setup must no-op, not spawn a failing background process per git op.
#!/bin/sh
root="$(git rev-parse --show-toplevel 2>/dev/null)" || exit 0
[ -d "$root/.my-tool" ] || exit 0
( cd "$root" && my-tool index ) >>"$root/.my-tool/hook.log" 2>&1 &
exit 0

Redirect to a log file inside the tool's state dir, not /dev/null — silent failures produce stale state you only notice hours later.

Local Excludes: .git/info/exclude vs .gitignore

Tooling artifacts (local index dirs, hook helpers, per-developer scratch files) belong in .git/info/exclude, NOT in the tracked .gitignore.

  • .gitignore is content — tracked, shared with the team, reviewed in PRs. Adding a personal tooling rule there pollutes a shared file. On foreign repos (upstream projects, third-party clones) the rule either rides into a PR by accident or sits as a dirty working tree forever.
  • .git/info/exclude is local — untracked, lives in the common git dir, shared across every worktree of the clone. Same syntax and semantics as .gitignore without the leakage.

Resolving the path correctly under worktrees

Don't hardcode $repo/.git/info/exclude. In a worktree, .git is a file (gitlink), not a directory. Use git itself:

exclude=$(git -C "$repo" rev-parse --git-path info/exclude)

Idempotent append

line="/.my-tool/"
mkdir -p "$(dirname "$exclude")"
grep -qxF "$line" "$exclude" 2>/dev/null || printf '\
# my-tool\
%s\
' "$line" >> "$exclude"

grep -qxF matches the exact line with no regex surprises.

When to break the rule

Only when the artifact is genuinely team-shared and belongs in the repo (build outputs used in CI, generated files, vendored dependencies). If in doubt, ask: "would another contributor benefit from this rule?" If no, exclude locally.

Verify

  • git worktree list shows the new entry
  • .worktrees directory confirmed in .gitignore
  • Dependencies installed in the worktree
  • Baseline test suite passes in the worktree

References

安全使用建议
This skill appears intended to manage git worktrees, but the SKILL.md promises extra automation (dependency installs, hook management, sandbox detection) that the provided script doesn't implement — a sign of mismatch or stale docs. Before installing or invoking: 1) review and validate scripts locally (they will run git checkout/pull and modify .gitignore); 2) be aware the script copies all .env* files (except .env.example) into worktrees — this duplicates any secrets on disk and may be undesirable; 3) back up .gitignore and test in a disposable clone to observe behavior (especially interactive prompts and network git pulls); 4) if you expect automatic dependency installation or hook handling, request an updated script or reject until implemented. The issues look like sloppy/incomplete packaging rather than intentional malice, but confirm behavior in a safe environment first.
功能分析
Type: OpenClaw Skill Name: compound-eng-git-worktree Version: 3.0.4 The skill is a Git worktree management utility designed to facilitate parallel development by automating worktree creation, environment file synchronization, and cleanup. The `worktree-manager.sh` script handles the local copying of `.env` files to ensure development parity, and `SKILL.md` provides legitimate technical guidance on managing Git hooks and local excludes (`.git/info/exclude`) within a worktree context. No evidence of data exfiltration, malicious execution, or harmful prompt injection was found; the operations are consistent with the stated purpose of improving developer workflows.
能力评估
Purpose & Capability
Name/description align with a git-worktree manager. However SKILL.md documents extra behaviors (automatic dependency installation, hook installation/handling, environment detection logic) that are not implemented in the included script. The script implements core worktree creation, listing, switching, copying .env files, and cleanup — which is coherent — but the README over-promises additional automation.
Instruction Scope
SKILL.md instructs agents to always call the manager script and describes actions beyond the script (installing dependencies, running tests, hook logic, CODEX_SANDBOX detection). The script does copy local .env* files (except .env.example) into worktrees and appends .worktrees to .gitignore, and performs git checkout/pull which modifies repo state. Copying .env files exposes local secrets within additional directories (no network exfiltration present, but still sensitive). The mismatch between instructions and actual script behavior is problematic for automation.
Install Mechanism
No install spec (instruction-only) and only a single bundled script. Nothing is downloaded or written to disk by an installer here beyond what the script itself does when executed.
Credentials
The skill declares no required environment variables or credentials. SKILL.md references an env var (CODEX_SANDBOX) for context detection but the script does not use it. The main proportionality concern is that the script copies .env* files (which commonly contain secrets) from the repository into worktree directories — this is local file access rather than external exfiltration, but it increases the number of places secrets live on disk and may be undesirable.
Persistence & Privilege
always is false and the skill does not request persistent platform-level privileges. It does modify repo files (.gitignore) and runs git commands that change local repo state, but it does not alter other skills or system-wide agent settings.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install compound-eng-git-worktree
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /compound-eng-git-worktree 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v3.0.4
v3.0.4
v3.0.3
v3.0.3
v3.0.2
v3.0.2
v3.0.1
v3.0.1
v3.0.0
v3.0.0
v2.56.1
v2.56.1
v2.56.0
v2.56.0
v2.55.1
v2.55.1
v2.55.0
v2.55.0
v2.53.2
v2.53.2
v2.53.0
v2.53.0
元数据
Slug compound-eng-git-worktree
版本 3.0.4
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 11
常见问题

ia-git-worktree 是什么?

Manage Git worktrees for isolated parallel development. Use when creating, listing, switching, or cleaning up git worktrees, or when needing isolated branche... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 261 次。

如何安装 ia-git-worktree?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install compound-eng-git-worktree」即可一键安装,无需额外配置。

ia-git-worktree 是免费的吗?

是的,ia-git-worktree 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

ia-git-worktree 支持哪些平台?

ia-git-worktree 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 ia-git-worktree?

由 Ilia Alshanetsky(@iliaal)开发并维护,当前版本 v3.0.4。

💬 留言讨论