Marketplace

iterm2-layout

Configure iTerm2 workspace layouts with TOML-based configuration. Use when user mentions iTerm2 layout, workspace tabs, layout.toml, AutoLaunch script, or configuring terminal workspaces.

$ 安裝

git clone https://github.com/terrylica/cc-skills /tmp/cc-skills && cp -r /tmp/cc-skills/plugins/iterm2-layout-config/skills/iterm2-layout ~/.claude/skills/cc-skills

// tip: Run this command in your terminal to install the skill


name: iterm2-layout description: Configure iTerm2 workspace layouts with TOML-based configuration. Use when user mentions iTerm2 layout, workspace tabs, layout.toml, AutoLaunch script, or configuring terminal workspaces.

iTerm2 Layout Configuration

Configure iTerm2 workspace layouts with proper separation of concerns: private paths in TOML config, publishable code in Python script.

Triggers

Invoke this skill when user mentions:

  • "iTerm2 layout"
  • "workspace tabs"
  • "layout.toml"
  • "AutoLaunch script"
  • "default-layout.py"
  • "configure terminal workspaces"
  • "add workspace tab"

Configuration Overview

File Locations

FileLocationPurpose
Config (private)~/.config/iterm2/layout.tomlUser's workspace paths
Script (public)~/scripts/iterm2/default-layout.pyLayout logic
Template~/scripts/iterm2/layout.example.tomlExample config

Config File Format

# ~/.config/iterm2/layout.toml

[layout]
left_pane_ratio = 0.20    # 0.0 to 1.0
settle_time = 0.3         # seconds

[commands]
left = "br --sort-by-type-dirs-first"
right = "zsh"

[worktrees]
# Optional: Enable git worktree discovery
# main_repo_root = "~/projects/my-project"
# worktree_pattern = "my-project.worktree-*"

[[tabs]]
name = "home"
dir = "~"

[[tabs]]
name = "projects"
dir = "~/projects"

[[tabs]]
dir = "~/Documents"  # name defaults to "Documents"

Setup Instructions

First-Time Setup

/usr/bin/env bash << 'CONFIG_EOF'
# 1. Ensure config directory exists
mkdir -p ~/.config/iterm2

# 2. Copy template
cp ~/scripts/iterm2/layout.example.toml ~/.config/iterm2/layout.toml

# 3. Edit with your workspace paths
# Add [[tabs]] entries for each workspace

# 4. Restart iTerm2 to test
CONFIG_EOF

Adding a New Tab

Add a [[tabs]] entry to ~/.config/iterm2/layout.toml:

[[tabs]]
name = "MyProject"  # Tab display name (optional)
dir = "~/path/to/project"

Name field:

  • If omitted, uses directory basename
  • Custom names useful for abbreviations (e.g., "AF" instead of "alpha-forge")

Removing a Tab

Delete or comment out the [[tabs]] entry:

# [[tabs]]
# name = "OldProject"
# dir = "~/old/project"

Configuration Schema

SectionKeyTypeDefaultDescription
[layout]left_pane_ratiofloat0.20Left pane width (0.0-1.0)
[layout]settle_timefloat0.3Wait after cd (seconds)
[commands]leftstringbr...Left pane command
[commands]rightstringzshRight pane command
[worktrees]alpha_forge_rootstringnullWorktree root (optional)
[worktrees]worktree_patternstring*.worktree-*Glob pattern
[[tabs]]dirstringrequiredDirectory path
[[tabs]]namestringbasenameTab display name

Troubleshooting

Error: "Layout configuration not found"

Symptom: Script Console shows error about missing config

Solution:

# Create config from template
cp ~/scripts/iterm2/layout.example.toml ~/.config/iterm2/layout.toml

Error: "Invalid TOML syntax"

Symptom: Script Console shows TOML parse error

Solution:

  1. Check TOML syntax (quotes, brackets)
  2. Validate with: python3 -c "import tomllib; tomllib.load(open('~/.config/iterm2/layout.toml', 'rb'))"

Tabs Not Appearing

Symptom: iTerm2 opens but no custom tabs created

Causes:

  1. No [[tabs]] entries in config
  2. Config file in wrong location
  3. Script not in AutoLaunch

Solution:

# Verify config location
ls -la ~/.config/iterm2/layout.toml

# Verify AutoLaunch symlink
ls -la ~/Library/Application\ Support/iTerm2/Scripts/AutoLaunch/

# Check Script Console for errors
# iTerm2 > Scripts > Manage > Console

Directory Does Not Exist Warning

Symptom: Tab skipped with warning in Script Console

Solution: Verify directory path exists or create it:

mkdir -p ~/path/to/missing/directory

Error Handling Behavior

The script uses "print + early return" pattern:

  1. Missing config: Logs instructions to Script Console, exits cleanly
  2. Invalid TOML: Logs parse error with details, exits cleanly
  3. Missing directory: Logs warning, skips tab, continues with others

Viewing errors: Scripts > Manage > Console in iTerm2

Git Worktree Detection (Optional)

Enable dynamic tab creation for git worktrees:

[worktrees]
main_repo_root = "~/projects/my-project"
worktree_pattern = "my-project.worktree-*"

How it works:

  1. Script globs for ~/projects/my-project.worktree-* directories
  2. Validates each against git worktree list
  3. Generates acronym-based tab names (e.g., AF-ssv for sharpe-statistical-validation)
  4. Inserts worktree tabs after main project tab

References