diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 475150fd..965d5620 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -141,6 +141,9 @@ /modules/programs/sbt.nix @kubukoz /tests/modules/programs/sbt @kubukoz +/modules/programs/scmpuff.nix @cpcloud +/tests/modules/programs/scmpuff @cpcloud + /modules/programs/ssh.nix @rycee /modules/programs/starship.nix @marsam diff --git a/modules/modules.nix b/modules/modules.nix index 0e4e7fef..952abc1e 100644 --- a/modules/modules.nix +++ b/modules/modules.nix @@ -118,6 +118,7 @@ let (loadModule ./programs/rofi.nix { }) (loadModule ./programs/rofi-pass.nix { }) (loadModule ./programs/rtorrent.nix { }) + (loadModule ./programs/scmpuff.nix { }) (loadModule ./programs/skim.nix { }) (loadModule ./programs/starship.nix { }) (loadModule ./programs/sbt.nix { }) diff --git a/modules/programs/scmpuff.nix b/modules/programs/scmpuff.nix new file mode 100644 index 00000000..5f34e7db --- /dev/null +++ b/modules/programs/scmpuff.nix @@ -0,0 +1,46 @@ +{ config, lib, pkgs, ... }: +with lib; +let cfg = config.programs.scmpuff; +in { + meta.maintainers = [ maintainers.cpcloud ]; + + options.programs.scmpuff = { + enable = mkEnableOption + "scmpuff, a command line tool that allows you to work quicker with Git by substituting numeric shortcuts for files"; + + package = mkOption { + type = types.package; + default = pkgs.gitAndTools.scmpuff; + defaultText = literalExample "pkgs.gitAndTools.scmpuff"; + description = "Package providing the scmpuff tool."; + }; + + enableBashIntegration = mkOption { + default = true; + type = types.bool; + description = '' + Whether to enable Bash integration. + ''; + }; + + enableZshIntegration = mkOption { + default = true; + type = types.bool; + description = '' + Whether to enable Zsh integration. + ''; + }; + }; + + config = mkIf cfg.enable { + home.packages = [ cfg.package ]; + + programs.bash.initExtra = mkIf cfg.enableBashIntegration '' + eval "$(${cfg.package}/bin/scmpuff init -s)" + ''; + + programs.zsh.initExtra = mkIf cfg.enableZshIntegration '' + eval "$(${cfg.package}/bin/scmpuff init -s)" + ''; + }; +} diff --git a/tests/default.nix b/tests/default.nix index c2202759..de0a2eb3 100644 --- a/tests/default.nix +++ b/tests/default.nix @@ -71,6 +71,7 @@ import nmt { ./modules/programs/qutebrowser ./modules/programs/readline ./modules/programs/sbt + ./modules/programs/scmpuff ./modules/programs/ssh ./modules/programs/starship ./modules/programs/texlive diff --git a/tests/modules/programs/scmpuff/bash.nix b/tests/modules/programs/scmpuff/bash.nix new file mode 100644 index 00000000..8011e2d5 --- /dev/null +++ b/tests/modules/programs/scmpuff/bash.nix @@ -0,0 +1,15 @@ +{ pkgs, ... }: { + config = { + programs = { + scmpuff.enable = true; + bash.enable = true; + }; + + nmt.script = '' + assertFileExists home-files/.bashrc + assertFileContains \ + home-files/.bashrc \ + 'eval "$(${pkgs.gitAndTools.scmpuff}/bin/scmpuff init -s)"' + ''; + }; +} diff --git a/tests/modules/programs/scmpuff/default.nix b/tests/modules/programs/scmpuff/default.nix new file mode 100644 index 00000000..5852c5b6 --- /dev/null +++ b/tests/modules/programs/scmpuff/default.nix @@ -0,0 +1,7 @@ +{ + scmpuff-bash = ./bash.nix; + scmpuff-no-bash = ./no-bash.nix; + scmpuff-no-shell = ./no-shell.nix; + scmpuff-no-zsh = ./no-zsh.nix; + scmpuff-zsh = ./zsh.nix; +} diff --git a/tests/modules/programs/scmpuff/no-bash.nix b/tests/modules/programs/scmpuff/no-bash.nix new file mode 100644 index 00000000..0b67e1f6 --- /dev/null +++ b/tests/modules/programs/scmpuff/no-bash.nix @@ -0,0 +1,15 @@ +{ pkgs, ... }: { + config = { + programs = { + scmpuff = { + enable = true; + enableBashIntegration = false; + }; + bash.enable = true; + }; + + nmt.script = '' + assertFileNotRegex home-files/.bashrc '${pkgs.gitAndTools.scmpuff}/bin/scmpuff' + ''; + }; +} diff --git a/tests/modules/programs/scmpuff/no-shell.nix b/tests/modules/programs/scmpuff/no-shell.nix new file mode 100644 index 00000000..02657e02 --- /dev/null +++ b/tests/modules/programs/scmpuff/no-shell.nix @@ -0,0 +1,18 @@ +{ pkgs, ... }: { + config = { + programs = { + scmpuff = { + enable = true; + enableBashIntegration = false; + enableZshIntegration = false; + }; + bash.enable = true; + zsh.enable = true; + }; + + nmt.script = '' + assertFileNotRegex home-files/.zshrc '${pkgs.gitAndTools.scmpuff} init -s' + assertFileNotRegex home-files/.bashrc '${pkgs.gitAndTools.scmpuff} init -s' + ''; + }; +} diff --git a/tests/modules/programs/scmpuff/no-zsh.nix b/tests/modules/programs/scmpuff/no-zsh.nix new file mode 100644 index 00000000..b2d3eec2 --- /dev/null +++ b/tests/modules/programs/scmpuff/no-zsh.nix @@ -0,0 +1,15 @@ +{ pkgs, ... }: { + config = { + programs = { + scmpuff = { + enable = true; + enableZshIntegration = false; + }; + zsh.enable = true; + }; + + nmt.script = '' + assertFileNotRegex home-files/.zshrc '${pkgs.gitAndTools.scmpuff} init -s' + ''; + }; +} diff --git a/tests/modules/programs/scmpuff/zsh.nix b/tests/modules/programs/scmpuff/zsh.nix new file mode 100644 index 00000000..183b0544 --- /dev/null +++ b/tests/modules/programs/scmpuff/zsh.nix @@ -0,0 +1,15 @@ +{ pkgs, ... }: { + config = { + programs = { + scmpuff.enable = true; + zsh.enable = true; + }; + + nmt.script = '' + assertFileExists home-files/.zshrc + assertFileContains \ + home-files/.zshrc \ + 'eval "$(${pkgs.gitAndTools.scmpuff}/bin/scmpuff init -s)"' + ''; + }; +}