forked from lix-project/lix
9e975458b4
need any info on substitutable paths, we just call the substituters (such as download-using-manifests.pl) directly. This means that it's no longer necessary for nix-pull to register substitutes or for nix-channel to clear them, which makes those operations much faster (NIX-95). Also, we don't have to worry about keeping nix-pull manifests (in /nix/var/nix/manifests) and the database in sync with each other. The downside is that there is some overhead in calling an external program to get the substitutes info. For instance, "nix-env -qas" takes a bit longer. Abolishing the substitutes table also makes the logic in local-store.cc simpler, as we don't need to store info for invalid paths. On the downside, you cannot do things like "nix-store -qR" on a substitutable but invalid path (but nobody did that anyway). * Never catch interrupts (the Interrupted exception).
89 lines
2.2 KiB
C++
89 lines
2.2 KiB
C++
#ifndef __GLOBALS_H
|
|
#define __GLOBALS_H
|
|
|
|
#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;
|
|
|
|
/* 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 unsigned int maxSilentTime;
|
|
|
|
/* 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;
|
|
|
|
|
|
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);
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif /* !__GLOBALS_H */
|