Skip to content

dylanroscover/Embody

Repository files navigation

💬 Embody

Have a conversation with TouchDesigner.

Version TouchDesigner MCP Tools License

Full Documentation  |  Changelog


TouchDesigner projects are binary .toe files — impossible to diff, merge, or review in git. Embody makes your TD projects readable: by AI, by git, and by you.

What It Does

Envoy, Embody's embedded MCP server, lets AI assistants like Claude Code, Cursor, and Windsurf talk directly to your live TouchDesigner session. Create operators, wire connections, set parameters, write extensions, and debug errors — all through natural conversation. No copy-pasting code. No describing your network in chat.

Embody externalizes your operators to diffable files (.tox, .py, .json, .glsl, etc.) in a folder structure that mirrors your network hierarchy. Tag operators, save with ctrl + shift + u, and everything restores from disk automatically on project open — your externalized files are the source of truth.

TDN (TouchDesigner Network) exports your entire operator network to human-readable JSON — a structured language that both humans and LLMs can read, diff, and reconstruct. Review structural changes in pull requests, snapshot configurations, or hand an LLM a complete picture of your network.

Embody Manager UI

Feature What It Does
📦 Automated Externalization Tags COMPs and DATs, keeps external files in sync — auto-restores everything from disk on project open
🤖 Envoy MCP Server 45 tools let AI assistants create operators, set parameters, wire connections, and more
📄 TDN Network Format Export/import operator networks as diffable JSON for code review and snapshots
📤 Portable Tox Export Export any COMP as a self-contained .tox with all external references stripped

Quick Start

1. Project Setup

Your TouchDesigner .toe file should live inside a git repository. Embody writes externalized files relative to the .toe location:

my-project/              ← git repo root
├── .gitignore
├── my-project.toe       ← your TouchDesigner project
├── base1/               ← externalized operators
│   ├── base2.tox        ← COMP (TOX strategy)
│   ├── base3.tdn        ← COMP (TDN strategy — diffable JSON)
│   └── text1.py         ← DAT
└── ...

2. Install and Tag

  1. Download the Embody .tox from /release and drag it into your TouchDesigner project
  2. Tag operators — select any COMP or DAT and press lctrl twice to tag and externalize it
  3. Work normally — press ctrl + shift + u to save all changes, or ctrl + alt + u to save only the current COMP. On project open, Embody restores everything from disk automatically

Tip: If no operators are tagged, Embody will externalize all eligible COMPs and DATs, which may slow down complex projects. Tagging selectively is recommended.

3. Keyboard Shortcuts

Shortcut Action
lctrl + lctrl Tag or manage the operator under the cursor
ctrl + shift + u Initialize / update all externalizations
ctrl + alt + u Save only the current COMP
ctrl + shift + o Open the Manager UI
ctrl + shift + e Export entire project to .tdn file
ctrl + alt + e Export current COMP to .tdn file

For supported formats, folder configuration, duplicate handling, Manager UI, and more — see the Embody docs.


Envoy MCP Server

Embody includes Envoy, an embedded MCP server that gives AI coding assistants direct access to your live TouchDesigner session.

Setup

  1. Enable Envoy — toggle the Envoyenable parameter on the Embody COMP
  2. Server starts on localhost:9870 (configurable via Envoyport)
  3. Auto-configuration — Envoy creates a .mcp.json in your git repo root
  4. Connect — open a Claude Code session (or restart your IDE) in the repo root — it picks up .mcp.json automatically

If your project isn't in a git repo, add .mcp.json manually to your project root:

{
  "mcpServers": {
    "envoy": {
      "type": "http",
      "url": "http://localhost:9870/mcp"
    }
  }
}

Tools at a Glance

Tool What It Does
create_op Create any operator type in any network
set_parameter Set values, expressions, or bind modes on any parameter
connect_ops Wire operators together
execute_python Run arbitrary Python in TD's main thread
export_network Export networks to diffable .tdn JSON
create_extension Scaffold a full extension (COMP + DAT + wiring)
get_op_errors Inspect errors on any operator and its children

...and 37 more. See the full tools reference.

When Envoy starts, it generates a CLAUDE.md file in your project root with TD development patterns, the complete MCP tool reference, and project-specific guidance.


TDN Network Format

TDN (TouchDesigner Network) is a JSON-based format for exporting operator networks as human-readable, diffable text. Unlike binary .toe and .tox files, .tdn files can be meaningfully diffed in git.

  • Entire project: ctrl + shift + e
  • Current COMP: ctrl + alt + e
  • Via Envoy: export_network / import_network MCP tools

See the full TDN specification for format details, import process, and round-trip guarantees.


Logging

Embody provides a multi-destination logging system:

  • File logging (default): dev/logs/<project_name>_YYMMDD.log, auto-rotates at 10 MB
  • FIFO DAT: Recent entries visible in the TD network editor
  • Textport: Enable the Print parameter to echo logs
  • Ring buffer: Last 200 entries via the Envoy get_logs MCP tool
op.Embody.Log('Something happened', 'INFO')
op.Embody.Warn('Check this out')
op.Embody.Error('Something broke')
Testing

Embody includes 38 test suites covering core externalization, MCP tools, TDN format, and server lifecycle. Tests run inside TouchDesigner using a custom test runner with sandbox isolation.

op.unit_tests.RunTests()                              # All tests (non-blocking)
op.unit_tests.RunTests(suite_name='test_path_utils')   # Single suite
op.unit_tests.RunTestsSync()                           # All in one frame (blocks TD)

Via Envoy MCP: use the run_tests tool. See the full testing docs for coverage details and how to write new tests.

Troubleshooting
  • Timeline Paused: Embody requires the timeline to be running. An error appears if paused.
  • Clone/Replicant Operators: Cannot be externalized. Embody warns if you try to tag them.
  • Engine COMPs: Engine, time, and annotate COMPs are not supported for externalization.

For more, see Troubleshooting.


Version History

See the full changelog for detailed version history.

Recent releases:

  • 5.0.233: Project-level performance monitoring, /validate command, test runner dialog fix
  • 5.0.229: Warning support in get_op_errors, Envoy enable dialog improvement
  • 5.0.228: macOS timezone fix, toolbar hover highlight
  • 5.0.227: TDN crash safety — atomic writes, backup rotation, content-equal skip, About page filtering
  • 5.0.222: Rename tag_for_externalizationexternalize_op, clarify single-step workflow
  • 5.0.221: TDN annotation properties, GitHub release rule, templates cleanup
  • 5.0.220: Network layout rewrite, commit-push checklist rule, expanded MCP tool allowlist, tooltip fix
  • 5.0.217: TDN target COMP parameter preservation, user-prompted file cleanup, dock safety, git init hardening
  • 5.0.210: DAT restoration on startup, continuity check hardening, manager list row limiting
  • 5.0.208: Settings auto-deploy, bridge template, Envoy startup resilience
  • 5.0.206: Metadata reconciliation, network layout tool, TDN companion dedup
  • 5.0.204: Custom window header, path portability, TDN cleanup
  • 5.0.201: Robust first-install init, table schema expansion, release build hardening
  • 5.0.190: Automatic restoration — TOX and TDN strategy COMPs fully restored from disk on project open
  • 5.0: Envoy MCP server (45 tools), TDN format, test framework (38 suites), macOS support

Contributors

Originally derived from External Tox Saver by Tim Franklin. Refactored entirely by Dylan Roscover, with inspiration and guidance from Elburz Sorkhabi, Matthew Ragan and Wieland Hilker.

License

TEC Friendly License v1.0

About

Have a conversation with TouchDesigner

Topics

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages