erl

command module
v0.0.0-...-56cb69b Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 9, 2026 License: MIT Imports: 18 Imported by: 0

README

E(a)rl

E(a)rl helps with your development by restarting your command when files change.

A file watcher based on things I liked about nodemon and watchexec:

  • When command exits, wait for changes instead of re-starting ad infinitum

The name is an acronym for "Execute Reload Loop", inspired by "Read Eval Print Loop". "Earl" is nicer to say than "erl", but "erl" is nicer to type on a QWERTY keyboard.

Installation

Using Nix

If you have Nix with flakes enabled:

nix run git+https:git.alin.ovh/erl -- --exec your-command arg1 arg2

Or install it:

nix profile install git+https:git.alin.ovh/erl

Usage

Basic usage:

erl --exec go run main.go
Command Line Options
  • --exec string - Command to execute on file change (optional, defaults to "go run")
  • --quiet - Suppress erl's own output
  • --verbose - Enable verbose output (print file events)
  • --watch path - Add extra paths to watch (recursive)
Examples

Go development (explicit):

erl --exec go run .

Go development (implicit):

erl .

When no --exec flag is provided, erl defaults to running go run with the provided arguments.

Build and test:

erl --exec make test

Quiet mode:

erl --quiet --exec npm start

Verbose mode:

erl --verbose --exec python app.py

Development

nix develop

just run

just test

just build

License

This project is available under the MIT License.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
git
testcases
runaway command

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL