flutter-mcp-toolkit-setup

star 322

Verify the flutter-mcp-toolkit install, run doctor preflight, troubleshoot connection issues. Use when the toolkit isn't responding or first-time setup.

Arenukvern By Arenukvern schedule Updated 6/3/2026

name: flutter-mcp-toolkit-setup description: Verify the flutter-mcp-toolkit install, run doctor preflight, troubleshoot connection issues. Use when the toolkit isn't responding or first-time setup.

When to use

Use this skill when:

  • First-time install: flutter-mcp-toolkit is not yet on PATH.
  • doctor --json returns any check with "status": "fail".
  • MCP server fails to connect or tools return vm_not_connected / connect_failed.
  • Visual capture or toolkit-bridge commands are returning unexpected errors.

Verify install

flutter-mcp-toolkit --version

Expected output: version string (e.g. flutter-mcp-toolkit 3.0.0).

If you get command not found, the binary is not on PATH:

# Binary is built to mcp_server_dart/build/ inside the repo
export PATH="$PATH:/path/to/mcp_flutter/mcp_server_dart/build"
# Or rebuild from source
cd /path/to/mcp_flutter && make build

Then verify with flutter-mcp-toolkit --version.


Run doctor

Always run doctor before any VM-dependent command:

flutter-mcp-toolkit doctor --json

Flags: --target <ws_uri> (test a specific URI), global --vm-service-uri <ws_uri> (same as --target when omitted on doctor), --timeout-ms <n> (default: 2500).

# Global URI works for doctor (same as validate-runtime)
flutter-mcp-toolkit --vm-service-uri 'ws://127.0.0.1:8181/<token>/ws' doctor --json

Sample green output:

{
  "summary": { "criticalFailures": 0 },
  "checks": [
    { "id": "vm_target_reachable", "status": "pass", "critical": true },
    { "id": "mcp_toolkit_extensions", "status": "pass", "critical": true },
    { "id": "dynamic_registry_available", "status": "pass", "critical": false }
  ]
}

Triage: criticalFailures > 0 means VM/setup is blocked — not that every tool is broken. dynamic_registry_available: pass with vm_target_reachable: fail usually means a stale URI after hot restart; run discover_debug_apps and pass the new targetId.

Read error.descriptor (not top-level) for retry policy and exit codes. Each check includes fix_command — run it directly.


Recover by error code

binary_not_found

Binary missing or not on PATH. Rebuild and add to PATH:

cd /path/to/mcp_flutter && make build
export PATH="$PATH:/path/to/mcp_flutter/mcp_server_dart/build"

vm_not_connected

Flutter app not running, stale token after restart, or URI not resolved:

flutter-mcp-toolkit exec --name discover_debug_apps --args '{}'
flutter-mcp-toolkit exec --name status --args '{}'
flutter-mcp-toolkit doctor --json --target ws://127.0.0.1:8181/<new-token>/ws

After a successful auto re-attach, meta.recovery.reattachedTo shows the new endpoint.

connect_failed

Wrong port, app not started, or stale token. Pass explicit URI from app.debugPort.wsUri:

flutter-mcp-toolkit exec --name get_vm --args '{"connection":{"uri":"ws://127.0.0.1:8181/<token>/ws"}}'

connection_selection_required

Multiple debug targets detected. List with discover_debug_apps, then pass the chosen URI from details.availableTargets explicitly to get_vm.

hot_reload_failed

Dart compilation error or VM disconnected. Check errors, fix, then retry:

flutter-mcp-toolkit exec --name get_app_errors --args '{}'

visual_capture_unsupported

macOS screen recording permission not granted or unsupported platform:

flutter-mcp-toolkit permissions request --kind visual_capture

Connection issues (deeper troubleshooting)

Port conflicts: VM service defaults to 8181. Override if another process holds it:

flutter run --debug --host-vmservice-port=8182 -d macos
flutter-mcp-toolkit --dart-vm-port 8182 doctor --json

Use flutter run --machine and copy app.debugPort.wsUri when you need the exact websocket URI (recommended for validate-runtime and exec).

Flutter app not in debug mode: Release/profile builds don't expose the VM service. Always use flutter run --debug.

