Shell Variable

$$var $$( python -c ‘import sys; print(sys.implementation.name)’ )

Make Variable

T ?= foo # give a default value T := $(shell whoami) # execute shell immediately to put in the var

PHONY to execute several makefile

Example 1

1SUBDIRS = foo bar baz
2
3## dir is a Shell variables
4## SUBDIR and MAKE are Internal make variables
5subdirs:
6        for dir in $(SUBDIRS); do \
7          $(MAKE) -C $$dir; \
8        done

Example 2

1SUBDIRS = foo bar baz
2
3.PHONY: subdirs $(SUBDIRS)
4subdirs: $(SUBDIRS)
5$(SUBDIRS):
6        $(MAKE) -C $@
7foo: baz

Idea for a testing tools

1git clone xxx /tmp/xxx&& make -C !$/Makefile
2make download le conteneur
3make build le binaire
4make met le dans /use/local/bin
5make clean
6make help

Sources:

Tutorials

A Gist for a colored help

The RAW version