Wave: 21th Century Terminal Emulator Designed for Gen Z

Linux TLDR
Last Updated:
Reading time: 5 minutes

Wave is a free, open-source, cross-platform (currently not available on Windows) fancy terminal emulator designed for the modern generation to become comfortable with the command-line.

It offers some interesting features lacking in traditional terminal emulators such as GNOME or Konsole, and I’ve been searching for them for a while, including a focus on managing different SSH connections.

Apart from that, it has a lot of built-in tools and customization options that can enhance the workflow of a SysAdmin or DevOps engineer, including a built-in JSON and Markdown editor, an image viewer, ChatGPT integration, etc.

There is a lot to discuss, so stick with this article until the end to discover its interesting features, learn how to install it on your system, and explore a few practical examples.

Tutorial Details

DescriptionWave: A Modern Terminal Emulator
Difficulty LevelLow
Root or Sudo PrivilegesNo
OS CompatibilitymacOS and Linux
Prerequisites
Internet RequiredYes (for installation)

Features of Wave

The following is a list of features (or options) it provides to enhance your daily workflow.

  • All terminal tabs can have their own custom title, color, icon, and connections customized.
  • Organize terminal tabs to relevant workspaces; for instance, group four tabs connected to the production server under the “Production” workspace and three tabs linked to the deployment server under the “Deployment” workspace, reducing the chance of wandering.
  • Option to delete or archive a specific tab or workspace for future access.
  • Built-in history mechanism to immediately check the list of commands executed on other instances of the Wave terminal, whether on the same network or remotely.
  • Add or remove different local or remote systems on the connection tab.
  • Automatically connect to a remote system via SSH, even if the system times out or is restarted.
  • Built-in features for image viewing, markdown editing (with preview), and ChatGPT support.

Here, the list of features ends. However, there are certain things that I dislike about this terminal that can be improved in future releases.

  • The absence of various installation methods in Linux, such as Snap, Flatpak, DPKG, or RPM packages.
  • The term “cross-platform” is used, but there is no option for the Windows system.
  • The “Help” option in the menu is not working in both Xorg and Waveland.
  • Deleting the terminal tab or workspace is a little annoying, as it always prompts you with a window asking whether to archive it or delete it.
  • Reconnecting to a disconnected SSH system is not a seamless experience, as it prompts you that it’s trying to connect, or sometimes you have to click on the “Connect Now” button.

These are not significant issues that can’t be dealt with; future versions might address most of them. If any changes occur, the article will be updated accordingly.

How to Install Wave

There are a limited number of ways to install Wave on your system, making it more straightforward. For example, if you are running a Mac system, run the following command to install it:

$ brew install --cask wave

For Linux operating on ARM64 or x64, simply visit the official download page and download the latest package file compressed in zip format.

download wave linux package

Once downloaded, navigate to the download location and unzip the compressed content by executing the following command:

$ unzip waveterm-linux-*.zip

Finally, move into the extracted directory and run the Wave binary file by executing:

$ ./Wave

In the future, when there is an update, you will be notified within the app, but you’ll need to perform all these steps again. Don’t worry, as your data is saved locally (“~/.waveterm/“) and will be accessible across different Wave versions.

Usage of Wave

When you launch the Wave for the first time, you will be presented with the following welcome window, where it will give you the option to enable or disable a telemetry collection and ask you to agree to the license agreement.

wave welcome window

Next, you will interact with the Wave main window, where you will have customization options to select the name, icon, and color for the tab, as well as the connection profile to be used for the local or remote system.

terminal tab customization

Once you’re done, you can start executing your command in the input box at the bottom.

running commands in wave

The default command output text is too small due to the default font size being set to 12px; I recommend changing it to 14px for an improved experience, which you can do in the settings where you’ll also find options for OpenAI Token key, model selection, and MaxTokens.

settings in wave terminal

To view an image within the terminal, use the “imageview” command and specify the image’s path.

opening image in wave terminal

To edit markdown files and preview the output without leaving the terminal, use the “codeedit” command and specify the markdown filename as an argument.

editing markdown file in wave terminal

The following are shortcut keys that you can use while editing your markdown file.

Shortcut KeyDescription
Ctrl+PToggle preview
Ctrl+SSave changes
Ctrl+DQuit

To access your remote system through an SSH connection, navigate to the “Connections” window and click the “New Connection” button.

connection window in wave terminal

The following “Add Connection” window will prompt you to provide all required information for the remote system, including USER@HOST/IPADDRESS, Alias (which can be anything), port (if it’s not 22), and options for key and password for authentication. Lastly, keep the connect mode to auto and click on the “Connect” button.

adding new connection in wave terminal

If all the provided information for the remote system is correct, you will be automatically connected to that system in the “Connection” window.

connected to remote system in wave

This way, you can provide information for all your remote systems, and after adding them, you can conveniently locate them in the “Connections” window.

listing all add connection in wave

To connect with your newly added remote system, simply open a new tab and select the added remote system (also known as a connection) from the list of connections.

connecting to remote system in wave

The best thing about Wave Terminal comes here. Let me explain with an example. If you’ve executed a command in your local system under Wave Terminal and then, in a new tab connected to a remote system, you can check the history of commands executed in your local system and utilize them without manual selection and copying.

To accomplish this, simply use the “Ctrl+R” shortcut key to view the history on your remote system, followed by the “Ctrl+S” shortcut key to display the list of locally executed commands.

viewing local command in remote system

Here comes the end of this article; almost all the necessary details about the current version of Wave Terminal are covered, except for Workspace, which I’ll leave to you.

If I share my opinion on this terminal, it could be my favorite from the early days of my Linux journey; today, it still proves helpful to me through its connections and workspace options.

But I’m too stuck with tmux as it currently does not provide any seamless method for installation, and fetching its package file from the project release page, unzipping it, and using it from there is kind of time-consuming.

So for now, I would rather use my standard terminal with tmux, but I’m definitely excited for the upcoming release.

Now, if you have any questions or queries related to the article, please let me know in the comments.

Till then, peace!

Join The Conversation

Users are always welcome to leave comments about the articles, whether they are questions, comments, constructive criticism, old information, or notices of typos. Please keep in mind that all comments are moderated according to our comment policy.