When writing a Makefile, it can sometimes be useful to be able to see the
values of variables to catch mistakes or bugs in the Makefile. To facilitate
this, Make contains two commands: info and error, and there is a debug
mode to Make.
With the info command you can print the current value of a variable to
stdout, while Make is processing the file. For instance, in the Makefile above
you could add:
$(info $$DATA = $(DATA))This will print DATA = data/action.csv ... data/western.csv.
With the error command you can stop the execution of Make at a certain
point in the Makefile. This is useful when you want to print the value of a
variable and not run Make any further:
$(error $$DATA = $(DATA))Finally, you can also debug the Makefile by running Make with the debug flag:
make -d. This will print all the rules (including built-in ones) that Make
tries for each of the targets, and whether or not a rule needs to be run.
If you only want to print the rules that Make will run and not actually run
them, you can use make -n. These last two options can also be combined, so
that you see the debug output and Make doesn’t run anything: make -dn.