forked from lix-project/lix
use nixpkgs#bashInteractive for dev-shell
This commit is contained in:
parent
5f64655ff4
commit
8fbc8540d3
1 changed files with 39 additions and 2 deletions
|
@ -6,6 +6,9 @@
|
||||||
#include "derivations.hh"
|
#include "derivations.hh"
|
||||||
#include "affinity.hh"
|
#include "affinity.hh"
|
||||||
#include "progress-bar.hh"
|
#include "progress-bar.hh"
|
||||||
|
#include "attr-path.hh"
|
||||||
|
#include "eval-cache.hh"
|
||||||
|
#include "flake/flake.hh"
|
||||||
|
|
||||||
#include <regex>
|
#include <regex>
|
||||||
|
|
||||||
|
@ -281,6 +284,41 @@ struct CmdDevShell : Common, MixEnvironment
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string getBashPath(ref<Store> store)
|
||||||
|
{
|
||||||
|
auto flakeRef = FlakeRef::fromAttrs({{"type","indirect"}, {"id", "nixpkgs"}});
|
||||||
|
auto state = getEvalState();
|
||||||
|
auto lockedFlake = std::make_shared<flake::LockedFlake>(lockFlake(*state, flakeRef, lockFlags));
|
||||||
|
auto cache = openEvalCache(*state, lockedFlake, true);
|
||||||
|
auto root = cache->getRoot();
|
||||||
|
|
||||||
|
auto attrPath = "legacyPackages." + settings.thisSystem.get() + ".bashInteractive";
|
||||||
|
auto attr = root->findAlongAttrPath(parseAttrPath(*state, attrPath));
|
||||||
|
if (!attr || !attr->isDerivation()) throw Error("couldn't find bashInteractive derivation");
|
||||||
|
|
||||||
|
auto aDrvPath = attr->getAttr(state->sDrvPath);
|
||||||
|
auto drvPath = store->parseStorePath(aDrvPath->getString());
|
||||||
|
if (!store->isValidPath(drvPath) && !settings.readOnlyMode) {
|
||||||
|
/* The eval cache contains 'drvPath', but the actual path
|
||||||
|
has been garbage-collected. So force it to be
|
||||||
|
regenerated. */
|
||||||
|
aDrvPath->forceValue();
|
||||||
|
if (!store->isValidPath(drvPath))
|
||||||
|
throw Error("don't know how to recreate store derivation '%s'!",
|
||||||
|
store->printStorePath(drvPath));
|
||||||
|
}
|
||||||
|
|
||||||
|
auto outputName = attr->getAttr(state->sOutputName)->getString();
|
||||||
|
if (outputName == "")
|
||||||
|
throw Error("derivation '%s' lacks an 'outputName' attribute", store->printStorePath(drvPath));
|
||||||
|
|
||||||
|
auto outPath = store->parseStorePath(attr->getAttr(state->sOutPath)->getString());
|
||||||
|
|
||||||
|
store->buildPaths({{drvPath, {outputName}}});
|
||||||
|
|
||||||
|
return store->printStorePath(outPath) + "/bin/bash";
|
||||||
|
}
|
||||||
|
|
||||||
void run(ref<Store> store) override
|
void run(ref<Store> store) override
|
||||||
{
|
{
|
||||||
auto [buildEnvironment, gcroot] = getBuildEnvironment(store);
|
auto [buildEnvironment, gcroot] = getBuildEnvironment(store);
|
||||||
|
@ -303,12 +341,11 @@ struct CmdDevShell : Common, MixEnvironment
|
||||||
|
|
||||||
stopProgressBar();
|
stopProgressBar();
|
||||||
|
|
||||||
auto shell = getEnv("SHELL").value_or("bash");
|
|
||||||
|
|
||||||
setEnviron();
|
setEnviron();
|
||||||
// prevent garbage collection until shell exits
|
// prevent garbage collection until shell exits
|
||||||
setenv("NIX_GCROOT", gcroot.data(), 1);
|
setenv("NIX_GCROOT", gcroot.data(), 1);
|
||||||
|
|
||||||
|
auto shell = getBashPath(store);
|
||||||
auto args = Strings{std::string(baseNameOf(shell)), "--rcfile", rcFilePath};
|
auto args = Strings{std::string(baseNameOf(shell)), "--rcfile", rcFilePath};
|
||||||
|
|
||||||
restoreAffinity();
|
restoreAffinity();
|
||||||
|
|
Loading…
Reference in a new issue