dev-resources.site
for different kinds of informations.
The terminal is on life support. Is it worth saving?
Why doesnât the terminal work like the rest of your apps? Developer tools have evolved towards reusability, composability, and collaboration. Meanwhile, terminals are inherently single-user, linear, and ephemeral.
For instance:
- Developers work in teams, but terminals donât support collaboration
- Developers rely on sharing knowledge, but all my terminal work disappears every time I close a session
- Developers work across machines, but my terminal environment is tethered to my computer
- Developers are becoming accustomed to nice interfaces, but the terminal inflicts pain and makes me feel like an idiot when I try to do moderately complicated things
In spite of these obvious shortcomings, terminals persist!
A lot of developers swear by them. And I understand why: if you know what youâre doing, the terminalâs text-based interface is fast, efficient, composable, and programmable. Terminals are awesome power tools.
So we have an interesting situation: terminals are both obviously useful and highly antiquated. How did we get here? Whatâs the best way forward?
In the rest of this post, Iâll argue that
- Terminals persist because CLIs are the best interface for a lot of developer tasks
- Their antiquated architecture has stifled innovation
- This has in turn caused terminals to lose share to GUIs
- The right way forward is to keep whatâs best about the terminal, but modernize it...which is what we are working on at Warp
And for those who donât want to read a whole blog post, you can get a sneak peek at Warp up front:
A preview of Warp showing blocks, text-editing, native completions and visual hisory.
Terminals persist because CLIs are good interfaces for developers
As a simple example, say you have written a program and suspect itâs leaking file handles but arenât sure. If you are comfortable in the terminal you can run a few commands to see whatâs going on:
First you can find your programâs process id using ps and grep:
ps aux | grep {program-name}
Then you can see how many files it has open:
lsof -p {process-id} | wc -l
And you can use watch
to track this over time to see if your debugging theory is right.
A GUI is almost all downside for this use case. Slower, less-flexible, wonât work over ssh, etc, plus it would be a pain to build. There are lots of developer tasks like this.
Even though capital-letter CLIs have a lot of use-cases, the current implementation of the terminal is really bad for reasons mentioned earlier - no collaboration, transient sessions, bad UX, etc.
Consequently, terminals are losing developer market share to user-friendly and modern GUI apps like VSCode, Postman, and more.
Why hasnât anyone already fixed the CLI?
People have tried, but the terminal architecture makes it really difficult to innovate.
Terminals and shells only support the character-in-character-out protocol of a teletype, a piece of hardware that hasnât been used in most new developersâ lifetimes. Specifically, the terminal sits on one side of a PTY and the shell sits on the other. Between them flows a sequence of characters. The only structure in place is a set of character codes that control how the terminal lays out and paints its buffer.
Because shells are responsible for parsing input and running programs, terminals donât know even basic things about what's happening; e.g. what separates a command from its output from the next command? Was the command successful? What text was written to stdout vs. stderr? Terminals have a knowledge deficit.
Conversely, shells have a much richer understanding of all this, but they have extremely limited capabilities on the UX side. They can't handle mouse interactions or render graphics, like for instance a completion UI. Shells have a capability deficit.
As someone wanting to modernize "the CLI", you are faced with the fact that there actually is no single CLI app â there are terminals and shells. Trying to fix the experience at the shell level can be somewhat effective â e.g. ohmyzsh, fzf, thefuck â but it can never fix fundamental accessibility issues and it will never make the terminal feel like a modern app.
In order to really modernize the CLI, you need to start with the terminal, and keep pushing further and further into the world of shells, ultimately ending up with a better integrated experience. This is hard, but we think it's worthwhile because of the productivity gains it will unlock.
Warp: a more accessible, powerful terminal
At Warp we are building a new Rust-based terminal that keeps whatâs best about the CLI while modernizing and upgrading the experience. One awesome thing about how we are building it is that it works with your existing shell so it's easy to try.
If youâre interested in how we are pushing the technical limits, please give How Warp Works a read.
A quick preview
Rather than a single buffer, we divide terminal output into a sequence of commands - making it easy for them to navigate, copy, save, and share units of work.
Warp is a block-based terminal
We make input more familiar and usable, replacing the character buffer with a full-fledged text editor built in Rust, and equipping it with intellisense-like autocomplete:
Built-in completions and documentation
And finally, we want to transform the terminal from an inherently single user utility into a modern collaborative app where sessions, blocks, and environments are all persistent, searchable and shared by link (being very mindful of security and privacy).
These types of features are just the start, and part of a larger set of principles we have for improving the terminalâs CLI.
If youâre interested in learning more, please check out our site and request early access here. We are still in the early days of implementing our vision but would love feedback and input as we move forward.
Featured ones: