#pragma once #include "types.hh" namespace nix { /* Path names. */ /* nixStore is the directory where we generally store atomic and derived files. */ extern string nixStore; extern string nixDataDir; /* !!! fix */ /* nixLogDir is the directory where we log various operations. */ extern string nixLogDir; /* nixStateDir is the directory where state is stored. */ extern string nixStateDir; /* nixDBPath is the path name of our Berkeley DB environment. */ extern string nixDBPath; /* nixConfDir is the directory where configuration files are stored. */ extern string nixConfDir; /* nixLibexecDir is the directory where internal helper programs are stored. */ extern string nixLibexecDir; /* nixBinDir is the directory where the main programs are stored. */ extern string nixBinDir; /* Misc. global flags. */ /* Whether to keep temporary directories of failed builds. */ extern bool keepFailed; /* Whether to keep building subgoals when a sibling (another subgoal of the same goal) fails. */ extern bool keepGoing; /* Whether, if we cannot realise the known closure corresponding to a derivation, we should try to normalise the derivation instead. */ extern bool tryFallback; /* Verbosity level for build output. */ extern Verbosity buildVerbosity; /* Maximum number of parallel build jobs. 0 means unlimited. */ extern unsigned int maxBuildJobs; /* Number of CPU cores to utilize in parallel within a build, i.e. by passing this number to Make via '-j'. 0 means that the number of actual CPU cores on the local host ought to be auto-detected. */ extern unsigned int buildCores; /* Read-only mode. Don't copy stuff to the store, don't change the database. */ extern bool readOnlyMode; /* The canonical system name, as returned by config.guess. */ extern string thisSystem; /* The maximum time in seconds that a builer can go without producing any output on stdout/stderr before it is killed. 0 means infinity. */ extern time_t maxSilentTime; /* The maximum duration in seconds that a builder can run. 0 means infinity. */ extern time_t buildTimeout; /* The substituters. There are programs that can somehow realise a store path without building, e.g., by downloading it or copying it from a CD. */ extern Paths substituters; /* Whether to use build hooks (for distributed builds). Sometimes users want to disable this from the command-line. */ extern bool useBuildHook; /* Whether buildDerivations() should print out lines on stderr in a fixed format to allow its progress to be monitored. Each line starts with a "@". The following are defined: @ build-started <drvpath> <outpath> <system> <logfile> @ build-failed <drvpath> <outpath> <exitcode> <error text> @ build-succeeded <drvpath> <outpath> @ substituter-started <outpath> <substituter> @ substituter-failed <outpath> <exitcode> <error text> @ substituter-succeeded <outpath> Best combined with --no-build-output, otherwise stderr might conceivably contain lines in this format printed by the builders. */ extern bool printBuildTrace; Strings querySetting(const string & name, const Strings & def); string querySetting(const string & name, const string & def); bool queryBoolSetting(const string & name, bool def); unsigned int queryIntSetting(const string & name, unsigned int def); void overrideSetting(const string & name, const Strings & value); void reloadSettings(); void setDefaultsFromEnvironment(); string packSettings(); }