mcp_toolkit not initialized: Doctor's mcp_toolkit_extensions check will fail. Add before runApp — use flutter-mcp-toolkit codegen-init to generate the boilerplate (see CLI surface below). After adding, hot restart (not hot reload — binding init requires a full restart).

Multiple apps / wrong target: Pass --target with the exact websocket URI:

flutter-mcp-toolkit doctor --json --target ws://127.0.0.1:8181/<token>/ws

CLI surface

The binary is flutter-mcp-toolkit (built to mcp_server_dart/build/).

Subcommand Purpose Minimal example
exec Run a single named command against the VM flutter-mcp-toolkit exec --name get_vm --args '{}'
batch Run multiple commands in one call flutter-mcp-toolkit batch --steps '[{"name":"get_vm"},{"name":"status"}]'
schema Print the JSON schema for a named command flutter-mcp-toolkit schema --name hot_reload_flutter
capabilities List all registered capabilities flutter-mcp-toolkit capabilities
serve Start the MCP server (stdio transport) flutter-mcp-toolkit serve
snapshot create Capture and save a named snapshot flutter-mcp-toolkit snapshot create --name baseline --args '{}'
snapshot diff Diff two snapshots flutter-mcp-toolkit snapshot diff --from baseline --to current
bundle create Package a snapshot into a publishable bundle flutter-mcp-toolkit bundle create --from-snapshot baseline --output ./out
doctor Run preflight checks (VM + toolkit + registry) flutter-mcp-toolkit doctor --json
permissions status Check a permission (e.g. visual_capture) flutter-mcp-toolkit permissions status --kind visual_capture
permissions request Request a permission flutter-mcp-toolkit permissions request --kind visual_capture
permissions open-settings Open OS settings for a permission flutter-mcp-toolkit permissions open-settings --kind visual_capture
validate-runtime End-to-end VM + toolkit + capture smoke test flutter-mcp-toolkit validate-runtime --target ws://127.0.0.1:8181/<token>/ws
init <agent> Install skills + MCP server config for an AI agent flutter-mcp-toolkit init claude-code
codegen-init Add toolkit dependency and emit main.dart boilerplate flutter-mcp-toolkit codegen-init

Global flags (before the subcommand): --dart-vm-port <n>, --dart-vm-host <host>, --vm-service-uri <ws_uri>, --log-level <level>, --dumps, -h/--help.

VM targeting: Global --vm-service-uri applies to doctor and validate-runtime when subcommand --target is omitted. If both are set and differ, --target wins (stderr warning).

validate-runtime screenshots: the first capture uses auto (often desktop_window on macOS). If that step fails with a retryable get_screenshots_failed, the CLI retries once with flutter_layer. On success, data.summary.captureFallbackUsed is true in the JSON envelope.


init <agent>

Install the flutter-mcp-toolkit skills + MCP server config for an AI agent.

Targets: claude-code | cursor | codex | cline | agents-skills | all.

flutter-mcp-toolkit init claude-code        # install for Claude Code (project-scoped)
flutter-mcp-toolkit init cursor --scope user # install user-globally for Cursor
flutter-mcp-toolkit init all --mode cli      # install for every detected agent in CLI mode

Mode auto-detects (MCP if registered, else CLI). Override with --mode mcp|cli|auto.

Alternative (skills only, open ecosystem): npx skills add Arenukvern/mcp_flutter -a cursor -y installs the same SKILL.md bundles via skills.sh; it does not write mcp.json — run init afterward or configure mcpServers manually. See AI agent overview.


codegen-init

From a Flutter project root, add mcp_toolkit as a dependency and emit the boilerplate snippet for lib/main.dart.

cd my-flutter-app
flutter-mcp-toolkit codegen-init             # runs `flutter pub add` + prints snippet
flutter-mcp-toolkit codegen-init --no-pub-add  # snippet only, skip pub add

Reinstall / upgrade

The install script is idempotent — re-running it replaces the binary in place:

curl -fsSL https://raw.githubusercontent.com/Arenukvern/mcp_flutter/main/install.sh | bash

After reinstall, verify with flutter-mcp-toolkit --version.

Install via CLI
npx skills add https://github.com/Arenukvern/mcp_flutter --skill flutter-mcp-toolkit-setup
Repository Details
star Stars 322
call_split Forks 36
navigation Branch main
article Path SKILL.md
More from Creator