roo-code-custom-mode-editor-mcp-server

roo-code-custom-mode-editor-mcp-server

0

The roo-code-custom-mode-editor-mcp-server is an MCP server designed to manage Roo Code custom modes files efficiently. It offers functionality to list, create, and update custom modes without overwriting existing files.

roo-code-custom-mode-editor-mcp-server

An MCP server that knows how to edit the Roo Code custom modes file

Avoids having to overwrite the .roomodes file using file writes or edit the json with unreliable diffs.

The MCP server exposes tools to:

  • List all custom modes
  • Create a new custom mode
  • Get the fields of a custom mode ( "slug","name", "roleDefinition", "customInstructions", "groups")
  • Put and overwrite any one or more fields of a custom mode.

Fields are:

  • slug : short string
  • name : short string
  • roleDefinition : long string
  • customInstructions : long string
  • groups : array of short strings

Usage

This server is located at https://github.com/raymondlowe/roo-code-custom-mode-editor-mcp-server and can be run using the following command:

npx https://github.com/raymondlowe/roo-code-custom-mode-editor-mcp-server

MCP Configuration

To use with Roo Code, add the server config to the MCP settings file:

{
  "mcpServers": {
    "roo-code-custom-mode-editor": {
      "command": "node",
      "args": [
        "/path/to/roo-code-custom-mode-editor-mcp-server/build/index.js"
      ],
      "disabled": false,
      "alwaysAllow": []
    }
  }
}

Development

Install dependencies:

npm install

Build the server:

npm run build

For development with auto-rebuild:

npm run watch

Debugging

Since MCP servers communicate over stdio, debugging can be challenging. We recommend using the MCP Inspector, which is available as a package script:

npm run inspector

The Inspector will provide a URL to access debugging tools in your browser.

Tools

list_custom_modes

Lists all custom modes in the .roomodes file.

create_custom_mode

Creates a new custom mode with the specified fields.

Parameters:

  • slug: string
  • name: string
  • roleDefinition: string
  • customInstructions: string
  • groups: string[]

get_custom_mode_fields

Gets the fields of a custom mode.

Parameters:

  • slug: string

put_custom_mode_fields

Updates one or more fields of a custom mode.

Parameters:

  • slug: string
  • fields: object containing any of the following fields:
    • name: string
    • roleDefinition: string
    • customInstructions: string
    • groups: string[]