Hacker Codex   Linux servers · Python development · MacOS tinkering

Install Fish Shell on MacOS and Ubuntu

The Fish shell goes where few command-line shells have gone before, shedding the POSIX baggage of its forebears in favor of simplicity, consistency, and ease-of-use. Much like the Mac creators thought computers should be made to understand how humans work (and not the other way around), Fish observes your past behavior and suggests commands that it thinks you might be trying to execute. Sometimes, those suggestions are so spot-on that it can be downright spooky. Reactions of “How did Fish know that’s what I wanted to do?” are not uncommon.

In this article, we’re going to show how to install the Fish shell on MacOS and Ubuntu, followed by some basic setup steps. Subsequent posts will cover more advanced configuration.

So can a command-line shell be Mac-like? Let’s find out.

What is Fish and why would someone use it instead of another shell?

Fish has a number of advantages over other shells:

  • Fish suggests commands as you type based on history and completions, just like a web browser’s search bar
  • Fish generates completions automatically by parsing your installed man pages
  • Fish has a more intuitive syntax
  • Fish has less historical baggage and technical debt

For additional background information, read:



Installing Fish on MacOS

There are several ways to install Fish on MacOS:

  • traditional .pkg installer
  • standalone Mac application
  • Homebrew
  • manual compilation

The first two options are available from the Fish web site and are straightforward enough to be considered self-explanatory.

That said, if you already use Homebrew (which I recommend) and have configured your environment as noted in the MacOS Setup Guide, then you can install Fish as you would any other package:

brew install fish

If you would prefer to install the latest bleeding-edge version of Fish via Homebrew, run the following instead of the above command:

brew install --HEAD fish

Once installation has completed, add Fish to /etc/shells, which will require an administrative password:

echo "/usr/local/bin/fish" | sudo tee -a /etc/shells

To make Fish your default shell:

chsh -s /usr/local/bin/fish

Now that Fish is installed, you can proceed to the Basic Configuration section below.

Install latest Fish on MacOS from source

If you want to use the latest bleeding-edge version of Fish and already have Xcode installed, use the following steps to install from source:

git clone https://github.com/fish-shell/fish-shell ~/src/fish
cd ~/src/fish
xcodebuild install
ditto /tmp/fish.dst /

Add Fish to /etc/shells, which will require an administrative password:

echo "/usr/local/bin/fish" | sudo tee -a /etc/shells

Make Fish your default shell:

chsh -s /usr/local/bin/fish

Now that Fish is installed, you can proceed to the Basic Configuration section below.



Installing Fish on Ubuntu

On Ubuntu, the easiest way to keep up-to-date is via the offical PPA. If you prefer to install via .deb package, or if you want to install the bleeding-edge version of Fish from source, those instructions are further below.

Install Fish via PPA

The following steps will add the Fish 3.x PPA repository and install Fish:

sudo apt-add-repository ppa:fish-shell/release-3
sudo apt-get update
sudo apt-get install fish

Make Fish your default shell:

chsh -s /usr/bin/fish

Now that Fish is installed, you can proceed to the Basic Configuration section below.

Install Fish on Ubuntu via .deb

The following steps are for the 64-bit version of Ubuntu 22.04 LTS (“Jammy”). If you are using a different version of Ubuntu, you’ll need to retrieve an appropriate .deb package from LaunchPad.

First retrieve and then install the .deb package:

wget https://launchpad.net/~fish-shell/+archive/ubuntu/release-3/+files/fish_3.6.0-1~jammy_amd64.deb
sudo dpkg -i fish_3.6.0-1~jammy_amd64.deb

Make Fish your default shell:

chsh -s /usr/bin/fish

Now that Fish is installed, you can proceed to the Basic Configuration section below.

Install bleeding-edge Fish via PPA

If you prefer, you can keep up-to-date with the bleeding-edge version of Fish via the nightly build PPA. To do so, add the nightly PPA and install Fish:

sudo add-apt-repository ppa:fish-shell/nightly-master
sudo apt-get update
sudo apt-get install fish

Make Fish your default shell:

chsh -s /usr/bin/fish

Now that Fish is installed, you can proceed to the Basic Configuration section below.

Install Fish on Ubuntu from source

Install dependencies:

sudo aptitude install build-essential git autoconf libncurses5-dev libncursesw5-dev gettext

Retrieve source, compile, and install:

mkdir -p ~/src
git clone https://github.com/fish-shell/fish-shell ~/src/fish
cd ~/src/fish
autoconf
./configure --without-xsel
make
sudo make install

Add Fish to /etc/shells:

echo "/usr/local/bin/fish" | sudo tee -a /etc/shells

Make Fish your default shell:

chsh -s /usr/local/bin/fish

Now that Fish is installed, it’s time for some basic configuration.



Basic configuration

The Fish shell should now be installed, but a bit more configuration will prove helpful later.

Create the Fish config directory:

mkdir -p ~/.config/fish

Create initial config file:

vim ~/.config/fish/config.fish

Initial config file contents, which adds /usr/local/bin to the PATH environment variable:

set -g -x PATH /usr/local/bin $PATH

Open a new terminal session, which should now load the Fish shell by default for the first time. You can enter help, followed by the return key, to load user documentation in your default browser.

You can also see your current configuration in your default browser by first entering this command:

fish_config

… and then visiting http://localhost:8000/ in your browser of choice.

Fish can parse your installed man pages and automatically generate completion files for your command-line tools. You should periodically run the following command to update those completions, which are stored in ~/.config/fish/completions by default:

fish_update_completions

Last but not least, running:

echo "set -gx fish_greeting ''" >> ~/.config/fish/config.fish

… will eliminate the Fish welcome message that appears by default. If you want to add your own custom welcome message instead of removing the message entirely, insert your preferred text inside the '' marks.

Getting back to Bash

If you want to temporarily switch to the Bash shell for a single session, run:

bash

When you are done with your Bash session, type exit to return to your Fish shell.

If you decide Fish isn’t for you and want to permanently revert your default shell back to Bash:

chsh -s /bin/bash

… will switch your default shell to Bash.

Taking it to the next level

With Fish as your default shell, you may find that customizations you’ve made to your Bash environment are not present in Fish. The good news is that it’s easy to re-create those customizations — and create new enhancements — via Tacklebox, which allows you to easily use community-curated modules, plugins, and themes so you don’t have to create them yourself.

If you found this article to be useful, feel free to follow me on Twitter.