[ < ] [ > ]   [ << ] [ Up ] [ >> ]         [Top] [Contents] [Index] [ ? ]

6. How to Use Variables

A variable is a name defined in a makefile to represent a string of text, called the variable's value. These values are substituted by explicit request into targets, prerequisites, commands, and other parts of the makefile. (In some other versions of make, variables are called macros.)

Variables and functions in all parts of a makefile are expanded when read, except for the shell commands in rules, the right-hand sides of variable definitions using `=', and the bodies of variable definitions using the define directive.

Variables can represent lists of file names, options to pass to compilers, programs to run, directories to look in for source files, directories to write output in, or anything else you can imagine.

A variable name may be any sequence of characters not containing `:', `#', `=', or leading or trailing whitespace. However, variable names containing characters other than letters, numbers, and underscores should be avoided, as they may be given special meanings in the future, and with some shells they cannot be passed through the environment to a sub-make (see section Communicating Variables to a Sub-make).

Variable names are case-sensitive. The names `foo', `FOO', and `Foo' all refer to different variables.

It is traditional to use upper case letters in variable names, but we recommend using lower case letters for variable names that serve internal purposes in the makefile, and reserving upper case for parameters that control implicit rules or for parameters that the user should override with command options (see section Overriding Variables).

A few variables have names that are a single punctuation character or just a few characters. These are the automatic variables, and they have particular specialized uses. See section Automatic Variables.

6.1 Basics of Variable References  How to use the value of a variable.
6.2 The Two Flavors of Variables  Variables come in two flavors.
6.3 Advanced Features for Reference to Variables  Advanced features for referencing a variable.
6.4 How Variables Get Their Values  All the ways variables get their values.
6.5 Setting Variables  How to set a variable in the makefile.
6.6 Appending More Text to Variables  How to append more text to the old value of a variable.
6.7 The override Directive  How to set a variable in the makefile even if the user has set it with a command argument.
6.8 Defining Variables Verbatim  An alternate way to set a variable to a verbatim string.
6.9 Variables from the Environment  Variable values can come from the environment.
6.10 Target-specific Variable Values  Variable values can be defined on a per-target basis.
6.11 Pattern-specific Variable Values  Target-specific variable values can be applied to a group of targets that match a pattern.


[ < ] [ > ]   [ << ] [ Up ] [ >> ]         [Top] [Contents] [Index] [ ? ]

This document was generated by Jeff Bailey on December, 25 2002 using texi2html