Clobbering
In computing, clobbering is the act of overwriting a resource such as a file, processor register or a region of memory, such that its content is lost. Generally, the term is used in the context of unintentional loss of information, but it can be used for intentional overwriting as well. The Jargon File defines clobbering as
The term originated in pottery, where clobbering is a traditional term for the deceptive and fraudulent later addition of decoration to an originally plain piece. This was especially done to Chinese porcelain, but also European wares.
Examples
File redirection
In many shells, the> file redirection operator clobbers if the output path refers to an existing file. This can be prevented in bash and ksh via the command set -o noclobber and in csh and tcsh via set noclobber. Subsequently, attempting to clobber via redirection fails with an error message. For example:$ echo "Hello, world" >file.txt
$ cat file.txt
Hello, world
$ echo "This will overwrite the first greeting." >file.txt
$ cat file.txt
This will overwrite the first greeting.
$ set -o noclobber
$ echo "Can we overwrite it again?" >file.txt
-bash: file.txt: cannot overwrite existing file
$ echo "But we can use the >| operator to ignore the noclobber." >|file.txt
$ cat file.txt # Successfully overwrote the contents of file.txt using the >| operator
But we can use the >| operator to ignore the noclobber.
$ set +o noclobber # Changes setting back
File mv and cp
The default behavior of themv and cp commands is to clobber an existing destination file. This behavior may be overridden via the -i option which results in prompting the user to confirm clobbering a file. Alternatively, the -n option selects to skip operations that would clobber.Makefiles
A commonly usedmaketarget, named clobber, performs a complete cleanup of files and directories produced via previous invocations of the command for a particular makefile. It is a more thorough cleanup operation than clean and is commonly used to uninstall software. Some make-related commands invoke during their execution. They check the CLOBBER environment variable. If it is set to OFF then clobbering is not done.