MCP ExplorerExplorer

Zen Ai Mcp Devtools

@daoch4non 5 days ago
2 Unlicense
FreeCommunity
AI Systems
#agent#agentic-ai#agents#aider#automation-tools#cli#cline#copilot#cursor#git#mcp-server#mcp-servers#mcp-sse#mcp-tools#modelcontextprotocol#roocode#sse#tasks#vibe-coding#windsurf
mcp sse server for vibe coding / nested agents / aider / git / terminal

Overview

What is Zen Ai Mcp Devtools

mcp-devtools is a multi-functional development tool server that enables seamless interaction with local files, Git repositories, and terminal commands through SSE (Server-Sent Events). It empowers developers with AI-assisted coding capabilities and direct management of programming tasks.

Use cases

mcp-devtools can be utilized to enhance AI chat assistants like ChatGPT or integrations with code editors such as VSCode. It allows for direct code editing, Git operations, and the execution of terminal commands, combining AI assistance for efficient workflow management.

How to use

To use mcp-devtools, install the package via PyPI or GitHub, then run the server. Integrate it with your AI assistant by configuring the MCP settings file to point to the server’s SSE endpoint. Use the available tools to perform various coding tasks, including Git management and AI code modifications.

Key features

Key features include detailed Git management operations (status, diff, commit, branch creation), direct file operations (read, write, search and replace), and AI-assisted file editing using Aider for seamless updates. It also enables execution of arbitrary terminal commands.

Where to use

mcp-devtools is ideal for local development environments requiring Git functionalities, code editing, and automation. It is particularly useful in projects that involve collaborative coding through AI assistants or automation scripts within interactive IDEs.

Content

⚙️ mcp-devtools: multi-functional development tools MCP server over SSE 🌸 リードミー 🏮 读我

GitHub repository
GitHub Workflow Status
PyPI

https://github.com/user-attachments/assets/05670a7a-72c5-4276-925c-dbd1ed617d99

⬇️ Skip to Downloads

⛎ Use Cases

  • 🌐 Use it to extend online chat-based assistants such as ChatGPT, Google Gemini or AI Studio, Perplexity, Grok, OpenRouter Chat, DeepSeek, Kagi, T3 Chat with direct access to local files, git, terminal commands execution and AI-assisted file editing capabilities via MCP-SuperAssistant or similar projects.
  • 👩🏻‍💻 Use it to boost code editors like Cursor, Windsurf or VSCode extensions like Roo Code, Cline, Copilot or Augment with intuitive Git management and AI-assisted file editing capabilities and say goodbye to those pesky diff application failures wasting your time or Roo having trouble... breaking your carefully engineered automation workflows. Aider seems to get diffs right! (if it still doesn’t work quite well, try to find perfect way for your AI model by explicitly passing different edit_format parameters to ai_edit tool):
    • unidiff seems to work better with GPT
    • diff-fenced performs best with Gemini
    • diff provides balanced quick results on all models (default)
    • whole is the slowest but most reliable option as it simply overwrites file

🦘 Agentic-Driven Workflows with Roo

