Dotfiles ios-debugger-agent
Use XcodeBuildMCP to build, run, launch, and debug the current iOS project on a booted simulator. Trigger when asked to run an iOS app, interact with the simulator UI, inspect on-screen state, capture logs/console output, or diagnose runtime behavior using XcodeBuildMCP tools.
install
source · Clone the upstream repo
git clone https://github.com/harperreed/dotfiles
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/harperreed/dotfiles "$T" && mkdir -p ~/.claude/skills && cp -r "$T/.claude/skills/ios-debugger-agent" ~/.claude/skills/harperreed-dotfiles-ios-debugger-agent && rm -rf "$T"
manifest:
.claude/skills/ios-debugger-agent/SKILL.mdsource content
iOS Debugger Agent
Overview
Use XcodeBuildMCP to build and run the current project scheme on a booted iOS simulator, interact with the UI, and capture logs. Prefer the MCP tools for simulator control, logs, and view inspection.
Core Workflow
Follow this sequence unless the user asks for a narrower action.
1) Discover the booted simulator
- Call
and select the simulator with statemcp__XcodeBuildMCP__list_sims
.Booted - If none are booted, ask the user to boot one (do not boot automatically unless asked).
2) Set session defaults
- Call
with:mcp__XcodeBuildMCP__session-set-defaults
orprojectPath
(whichever the repo uses)workspacePath
for the current appscheme
from the booted devicesimulatorId- Optional:
,configuration: "Debug"useLatestOS: true
3) Build + run (when requested)
- Call
.mcp__XcodeBuildMCP__build_run_sim - If the app is already built and only launch is requested, use
.mcp__XcodeBuildMCP__launch_app_sim - If bundle id is unknown:
mcp__XcodeBuildMCP__get_sim_app_pathmcp__XcodeBuildMCP__get_app_bundle_id
UI Interaction & Debugging
Use these when asked to inspect or interact with the running app.
- Describe UI:
before tapping or swiping.mcp__XcodeBuildMCP__describe_ui - Tap:
(prefermcp__XcodeBuildMCP__tap
orid
; use coordinates only if needed).label - Type:
after focusing a field.mcp__XcodeBuildMCP__type_text - Gestures:
for common scrolls and edge swipes.mcp__XcodeBuildMCP__gesture - Screenshot:
for visual confirmation.mcp__XcodeBuildMCP__screenshot
Logs & Console Output
- Start logs:
with the app bundle id.mcp__XcodeBuildMCP__start_sim_log_cap - Stop logs:
and summarize important lines.mcp__XcodeBuildMCP__stop_sim_log_cap - For console output, set
and relaunch if required.captureConsole: true
Troubleshooting
- If build fails, ask whether to retry with
.preferXcodebuild: true - If the wrong app launches, confirm the scheme and bundle id.
- If UI elements are not hittable, re-run
after layout changes.describe_ui