pumpkin: syncoid: setup service
[julm/julm-nix.git] / home-manager / profiles / git.nix
index 53dfead29e916d6fc52395acab56a247009b9890..677f4a68a6340329c5dcea9c104c96f9fbb00884 100644 (file)
@@ -1,6 +1,6 @@
-{ pkgs, lib, ... }:
+{ pkgs, lib, config, ... }:
 {
-  home.packages = [
+  home.packages = lib.mkIf config.programs.git.enable [
     pkgs.b4
     pkgs.delta
     pkgs.difftastic
     #pkgs.git-publish
     pkgs.git-quick-stats
     pkgs.gitui
+    #pkgs.radicle-node
     pkgs.tig
   ];
   programs.git = {
-    enable = true;
+    enable = lib.mkDefault true;
     ignores = [ "*~" "*.swp" ];
     package = lib.mkDefault pkgs.gitMinimal;
     aliases = {
       ign = "ls-files -o -i --exclude-standard";
       l = "log";
       ll = "log --graph --decorate --pretty=oneline --abbrev-commit";
-      lp = "log -p --pretty=fuller";
-      lpg = "log -p --pretty=fuller -g";
+      lp = "log -p --pretty=fuller --stat";
+      lpg = "log -p --pretty=fuller --stat -g";
       p = "push -v";
-      pf = "push -vf";
-      pu = "pull";
+      pa = "patch";
+      patch = "push rad HEAD:refs/patches";
+      # See https://stackoverflow.com/a/65839129/6741004
+      pf = "push -v --force-with-lease --force-if-includes";
+      pl = "pull";
       r = "reset";
       rh = "reset --hard";
       ri = "rebase -i";
@@ -61,6 +65,7 @@
       spush = "!git-svn dcommit";
       ss = "status -s";
       st = "status -uno";
+      stu = "status -unormal";
       sw = "switch";
       fetch-local = "!git fetch local && git tag -d $(git describe --exact-match 2>/dev/null >/dev/null) && git fetch --tags local";
       pull-local = "!git fetch-local && git checkout -B master local/master";
       protocol.version = 2;
       pull.rebase = true;
       push.default = "simple";
+      push.useForceIfIncludes = true;
       rebase.autosquash = "true";
       sendemail.chainReplyTo = "false";
       sendemail.composeencoding = "UTF-8";
 
       # delta
       /*
-      core.pager = "delta";
-      interactive.diffFilter = "${pkgs.delta}/bin/delta --color-only --features=interactive";
+      core.pager = "delta --grep-separator-symbol keep";
+      interactive.diffFilter = "delta --color-only --features=interactive";
       delta.features = "decorations";
       delta.interactive = {
         keep-plus-minus-markers = false;
       */
     };
   };
-  programs.bash = {
+  programs.bash = lib.mkIf config.programs.git.enable {
     shellAliases = {
       g = "git";
       ge = "git-edit-commit";