https://github.com/user-attachments/assets/4d218e5e-906c-4d24-abc3-09ab0acdc1d0

  • For Roo Code, place the .roomodes file and .roo/ folder into your repo root to experience automated two-levels deep nested agents execution flow:

    https://github.com/user-attachments/assets/a2f5e4f0-4092-4a0e-9805-f5c41d1bbb23

    😺 Basic Flow (Roo 🪃 adapted to summon Aider as level 2 subagent)

    • 🛸 AI Orchestrator agent is your Basic Flow manager, so talk to it if you prefer to keep your agent management simple. It coordinates agents by breaking complex problems into logical subtasks and delegates each using the Roo Code native new_task tool, providing comprehensive, context-rich instructions for each specialized AI agent. Each subtask receives explicit instructions to only perform the outlined work and signal completion using native attempt_completion tool. The orchestrator tracks all subtasks, synthesizes results, and suggests workflow improvements to reach near complete automation of your dev workflow (this pdf might help). Works fine using fast models with reasoning enabled to speed up your workflow or deep reasoning models to add basic subtasks management.
    • 🤖 AI Code and 👾 AI Debug agents (fast models like Gemini Flash 2.5 / GPT 4.1 work well here with lower temperature) delegate all code changes to Aider via ai_edit tool and enforce strict MCP tool schema compliance, then review of Aider agent work with automated agent redelegation on unsatisfactory or missing results by checking diff (or stdout) output of ai_edit tool call.
    • 👽 AI Architect and 🔬 AI Researcher agents are responsible for architectural directions and geneal R&D needs. Deep reasoning models (like DeepSeek R1 / Gemini Pro 2.5 / OpenAI o1/o3/o4mini) are recommended for 👽 AI Architect, and internet-connected models (like Perplexity Sonar) are recommended for 🔬 AI Researcher. Adjust temperatures based on creativity level needed.

    😼 Advanced Flow (如如 🧭 adapted to summon Aider as level 2 subagent) ℹ️

    • 🧭 Rooroo Navigator agent is your Advanced Flow manager, so talk to it if you prefer to keep your agent management in orderly manner. Responsible for overall project coordination and task orchestration, task lifecycles, delegation to Planner, Developer, Analyzer, Idea Sparker, processes your commands, and oversees your workflows. Provides context.md files to tasks, either the ones generated by 🗓️ Rooroo Planner, or generates new one if Planner wasn’t deemed neccessary for the task. If used without deep reasoning model, Navi tends to forget generating them on its own, but delegated agents will remind Navi, and task will be redelegated correctly with context.md provided.
      Decide on Navi LLM model choice like this: If you prefer speed but can tolerate some inefficencies, use fast models with reasoning enabled. If you don’t mind Navi thinking for a minute on every step to provide predictable results, use deep reasoning model here as well. Still can’t decide? This DeepSeek R1/V3 hybrid is a good candidate.
    • 👩🏻‍💻 Rooroo Developer agent gets detailed instructions from 🧭 Rooroo Navigator via context.md passed to it and delegates all code changes to Aider subagent via ai_edit tool then reviews Aider work results with automated subagent redelegation on unsatisfactory or missing results, outputs task result in strict JSON schema asking Navi for clarification or complaining if context file was not provided. (context file in question needs to be generated either by Navi itself or via invocation of specialized 🗓️ Rooroo Planner agent). Same model recommendations apply from Basic flow.
    • 📊 Rooroo Analyzer agent combines the functions of 👽 AI Architect and 🔬 AI Researcher from Basic flow, it also gets task context via context.md passed and complains back to Navi if it wasn’t found. Deep reasoning models remommended. Internet-connected models might provide more relevant analysis results. Adjust temperature based on creativity needed.
    • 🗓️ Rooroo Planner agent decomposes complex goals requiring multi-expert coordination into clear, actionable sub-tasks for other agents to do. It is also the main supplier of context.md files for them. Deep reasoning model also recommended.
    • 💡 Rooroo Idea Sparker agent is your brainstorming copilot and innovation catalyst, talk to it if you’d like some creative thinking and assumption challenging done, or just explore something new with it. Deep reasoning model with higher temperature set or internet-connected model recommended here.

    ℹ️ Advanced Flow Tutorial

    • Initiate: Select 🧭 Rooroo Navigator agent and state your goal.
    • Navigator Triage: The Navigator assesses your request:
      • For complex/uncertain tasks, it engages the 🗓️ Rooroo Planner agent to break it down into sub-tasks with context.md briefings. These go into the .rooroo/queue.jsonl.
      • For simple, clear single-expert tasks, it prepares context.md and may execute directly or queue the task.
    • If ambiguous, it asks you for clarification.
    • Execution: The Navigator dispatches tasks from the queue to the assigned Rooroo expert. The expert uses its context.md and stores outputs in .rooroo/tasks/TASK_ID/.
    • Reporting: The expert returns a JSON Output Envelope (status, message, artifacts) to the Navigator.
    • Processing & Iteration: The Navigator parses the envelope:
      • NeedsClarification: Relays question to you.
      • Done/Failed: Logs event, updates queue, informs you. Auto-proceeds with plans if applicable.
    • Monitor: Track progress via .rooroo/queue.jsonl and .rooroo/logs/activity.jsonl.

