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).
120 lines
2.8 KiB
C++
120 lines
2.8 KiB
C++
#include "globals.hh"
|
|
#include "util.hh"
|
|
|
|
#include <map>
|
|
#include <algorithm>
|
|
|
|
|
|
namespace nix {
|
|
|
|
|
|
string nixStore = "/UNINIT";
|
|
string nixDataDir = "/UNINIT";
|
|
string nixLogDir = "/UNINIT";
|
|
string nixStateDir = "/UNINIT";
|
|
string nixDBPath = "/UNINIT";
|
|
string nixConfDir = "/UNINIT";
|
|
string nixLibexecDir = "/UNINIT";
|
|
string nixBinDir = "/UNINIT";
|
|
|
|
bool keepFailed = false;
|
|
bool keepGoing = false;
|
|
bool tryFallback = false;
|
|
Verbosity buildVerbosity = lvlInfo;
|
|
unsigned int maxBuildJobs = 1;
|
|
bool readOnlyMode = false;
|
|
string thisSystem = "unset";
|
|
unsigned int maxSilentTime = 0;
|
|
Paths substituters;
|
|
|
|
|
|
static bool settingsRead = false;
|
|
|
|
static std::map<string, Strings> settings;
|
|
|
|
|
|
string & at(Strings & ss, unsigned int n)
|
|
{
|
|
Strings::iterator i = ss.begin();
|
|
advance(i, n);
|
|
return *i;
|
|
}
|
|
|
|
|
|
static void readSettings()
|
|
{
|
|
Path settingsFile = (format("%1%/%2%") % nixConfDir % "nix.conf").str();
|
|
if (!pathExists(settingsFile)) return;
|
|
string contents = readFile(settingsFile);
|
|
|
|
unsigned int pos = 0;
|
|
|
|
while (pos < contents.size()) {
|
|
string line;
|
|
while (pos < contents.size() && contents[pos] != '\n')
|
|
line += contents[pos++];
|
|
pos++;
|
|
|
|
string::size_type hash = line.find('#');
|
|
if (hash != string::npos)
|
|
line = string(line, 0, hash);
|
|
|
|
Strings tokens = tokenizeString(line);
|
|
if (tokens.empty()) continue;
|
|
|
|
if (tokens.size() < 2 || at(tokens, 1) != "=")
|
|
throw Error(format("illegal configuration line `%1%' in `%2%'") % line % settingsFile);
|
|
|
|
string name = at(tokens, 0);
|
|
|
|
Strings::iterator i = tokens.begin();
|
|
advance(i, 2);
|
|
settings[name] = Strings(i, tokens.end());
|
|
};
|
|
|
|
settingsRead = true;
|
|
}
|
|
|
|
|
|
Strings querySetting(const string & name, const Strings & def)
|
|
{
|
|
if (!settingsRead) readSettings();
|
|
std::map<string, Strings>::iterator i = settings.find(name);
|
|
return i == settings.end() ? def : i->second;
|
|
}
|
|
|
|
|
|
string querySetting(const string & name, const string & def)
|
|
{
|
|
Strings defs;
|
|
defs.push_back(def);
|
|
|
|
Strings value = querySetting(name, defs);
|
|
if (value.size() != 1)
|
|
throw Error(format("configuration option `%1%' should not be a list") % name);
|
|
|
|
return value.front();
|
|
}
|
|
|
|
|
|
bool queryBoolSetting(const string & name, bool def)
|
|
{
|
|
string v = querySetting(name, def ? "true" : "false");
|
|
if (v == "true") return true;
|
|
else if (v == "false") return false;
|
|
else throw Error(format("configuration option `%1%' should be either `true' or `false', not `%2%'")
|
|
% name % v);
|
|
}
|
|
|
|
|
|
unsigned int queryIntSetting(const string & name, unsigned int def)
|
|
{
|
|
int n;
|
|
if (!string2Int(querySetting(name, int2String(def)), n) || n < 0)
|
|
throw Error(format("configuration setting `%1%' should have an integer value") % name);
|
|
return n;
|
|
}
|
|
|
|
|
|
}
|