direnv: work around nushell bug

try/catch in a pipeline does not always work correctly in 0.98,
so avoid the try-catch entirely.

Upstream issue: https://github.com/nushell/nushell/issues/13868
This commit is contained in:
K900 2024-09-26 20:07:37 +03:00 committed by GitHub
parent c124568e10
commit 57e6b30d18
Failed to generate hash of commit
2 changed files with 7 additions and 8 deletions

View file

@ -141,12 +141,12 @@ in {
| default [] | default []
| append {|| | append {||
let direnv = ( let direnv = (
try { # We want to get the stdout from direnv even if it exits with non-zero,
${getExe cfg.package} export json # because it will have the DIRENV_ internal variables defined.
} catch { do { ${getExe cfg.package} export json }
"" | complete
} | get stdout
| from json | from json --strict
| default {} | default {}
) )
if ($direnv | is-empty) { if ($direnv | is-empty) {

View file

@ -13,7 +13,6 @@
"home-files/.config/nushell/config.nu"; "home-files/.config/nushell/config.nu";
in '' in ''
assertFileExists "${configFile}" assertFileExists "${configFile}"
assertFileRegex "${configFile}" \ assertFileRegex "${configFile}" '/nix/store/.*direnv.*/bin/direnv export json'
'^\s*/nix/store/.*direnv.*/bin/direnv export json$'
''; '';
} }