1️⃣ Prerequisites

  • Python 3.12, uv

🐧 Linux/macOS

curl -LsSf https://astral.sh/uv/install.sh | sh

🪟 Windows

powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"

2️⃣ Usage

🐍 Running from PyPi

uvx [email protected] -p 1337

🐈‍⬛ Running from GitHub

🐧 Linux/macOS

git clone "https://github.com/daoch4n/zen-ai-mcp-devtools/"
cd zen-ai-mcp-devtools
./server.sh -p 1337

🪟 Windows

git clone "https://github.com/daoch4n/zen-ai-mcp-devtools/"
cd zen-ai-mcp-devtools
.\server.ps1 -p 1337

3️⃣ MCP Server Configuration

To integrate mcp-devtools with your AI assistant, add the following configuration to your MCP settings file:

{
  "mcpServers": {
    "devtools": {
      "url": "http://127.0.0.1:1337/sse",
      "disabled": false,
      "alwaysAllow": [],
      "timeout": 900
    }
  }
}

4️⃣ AI System Prompt Example

ℹ️ Show Prompt


**Persona: Lead Developer AI**

You are an expert, hands-on software developer. Your primary function is to understand user requests, formulate a clear plan, and execute that plan using the provided development tools. You are methodical, precise, and communicative. Your goal is to write, modify, and manage code and repository state to solve user problems effectively.

**Core Objective: Plan, Execute, Verify**

For any given task, you will operate in a clear cycle:
1.  **Plan:** Analyze the request and create a public, step-by-step plan.
2.  **Execute:** Perform one step of the plan at a time using the appropriate tool.
3.  **Verify & Report:** Confirm the result of each action and inform the user of the outcome before proceeding to the next step.

**Guiding Principles**

* **User-Centric Initialization:** At the very beginning of the conversation, your first action must be to ask the user for the absolute path to the project's working directory. Store this as the `{repo_path}` for all subsequent operations.
* **Path Integrity:** The `{repo_path}` is critical for all tool calls.
    * **Instruction:** For any `devtools` tool, you must provide the `{repo_path}` in the `repo_path` parameter.
    * **Instruction:** When using `execute_command` for file operations (e.g., `touch`, `mkdir`, `rm`), construct the command using the absolute path by prefixing the filename with `{repo_path}`.
* **Tool Safety and Clarity:** Your tool inputs must be predictable and safe.
    * **Instruction:** When using the `ai_edit` tool, you must describe any symbols that could break a JSON structure (like square or curly brackets) in plain language within the `instructions` field. This ensures the integrity of the tool call.

**Example Workflow**

This example demonstrates the correct application of your principles for a task: "Add error handling to the `database_connect` function in `utils.py`."

***
**Step 1: Ask for the Repository Path (Your First Action)**

**You:** "To begin, please provide the absolute path to your repository's working directory."

**User:** "/home/user/projects/my-flask-app"

---
**Step 2: Formulate and Share the Plan**

**You:** "Understood. My plan is as follows:
1.  Read the content of `src/utils.py` to understand the current structure of the `database_connect` function.
2.  Use the `ai_edit` tool to add a `try...except` block to the function.
3.  List the files in the `src` directory to confirm the modification timestamp has changed."

---
**Step 3: Execute Step 1 of the Plan (Read File)**

**You:** "First, I will read the file to get the necessary context."
<tool_code>
print(devtools.read_file(
  repo_path="/home/user/projects/my-flask-app",
  file_path="src/utils.py"
))
</tool_code>

---
**Step 4: Execute Step 2 of the Plan (Edit File with Verbal Descriptions)**

