Font Proof — Complete Feature Reference

How Font Proof Works

Font Proof is a native macOS app for creating font proofs — the typographic test documents that type designers use to evaluate their work in progress. The core idea is simple: what you see is what you get.

Live PDF Rendering

Everything in Font Proof is rendered as a live PDF. The proof document is a real PDF that updates in real-time as you change settings, swap fonts, or edit content. This isn’t a web preview or a rough approximation — it’s the same CoreText rendering pipeline that produces the final exported PDF. What you see on screen is exactly what you’ll get in print.

The PDF viewer supports single page, two-page, and continuous scroll display modes with zoom from 10% to 1000%.

Document Structure

A Font Proof document (.fontproof) is a JSON file containing one or more sections. Each section has its own type (Basic, Waterfall, Glyph Grid, etc.), its own text content, and its own independent typography settings. Sections are displayed sequentially in the proof, and each section generates one or more pages depending on content length and the “overflow to multiple pages” setting.

Fonts are selected at the document level and shared across sections. By default, each section renders a separate page for each selected font. Sections can override this with per-section font selection, font disabling, or inline font mixing.

Page layout (dimensions, margins, header position) is set at the document level. Dozens of presets are available (Letter, A4, device screens, etc.) or you can specify custom dimensions.

The Workflow

  1. Create a new document or use a template
  2. Add fonts — from the system, imported files, or directly from Glyphs.app
  3. Add sections — choose a type, enter or link content, adjust typography
  4. The proof renders live as you work
  5. Export to PDF for print or markup

Font Proof is designed to stay open alongside your font editor. With Live Reload enabled, changes you make in Glyphs are reflected in the proof within seconds.


Live Glyphs Integration

What it is: Font Proof connects directly to Glyphs.app via a native Objective-C bridge (NSConnection). When you select a Glyphs font in Font Proof, the app exports and registers that instance in real-time.

How it works:

  • Monitors open Glyphs documents for changes (font edits, instance changes, document open/close)
  • Exports instances to a temp directory and registers them with CoreText
  • Tracks instances by index (not just name) to handle duplicate style names
  • Debounced reloads prevent redundant exports during rapid edits
  • Sleep/wake handling avoids stale IPC connections
  • Toggleable via “Live Reload” switch in toolbar
  • Supports “Install for Testing” fonts from Glyphs as a separate source

What it’s for: Type designers working in Glyphs can see their changes in a professional proof layout instantly, without exporting, installing, or refreshing anything.


Section Types

Font Proof documents are composed of sections. Each section has its own type, content, typography settings, and font selection.

Basic

Simple text layout. Content is rendered with the selected fonts, one page per font (or mixed via inline styling). Supports multi-page overflow, word wrap, and all typography controls.

Waterfall

Size progression display. The same text is rendered at multiple point sizes in a single view. Default sizes: 8, 12, 18, 24, 32, 48, 72, 96pt. Sizes are fully customizable. Optional size labels (“12pt”, “18pt”) and fixed column width for text wrapping.

Columns & Rows

Grid layout with up to 6+ columns and multiple rows. Three content flow modes:

  • Continuous: text flows across all cells
  • Repeated: same text in every cell (for comparing typography settings)
  • Unique: different content per cell (via manual entry or linked files)

Per-cell typography: each cell can have its own font size, line height, letter spacing, alignment, text direction, orientation, and case transform. Supports cell merging for complex layouts. Optional grid labels.

Style Comparison

Side-by-side font/style comparison. Fonts are displayed in rows or columns. Dynamic column count calculated from content width (min 120pt per column, max 6). Intelligently paginates when fonts don’t fit on a single page.

Glyph Grid

Full character repertoire display. Shows every glyph in the font in a grid with:

  • Character name/Unicode code point labels below each glyph
  • Metric lines: baseline, x-height, cap-height, ascender, descender
  • Two metric line styles: individual (per-glyph) or continuous (reference lines)
  • WCAG-compliant contrast calculation for metric line opacity
  • Option to show all glyphs or only those present in the section content

Markup

Frozen PDF snapshot with freehand annotation overlay. Captures a page as a static image, then allows drawing and text annotations on top.

Drawing tools:

  • Pen tool (freehand strokes)
  • Text tool (click-to-place text boxes)
  • Select tool

