summaryrefslogtreecommitdiff
path: root/users/seth/shell/default.nix
diff options
context:
space:
mode:
authorseth <[email protected]>2024-05-05 11:35:18 -0400
committerGitHub <[email protected]>2024-05-05 11:35:18 -0400
commit34a7a042a36b63eb6b900932b1e420e4b6014a57 (patch)
tree40dace9b4bb7b6e99c5d54165d8eb203963f5306 /users/seth/shell/default.nix
parent9380483bdf038149fc308698e9f115b1474a0c85 (diff)
simplify some things (#353)
* flake: drop flake-parts * flake: add back flake-parts * flake: use flake module again for configurations
Diffstat (limited to 'users/seth/shell/default.nix')
-rw-r--r--users/seth/shell/default.nix40
1 files changed, 40 insertions, 0 deletions
diff --git a/users/seth/shell/default.nix b/users/seth/shell/default.nix
new file mode 100644
index 0000000..b86697c
--- /dev/null
+++ b/users/seth/shell/default.nix
@@ -0,0 +1,40 @@
+{
+ config,
+ lib,
+ ...
+}: let
+ cfg = config.seth.shell;
+in {
+ options.seth.shell = {
+ aliases.enable = lib.mkEnableOption "Shell aliases" // {default = config.seth.enable;};
+ variables.enable = lib.mkEnableOption "Shell variables" // {default = config.seth.enable;};
+ };
+
+ imports = [
+ ./bash.nix
+ ./fish.nix
+ ./nu.nix
+ ./zsh.nix
+ ];
+
+ config = {
+ home = lib.mkMerge [
+ (lib.mkIf cfg.variables.enable {
+ sessionVariables = rec {
+ EDITOR = "nvim";
+ VISUAL = EDITOR;
+ CARGO_HOME = "${config.xdg.dataHome}/cargo";
+ LESSHISTFILE = "${config.xdg.stateHome}/less/history";
+ };
+ })
+
+ (lib.mkIf cfg.aliases.enable {
+ shellAliases = {
+ diff = "diff --color=auto";
+ g = "git";
+ gs = "g status";
+ };
+ })
+ ];
+ };
+}