The top image shows the structural editor, and shell, for the eyg programming language running on a phone. Later on I’ll show it running on a TV. On both devices the structural editor is a better coding experience than a text editor would be.
This post outlines the evolution of the editor over several years, and highlights the major changes over time along with some design thoughts and implementation notes. The web editor is built in Gleam and Lustre; originally it was Gleam and Svelte. There also exists a terminal based structural editor built in Go.
Structural editors, also known as projectional editors, enhance writing, editing and understanding code. Unlike traditional text-based editors, these tools treat code as a structured tree rather than a flat sequence of characters.
This structured data may be the Abstract Syntax Tree(AST) of the represented program, however it can also be a different structure. For this post I won’t quibble over the differences.