Markup controls:

  • Stroke width: 1, 2, 3, 5, 8, 12, 20pt
  • Color picker for pen and text
  • Text formatting: font size (1–999pt), bold, italic, alignment (left/center/right)
  • Undo support (Cmd+Z)
  • Keyboard shortcuts: V (select), P (pen), T (text), Cmd+Return (done), Escape (cancel)

What it’s for: Annotating proofs with design feedback — circling problem areas, noting kerning issues, writing revision comments directly on the proof.


Typography Controls

Every section type has access to these typography controls (some section-specific):

Core Typography

  • Font size — spinner + text field input
  • Line height — multiplier (1.0–2.0 typical range)
  • Letter spacing — horizontal and vertical (in ems), separate controls for CJK vertical text
  • Paragraph spacing — space after paragraphs (in ems)
  • Word wrap — toggle on/off
  • Kerning — toggle on/off (kern feature)

Case Transforms

  • Unchanged, UPPERCASE, lowercase, Title Case
  • Scope control: Latin-only vs. all scripts (handles Turkish i, Greek sigma, etc.)

Alignment

  • Auto (script-aware — Arabic/Hebrew right-align, Latin left-aligns)
  • Start, Center, End, Justify
  • Maps correctly to NSTextAlignment based on detected text direction

Text Direction & Orientation

  • Direction: auto (content-based detection), LTR, RTL
  • Orientation: auto, horizontal, vertical-left, vertical-right
  • Force upright in vertical: keeps Latin characters upright in CJK vertical text (overrides W3C rotation standards)

Language & Script

  • Language tag support: auto-detect, Arabic (ar), Farsi (fa), Hebrew (he), Japanese (ja), Korean (ko), Simplified Chinese (zh-Hans), Traditional Chinese (zh-Hant), German (de), Turkish (tr)
  • Proper text shaping via CoreText for each language
  • Numeral systems: default, Arabic-Indic, Extended Arabic-Indic, Latin

OpenType Feature Support

Comprehensive OpenType feature management with 70+ features organized by category:

Categories

  • Ligatures: liga, dlig, clig, rlig, hlig
  • Numbers: lnum, onum, pnum, tnum, zero
  • Case & Capitalization: smcp, c2sc, pcap, c2pc, unic, case, cpsp, titl
  • Fractions & Math: frac, afrc, numr, dnom, sups, subs, sinf, ordn
  • Stylistic: salt, swsh, cswh, hist, aalt, rand, plus ss01–ss20 stylistic sets
  • Positioning: kern, vkrn, palt, halt, vpal, vhal
  • Language-Specific: locl, ccmp, isol, init, medi, fina, med2, fin2, fin3, mset
  • CJK: jp78, jp83, jp90, jp04, smpl, trad, hojo, nlck, expt, ruby, hkna, vkna, hngl, vert, vrt2
  • Character Variants: cv01–cv99 with auto-generated names

Feature Management

  • Per-font, per-section feature toggling
  • Robust OpenType table parsing to detect available features
  • Glyph-based feature verification (compares glyph IDs before/after)
  • Custom feature names extracted from font’s name table
  • “Reset to Defaults” and “Apply to Family” actions
  • Feature state persisted per document

Font Management

Font Sources

  1. System — all macOS installed fonts via NSFontManager
  2. Glyphs — from open Glyphs.app documents (live reload capable)
  3. Test Install — fonts exported from Glyphs via “Install for Testing”
  4. Imported — manually imported .otf, .ttf, .ttc, .var files via file picker

Variable Font Support

  • Axis detection and display via CTFontCopyVariationAxes
  • Axis values stored per font instance (e.g., wght=500, wdth=75)
  • WWS name table integration (Name ID 21/22 preferred over computed axes)
  • Per-instance axis presets from Glyphs

Font Sorting

  • Document order (global default)
  • Manual (drag-to-reorder)
  • Weight (parsed from style string)
  • Alphabetical
  • Date added
  • Per-section override with independent sort order
  • Ascending/descending direction

Per-Section Font Control

  • Disable specific fonts per section (hide without removing)
  • Section-specific font override (use different fonts than global selection)
  • Per-section font ordering
  • Solo mode: focus on a single font across all sections

Inline Styling & Font Mixing

Three modes for mixing fonts and styles within a single section:

Off (Default)

No tag processing. Each font gets its own page(s).

Auto Mode

Auto-generates <fN> tags to distribute multiple fonts across text by weighted probability. Configurable per-font mix weights (e.g., 50% base font, 30% second, 20% third). Seeded random distribution for reproducible output. Useful for simulating real-world text with multiple weights.

