Inspecting Files
The CLI lets you explore design documents without opening the editor. Every command also works on the live app — just omit the file argument.
Install
npm install -g @open-pencil/cli
# or
brew install open-pencil/tap/open-pencilDocument Info
Get a quick overview — page count, total nodes, fonts used, file size:
openpencil info design.figNode Tree
Print the full node hierarchy:
openpencil tree design.fig[0] [page] "Getting started" (0:46566)
[0] [section] "" (0:46567)
[0] [frame] "Body" (0:46568)
[0] [frame] "Introduction" (0:46569)
[0] [frame] "Introduction Card" (0:46570)
[0] [frame] "Guidance" (0:46571)Find Nodes
Search by type:
openpencil find design.fig --type TEXTSearch by name:
openpencil find design.fig --name "Button"Both flags can be combined to narrow results further.
Query with XPath
Use XPath selectors to find nodes by type, attributes, and tree structure:
openpencil query design.fig "//FRAME"Useful patterns
By type:
openpencil query design.fig "//TEXT" # All text nodes
openpencil query design.fig "//COMPONENT" # All components
openpencil query design.fig "//INSTANCE" # All instancesBy attributes:
openpencil query design.fig "//FRAME[@width < 300]" # Frames under 300px wide
openpencil query design.fig "//*[@cornerRadius > 0]" # Rounded corners
openpencil query design.fig "//*[@visible = false]" # Hidden nodes
openpencil query design.fig "//TEXT[@fontSize >= 24]" # Large text
openpencil query design.fig "//*[@opacity < 1]" # Semi-transparent nodesBy name and text content:
openpencil query design.fig "//TEXT[contains(@name, 'Button')]" # Name contains 'Button'
openpencil query design.fig "//TEXT[contains(@text, 'Hello')]" # Text content contains 'Hello'By hierarchy:
openpencil query design.fig "//SECTION//TEXT" # Text inside sections
openpencil query design.fig "//FRAME/TEXT" # Direct text children of frames
openpencil query design.fig "//COMPONENT_SET//INSTANCE" # Instances inside component setsQueryable attributes
name, width, height, x, y, visible, opacity, cornerRadius, fontSize, fontFamily, fontWeight, layoutMode, itemSpacing, paddingTop, paddingRight, paddingBottom, paddingLeft, strokeWeight, rotation, locked, blendMode, text, lineHeight, letterSpacing
Example output
Found 5 nodes
[0] [frame] "Logo 92×32" (0:9)
[1] [frame] "logo-short-6 31×32" (0:10)
[2] [frame] "wrapper 128×73" (0:20)
[3] [frame] "pen-drawing 148×52" (0:21)
[4] [frame] "surprised-emoji 32×32" (0:26)Node Details
Inspect all properties of a specific node by its ID:
openpencil node design.fig --id 1:23Pages
List all pages in the document:
openpencil pages design.figVariables
List design variables and their collections:
openpencil variables design.figLive App Mode
When the desktop app is running, omit the file argument — the CLI connects via RPC and operates on the live canvas:
openpencil tree # inspect the live document
openpencil eval -c "..." # query the editorLint Designs
Check documents for naming, layout, structure, and accessibility issues:
openpencil lint design.fig
openpencil lint design.pen --preset strict
openpencil lint design.fig --rule color-contrast
openpencil lint design.fig --list-rulesUse --json for machine-readable output.
JSON Output
All commands support --json for machine-readable output — pipe into jq, feed to CI scripts, or process with other tools:
openpencil tree design.fig --json | jq '.[] | .name'