If your build environment is fairly constant, you might want to use environment variables to avoid respecifying values for each build. Environment variables function the same way as command-line options, but command-line options take precedence over environment variables.
Because eMake environment variables are propagated automatically to Agents, most commands running on an Agent will run with the correct environment without modifications.
However, two important exceptions exist.
-
As described in Configuring Tools, if tools on the cluster host in different locations from the build system, the
PATH
variable (and other variables that reference tool locations) on the build system must be modified to include the locations for the cluster tools. -
Generally, differences between the build system and cluster hosts might indicate it is undesirable to override environment variables with eMake values. In this case, use the
--emake-exclude-env
command-line option or theEMAKE_EXCLUDE_ENV
environment variable.
For example, consider a build system environment variable called LICENSE_SERVER
that normally contains the license server name that the system should contact to obtain a tools license. If this variable is machine-specific, eMake overrides the correct machine-specific value on the cluster hosts with the value from the build system. To ensure eMake does not override LICENSE_SERVER
with the value from the build system, use the option, --emake-exclude-env
, when running eMake:
--emake-exclude-env=LICENSE_SERVER
You can specify more than one value by separating them with commas:
--emake-exclude-env=LICENSE_SERVER,TOOLS_SERVER
Some variables are almost always used to describe the local machine state, so eMake always excludes them from mirroring. These variables are:
TMP TEMP TMPDIR
For Windows, this list also includes:
COMSPEC SYSTEMROOT
Configuring ccache
The only configuration required to use ccache with Accelerator is to set the CCACHE_NOSTATS
environment variable. If you do not set this environment variable, the entire build becomes serialized because ccache continuously writes to a statistics file throughout the build. To learn more about ccache, refer to https://ccache.dev/.