Flow Control: a programmer's text editor https://flow-control.dev
Find a file
2025-08-22 14:22:15 +02:00
contrib build: add strace output to test_race.sh script 2025-04-30 14:57:09 +02:00
src Merge branch 'master' into zig-0.15.0 2025-08-22 13:12:37 +02:00
test refactor: rename Buffer.del_chars to Buffer.delete_bytes 2024-12-19 22:41:26 +01:00
.gitattributes build: prevent git from causing zig fmt errors on windows 2025-05-05 15:58:59 +02:00
.gitignore build: update to latest zig and libvaxis and remove notcurses dependency 2024-06-04 23:14:43 +02:00
build.zig build: update build to zig-0.15.1 2025-08-22 13:16:20 +02:00
build.zig.version build: update build to zig-0.15.1 2025-08-22 13:16:20 +02:00
build.zig.zon build: update all dependecies for zig-0.15.1 2025-08-22 14:22:15 +02:00
help.md docs: mention file type configuration in README.md and help.md 2025-07-14 18:02:25 +02:00
LICENSE
README.md docs: mention file type configuration in README.md and help.md 2025-07-14 18:02:25 +02:00
zig build: update to zig 0.14.1 2025-05-25 23:21:27 +02:00

Flow Control: a programmer's text editor

This is my Zig text editor. It is under active development, but usually stable and is my daily driver for most things coding related.

Announcement

Requirements

  • A modern terminal with 24bit color and, ideally, kitty keyboard protocol support. Kitty, Foot and Ghostty are the only recommended terminals at this time. Most other terminals will work, but with reduced functionality.
  • NerdFont support. Either via terminal font fallback or a patched font.
  • Linux, MacOS, Windows, Android (Termux) or FreeBSD.
  • A UTF-8 locale

Download / Install

Binary release builds are found here: neurocyte/flow/releases

Fetch and install the latest release to /usr/local/bin with the installation helper script:

curl -fsSL https://flow-control.dev/install | sh

Nightly binary builds are found here: neurocyte/flow-nightly/releases

Install latest nightly build and (optionally) specify the installation destination:

curl -fsSL https://flow-control.dev/install | sh -s -- --nightly --dest ~/.local/bin

See all avalable options for the installer script:

curl -fsSL https://flow-control.dev/install | sh -s -- --help

Or check your favorite local system package repository.

Packaging status

Building

Make sure your system meets the requirements listed above.

Flow builds with zig 0.14.1 at this time. Build with:

zig build -Doptimize=ReleaseSafe

Zig will by default build a binary optimized for your specific CPU. If you get illegal instruction errors add -Dcpu=baseline to the build command to produce a binary with generic CPU support.

Thanks to Zig you may also cross-compile from any host to pretty much any target. For example:

zig build -Doptimize=ReleaseSafe -Dtarget=x86_64-windows --prefix zig-out/x86_64-windows
zig build -Doptimize=ReleaseSafe -Dtarget=x86_64-macos-none --prefix zig-out/x86_64-macos
zig build -Doptimize=ReleaseSafe -Dtarget=aarch64-linux-musl --prefix zig-out/aarch64-linux

When cross-compiling zig will build a binary with generic CPU support.

Ask DeepWiki

Running Flow Control

The binary is:

zig-out/bin/flow

Place it in your path for convenient access:

sudo cp zig-out/bin/flow /usr/local/bin

Or if you prefer, let zig install it in your home directory:

zig build -Doptimize=ReleaseSafe --prefix ~/.local

Flow Control is a single statically linked binary. No further runtime files are required. You may install it on another system by simply copying the binary.

scp zig-out/bin/flow root@otherhost:/usr/local/bin

Files to load may be specifed on the command line:

flow fileA.zig fileB.zig

The last file will be opened and the previous files will be placed in reverse order at the top of the recent files list. Switch to recent files with Ctrl-e.

Common target line specifiers are supported too:

flow file.txt:123

Or Vim style:

flow file.txt +123

Use the --language option to force the file type of a file:

flow --language bash ~/.bash_profile

Show supported language names with --list-languages.

See flow --help for the full list of command line options.

Configuration

Configuration is mostly dynamically maintained with various commands in the UI. It is stored under the standard user configuration path. Usually ~/.config/flow on Linux. %APPDATA%\Roaming\flow on Windows. Somewhere magical on MacOS.

There are commands to open the various configuration files, so you don't have to manually find them. Look for commands starting with Edit in the command palette.

File types may be configured with the Edit file type configuration command. You can also create a new file type by adding a new .conf file to the file_type directory. Have a look at an existing file type to see what options are available.

Logs, traces and per-project most recently used file lists are stored in the standard user application state directory. Usually ~/.local/state/flow on Linux and %APPDATA%\Roaming\flow on Windows.

Key bindings and commands

Press F4 to switch the current keybinding mode. (flow, vim, emacs, etc.) Press ctrl+shift+p or alt+x to show the command palette. Press ctrl+F2 to see a full list of all current keybindings and commands.

Run the Edit keybindings command to save the current keybinding mode to a file and open it for editing. Save your customized keybinds under a new name in the same directory to create an entirely new keybinding mode. Keybinding changes will take effect on restart.

Terminal configuration

Kitty, Ghostty and most other terminals have default keybindings that conflict with common editor commands. I highly recommend rebinding them to keys that are not generally used anywhere else.

For Kitty rebinding kitty_mod is usually enough:

kitty_mod ctrl+alt

For Ghostty each conflicting binding has to be reconfigured individually.

Features

  • fast TUI interface. no user interaction should take longer than one frame (6ms) (even debug builds)
  • tree sitter based syntax highlighting
  • linting (diagnostics) and code navigation (goto definition) via language server
  • multi cursor editing support
  • first class mouse support (yes, even with a scrollbar that actually works properly!) (Windows included)
  • vscode compatible keybindings (thanks to kitty keyboard protocol)
  • vim compatible keybindings (the standard vimtutor bindings, more on request)
  • user configurable keybindings
  • excellent unicode support including 2027 mode
  • hybrid rope/piece-table buffer for fast loading, saving and editing with hundreds of cursors
  • theme support (compatible with vscode themes via the flow-themes project)
  • infinite undo/redo (at least until you run out of ram)
  • find in files
  • command palette
  • stuff I've forgotten to mention...

Features in progress (aka, the road to 1.0)

  • completion UI/LSP support for completion
  • persistent undo/redo
  • file watcher for auto reload

Features planned for the future

  • multi tty support (shared editor sessions across multiple ttys)
  • multi user editing
  • multi host editing

Community

Discord

Join our Discord server or use the discussions section here on GitHub to meet with other Flow users!