summary refs log tree commit diff
path: root/src/libstore/globals.hh
blob: 231c1f8508ac51a96676c4b40c66ed288a138dd2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#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;

/* 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();

    
}


#endif /* !__GLOBALS_H */