Skip to main content

MCP bridge for AI-assisted type design in GlyphsApp

Project description

GlyphsMCP

MCP bridge for AI-assisted type design in GlyphsApp.

Lets Claude, Cursor, or any MCP client read and write font data directly in GlyphsApp — bidirectional, real-time, live in the editor.

MCP Client  ←(stdio/MCP)→  MCP Server  ←(HTTP/localhost)→  GlyphsApp Plugin

Requirements

Installation

1. Install the GlyphsApp plugin

From Plugin Manager (recommended): Open GlyphsApp, go to Window > Plugin Manager, search for MCP, and click Install.

Manual install: Download GlyphsMCP.glyphsPlugin.zip from the latest release, unzip, and double-click to install.

Restart GlyphsApp. You should see an MCP menu in the menu bar.

2. Connect your MCP client

Claude Code:

claude mcp add glyphs-mcp -- uvx glyphs-mcp

Cursor / VS Code — add to your MCP config:

{
  "mcpServers": {
    "glyphs-mcp": {
      "command": "uvx",
      "args": ["glyphs-mcp"]
    }
  }
}

That's it.

GlyphsMCP

3. Use it

Open a font in GlyphsApp, then ask your AI assistant:

"Run a full color audit on my font and tell me which glyphs are inconsistent"

"Compare the stems across all my lowercase letters"

"Check if my figures are consistent with my letters"

"Make the R 20% wider and harmonize the curves"

Tools

GlyphsMCP

Read

Tool Description
get_font_info Font family name, UPM, glyph count, masters, axes, metrics, instances
list_glyphs All glyph names with unicode, category, layer count
get_glyph Full glyph data: paths, components, anchors, sidebearings for all layers
get_glyph_svg Glyph rendered as SVG markup
get_selection Current editor selection: active glyph, layer, selected paths/nodes
get_masters All masters with metrics and axis positions
get_kerning All kerning pairs for a master
get_features OpenType feature code

Write

Tool Description
create_glyph Create a new glyph with optional width, unicode, and initial paths
set_glyph_paths Replace all paths on a glyph's layer
set_glyph_width Set advance width
set_glyph_color Set color label (0-11)
set_glyph_unicode Assign or clear a unicode value
rename_glyph Rename a glyph
duplicate_glyph Copy a glyph with all layers to a new name
delete_glyph Delete a glyph
set_kerning_pair Add or modify a kerning pair
delete_kerning_pair Remove a kerning pair
set_feature_code Create or update an OpenType feature

Analysis

Tool Description
measure_stems Measure stem thicknesses via perpendicular ray-casting
compare_stems Compare stems across glyphs using industry patterns
get_stem_targets Designer's intended stem values from Dimensions palette
measure_color Measure ink density for a single glyph
compare_color Compare ink density across glyphs
audit_font_color Full font color audit across all letters
check_overshoots Overshoot consistency at baseline, x-height, cap-height
compare_proportions Width ratios, related-form groups, ordering constraints
check_diagonal_weights Diagonal stem thickness vs straight reference
check_junctions Stem thinning at arch/bowl junctions
check_related_forms Cross-validate figures and letters (0/O, 6/9, 8/S, 3/B)
check_punctuation Mirrored pair widths, dash ratios, related punctuation

Analysis tools automatically mark glyphs in GlyphsApp: red = inconsistent, orange = unreliable, yellow = optical compensation, green = pass.

RMX Tools

Requires RMX Tools for full functionality. Falls back to native transforms when RMX is unavailable.

Tool Description
rmx_harmonize Optimize bezier curves
rmx_scale Scale by percentage with stroke weight compensation
rmx_tune Adjust weight, width, height, or slant
rmx_monospace Adjust a glyph to a fixed advance width
rmx_batch Apply any RMX filter to multiple glyphs

Advanced

Tool Description
execute_in_glyphs Run arbitrary Python inside GlyphsApp (disabled by default)

Multi-master support

All tools accept an optional master_id parameter. When omitted, read/write tools use the first master. Analysis tools analyze all masters and return per-master results.

Menu

The plugin adds an MCP menu to the menu bar:

  • Start/Stop Server — toggle the HTTP server
  • Connect — copy ready-to-paste MCP config for Claude Code or VS Code (and forks)
  • Documentation — open this page in your browser
  • Allow Execute Endpoint — enable execute_in_glyphs (off by default for security)

Preferences

Key Default Description
com.glyphsmcp.port 7745 HTTP server port
com.glyphsmcp.autostart true Start server on GlyphsApp launch
com.glyphsmcp.allowExecute false Enable the execute endpoint

GlyphsMCP

How it works

The GlyphsApp plugin runs an HTTP server on 127.0.0.1:7745 inside GlyphsApp. All GlyphsApp API calls run on the main thread via a queue + NSTimer bridge for thread safety.

The MCP server is a thin translation layer — it receives MCP tool calls via stdio and forwards them as HTTP requests to the plugin.

Roadmap

  • Kerning analysis — Multi-master kerning consistency checks, inspired by Kern On
  • Auto-update — Check for updates directly from the GlyphsMCP menu
  • Analytics — Optional usage telemetry to guide development priorities

License

MIT — Nicolas Massi www.nico.works

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

glyphs_mcp-0.1.1.tar.gz (351.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

glyphs_mcp-0.1.1-py3-none-any.whl (361.1 kB view details)

Uploaded Python 3

File details

Details for the file glyphs_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: glyphs_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 351.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for glyphs_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 ed5997f9caad89bbbeefe37edf25f153e0f5ba3efa1de04f801c847944f16163
MD5 159b1eeb1379ab954d6d512b1bf91c7d
BLAKE2b-256 6ed142ba0288cc69298c864a3890f13ca0b74e92f179a80f09ae40a0bc8a37f6

See more details on using hashes here.

File details

Details for the file glyphs_mcp-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: glyphs_mcp-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 361.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for glyphs_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 44ce2e220668f37b5a3a08a020be6afe12bc6d4b20f7a110cf0ffd19aeb3e860
MD5 d3373c6c3d51a65981b53027cc4b2ae8
BLAKE2b-256 c2079c9eab56931559088a0d33bbcaa0e40d8d066d4a835c1468a12e7fe20add

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page