+++
title = "A modern CLI renaissance?"
date = 2024-03-04T12:20:02-06:00
draft = true
+++
:caution-caption: pass:[☠]
:important-caption: pass:[❗]
:note-caption: pass:[✏️]
:tip-caption: pass:[💡]
:warning-caption: pass:[⚠]
:toc:
:toclevels: 6
// btop, 2021, c++
// bat, 2018, rust
// helix, 2020, rust
// zoxide, 2020, rust
// starship, 2019, rust
// difftastic, 2018, rust
// git-delta, 2019, rust
// nushell, 2018, rust
// hyperfine, 2018, rust
// sd, 2018, rust
// tre, 2019, rust
// typst, 2019, rust
// yazi, 2024, rust
// fd, 2017, rust
// ripgrep, 2016, rust
// ast-grep, 2022, rust
// pueue, 2015, rust
// diskonaut, 2020, rust
// broot, 2018, rust
// just, 2016, rust
// zellij, 2020, rust
// scc, 2018, go
// fzf, 2013, go
// lazygit, 2018, go
// grex, 2019, rust
// micro, 2016, go
// oh-my-posh, 2019, go
// nnn, 2016, c
// qalculate, 2016, c++
// eza/exa, 2014, rust
// lsd, 2018, rust
// neovim, 2015, c
// cat, cd, rm, cp, man was included in the first version of unix, in 1971
// ls specifically can trace its history to 1961 (https://tldp.org/LDP/LG/issue48/fischer.html)
// vi was made in 1976
// sed in 1974
// awk in 1985
// grep in 1973
// bc in 1975
// diff in 1974
// make in 1976
// vim in 1991
// ssh in 1995
// midnight commander in 1994
// screen in 1987
// tmux in 2007
// rust 1.0 in 2015
Id like to talk about a trend Ive seen these past few years, where people are rewriting core CLI tools,
why I think this trend is a good thing, and why I think this trend might be happening.
== History
The terminal has been a staple of computer user interfaces since before computer monitors were available,
with some of the first computers offering an interactive mode in the late 1950's.
The 'modern' Linux terminal traces its linage to the very first version of Unix, in 1971.
Many utilities that a Linux user interacts with every day,
commands like `rm`, `cat`, `cd`, `cp`, `man` and a host of other core commands trace their initial versions to this first version of Unix.
Other tools are a bit newer, such as `sed` (1974), `diff` (1974) `bc` (1975), `make` (1976) or `vi` (1976).
There were a few more tools introduced in the 90's, such as `vim` (1991) and `ssh`, (1995), but you get the picture.
The majority of the foundational CLI tools on a Linux pc, even one installed yesterday, are older than Linux itself is.
== Ok, so?
Now, theres nothing wrong with this, the tools work fine still, but,
in the half-century since they were first written,
Terminals and the broader Linux ecosystem have all changed.
Terminals now have capacity to display more colours, Unicode symbols, and even inline images.
Terminal programs now coexist with graphical user interfaces,
and only a small subset of computer users even know they exist,
wheras in the past, terminals were the only way one interacted with the computer.
Additionally, and perhaps more importantly, our knowledge has expanded,
our knowledge of user interfaces,
of what works and what doesnt,
of what usecases are common and what usecases are niche,
the way that error messages can teach,
the value of a good out of the box experience,
and the value of documentation that is easy to find and digest.
== The new tools
These changes to the environment surrounding CLI apps has, in recent years,
led to a resurgence in development of command line utilities.
Instead of just developing tools that dont exist,
Ive noticed that people are rethinking and reinventing tools that have existed since the early days of Unix.
== Exploration of the design space
== The lessons learned from the past
=== A good out of the box experience
// look at helix compared to (neo)vim
=== Friendly error messages
// look at nushells error messages
=== Concise and discoverable documentation
// look at zellij and helix and their built in keymap cheatsheets
=== Common usecases should be easy
// look at sd, rg, and fd
== Shedding historical baggage
// look at just command runner, simplifying the common use case of make
== The trendsetter
// did neovim kick this all off?
== The languages
// most of the new tools are written in rust and go.
// rusts clap and gos cobra