I like writing custom scripts to automate stuff or fix repetitive headaches. Most of them are shell scripts, and a few of them are written in Python. Over the years, I’ve accumulated quite a few of them. I use Git and GNU stow1 to manage them across different machines, and the workflow2 is quite effective. However, as the list of scripts grows larger, invoking them becomes a pain because the tab completion results get cluttered with other system commands. Plus, often I even forget the initials of a script’s name and stare at my terminal while the blinking cursor facepalms at my stupidity.
I was watching this amazing talk3 by Brandon Rhodes that proposes quite an elegant solution to this problem. It goes like this:
All your scripts should start with a character as a prefix that doesn’t have any special meaning in the shell environment. Another requirement is that no other system command should start with your chosen character.
That way, when you type the prefix character and hit tab, only your custom scripts should appear and nothing else. This works with your aliases too!
The dilemma here is picking the right character that meets both of the requirements. Luckily, Brandon did the research for us. Turns out, the shell environment uses pretty much all the characters on the keyboard as special characters other than these 6:
@ _ + - : ,
Among them, the first 5 requires pressing the Shift key, which is inconvenient. But the
plain old comma ,
is right there. You can start your script or alias names with a comma
,
and it’ll be golden.
My tab completion looks like this:
rednafi@air:~/canvas/rednafi.com
$ ,
,brclr ,clear-cache ,docker-prune-containers ,redis
,brpre ,docker-nuke ,docker-prune-images ,www
All my aliases start with ,
too so that they also appear in the list with the custom
scripts. Fin!
Recent posts
- The domain knowledge dilemma
- Hierarchical rate limiting with Redis sorted sets
- Dynamic shell variables
- Link blog in a static site
- Running only a single instance of a process
- Function types and single-method interfaces in Go
- SSH saga
- Injecting Pytest fixtures without cluttering test signatures
- Explicit method overriding with @typing.override
- Quicker startup with module-level __getattr__