A command by any other name: The utility of aliases and wrappers in the shell

This isn’t a manifesto about anonymity, not that kind of alias, just a simple moments appreciation for decoupling programs from their invocations.

The title makes reference to the line “A rose by any other name would smell as sweet” from Shakespeare’s Romeo and Juliet.

For as long as I have made a home on the terminal I have made heavy use of aliases to make common tasks more efficient and less brittle.

Example: I wrote a script that switches all the theming on my system (window manager, terminal, editor, browser etc). Rather than typing out system-theme-switcher --dark when I want to switch to ‘dark-mode’ across my system, I have dark as an alias to this same command.

Click here to see the whole script

#!/bin/sh
# creator: Silas Jelley
# created: 2022-12-09
# updated: 2023-09-22 17:09:38 

# Place script somewhere on your PATH and make it executable.
# For convenience, create the following aliases:
#   alias light="system-theme-switcher --light"
#   alias dark="system-theme-switcher --dark"

# Themes and colors
dark_gtk_theme="Arc-Gruvbox"
dark_alacritty_theme="$HOME/.config/alacritty/themes/pencil-dark.yml"
dark_waybar_bg_color="#212121"
dark_wofi_bg_color="#212121"
dark_wofi_fg_color="#f1f1f1"
dark_wallpaper="#000000 solid_color"
dark_btop_theme="Default"
dark_neovim_theme="$HOME/.config/nvim/colors/gruvbox.vim"

light_gtk_theme="Default"
light_alacritty_theme="$HOME/.config/alacritty/themes/pencil-light.yml"
light_waybar_bg_color="#f1f1f1"
light_wofi_bg_color="#f1f1f1"
light_wofi_fg_color="#212121"
light_wallpaper="#999993 solid_color"
light_btop_theme="whiteout"
light_neovim_theme="$HOME/.config/nvim/colors/theme.vim"

if [ "$1" = "--light" ]; then
	prefer_color_scheme="prefer-light"
	gtk_theme="$light_gtk_theme"
	alacritty_theme="$light_alacritty_theme"
	waybar_bg_color="$light_waybar_bg_color"
	wofi_bg_color="$light_wofi_bg_color"
	wofi_fg_color="$light_wofi_fg_color"
	wallpaper="$light_wallpaper"
	btop_theme="$light_btop_theme"
	NEOVIM_THEME="$light_neovim_theme"
	FIREFOX_DARKMODE_SETTING="0"

elif [ "$1" = "--dark" ]; then
	prefer_color_scheme="prefer-dark"
	gtk_theme="$dark_gtk_theme"
	alacritty_theme="$dark_alacritty_theme"
	waybar_bg_color="$dark_waybar_bg_color"
	wofi_bg_color="$dark_wofi_bg_color"
	wofi_fg_color="$dark_wofi_fg_color"
	wallpaper="$dark_wallpaper"
	btop_theme="$dark_btop_theme"
	NEOVIM_THEME="$dark_neovim_theme"
	FIREFOX_DARKMODE_SETTING="1"

else
	echo "Mode not specified, options are --light, --dark"
	exit
fi

sed -i 's/ *background-color:.*/    background-color: '"$waybar_bg_color"';/' "$HOME/.config/waybar/style.css"
sed -i 's/ *background-color:.*/    background-color: '"$wofi_bg_color"';/' "$HOME/.config/wofi/style.css"
sed -i 's/    color:.*/    color: '"$wofi_fg_color"';/' "$HOME/.config/wofi/style.css"
sed -i 's/ *output \* bg.*.*/    output \* bg '"$wallpaper"'/' "$HOME/.config/sway/config"
sed -i 's/color_theme = .*/color_theme = '"$btop_theme"'/' "$HOME/.config/btop/btop.conf"
gsettings set org.gnome.desktop.interface gtk-theme "$gtk_theme"
gsettings set org.gnome.desktop.interface color-scheme "$prefer_color_scheme"
nohup pkill waybar_bg >/dev/null 2>&1 &
swaymsg reload >/dev/null
cp "$alacritty_theme" "$HOME/.config/alacritty/themes/auto.yml"
cp "$NEOVIM_THEME" "$HOME/.config/nvim/colors/auto.vim"
nvim --server ~/.cache/nvim/server.pipe --remote-send ':colorscheme auto'
touch "$HOME/.config/alacritty/alacritty.yml"
sed -i "s/user_pref(\"ui.systemUsesDarkTheme\",.*);/user_pref(\"ui.systemUsesDarkTheme\",$FIREFOX_DARKMODE_SETTING);/" ~/.mozilla/firefox/silas/prefs.js

