aboutsummaryrefslogtreecommitdiff
path: root/src/nix-env
diff options
context:
space:
mode:
Diffstat (limited to 'src/nix-env')
-rw-r--r--src/nix-env/nix-env.cc42
-rw-r--r--src/nix-env/user-env.cc12
2 files changed, 27 insertions, 27 deletions
diff --git a/src/nix-env/nix-env.cc b/src/nix-env/nix-env.cc
index 02a9f25a7..12e19d4af 100644
--- a/src/nix-env/nix-env.cc
+++ b/src/nix-env/nix-env.cc
@@ -1,17 +1,17 @@
-#include "profiles.hh"
-#include "names.hh"
-#include "globals.hh"
-#include "misc.hh"
-#include "shared.hh"
-#include "eval.hh"
-#include "get-drvs.hh"
#include "attr-path.hh"
#include "common-opts.hh"
-#include "xml-writer.hh"
+#include "derivations.hh"
+#include "eval.hh"
+#include "get-drvs.hh"
+#include "globals.hh"
+#include "names.hh"
+#include "profiles.hh"
+#include "shared.hh"
#include "store-api.hh"
#include "user-env.hh"
#include "util.hh"
#include "value-to-json.hh"
+#include "xml-writer.hh"
#include <cerrno>
#include <ctime>
@@ -223,8 +223,8 @@ static int comparePriorities(EvalState & state, DrvInfo & drv1, DrvInfo & drv2)
static bool isPrebuilt(EvalState & state, DrvInfo & elem)
{
Path path = elem.queryOutPath();
- if (store->isValidPath(path)) return true;
- PathSet ps = store->querySubstitutablePaths(singleton<PathSet>(path));
+ if (state.store->isValidPath(path)) return true;
+ PathSet ps = state.store->querySubstitutablePaths(singleton<PathSet>(path));
return ps.find(path) != ps.end();
}
@@ -398,7 +398,7 @@ static void queryInstSources(EvalState & state,
if (isDerivation(path)) {
elem.setDrvPath(path);
- elem.setOutPath(findOutput(derivationFromPath(*store, path), "out"));
+ elem.setOutPath(state.store->derivationFromPath(path).findOutput("out"));
if (name.size() >= drvExtension.size() &&
string(name, name.size() - drvExtension.size()) == drvExtension)
name = string(name, 0, name.size() - drvExtension.size());
@@ -445,7 +445,7 @@ static void printMissing(EvalState & state, DrvInfos & elems)
targets.insert(i.queryOutPath());
}
- printMissing(*store, targets);
+ printMissing(state.store, targets);
}
@@ -711,18 +711,18 @@ static void opSet(Globals & globals, Strings opFlags, Strings opArgs)
if (drv.queryDrvPath() != "") {
PathSet paths = singleton<PathSet>(drv.queryDrvPath());
- printMissing(*store, paths);
+ printMissing(globals.state->store, paths);
if (globals.dryRun) return;
- store->buildPaths(paths, globals.state->repair ? bmRepair : bmNormal);
+ globals.state->store->buildPaths(paths, globals.state->repair ? bmRepair : bmNormal);
}
else {
- printMissing(*store, singleton<PathSet>(drv.queryOutPath()));
+ printMissing(globals.state->store, singleton<PathSet>(drv.queryOutPath()));
if (globals.dryRun) return;
- store->ensurePath(drv.queryOutPath());
+ globals.state->store->ensurePath(drv.queryOutPath());
}
debug(format("switching to new user environment"));
- Path generation = createGeneration(globals.profile, drv.queryOutPath());
+ Path generation = createGeneration(globals.state->store, globals.profile, drv.queryOutPath());
switchLink(globals.profile, generation);
}
@@ -973,8 +973,8 @@ static void opQuery(Globals & globals, Strings opFlags, Strings opArgs)
printMsg(lvlTalkative, format("skipping derivation named ‘%1%’ which gives an assertion failure") % i.name);
i.setFailed();
}
- validPaths = store->queryValidPaths(paths);
- substitutablePaths = store->querySubstitutablePaths(paths);
+ validPaths = globals.state->store->queryValidPaths(paths);
+ substitutablePaths = globals.state->store->querySubstitutablePaths(paths);
}
@@ -1394,9 +1394,9 @@ int main(int argc, char * * argv)
if (!op) throw UsageError("no operation specified");
- store = openStore();
+ auto store = openStore();
- globals.state = std::shared_ptr<EvalState>(new EvalState(searchPath));
+ globals.state = std::shared_ptr<EvalState>(new EvalState(searchPath, store));
globals.state->repair = repair;
if (file != "")
diff --git a/src/nix-env/user-env.cc b/src/nix-env/user-env.cc
index 9a20b9433..4e0e28c11 100644
--- a/src/nix-env/user-env.cc
+++ b/src/nix-env/user-env.cc
@@ -38,7 +38,7 @@ bool createUserEnv(EvalState & state, DrvInfos & elems,
drvsToBuild.insert(i.queryDrvPath());
debug(format("building user environment dependencies"));
- store->buildPaths(drvsToBuild, state.repair ? bmRepair : bmNormal);
+ state.store->buildPaths(drvsToBuild, state.repair ? bmRepair : bmNormal);
/* Construct the whole top level derivation. */
PathSet references;
@@ -76,8 +76,8 @@ bool createUserEnv(EvalState & state, DrvInfos & elems,
/* This is only necessary when installing store paths, e.g.,
`nix-env -i /nix/store/abcd...-foo'. */
- store->addTempRoot(j.second);
- store->ensurePath(j.second);
+ state.store->addTempRoot(j.second);
+ state.store->ensurePath(j.second);
references.insert(j.second);
}
@@ -100,7 +100,7 @@ bool createUserEnv(EvalState & state, DrvInfos & elems,
/* Also write a copy of the list of user environment elements to
the store; we need it for future modifications of the
environment. */
- Path manifestFile = store->addTextToStore("env-manifest.nix",
+ Path manifestFile = state.store->addTextToStore("env-manifest.nix",
(format("%1%") % manifest).str(), references);
/* Get the environment builder expression. */
@@ -128,7 +128,7 @@ bool createUserEnv(EvalState & state, DrvInfos & elems,
/* Realise the resulting store expression. */
debug("building user environment");
- store->buildPaths(singleton<PathSet>(topLevelDrv), state.repair ? bmRepair : bmNormal);
+ state.store->buildPaths(singleton<PathSet>(topLevelDrv), state.repair ? bmRepair : bmNormal);
/* Switch the current user environment to the output path. */
PathLocks lock;
@@ -141,7 +141,7 @@ bool createUserEnv(EvalState & state, DrvInfos & elems,
}
debug(format("switching to new user environment"));
- Path generation = createGeneration(profile, topLevelOut);
+ Path generation = createGeneration(state.store, profile, topLevelOut);
switchLink(profile, generation);
return true;