diff options
author | Shea Levy <shea@shealevy.com> | 2013-10-17 11:07:34 -0400 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2013-10-18 14:34:46 +0200 |
commit | 4ea034a5c56a60ae0ceedf18a066c428a963c836 (patch) | |
tree | 938709e8fc741cc0b494df7b1dd870f41d78a819 | |
parent | 792fd51f41212b0bf1d8a121a4f228a92fec3906 (diff) |
nix-shell: Play nicely with non-interactive shells
nix-shell with the --command flag might be used non-interactively, but
if bash starts non-interactively (i.e. with stdin or stderr not a
terminal), it won't source the script given in --rcfile. However, in
that case it *will* source the script found in $BASH_ENV, so we can use
that instead.
Also, don't source ~/.bashrc in a non-interactive shell (detectable by
checking the PS1 env var)
Signed-off-by: Shea Levy <shea@shealevy.com>
-rwxr-xr-x | scripts/nix-build.in | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/scripts/nix-build.in b/scripts/nix-build.in index 3b5b8413c..4bf85ae13 100755 --- a/scripts/nix-build.in +++ b/scripts/nix-build.in @@ -202,7 +202,8 @@ foreach my $expr (@exprs) { my $rcfile = "$tmpDir/rc"; writeFile( $rcfile, - '[ -e ~/.bashrc ] && source ~/.bashrc; ' . + 'unset BASH_ENV; ' . + '[ -n "$PS1" ] && [ -e ~/.bashrc ] && source ~/.bashrc; ' . ($pure ? '' : 'p=$PATH; ' ) . 'dontAddDisableDepTrack=1; ' . '[ -e $stdenv/setup ] && source $stdenv/setup; ' . @@ -212,6 +213,7 @@ foreach my $expr (@exprs) { 'unset NIX_ENFORCE_PURITY; ' . 'shopt -u nullglob; ' . $envCommand); + $ENV{BASH_ENV} = $rcfile; exec($ENV{NIX_BUILD_SHELL} // "bash", "--rcfile", $rcfile); die; } |