In the above case that’s a simple matter of putting the following in my shell config:

  alias light="system-theme-switcher --light"
  alias dark="system-theme-switcher --dark"

After reading something a long while back by Drew Devault, I also began using wrapper scripts over the programs I use often. Primarily this is done so that I can call these programs with the options I almost always use without having to repeat myself.

One such wrapper I use often is one over networkmanager so I don’t have to remember its somewhat verbose command structure. And I alias this to wifi allowing me to type wifi connect, select from available networks and be prompted to enter a password. For my most common networks I have custom handling, so wifi home connects me to my home network, automatically retrieving the password from my password manager.

Click here to view the script

#!/bin/sh
# creator:  Silas Jelley
# created: 2019-06-15 13:12:04
# updated: 2022-12-09 07:04:28
# Without completion nmcli is damned inscrutable, and even with completion it's
# a bit on the arcane side. Here's my little helper wrapper.

# DEPENDENCIES: nmcli, fzf, pass, sed etc

# Place script somewhere on your PATH and make it executable.
# For convenience, create the following alias:
#   alias wifi="system-wifi-wrapper"


if [ "$1" = "list" ]; then # List available wifi networks
    nmcli device wifi list

elif [ "$1" = "connect" ]; then # Connect to specified network, else provide 
    if [ "$2" != '' ]; then     # a fuzzy selection of available networks.
        WIFI_SSID="$2"
    else
        WIFI_SSID="$(nmcli device wifi list | sed 's/^... *//' | sed 's/^USE *//' | fzf | awk '{print $1}')"
    fi
    nmcli device wifi connect $WIFI_SSID --ask

elif [ "$1" = "status" ]; then  # Show device status
    nmcli device status

elif [ "$1" = "off" ]; then     # Turn off the wifi radio
    nmcli radio wifi off

elif [ "$1" = "on" ]; then      # Turn on the wifi radio
    nmcli radio wifi on

elif [ "$1" = "ip" ]; then      # Show IPv4 address
    nmcli device show wlp0s20f3 | grep IP4.ADDRESS  | sed 's/^.*: //' | awk '{$1=$1};1'

elif [ "$1" = "house" ]; then   # Connect to house wifi
    WIFI_SSID="Orcon-Wireless"
    WIFI_PASSWORD="$(pass show misc/locking-street | grep primary | sed 's/^.*: //')"
    nmcli device wifi connect $WIFI_SSID password $WIFI_PASSWORD

elif [ "$1" = "cabin" ]; then   # Connect to cabin wifi
    WIFI_SSID="Jelleybean"
    WIFI_PASSWORD="$(pass show misc/locking-street | grep extender | sed 's/^.*: //')"
    nmcli device wifi connect $WIFI_SSID password $WIFI_PASSWORD
else
    echo "Input invalid"
fi

I have a similar setup for if I’m torrenting something that I’m not able to find in print, or those that I own in print but wish to have a digital copy of. When I recently switched from using aria2 to rtorrent for this purpose all I had to do was update my wrapper script with a call to rtorrent, adding a couple of options, in order to continue using torrent path/to/torrent.file. No need to learn and remember a new tools bespoke syntax.