I know there are many linters for programming languages, like pep8
for python
, but I have never come across one for a makefile
. Are there any such linters for makefile
s?
Any other ways to programmatically detect errors or problems in makefiles without actually running them?
As I have grown into using a makefile
, it keeps on getting more complicated and long, and for me it would make sense to have a linter to keep the makefile
more readable.
The variable $@ represents the name of the target and $< represents the first prerequisite required to create the output file.
As with the clean target, lint is a target name used by convention; it is usually a good practice to include it in makefiles that build C programs. lint produces output files that have been preprocessed through cpp and its own first (parsing) pass.
some projects put their makefile in src/ subdirectory of the root directories of the projects, some projects put their makefiles in the root directory of the project.
Things have apparently changed. I found the following:
Of the two, Checkmake has (as of 2018/11) more recent development, but I haven't tried either.
The only thing resembling lint
behaviour is the command-line option --warn-undefined-variables
I also do not know where to find make file lint (web search for "make file lint" got me here), but here is a incomplete list of shallow idea fragments for implementing a make file lint utility...
White spaces are one aspect of the readability, as tabs and spaces have distinct semantics within make file. Emacs makefile-mode
by default warns you of "suspicious" lines when you try to save make file with badly spaced tabs. Maybe it would be feasible to run emacs in batch mode and invoke the parsing and verification functions from that mode. If somebody were to start implementing such a make file lint utility, the emacs lisp mode could be an interesting to check.
About checking for correctness, @Mark Galeck in his answer already mentioned --warn-undefined-variables
. The problem is that there is a lot of output from undefined but standardized variables. To improve on this idea, a simple wrapper could be added to filter out messages about those variables so that the real typos would be spotted. In this case make
could be run with option --just-print
(aka -n
or --dry-run
) so as to not run the actual commands to build the targets.
It is not good idea to perform any changes when make is run with --just-print
option. It would be useful to grep for $(shell ...)
function calls and try to do ensure nothing is changed from within them. First iteration of what we could check for: $(shell pwd)
and some other common non-destructive uses are okay, anything else should invoke a warning for manual check.
We could grep for $
not followed by (
(maybe something like [$][^$(][[:space:]]
expressed with POSIX regular expressions) to catch cases like $VARIABLE
which parses as $(V)ARIABLE
and is possibly not what the author intended and also is not good style.
The problem with make files is that they are so complex with all the nested constructs like $(shell)
, $(call)
, $(eval)
and rule evaluations; the results can change from input from environment or command line or calling make invocations; also there are many implicit rules or other definitions that make any deeper semantic analysis problematic. I think all-compassing make lint utility is not feasible (except perhaps built-in within make utility itself), but certain codified guidelines and heuristic checks would already prove useful indeed.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With