In makefiles, a line prefixed with an at symbols disables the print of the output. I have a makefile where every line is prefixed with an at, but for debug I need to see what's going on. Is there a way to tell make to ignore the at and output the line ? the debug is excessive, and the -n option prints them, but does not do anything (it's for dry run)
相关问题
- CMakeList file to generate LLVM bitcode file from
- Makefile to compile lists of source files
- Have make fail if unit tests fail
- C++ - Compiling multiple files
- Undefined symbols for architecture x86_64: (Mac OS
相关文章
- How to arrange a Makefile to compile a kernel modu
- Makefile and use of $$
- Makefile: all vs default targets
- Automake Variables to tidy up Makefile.am
- How do I check the exit status of a Makefile shell
- Marking a makefile dependency as optional or other
- How to instruct Makefile to use different compiler
- Why does this makefile execute a target on 'ma
In GNU Make, this isn't possible out of the box. Having a
Makefile
which is non-configurably completely silent is simply bad practice. Removing the@
signs and running with-s
is the easiest way to get a silent build (except for possibleecho
commands).Take out all the @ and add this line to the Makefile:
.SILENT :
When you want to debug, comment out the .SILENT line.
Disabling the @ in front of a make script is useful, however sometimes it is too noisy when the make script is very long. Another debugging technique is to turn on a shell feature that echoes commands just before they execute. This obviates a need to manipulate @ or .SILENT. Consider an example Makefile:
This is likely non-portable since it depends on features present in the shell that executes the script, but portability is not really that important for debugging (if it works for you).
Make a variable that has a default value of
@
:And then use that in your
Makefile
:Then run
make
asmake AT=
. You can get fancier than that, if you like:This will make commands silent, unless
V
is set to1
(e.g.,make V=1
). This uses the non-POSIX, but common feature of recursive variable expansion.To make things even more configurable, allow a make switch to enable verbosity. It default normal to silent mode. Only with the -e VERBOSE=1 mode it will be verbose of course:
Thank you for this topic it was of great help for my work.
You can have make tell someone else to print the commands as they are executed, which is much the same thing:
However this won't work quite so well if your makefile contains shell script fragments as recipes, rather than sequences of separate simple commands, as you'll see the individual shell commands as they are encountered instead of the whole fragments as they are invoked.
Alternatively, you could actually take advantage of the free-software nature of GNU Make and hack up your own version that ignores the
@
signs. Grepping the GNU Make source code forCOMMANDS_SILENT
will soon show you that it suffices to add1 ||
to the?:
condition in the arguments to themessage()
call instart_job_command()
in job.c. Job done!