Back to list
desplega-ai

wts-expert

by desplega-ai

AI toolbox, intended to be developed and used by agents!

3🍴 0📅 Jan 24, 2026

SKILL.md


name: wts-expert description: Git worktree management expert for @desplega.ai/wts. Use when the user asks about git worktrees, wts commands, worktree workflows, or wants help managing multiple branches simultaneously.

WTS Expert

You are an expert on @desplega.ai/wts, a CLI tool for managing Git worktrees with tmux integration, Claude Code launcher support, and GitHub PR creation.

What is WTS?

WTS (Worktree Switch) simplifies Git worktree management. Instead of juggling branches in a single directory, worktrees let you have multiple branches checked out simultaneously in separate directories. WTS adds:

  • Organized worktree creation at .worktrees/<project>/<date>-<alias>/
  • tmux window integration
  • Claude Code auto-launch
  • GitHub PR creation from worktrees
  • Cleanup of merged worktrees

Quick Reference

GoalCommand
Initialize projectwts init
Create worktreewts create <alias>
Create with new branchwts create <alias> -n
Create with tmux + Claudewts create <alias> --tmux --claude
List worktreeswts list
Switch worktreewts switch (fzf picker)
Create PRwts pr
Delete worktreewts delete <alias>
Cleanup mergedwts cleanup

Interactive Assistance

When helping users, follow these steps:

1. Understand the Goal

If the user's request is unclear, ask:

  • What are you trying to accomplish?
  • Are you starting a new feature, switching context, or cleaning up?

2. Check Prerequisites

Before running wts commands, verify:

# Check if wts is installed
which wts || npm list -g @desplega.ai/wts

If not installed, guide installation:

npm install -g @desplega.ai/wts

3. Check Project Status

For project-specific commands:

# Check if in a git repo
git rev-parse --git-dir 2>/dev/null && echo "Git repo found"

# Check if wts is initialized
cat ~/.wts.json 2>/dev/null | grep -q "$(pwd)" && echo "Project registered"

4. Execute Commands

Run wts commands based on user's goal. Always show the command before running it.

Common Workflows

Starting a New Feature

# Create worktree with new branch and open in tmux with Claude Code
wts create my-feature --new-branch --tmux --claude

Switching Between Features

# Interactive switch with fzf
wts switch

# Or direct switch
wts switch my-feature

# Switch in new tmux window
wts switch my-feature --tmux

Creating a Pull Request

# From current worktree
wts pr

# With draft flag
wts pr --draft

# Open in browser after creation
wts pr --web

Cleaning Up

# See what would be cleaned
wts cleanup --dry-run

# Clean merged worktrees
wts cleanup

# Include worktrees older than 30 days
wts cleanup --older-than 30

Configuration

Global Config (~/.wts.json)

Stores all tracked projects and default settings:

  • worktreeDir: Base directory for worktrees
  • tmuxWindowTemplate: Template for tmux window names
  • autoTmux: Auto-open in tmux
  • autoClaude: Auto-launch Claude Code

Project Config (.wts-config.json)

Project-specific overrides:

  • setupScript: Script to run after worktree creation
  • All global settings can be overridden per-project

Troubleshooting

"Project not initialized"

Run wts init in the project root.

"Worktree already exists"

Use wts list to see existing worktrees, then either switch to it or delete it.

"Branch already exists"

Use -b <existing-branch> instead of -n (new branch).

tmux not working

Ensure tmux is installed and you're running from within a tmux session or terminal that can spawn tmux.

Detailed Reference

For complete command documentation with all flags and options, see COMMANDS.md.

Score

Total Score

55/100

Based on repository quality metrics

SKILL.md

SKILL.mdファイルが含まれている

+20
LICENSE

ライセンスが設定されている

0/10
説明文

100文字以上の説明がある

0/10
人気

GitHub Stars 100以上

0/15
最近の活動

1ヶ月以内に更新

+10
フォーク

10回以上フォークされている

0/5
Issue管理

オープンIssueが50未満

+5
言語

プログラミング言語が設定されている

+5
タグ

1つ以上のタグが設定されている

+5

Reviews

💬

Reviews coming soon