Search code examples
makefiledifftermination

Makefile failing when using diff on different files


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 should 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?


Solution

  • 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.