**You:** "Now I will add the error handling."
<tool_code>
print(devtools.ai_edit(
  repo_path="/home/user/projects/my-flask-app",
  file_path="src/utils.py",
  instructions="""Wrap the existing logic inside the `database_connect` function with error handling.
  1. Before the line `connection = ...`, insert a new line with the word 'try' followed by a colon.
  2. Indent all the existing code within the function one level deeper.
  3. After the existing code, add a new line with the word 'except', followed by 'Exception', the word 'as', the variable 'e', and a colon.
  4. Inside the except block, add a line to print the phrase 'An error occurred:', followed by the error variable 'e'.
  """
))
</tool_code>

---
**Step 5: Execute Step 3 of the Plan (Verify with `execute_command`)**

**You:** "Finally, I will verify the file was modified."
<tool_code>
print(devtools.execute_command(
  repo_path="/home/user/projects/my-flask-app",
  command="ls -l src/"
))
</tool_code>

⁉️ Known Issues and Workarounds

💾 Direct Code Editing vs 🤖 AI-assisted Editing

Issue:

  • 🔍 When using the write_to_file tool for direct code editing, especially with languages like JavaScript that utilize template literals (strings enclosed by backticks), you may encounter unexpected syntax errors. This issue stems from how the AI assistant generates the content string, where backticks and dollar signs within template literals might be incorrectly escaped with extra backslashes (\).

Mitigation:

  • 🔨 The write_to_file,search_and_replace and git_apply_diff tools are dynamically integrated with tsc (TypeScript compiler) for conditional type checking of .js, .mjs, and .ts files on edit. The output of tsc --noEmit --allowJs is provided as part of the tool’s response. AI assistants should parse this output to detect any compiler errors and should not proceed with further actions if errors are reported, indicating a problem with the written code.

Workarounds:

  • 🤖 (most reliable) Instruct your AI assistant to delegate editing files to MCP-compatible coding agent by using ai_edit tool instead, as it is more suitable for direct code manipulation, automatically commits changes and produces resulting diff as tool output, and let AI assistant act as task orchestrator that will write down plans and docs with write_to_file tool then delegate actual coding to specialized agent, get its report (diff) as tool call result, use git_read_file tool to double check agent’s work, and manage commits and branches (ai_edit tool basically integrates Aider via some logic ported from its MCP bridge).
  • 🖥️ (if you’re feeling lucky) Instruct your AI assistant to craft a terminal command to edit problematic file via execute_command tool.

❔ Aider limitations due to its commit-first nature

Issue:

  • 🔍 When using ai_edit tool in a dirty repo state, e.g. during merge or rebase active, it will probably get stuck trying to apply commit.

Workarounds:

  • ⚙️ Temporarily disable auto commiting functions in your .aider.conf.yml configuration file.

🙈 Automation-Related Security Considerations

  • 🛡️ For automated workflows, always run MCP Servers in isolated environments (🐧Firejail or 🪟Sandboxie)
  • 🗃️ Filesystem access boundaries are maintained via passing repo_path to every tool call, so AI assistant only has read/write access to files in the current workspace (relative to any path AI decides to pass as repo_path , make sure system prompt is solid on cwd use).
  • ⚠️ execute_command doesn’t have strict access boundaries defined, while it does execute all commands with cwd set to repo_path (relative to it), nothing is there to stop AI from passing full paths to other places it seems fit; reading, altering or deleting unintended data on your whole computer, so execise extreme caution with auto-allowing execute_command tool or at least don’t leave AI assistant unattended while doing so. MCP server is not responsible for your AI assistant executing rm -rf * in your home folder.

ℹ️ Available Tools

git_status

  • Description: Shows the current status of the Git working tree, including untracked, modified, and staged files.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        }
      },
      "required": [
        "repo_path"
      ]
    }

git_diff_all

  • Description: Shows all changes in the working directory, including both staged and unstaged modifications, compared to the HEAD commit. This provides a comprehensive view of all local changes.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        }
      },
      "required": [
        "repo_path"
      ]
    }

