summaryrefslogtreecommitdiff
path: root/users/seth/module/shell/default.nix
diff options
context:
space:
mode:
authorseth <[email protected]>2024-02-03 19:27:26 -0500
committerseth <[email protected]>2024-02-03 20:47:55 -0500
commitfcc60b84e5e3cc44986d40af63f5de488caae909 (patch)
tree45f4455c7dcbc63e59e62a9af79783e2e5509a2e /users/seth/module/shell/default.nix
parentde003fa28e56b81a33e831099987cd94d2f53b39 (diff)
make everything a module
Diffstat (limited to 'users/seth/module/shell/default.nix')
-rw-r--r--users/seth/module/shell/default.nix40
1 files changed, 40 insertions, 0 deletions
diff --git a/users/seth/module/shell/default.nix b/users/seth/module/shell/default.nix
new file mode 100644
index 0000000..050cb0c
--- /dev/null
+++ b/users/seth/module/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 = true;};
+ variables.enable = lib.mkEnableOption "Shell variables" // {default = true;};
+ };
+
+ 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";
+ };
+ })
+ ];
+ };
+}