From 4d1cbd614fd81602c0e166f14c0c7642be178af0 Mon Sep 17 00:00:00 2001 From: Chris Montgomery Date: Wed, 6 Sep 2023 18:32:21 -0400 Subject: [PATCH] fix(shell:aliases|nu): workaround to support exa aliases option --- .../homeProfiles/shells/nushell/default.nix | 22 +++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/profiles/homeProfiles/shells/nushell/default.nix b/profiles/homeProfiles/shells/nushell/default.nix index f9303893b..9750f53a0 100644 --- a/profiles/homeProfiles/shells/nushell/default.nix +++ b/profiles/homeProfiles/shells/nushell/default.nix @@ -8,10 +8,13 @@ inherit (config.home) username sessionVariables; l = flake.inputs.nixpkgs.lib // builtins; - # FIXME: hardcoded + exaCfg = config.programs.exa; + + # FIXME: hardcoded -- note also that we can't rely on variable expansion to resolve paths in env.nu userConfigDir = "~/.config/dotfield/users/${username}/config/nushell"; /* + @partial replaceVars :: [String] -> (String -> String) */ replaceVars = names: @@ -19,6 +22,11 @@ (l.map (v: "$" + v) names) (l.map (v: "$env.${v}") names); + /* + replaceVars' :: String -> String + */ + replaceVars' = replaceVars commonNames; + commonNames = [ "HOME" "EDITOR" @@ -37,7 +45,7 @@ lib.concatStringsSep "\n" (lib.mapAttrsToList (name: value: let - value' = replaceVars commonNames value; + value' = replaceVars' value; in "$env.${name} = `${value'}`") attrs); in { @@ -63,4 +71,14 @@ in { xdg.configFile."nushell/home.nu".source = pkgs.writeText "home.nu" '' ${attrsToEnvDecls sessionVariables} ''; + + # FIXME: needs PR to upstream `exa` module for fix to use + # `home.shellAliases`, not shell-specific options + home.shellAliases = lib.mkIf (exaCfg.enable && exaCfg.enableAliases) { + ls = "exa"; + ll = "exa -l"; + la = "exa -a"; + lt = "exa --tree"; + lla = "exa -la"; + }; }