git_diff

  • Description: Shows differences between the current working directory and a specified Git target (e.g., another branch, a specific commit hash, or a tag).
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "target": {
          "type": "string",
          "description": "The target (e.g., branch name, commit hash, tag) to diff against. For example, 'main', 'HEAD~1', or a full commit SHA."
        }
      },
      "required": [
        "repo_path",
        "target"
      ]
    }

git_stage_and_commit

  • Description: Stages specified files (or all changes if no files are specified) and then commits them to the repository with a given message. This creates a new commit in the Git history.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "message": {
          "type": "string",
          "description": "The commit message for the changes."
        },
        "files": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "An optional list of specific file paths (relative to the repository root) to stage before committing. If not provided, all changes will be staged."
        }
      },
      "required": [
        "repo_path",
        "message"
      ]
    }

git_reset

  • Description: Unstages all currently staged changes in the repository, moving them back to the working directory without discarding modifications. This is equivalent to git reset without arguments.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        }
      },
      "required": [
        "repo_path"
      ]
    }

git_log

  • Description: Shows the commit history for the repository, listing recent commits with their hash, author, date, and message. The number of commits can be limited.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "max_count": {
          "type": "integer",
          "default": 10,
          "description": "The maximum number of commit entries to retrieve. Defaults to 10."
        }
      },
      "required": [
        "repo_path"
      ]
    }

git_create_branch

  • Description: Creates a new Git branch with the specified name. Optionally, you can base the new branch on an existing branch or commit, otherwise it defaults to the current active branch.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "branch_name": {
          "type": "string",
          "description": "The name of the new branch to create."
        },
        "base_branch": {
          "type": "string",
          "nullable": true,
          "description": "Optional. The name of the branch or commit hash to base the new branch on. If not provided, the new branch will be based on the current active branch."
        }
      },
      "required": [
        "repo_path",
        "branch_name"
      ]
    }

git_checkout

  • Description: Switches the current active branch to the specified branch name. This updates the working directory to reflect the state of the target branch.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "branch_name": {
          "type": "string",
          "description": "The name of the branch to checkout."
        }
      },
      "required": [
        "repo_path",
        "branch_name"
      ]
    }

git_show

  • Description: Shows the metadata (author, date, message) and the diff of a specific commit. This allows inspection of changes introduced by a particular commit.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "revision": {
          "type": "string",
          "description": "The commit hash or reference (e.g., 'HEAD', 'main', 'abc1234') to show details for."
        }
      },
      "required": [
        "repo_path",
        "revision"
      ]
    }

git_apply_diff

  • Description: Applies a given diff content (in unified diff format) to the working directory of the repository. This can be used to programmatically apply patches or changes.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "diff_content": {
          "type": "string",
          "description": "The diff content string to apply to the repository. This should be in a unified diff format."
        }
      },
      "required": [
        "repo_path",
        "diff_content"
      ]
    }

git_read_file

  • Description: Reads and returns the entire content of a specified file within the Git repository’s working directory. The file path must be relative to the repository root.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "file_path": {
          "type": "string",
          "description": "The path to the file to read, relative to the repository's working directory."
        }
      },
      "required": [
        "repo_path",
        "file_path"
      ]
    }

search_and_replace

  • Description: Searches for a specified string or regex pattern within a file and replaces all occurrences with a new string. Supports case-insensitive search and line-range restrictions. It attempts to use sed for efficiency, falling back to Python logic if sed fails or makes no changes.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "file_path": {
          "type": "string",
          "description": "The path to the file to modify, relative to the repository's working directory."
        },
        "search_string": {
          "type": "string",
          "description": "The string or regex pattern to search for within the file."
        },
        "replace_string": {
          "type": "string",
          "description": "The string to replace all matches of the search string with."
        },
        "ignore_case": {
          "type": "boolean",
          "default": false,
          "description": "If true, the search will be case-insensitive. Defaults to false."
        },
        "start_line": {
          "type": "integer",
          "nullable": true,
          "description": "Optional. The 1-based starting line number for the search and replace operation (inclusive). If not provided, search starts from the beginning of the file."
        },
        "end_line": {
          "type": "integer",
          "nullable": true,
          "description": "Optional. The 1-based ending line number for the search and replace operation (inclusive). If not provided, search continues to the end of the file."
        }
      },
      "required": [
        "repo_path",
        "file_path",
        "search_string",
        "replace_string"
      ]
    }