Manual Mode

User types <b>, <i>, <u> tags directly in content. Parser converts to font substitution (bold tag → bold weight, italic tag → italic style). Supports [Family-Style:text] single-token syntax for explicit font assignment.


Linked Files

Section-Level Linking

Link external text files to any section. Content auto-refreshes when the file changes.

  • Supported formats: .txt (plain text), .rtf (rich text → inline tags), .md/.markdown (markdown → inline tags)
  • File watching: vnode events + parent directory monitoring + NSFilePresenter + 1-second polling fallback
  • Atomic save detection: 0.25s buffer for editors that write-then-rename
  • Security-scoped bookmarks for sandboxed file access

Per-Grid-Item Linking

In Columns & Rows sections, each grid cell can link to a different external file. Independent watchers per cell.


PDF Export

Rendering Pipeline

Dedicated renderers per section type: PDFTextRenderer, PDFWaterfallRenderer, PDFColumnsRenderer, PDFStyleComparisonRenderer, PDFGlyphGridRenderer, PDFMarkupRenderer. All coordinated by PDFProofGenerator.

Appearance Modes

  • Built-in: Light (white bg), Dark (dark bg/white text), Sepia (warm cream), High Contrast
  • Custom modes: user-defined background/foreground colors, stored in UserDefaults
  • Alt+click to flip foreground/background colors
  • Per-document mode override

Page Dimensions

  • Paper presets: Letter, A4, A5, A6, Tabloid
  • Device presets: MacBook Air, MacBook Pro 14”/16”, Desktop, Slides 16:9/4:3, iPad (all models), iPhone (all models)
  • Custom: arbitrary width x height in points
  • Margins: independent top, bottom, left, right

Headers

  • Section name, font name, font size displayed at top or bottom of each page
  • Three positions: Top, Bottom, Off

Export UI

Accessory panel in save dialog with appearance mode, page size, and margin options.


Fit to Page

One-click optimization that calculates the optimal font size, line height, and letter spacing to fill a single page. Uses binary search (0.5pt precision). Section-type-aware:

  • Basic: finds optimal font size
  • Waterfall: removes oversized entries
  • Columns: reduces font size, adjusts column count
  • Style Comparison: scales to target height
  • Glyph Grid: adjusts font size for grid layout
  • Markup: no optimization (frozen snapshot)

Templates

Section Templates (.fps files)

Reusable section configurations saved as standalone JSON files. Include content, all typography settings, and section type.

System Templates (Built-In)

Predefined proof setups organized by category:

  • Hamburgers: Ha/Hh/HH spacing tests, Hamburgefonts, Hamburged Spacing/Trio
  • Spacing: basic character sets, spacing tests, trio spacing
  • Pangrams: 8 variants (Wizards, Waltz, Dwarf, Sphinx, Zebras, Boxing, Jackdaws, Liquor)
  • Kerning: I Ask Jeff, Kerning Trio, Extra Kerning Words, Furniture Characters
  • Diacritics: 26 language variants (Afrikaans through Turkish)
  • Script-specific: Greek, Cyrillic templates

Custom Templates

User-created, starred for quick access. Browse by category in the template picker.


Document Format

.fontproof (JSON-based, version 3)

Contains:

  • Sections (UUID-keyed content text)
  • Section names and ordering
  • Per-section typography settings (SectionFontSettings)
  • Enabled/selected fonts with axis values
  • Font ordering
  • Per-font, per-section OpenType feature toggles
  • Linked text sources (section-level and per-grid-item)
  • Markup data (strokes + text annotations + frozen PDF snapshots)
  • Page dimensions, margins, header position
  • PDF appearance mode

Backward compatible: auto-migrates from v0 (name-based sections) through v2 (UUID-based) to v3 (markup support).

.fps — Section Template

Standalone single-section JSON. Stores template name, description, category, content, settings, created date, starred flag.

.fpt — Proof Template

Full proof configuration template (all sections, fonts, settings, page dimensions).


Zoom & Navigation

  • Incremental zoom in/out with adaptive step sizing
  • Custom zoom input (10–1000%)
  • Presets: 50%, 100%, 200%, Zoom to Fit
  • Cmd+/Cmd- shortcuts, Cmd+0 for 100%
  • PDFKit-based viewer with single page, two-page, and continuous scroll modes
  • Section sidebar with optional thumbnails (letterboxed, 140x100px)
  • Drag-to-reorder sections in sidebar
  • Section right-click: rename, duplicate, delete, create from template

