I’ve done something similiar to this over the years for organization purposes and not having to change much between shells except add a path. You can also add cases that check your shell and do something slightly different if needed.
Aliasing anything seems like an unnecessary abstraction in just about every instance.
Glad I don’t come across it or much other unnecessary stuff in my work.
I have never heard of anyone using aliases for anything but trivial one-liners. I don’t think people consider them as an alternative to scripts so I don’t really get the point of half of this post.
However, the part explaining the benefits of using scripts over aliases even for trivial one-liners is pretty neat.
I use aliases for renaming commands and making bash scripts look like real commands to the rest of my team.
That’s an anti-pattern if I’ve ever heard of one.
Which one?
Using aliases to rename commands.
Yeah, I can see how that could go wrong, in practice it’s used to alias a python version python2 to python and impacts about 10 build scripts. (Which should be rewritten, but no-one is going to prioritise that work)
Why not make them executable and stick them in bin
Mostly because there’s a profile everyone sources that’s relatively straightforward to that’s straightforward to get access to. Whereas I’d never get root level access.
You don’t need root level access though. What I usually do is stick a
PATH="$PATH:$HOME/.local/bin
and then place all the scripts in there.Wouldn’t that require me to have access to everyone’s home directory and need to dump the scripts in everyone’s?
Potentially I could set up an alt bin directory everyone has access to and configure that in the shared profile, the only drawback there is it might be less obvious whats going on if something breaks and someone else needs to take a look at it.
Functions are best for this.
I agree. My
.zshrc
is littered with functions. Most useful ones are mypack
andextract
I made ~10 years ago, they just recognize file extension and use the correct tool.I even wrote a function to parse a json for some configuration details, and loop through it to dynamically create more named functions from that json profile. I use it at work for automating my cloud account logins with a single profile name from the command line. :)
Nice!
Just recently I learned that one can also define functions in .bash_aliases. Very handy.
I also switched to scripts. Aliases tend to break in loops with modified IFS
I like fish abbreviations. They are like aliases but expand when you press space or enter. That way you can edit it, and also still see the full command so you are less likely to forget it when you don’t have your aliases. Of course I have some scripts as well.
And: Fish implements aliases as scripts! When you use alias —save, fish creates as script with a function in it.
I actually use both in fish. I use aliases for some longer commands. For example I have
la
as an alias foreza -la --icons=auto --group-directories-first
because I don’t really want to see it every time I runla
. I use abbreviations for some shorter commands. For examplesystemctl
abbreviated tosys
andsystemctl --user
abbreviated tosysu
.Thanks for this info! Didn’t know about it! 😃
I use zsh with aliases, and Atuin which I find very convenient.
I’ll definitely try out fish abbr in combo with aliases. Logic in aliases is great.
I use ZSH with plugins but back when I switched away from bash, I also looked at fish. I didn’t use it back then because people say it doesn’t follow the POSIX standard but is that really an issue? It probably only extends it instead of taking things away, right?
All POSIX compatible shells have their quirks and differences because the common POSIX part is rather small, so you will need to learn them anyway when switching from one to another. Fish is not that different from them (to much less extent than something like nushell) and it benefits from having less ancient baggage.
I still write most scripts for bash, but for interactive use fish is just so much better out of the box.
this is my sticking point with fish. I still need to know bash for writing portable scripts, so its hard to justify scripting in fish.
that’s actually a really good argument for not using either.
Taking a step back discussing shells seems like a never ending hell loop.
Sometimes the only way to win is not to play the game.
Use python and stop being stuck in the distant past.
Unless you have a particular reason for sticking to POSIX, who cares? I’ll take the user experience improvement without worry.
The thing is that, if you are not sticking to POSIX, you might as well use more widely available alternative scripting languages like perl or python, which are often included in most workspaces by default, so I’d say it’s more useful to get experienced in those than to get experienced in fish.