write_to_file

  • Description: Writes the provided content to a specified file within the repository. If the file does not exist, it will be created. If it exists, its content will be completely overwritten. Includes a check to ensure content was written correctly and generates a diff.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory."
        },
        "file_path": {
          "type": "string",
          "description": "The path to the file to write to, relative to the repository's working directory. The file will be created if it doesn't exist, or overwritten if it does."
        },
        "content": {
          "type": "string",
          "description": "The string content to write to the specified file."
        }
      },
      "required": [
        "repo_path",
        "file_path",
        "content"
      ]
    }

execute_command

  • Description: Executes an arbitrary shell command within the context of the specified repository’s working directory. This tool can be used for tasks not covered by other specific Git tools, such as running build scripts, linters, or other system commands.
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the directory where the command should be executed."
        },
        "command": {
          "type": "string",
          "description": "The shell command string to execute (e.g., 'ls -l', 'npm install')."
        }
      },
      "required": [
        "repo_path",
        "command"
      ]
    }

ai_edit

  • Description: AI pair programming tool for making targeted code changes using Aider. Use this tool to:

    1. Implement new features or functionality in existing code
    2. Add tests to an existing codebase
    3. Fix bugs in code
    4. Refactor or improve existing code
    5. Make structural changes across multiple files

    The tool requires:

    • A repository path where the code exists
    • A detailed message describing what changes to make. Please only describe one change per message. If you need to make multiple changes, please submit multiple requests.

    Edit Format Selection:
    If the edit_format option is not explicitly provided, the default is selected based on the model name:

    • If the model includes gemini, defaults to diff-fenced
    • If the model includes gpt, defaults to udiff
    • Otherwise, defaults to diff

    Best practices for messages:

    • Be specific about what files or components to modify
    • Describe the desired behavior or functionality clearly
    • Provide context about the existing codebase structure
    • Include any constraints or requirements to follow

    Examples of good messages:

    • “Add unit tests for the Customer class in src/models/customer.rb testing the validation logic”
    • “Implement pagination for the user listing API in the controllers/users_controller.js file”
    • “Fix the bug in utils/date_formatter.py where dates before 1970 aren’t handled correctly”
    • “Refactor the authentication middleware in middleware/auth.js to use async/await instead of callbacks”
  • Input Schema:

    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository's working directory where the AI edit should be performed."
        },
        "message": {
          "type": "string",
          "description": "A detailed natural language message describing the code changes to make. Be specific about files, desired behavior, and any constraints."
        },
        "files": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "A list of file paths (relative to the repository root) that Aider should operate on. This argument is mandatory."
        },
        "options": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Optional. A list of additional command-line options to pass directly to Aider (e.g., ['--model=gpt-4o', '--dirty-diff']). Each option should be a string."
        },
        "edit_format": {
          "type": "string",
          "enum": [
            "diff",
            "diff-fenced",
            "udiff",
            "whole"
          ],
          "default": "diff",
          "description": "Optional. The format Aider should use for edits. Defaults to 'diff'. Options: 'diff', 'diff-fenced', 'udiff', 'whole'."
        }
      },
      "required": [
        "repo_path",
        "message",
        "files"
      ]
    }

aider_status

  • Description: Check the status of Aider and its environment. Use this to:
    1. Verify Aider is correctly installed
    2. Check API keys
    3. View the current configuration
    4. Diagnose connection or setup issues
  • Input Schema:
    {
      "type": "object",
      "properties": {
        "repo_path": {
          "type": "string",
          "description": "The absolute path to the Git repository or working directory to check Aider's status within."
        },
        "check_environment": {
          "type": "boolean",
          "default": true,
          "description": "If true, the tool will also check Aider's configuration, environment variables, and Git repository details. Defaults to true."
        }
      },
      "required": [
        "repo_path"
      ]
    }

Tools

No tools

Comments