aliases in .bashrc
Linux
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Rules
- Posts must be relevant to operating systems running the Linux kernel. GNU/Linux or otherwise.
- No misinformation
- No NSFW content
- No hate speech, bigotry, etc
Related Communities
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
If you use fish
you can use abbreviations
Obvious things I don't see mentioned:
- Bash scripts kept in the home directory or another place that's logical for them specifically.
history | grep whatever
(or other useful piping), though your older commands are forgotten eventually. You can mess with the values ofHISTSIZE
andHISTFILESIZE
environment variables in your system.
I wouldn’t install a program for this if your use case is simple. You will end up relying on it when there are already some built in tools that can get you 99% of the way there.
- Bash scripts placed in ~/bin or ~/.local/bin
- Can have simple or complex scripts setup to do whatever you want
- Easily called from terminal or automated through cron or systemd
- Environment variables set in -/.bashrc
- Great for storing common paths, strings, etc.
- Can be easily incorporated into bash scripts
- Aliases set in ~/.bashrc
- Ideal (IMO) for common commands with preferred options
- for example you could setup your most used
rsync
command to an alias:alias rsync-cust=“rsync -avuP”
Edit: rephrased to not discount the tools shared. I am sure if you had a specific reason to use them they could be helpful. But I think for many users the above options are more than enough and are supported pretty universally.
I more or less was just looking for a general survey of what other people used.
I agree installing a binary for this small kind of thing might be excessive.
Yeah, potentially overkill, but all the power to anyone who wants to try them out. Freedom of choice is one of the best parts of Linux.
And sorry for the long response. It’s hard to gauge the proficiency that someone might have with Linux, so I tend to lean towards detailed explanations just in case
Fish shell. Out of the box it autocompletes taking into account in which directory you are. It's like bash Ctrl+r but without actually invoking it before. Really ergonomic.
I did not know any of the programs mentioned in the post, but some of them seem really nice. Can someone who thinks aliases are a better solution please explain why they think so and what is their advantage over these projects? Do they have any pitfalls that you are aware of?
I believe that if I use a command sparsely enough, I will forget the created alias name just a few days later than the actual command.
Bash is a shell but it's also a programming language, so between functions, aliases and scripts you can do anything you want without depending on an external program that might break, not be maintained anymore and you need to install everytime you reinstall, a machine.
I just have to restore my .bashrc and ~/bin...
I think that there are definitely valuable/valid use cases for the software in the OP, but I think that the built in bash tools can get most people most of the way there. And learning the common bash/shell conventions is way more valuable than learning a custom tool that some distros/environments won’t support.
If someone already uses aliases, creates some custom scripts, and sets some useful environment variables (along with effective use of piping and redirection) and still needs something more specialized, then getting a new tool could help.
The downsides are a reliance on another piece of software to use the terminal. So I would only use something like this if I had a really solid and specific use case I couldn’t accomplish with what I already use.
Fish (or zsh with some addons) will give you tab completion based on previous commands, might be something of interest?
Here's some addon tips if you'd rather run zsh instead of fish:
https://gist.github.com/abhigenie92/a907cdf8a474aa6b569ebe89aeee560d
Fish shell is great, but the more I've used it, the more incompatibilities I've found:
- Can't use subshells
- Can't use bash syntax (it would help if bass would process all commands by default)
- Can't use bash completions (there's a script to do that, but it makes start very slow)
Other than that, it just works by default (unlike zsh) and it works even better with an easy-to-install Tide
Yeah, it has its downsides. zsh with some addons is probably better overall. Or if you're at least aware of it's differences from bash and can work with that.
I like bash scripts + auto key! Custom commands with custom keybinds.
I have a file in my ~ called .alias and it is sourced by any shell I might use (currently just zsh) in it are common aliases like s => sudo and "sudo" => "sudo " (just put this as an alias if you use them a lot, you'll thank me when you're trying to use them with sudo)
I vi as the command line editor, so fetching history commands is quick:
ESC /searchstring
But if it's something really frequent or may benefit from parameters, I usually throw a perl or bash script in /usr/local/bin.
.zsh aliases to bash functions.
Thanks for the list though, gonna take a look at a few!
An alias file is what I’ve found to be the simplest. Just have to add one line to either .zshrc or .bashrc that links to the file. I store the alias file and some custom scripts that a few aliases call in a git repo so it’s literally just a matter of git pull, add one line to the rc file and then close and reopen the terminal and everything is ready to go.
I use vi as the command line editor, so fetching history commands is quick:
ESC /searchstring
But if it's something really frequent or may benefit from parameters, I usually throw a perl or bash script in /usr/local/bin.
I'd say aliases and functions are your friends here.
Fish and its search functionality work great for me.
McFly for better ”ctrl+c”. It also keeps track of what commands you ran in what directory.
Try fzf
. The default hooks will launch fuzzy finders for
C-r
: history searchAlt-c
: change directoryC-t
: fill in argument for a nested path
All seem pretty good for your use case.
I use this method from Luke smith for bookmarking.
https://vid.puffyan.us/watch?v=d_11QaTlf1I
I just have another file for commands.
You can use rofi/dmenu/bemenu. I use kickoff though.