From 12712f3f7738852c1e12eec98f1ddd6c6f9629f4 Mon Sep 17 00:00:00 2001 From: Bruno BELANYI Date: Fri, 19 Feb 2021 21:48:25 +0000 Subject: [PATCH] home: add git --- home/default.nix | 1 + home/git/default.nix | 95 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) create mode 100644 home/git/default.nix diff --git a/home/default.nix b/home/default.nix index 33e889a..99ec3e8 100644 --- a/home/default.nix +++ b/home/default.nix @@ -2,6 +2,7 @@ { imports = [ ./direnv.nix + ./git ./zsh ]; } diff --git a/home/git/default.nix b/home/git/default.nix new file mode 100644 index 0000000..fab4b7b --- /dev/null +++ b/home/git/default.nix @@ -0,0 +1,95 @@ +{ pkgs, ... }: +{ + programs.git = { + enable = true; + + # Who am I? + userEmail = "bruno@belanyi.fr"; + userName = "Bruno BELANYI"; + + # I want the full experience + package = pkgs.gitAndTools.gitFull; + + aliases = { + lol = "log --graph --decorate --pretty=oneline --abbrev-commit"; + lola = "lol --all"; + assume = "update-index --assume-unchanged"; + unassume = "update-index --no-assume-unchanged"; + assumed = "!git ls-files -v | grep ^h | cut -c 3-"; + push-new = "!git push -u origin " + + ''"$(git branch | grep '^* ' | cut -f2- -d' ')"''; + }; + + lfs.enable = true; + + # There's more + extraConfig = { + # Makes it a bit more readable + blame = { + coloring = "repeatedLines"; + markUnblamables = true; + markIgnoredLines = true; + }; + + # I want `pull --rebase` as a default + branch = { + autosetubrebase = "always"; + }; + + # Shiny colors + color = { + ui = "auto"; + branch = "auto"; + diff = "auto"; + interactive = "auto"; + status = "auto"; + }; + + # Pretty much the usual diff colors + "color.diff" = { + commit = "yellow"; + meta = "yellow"; + frag = "cyan"; + old = "red"; + new = "green"; + whitespace = "red reverse"; + }; + + commit = { + # Show my changes when writing the message + verbose = true; + }; + + diff = { + # Usually leads to better results + algorithm = "patience"; + }; + + fetch = { + # I don't want hanging references + prune = true; + pruneTags = true; + }; + + init = { + defaultBranch = "main"; + }; + + pull = { + # Avoid useless merge commits + rebase = true; + }; + + push = { + # Just yell at me instead of trying to be smart + default = "simple"; + }; + + rebase = { + # Why isn't it the default?... + autoSquash = true; + autoStash = true; + }; + }; + }; +}