JSPM

@mseep/xcode-mcp-server

1.0.3
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 3
  • Score
    100M100P100Q15537F
  • License MIT

An MCP server for Xcode integration, enabling AI assistants to interact with Xcode projects

Package Exports

    This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@mseep/xcode-mcp-server) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

    Readme

    Xcode MCP Server

    Xcode MCP Server Icon

    A Model Context Protocol (MCP) server that brings the power of AI to your Xcode projects. This server acts as a bridge between Claude and your local Xcode development environment, enabling intelligent code assistance, project management, and automated development tasks.

    Xcode Server MCP server

    What is Xcode MCP Server?

    At its core, this server follows a client-server architecture where Claude can securely interact with your local Xcode projects:

    flowchart LR
        subgraph "Your Computer"
            Claude["Claude Desktop"]
            MCP["Xcode MCP Server"]
            XP[("Xcode Projects")]
    
            Claude <-->|"MCP Protocol\n(Commands & Results)"| MCP
            MCP <-->|"Local Access\n(File & Build Operations)"| XP
        end

    The communication between the Xcode MCP server and your local projects happens entirely on your machineβ€”your code is not exposed to the internet. The Model Context Protocol ensures that Claude can only perform approved operations through well-defined interfaces, giving you a secure way to let AI assist with your development while maintaining complete control.

    MCP Client Compatibility

    This server implements the Model Context Protocol (MCP) specification, making it compatible with any MCP-compliant client or host. While the installation instructions focus on Claude Desktop, you can use this server with:

    • Self-built MCP clients
    • Cursor AI
    • Other MCP-compatible IDEs and tools
    • Any application that implements the MCP client specification

    The standardized protocol ensures consistent functionality across different clients while maintaining the same level of security and local-only operation.

    Key Features

    πŸ” Intelligent Project Detection

    • Automatically finds and connects to your active Xcode project
    • Supports manual project selection for precise control
    • Maintains workspace context across interactions

    πŸ“ Smart File Operations

    • Read and analyze Swift, Objective-C, and project configuration files
    • Create and modify source files with proper syntax and imports
    • Intelligent file listing with type filtering and search

    πŸ›  Project Management

    • Access project targets, configurations, and schemes
    • Analyze source files for potential issues
    • Execute builds with specific configurations
    • Run and manage test suites

    Installation

    You can install this server in three ways:

    1. Using Claude Desktop with NPM Package

    Update your Claude configuration file (~/Library/Application Support/Claude/claude_desktop_config.json):

    {
      "mcpServers": {
        "xcode": {
          "command": "npx",
          "args": [
            "-y",
            "xcode-mcp-server"
          ],
          "env": {
            "PROJECTS_BASE_DIR": "/path/to/your/xcode/projects"
          }
        }
      }
    }

    2. Global NPM Installation

    Install the package globally:

    npm install -g @modelcontextprotocol/xcode-server

    Then update your Claude configuration:

    {
      "mcpServers": {
        "xcode": {
          "command": "xcode-server",
          "env": {
            "PROJECTS_BASE_DIR": "/path/to/your/xcode/projects"
          }
        }
      }
    }

    3. From Source

    1. Clone this repository:

      git clone https://github.com/r-huijts/xcode-mcp-server.git
      cd xcode-mcp-server
    2. Install dependencies:

      npm install
    3. Set up environment variables:

      cp .env.example .env

      Edit .env and set PROJECTS_BASE_DIR to your Xcode projects directory.

    4. Build the project:

      npm run build

    Then update your Claude configuration:

    {
      "mcpServers": {
        "xcode": {
          "command": "node",
          "args": [
            "/absolute/path/to/xcode-mcp-server/dist/index.js"
          ],
          "env": {
            "PROJECTS_BASE_DIR": "/path/to/your/xcode/projects"
          }
        }
      }
    }

    Note: Replace /path/to/your/xcode/projects with the actual path to your Xcode projects directory.

    After updating the configuration, restart Claude Desktop for the changes to take effect.

    Working with the Server

    The server provides a natural interface for Claude to assist with your Xcode development. Here are some ways you can interact:

    Project Navigation

    Ask Claude to:

    • "Set my Xcode projects directory to /Users/username/Documents/XcodeProjects"
    • "What's my current active project?"
    • "Switch to the MyApp.xcodeproj project"
    • "Show me all Swift files in the project"

    Code Creation & Modification

    Get help with:

    • "Create a new view called ProfileView with a preview provider"
    • "Add a @Published email property to UserModel.swift"
    • "Set up a modern async/await networking layer"
    • "Implement Core Data models with SwiftUI bindings"

    Project Analysis & Building

    Let Claude assist with:

    • "Analyze NetworkManager.swift for potential issues"
    • "Build the project in Debug configuration"
    • "Run the unit tests for the UserModel module"
    • "What build schemes are available?"

    Development and Debugging

    Building the Project

    npm run build

    Running Tests

    npm test

    Troubleshooting

    The server provides detailed logging through stderr. Common issues and their solutions:

    1. Project Detection Issues

      • Verify your projects directory path
      • Ensure Xcode Command Line Tools are installed
      • Check file permissions
    2. Build Problems

      • Validate Xcode installation
      • Check project configurations
      • Review build settings

    Contributing

    We welcome contributions! Whether it's:

    • πŸ› Bug fixes
    • ✨ New features
    • πŸ“š Documentation improvements
    • πŸ§ͺ Additional tests

    Feel free to submit a Pull Request.

    License

    This project is licensed under the MIT License - see the LICENSE file for details.