Performance

  • CTFont cache: 5,000-entry limit with auto-eviction
  • Auto-styled text cache: avoids redundant tag generation
  • Feature detection cache: thread-safe per-font caching
  • Font data cache: binary font data cached per-font
  • Deferred section loading: large documents load sections incrementally
  • Render snapshots: main thread prepares state snapshot, PDF generated on background thread
  • CoreText workaround: splits attributed strings at 10,240 UTF-16 units to avoid feature loss
  • Page safety limit: 100,000 pages per section max

Licensing & Updates

Trial

  • 14-day free trial, one per machine (hardware UUID tracking)
  • Anti-tampering: hash verification on trial start date
  • No credit card required

License Activation

  • LemonSqueezy API integration (activate, validate, deactivate)
  • Machine-specific activation with instance tracking
  • License key + instance ID stored in macOS Keychain
  • Validates on every launch with 100-year offline grace period
  • License states: unlicensed, trial (with expiry), licensed, expired

Auto-Updates

  • Sparkle framework (SPUStandardUpdaterController)
  • EdDSA-signed ZIP archives hosted on GitHub Pages
  • Configurable check interval
  • Appcast feed at jakefleming.github.io/font-proof-swift/appcast.xml

Window & App Management

  • Multiple document windows (standard macOS document-based app)
  • Dedicated font manager window
  • Dedicated markup editor window
  • Floating activation/registration windows
  • Global file drop overlay (drag fonts or text files onto app)
  • Standard macOS “Open Recent” menu
  • macOS 14.6+ (Sonoma) required

Keyboard Shortcuts

ShortcutAction
Cmd++ / Cmd+-Zoom in/out
Cmd+0Zoom to 100%
Cmd+ZUndo (markup editor)
Cmd+ReturnDone (markup editor)
EscapeCancel (markup editor)
Cmd+RRefresh fonts
VSelect tool (markup)
PPen tool (markup)
TText tool (markup)

MCP Server (Claude Code / AI Integration)

Font Proof includes a built-in MCP (Model Context Protocol) server that lets AI tools like Claude Code create and modify proofs programmatically. The server binary (font-proof-mcp) is embedded in the app bundle.

Architecture: File-based, standalone. Creates and modifies .fontproof files (JSON) directly — the app doesn’t need to be running. Uses stdio transport for Claude Code and MCP clients. Can open results in the app via fontproof:// URL scheme.

Exposed Tools

Document tools:

  • create_proof — create empty .fontproof with page settings, margins, headers
  • open_proof — read full document contents
  • get_proof_info — get metadata without full content
  • open_in_app — open file in Font Proof for live PDF rendering
  • create_complete_proof — create full document with fonts + sections in one call

Section tools:

  • add_section — add new section (any type)
  • update_section — modify name, content, type, or settings
  • delete_section — remove section
  • reorder_sections — change display order
  • duplicate_section — copy existing section
  • set_section_content_bulk — update content for multiple sections at once
  • update_section_settings — modify all typography settings (font size, line height, letter spacing, alignment, direction, orientation, OpenType features, waterfall sizes, grid layout, etc.)

Font tools:

  • add_fonts — add system fonts (with variable font axis support)
  • remove_fonts — remove fonts by family + style
  • list_system_fonts — enumerate installed fonts with optional filter

Glyphs integration tools:

  • list_glyphs_fonts — query open Glyphs 3 documents, families, and instances
  • add_glyphs_fonts — add specific instances from Glyphs document to proof

Glyphs 3 Bridge

The MCP server communicates with Glyphs 3 via a Python bridge script using NSConnection (Mach IPC). It queries open documents and available instances without modifying the Glyphs project.

Two Implementations

  1. Swift (primary) — native macOS binary built via SPM, embedded in app bundle at Contents/Helpers/font-proof-mcp, codesigned with the app
  2. TypeScript (reference) — Node.js implementation using the official MCP SDK, runs standalone via npm

What This Enables

Claude Code can create type specimens from scratch, build Goldilocks tracking comparisons, construct multilingual proofs, toggle OpenType features, test variable fonts at specific axis values, and update content across sections — all programmatically. Results open instantly in Font Proof for live PDF rendering.


Debug & Developer

  • Toggleable os.log categories: PDF, Fonts, Glyphs, UI, OpenType, Templates, General
  • Accessible from Settings