7
votes

Part of my makefile for my C++ project uses the diff command to compare two files that were output by the recently built code. The issue is that if the files are different, the script you not fail and should continue. There are more files that need to be compared and I need to see them all before the build script should end. For example, something like this,

diff:   *
        diff $(TEST)/T4.board $(TEST)/T4.board
        diff $(TEST)/T4.board $(TEST)/sample.board

The first line causes no issue because the files are the same. The second line compares different files, and once the differences are displayed, I see

Makefile:102: recipe for target `diff' failed
make: *** [diff] Error 1

and the script stops. How can I get it to continue?

2
diff should return 0 on success and 1 on failure. The question is how do I deal with failure? I've only been using makefiles for a week or so. - gsingh2011

2 Answers

7
votes

As the GNU make manual states in section 5.5 "Errors", you can ignore the return status of a command by prefixing the command with -:

diff:   *
    -diff $(TEST)/T4.board $(TEST)/T4.board
    -diff $(TEST)/T4.board $(TEST)/sample.board
6
votes

Make your entire recipe to return no error:

diff:   *
    diff $(TEST)/T4.board $(TEST)/T4.board     || exit 0
    diff $(TEST)/T4.board $(TEST)/sample.board || exit 0

One can use echo 'Files differ' instead of exit 0.