aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLinus Heckemann <git@sphalerite.org>2018-03-16 22:15:24 +0000
committerLinus Heckemann <git@sphalerite.org>2018-03-16 22:15:24 +0000
commit12913ccf454c1bc82a51c59872f8185b40c533c5 (patch)
tree96f483a67dff776480d2fa5b41846b347c43efa9 /src
parent48662d151bdf4a38670897beacea9d1bd750376a (diff)
nix-shell: allow symlinks to .drvs
This makes persistent shell environments easier to use.
Diffstat (limited to 'src')
-rwxr-xr-xsrc/nix-build/nix-build.cc8
-rw-r--r--src/nix-instantiate/nix-instantiate.cc2
2 files changed, 7 insertions, 3 deletions
diff --git a/src/nix-build/nix-build.cc b/src/nix-build/nix-build.cc
index 99f773451..cf628519c 100755
--- a/src/nix-build/nix-build.cc
+++ b/src/nix-build/nix-build.cc
@@ -271,10 +271,14 @@ void mainWrapped(int argc, char * * argv)
exprs = {state.parseStdin()};
else
for (auto i : left) {
+ auto absolute = i;
+ try {
+ absolute = canonPath(absPath(i), true);
+ } catch (Error e) {};
if (fromArgs)
exprs.push_back(state.parseExprFromString(i, absPath(".")));
- else if (store->isStorePath(i) && std::regex_match(i, std::regex(".*\\.drv(!.*)?")))
- drvs.push_back(DrvInfo(state, store, i));
+ else if (store->isStorePath(absolute) && std::regex_match(absolute, std::regex(".*\\.drv(!.*)?")))
+ drvs.push_back(DrvInfo(state, store, absolute));
else
/* If we're in a #! script, interpret filenames
relative to the script. */
diff --git a/src/nix-instantiate/nix-instantiate.cc b/src/nix-instantiate/nix-instantiate.cc
index dd262bea0..5049460c7 100644
--- a/src/nix-instantiate/nix-instantiate.cc
+++ b/src/nix-instantiate/nix-instantiate.cc
@@ -70,7 +70,7 @@ void processExpr(EvalState & state, const Strings & attrPaths,
if (gcRoot == "")
printGCWarning();
else {
- Path rootName = gcRoot;
+ Path rootName = indirectRoot ? absPath(gcRoot) : gcRoot;
if (++rootNr > 1) rootName += "-" + std::to_string(rootNr);
auto store2 = state.store.dynamic_pointer_cast<LocalFSStore>();
if (store2)