That's why I always:
- cd .cache
- ls
- rm -r *
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.
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
That's why I always:
rm -r *
Also, if you have to type that, don't use the numpad: / is only one key away from *. If you finger snags the / key on its way to * and you happen to be root, your root partition will go bye-bye.
Type a space before rm to prevent it from being added to your history to be a extra careful.
For which shell? I just tried that on a bash system and the command was still stored in .bash_history 😔
Set the HISTCONTROL
variable. If it is set to ignorespace
then commands entered with a leading-space will not be stored in the history.
Holy shit, I never knew you could do that! I've always really wanted a feature to stop random commands from being added to my history.
Some shells provide ways to prevent some commands to be added to the history
I've started adopting the habit of putting "-rf" as the last argument to avoid accidentally deleting something before I've double-checked my input. Good luck, and may this never happen again.
I once had a directory in /tmp
called etc
which contained subdirectories for something I was migrating.
I thought that I was in /tmp
when I ran rm -rf etc
... I was actually in /
Here's a rule I learned the hard way a few decades ago:
-i
doesn't exist?
I'm a big fan of starting the command with a #
, then removing it once I'm happy with the command to defend against accidentally hitting enter
Putting ~
next to the enter key on keyboards (at least UK ones) was an evil villain level decision
When I'm unsure, I ls <the-glob>
, chek, then replace ls
with rm
.
This. When the ls command works, hit ctrl-a, meta-d, type rm, enter.
Oh, didn't knew about Alt d
. Thx
I really like this # idea. I've also taken to holding off on adding sudo when deleting privileged files
I never thought of doing that in 40 years. It's a great idea actually. Thanks!
Or have backups (lol)
AND have backups.
In the few years of me exclusively using the command line to manage files, even having rm aliased to rm -rf, and at some point to sudo rm -rf, out of convenience, I think it has happened thrice that I deleted the wrong file, and twice I was able to restore it with (hourly) backups. The third time, it was a minecraft world which I had created to test some mods and the server start script, and I had excluded it from backups because my ~/games dir is usually only used by steam.
I’m a complete moron,
You are not,
Every person learning with the hardway isnt a moron,
You have to do, to really learn,
If you do it again though...
🫢 🤷♀️ I would say, that depend the personnal situation,
But i think, OP learned :)
I should’ve […] used trash
For those who don’t know: trash-cli
It upsets me to no end that this isn't a standard package 😭
What an awesome tool that I wish I knew sooner. Also the && operator in sh. I think you can figure out what happened.
Also the && operator in sh. I think you can figure out what happened.
I'm guessing something like... Copy file/dir from location A to location B and then delete from A, but the copy had failed (and the delete unfortunately worked fine)?
I left the last sentence open ended, for comedic effect, but if you really wanna know:
I transcoded videos with ffmpeg, and tried to exit out of the bash script with ctrl C. the script was something like:
for
ffmpeg file finishedFile;
rm file;
my ^C broke out only from ffmpeg and before I realized what happened the file got removed and the next ffmpeg call filled my terminal. I tought the key didn't register, or something was stuck, so I pressed it again.. and again.. it cost like 45minutes of footage, wasn't that important tho.
Ow.
ZFS and dotfiles are your friend. Sorry for your loss.
Sorry for your loss. I did something similar recently. A script was creating a "~" folder in my notes folder. I wanted to delete it... Thankfully it stopped at some file it couldn't remove and my dotfiles are in git.
A tip, to delete files that have names similar to variables or other expandables, put the filename in between single ticks like this 'filename'. Single ticks prevent expansion.
Thanks for the tip!
Tipps to prevent future accidents:
Mistakes are unpreventable due to our error-prone brains, but it is a choice to repeat them.
if your session is still running you can use env
to help reconstruct it
Use nix home-manager or guix home and put your configs in a git repo (this is my guix home config for reference)
That's very helpful now. You have added nothing other than to pull the declarative distro equivalent of "I use Arch, BTW" And then link your literal code. For shame. For shame.
nix/guix can be used on any distro and it provides a way to organize .config files so that if the .config directory gets deleted or accidentally modified for some reason, restoring it would be very easy. By putting the configuration in a git repo, it also makes it easy to restore previous configurations. I accidentally deleted a bunch of stuff in my .config directory once and that's one of the reason I use this tooling now, so I thought OP would find it helpful also
You're just the latest member of a long and storied fraternity of the best worst operating system architecture.
https://web.mit.edu/~simsong/www/ugh.pdf
One of us...
I should’ve had that backed up
Absolutely! IT's time to check out Stow now. With this you can easily manage your configuration and dotfiles (and all other data) in a single location.
https://venthur.de/2021-12-19-managing-dotfiles-with-stow.html
I should have had backups of important files in my home directory
Lessons learned the hard way
But... why?
Reason's I never use auto-complete in the terminal. Sadly, that's sometimes not enough.
just be careful and review what tab-suggest shows.
Reasons no have backups more like. No need to make life hard
Can you say why were you trying to rm -r your .cache anyway? Also RIP.
Save space probably
Probably the number one cause of borked Linux systems - trying to "de-bloat".