I stumbled across a thread about terrible programming mistakes and found this:
Which contains the line:
rm -rf /foo-bar-usr /lib/nvidia-current/xorg/xorg
Note – I’ve added foo-bar- to the string so that if you try to run it, it won’t do the thing I’m warning about –even having that on my clipboard makes me nervous!.
Due to the space after /usr, the rm command interprets it as two separate directories to remove, not one mistyped path.
If that path had been wrapped in quotes so that it was passed as a single parameter, this wouldn’t have happened.
Most command-line examples won’t do this as it can obfuscate the meaning of a script or make it more difficult to read – but if you’re writing scripts rather than executing statements directly on the command line and especially if you’re accepting user input where they might accidentally tap space (never trust users), it’s worth wrapping your file paths as a precaution.
You don’t want to lose data, and you definitely don’t want to lose someone else’s data.