Deciding Whether a Command Succeeds

Problem

You need to run some commands, but you only want to run certain commands if certain other ones succeed. For example, you’d like to change directories (using the cd command) into a temporary directory and remove all the files. However, you don’t want to remove any files if the cd fails (e.g., if permissions don’t allow you into the directory, or if you spell the directory name wrong).

Solution

We can use the exit status ($?) of the cd command in combination with an if statement to do the rm only if the cd was successful.

cd mytmp
if (( $? == 0 )); then rm * ; fi

Discussion

Obviously, you wouldn’t need to do this if you were typing the commands by hand. You would see any error messages from the cd command, and thus you wouldn’t type the rm command. But scripting is another matter, and this test is very well worth doing to make sure that you don’t accidentally erase all the files in the directory where you are running.

Let’s say you ran that script from the wrong directory, one that didn’t have a subdirectory named mytmp. When it runs, the cd would fail, so the current directory remains unchanged. Without the if check (the cd having failed) the script would just continue on to the next statement. Running the rm * would remove all the files in your current directory. Ouch. The if is worth it.

So how does $? get its value? It is the exit code of the command. For C Language programmers, you’ll recognize this as the value of the argument supplied to the exit( ) function; e.g., exit(4); would return a 4. For the shell, zero is considered success and a non-zero value means failure.

If you’re writing bash scripts, you’ll want to be sure that your bash scripts explicitly set return values, so that $? is set properly from your script. If you don’t, the value set will be the value of the last command run, which you may not want as your result.

Get bash Cookbook now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.