Previous: , Up: Using Variables   [Contents][Index]

6.14 Other Special Variables

GNU make supports some variables that have special properties.


Contains the name of each makefile that is parsed by make, in the order in which it was parsed. The name is appended just before make begins to parse the makefile. Thus, if the first thing a makefile does is examine the last word in this variable, it will be the name of the current makefile. Once the current makefile has used include, however, the last word will be the just-included makefile.

If a makefile named Makefile has this content:

name1 := $(lastword $(MAKEFILE_LIST))


name2 := $(lastword $(MAKEFILE_LIST))

        @echo name1 = $(name1)
        @echo name2 = $(name2)

then you would expect to see this output:

name1 = Makefile
name2 =

Sets the default goal to be used if no targets were specified on the command line (see Arguments to Specify the Goals). The .DEFAULT_GOAL variable allows you to discover the current default goal, restart the default goal selection algorithm by clearing its value, or to explicitly set the default goal. The following example illustrates these cases:

# Query the default goal.
ifeq ($(.DEFAULT_GOAL),)
  $(warning no default goal is set)

.PHONY: foo
foo: ; @echo $@

$(warning default goal is $(.DEFAULT_GOAL))

# Reset the default goal.

.PHONY: bar
bar: ; @echo $@

$(warning default goal is $(.DEFAULT_GOAL))

# Set our own.

This makefile prints:

no default goal is set
default goal is foo
default goal is bar

Note that assigning more than one target name to .DEFAULT_GOAL is invalid and will result in an error.


This variable is set only if this instance of make has restarted (see How Makefiles Are Remade): it will contain the number of times this instance has restarted. Note this is not the same as recursion (counted by the MAKELEVEL variable). You should not set, modify, or export this variable.


When make starts it will check whether stdout and stderr will show their output on a terminal. If so, it will set MAKE_TERMOUT and MAKE_TERMERR, respectively, to the name of the terminal device (or true if this cannot be determined). If set these variables will be marked for export. These variables will not be changed by make and they will not be modified if already set.

These values can be used (particularly in combination with output synchronization (see Output During Parallel Execution) to determine whether make itself is writing to a terminal; they can be tested to decide whether to force recipe commands to generate colorized output for example.

If you invoke a sub-make and redirect its stdout or stderr it is your responsibility to reset or unexport these variables as well, if your makefiles rely on them.


The first character of the value of this variable is used as the character make assumes is introducing a recipe line. If the variable is empty (as it is by default) that character is the standard tab character. For example, this is a valid makefile:

> @echo Hello, world

The value of .RECIPEPREFIX can be changed multiple times; once set it stays in effect for all rules parsed until it is modified.


Expands to a list of the names of all global variables defined so far. This includes variables which have empty values, as well as built-in variables (see Variables Used by Implicit Rules), but does not include any variables which are only defined in a target-specific context. Note that any value you assign to this variable will be ignored; it will always return its special value.


Expands to a list of special features supported by this version of make. Possible values include, but are not limited to:


Supports ar (archive) files using special file name syntax. See Using make to Update Archive Files.


Supports the -L (--check-symlink-times) flag. See Summary of Options.


Supports “else if” non-nested conditionals. See Syntax of Conditionals.


Supports “job server” enhanced parallel builds. See Parallel Execution.


Supports the .ONESHELL special target. See Using One Shell.


Supports order-only prerequisites. See Types of Prerequisites.


Supports secondary expansion of prerequisite lists.


Uses the “shortest stem” method of choosing which pattern, of multiple applicable options, will be used. See How Patterns Match.


Supports target-specific and pattern-specific variable assignments. See Target-specific Variable Values.


Supports the undefine directive. See Undefine Directive.


Has GNU Guile available as an embedded extension language. See GNU Guile Integration.


Supports dynamically loadable objects for creating custom extensions. See Loading Dynamic Objects.


Expands to a list of directories that make searches for included makefiles (see Including Other Makefiles).

Previous: , Up: Using Variables   [Contents][Index]