xcodeinstrumentmcp
Local-first CLI and MCP server for turning Xcode Instruments artifacts into bounded, agent-sized evidence, with support for analyses like Time Profiler, Allocations, Network, and more.
README
<img width="125" height="125" alt="image" src="https://github.com/user-attachments/assets/c56fc28d-c447-4408-bdfa-8d18111c7af8" />
xcodeinstrumentmcp
xcodeinstrumentmcp is a local-first CLI and MCP server for turning Xcode Instruments artifacts into bounded, agent-sized evidence.
It ships one package with:
- CLI workflows for
doctor,list,record,import,summarize,compare,prompt,db,signpost, andmcp - local SQLite caching with stable snapshot, comparison, and prompt-pack IDs
- fixture-backed analyzers for Time Profiler, Allocations, Hangs, Network, Leaks, Energy Log, Memory Graph, and experimental Processor Trace
- Swift-only signpost scan/plan/apply/revert/status flows backed by the
xim-swiftsignpostSwiftSyntax helper - a bounded MCP surface over the same high-value workflows
Install
Repo-local install:
pnpm install
pnpm exec tsup
node dist/index.js doctor
Requirements:
- macOS 14+
- Node.js 22+
- Xcode /
xctrace - Swift toolchain for signpost helper build/use
CLI Quick Start
Check the local environment:
xcodeinstrumentmcp doctor
Import and persist a Time Profiler trace:
xcodeinstrumentmcp import --instrument time-profiler --input ./run.trace
Summarize a supported family fixture or artifact:
xcodeinstrumentmcp summarize --instrument allocations --input ./allocations.xml --format markdown
xcodeinstrumentmcp summarize --instrument network --input ./session.har --format json
Compare two stored snapshots:
xcodeinstrumentmcp compare --baseline-snapshot snap_base --candidate-snapshot snap_new --format json
Generate a reusable prompt pack:
xcodeinstrumentmcp prompt --snapshot snap_abc --size medium --format json
Scan and apply Swift signpost instrumentation:
xcodeinstrumentmcp signpost scan --project-root .
xcodeinstrumentmcp signpost plan --project-root . --strategy explicit-symbols --symbol GatewayViewModel.refresh
xcodeinstrumentmcp signpost apply --plan plan_abc
Inspect the local cache:
xcodeinstrumentmcp db stats
xcodeinstrumentmcp db list-snapshots
Support Matrix
time-profiler: stable first-class analyzer with record, summarize, compare, and prompt supportallocations: stable first-class analyzer from trace export or exported detail XMLhangs: stable first-class analyzer from hang tables or fixture XMLnetwork: stable first-class analyzer from HAR import with redaction by defaultleaks: stable summary analyzer with conservative confidence languageenergy-log: stable summary analyzer from exported summary XMLmemory-graph: stable summary analyzer from imported.memgraphfixturesprocessor-trace: experimental gated analyzer with explicit caveats in CLI and MCP responses
MCP Setup
Cursor / generic stdio client:
{
"command": "xcodeinstrumentmcp",
"args": ["mcp"]
}
Repo-local stdio launch:
{
"command": "node",
"args": ["/absolute/path/to/dist/index.js", "mcp"]
}
Current MCP surface includes bounded workflow tools such as:
record_time_profilerecord_profileimport_sourcesummarize_tracesummarize_snapshotcompare_tracescompare_snapshotsgenerate_optimization_promptgenerate_prompt_packlist_snapshotsget_snapshotget_comparisonget_findingsplan_signpostsapply_signpost_planrevert_signpost_patch
Limitations
- Processor Trace is experimental and returns
experimental: truein MCP responses. - Network analysis is HAR-first in this release; trace-side network capture is still target/platform dependent.
- Memory Graph support is import-oriented rather than a unified
xctrace recordpath. - Outputs are intentionally bounded; raw exports are not returned by default.
Privacy
The tool is local-only. Persistence is local SQLite under ~/Library/Application Support/xcodeinstrumentmcp/cache.db unless XIM_DB_PATH overrides it for tests or custom local workflows.
Network outputs keep bodies, auth headers, and sensitive query values redacted by default. Sensitive network fields require an explicit opt-in flag or MCP argument.
Troubleshooting
xctrace not found:
- Run
xcodeinstrumentmcp doctor. - Confirm
xcrun --find xctracesucceeds.
No Time Profiler table found:
- Re-record with the Time Profiler template or import a supported Time Profiler trace.
Processor Trace record/import is unavailable:
- The analyzer is experimental and capability-gated.
- Prefer importing a known-good Processor Trace artifact when host/target versions differ.
Signpost helper build fails:
- Confirm
swift --versionworks. - Re-run
xcodeinstrumentmcp doctorandswift build -c release --package-path tools/xim-swiftsignpost.
compare --baseline-snapshot fails:
- Ensure both snapshots come from the same family, or pass explicit source artifacts with a supported comparison strategy.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.