]> Git — Sourcephile - julm/julm-nix.git/blob - homes/softwares/git.nix
merge home-manager config
[julm/julm-nix.git] / homes / softwares / git.nix
1 { pkgs, lib, config, ... }:
2 {
3 programs.git = {
4 ignores = [ "*~" "*.swp" ];
5 package = lib.mkDefault pkgs.gitFull;
6 signing = {
7 signByDefault = false;
8 };
9 aliases = {
10 authors = "shortlog -s -n";
11 };
12 extraConfig = {
13 push.default = "simple";
14 color.diff = "auto";
15 #color.diff.whitespace = "red reverse";
16 color.status = "auto";
17 color.branch = "auto";
18 core.whitespace = "fix,-indent-with-non-tab,trailing-space,cr-at-eol";
19 core.quotepath = "false";
20 alias.s = "status -s";
21 alias.st = "status";
22 alias.ci = "commit";
23 alias.br = "branch";
24 alias.co = "checkout";
25 alias.dc = "diff --cached";
26 alias.df = "diff";
27 alias.dh = "diff --histogram";
28 alias.dp = "diff --patience";
29 alias.lp = "log -p";
30 alias.ll = "log --graph --decorate --pretty=oneline --abbrev-commit";
31 alias.ign = "ls-files -o -i --exclude-standard";
32 alias.spull = "!git-svn fetch && git-svn rebase";
33 alias.spush = "!git-svn dcommit";
34 alias.fetch-local = "!git fetch local && git tag -d $(git describe --exact-match 2>/dev/null >/dev/null) && git fetch --tags local";
35 alias.pull-local = "!git fetch-local && git checkout -B master local/master";
36 alias.pull-local-old = "!git fetch-local && git checkout HEAD'^' && git branch -f master local/master && git checkout master";
37 alias.root = ''!git rev-list --parents HEAD | egrep "^[a-f0-9]{40}$"'';
38 alias.has-tag-version = ''!git show-ref --tags -d | grep -qx \"^$(git rev-parse HEAD) refs/tags/v[0-9][0-9][0-9][0-9]\\.[0-9][0-9]\\.[0-9][0-9]\\(\\^{}\\)\\?\"'';
39 alias.tag-version = ''"!git has-tag-version && return; v=$(TZ=UTC date +v%Y-%m-%d) && name=$(git rev-parse --show-toplevel | sed -e 's:^.*/work::') && set -x && git tag -s -m \"$name $v\" $v"'';
40 alias.has-tag-majordate = ''!git show-ref --tags -d | grep -qx \"^$(git rev-parse HEAD) refs/tags/v[0-9]\\+.[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]\\(\\^{}\\)\\?\"'';
41 alias.tag-majordate = ''"!git has-tag-majordate && return; name=$(basename $(dirname $(git rev-parse --show-toplevel))); major=$(basename $(git rev-parse --show-toplevel)); version=''${version:-$(TZ=UTC date +\"v$major.%Y%m%d\")} && set -x && git tag -s -m \"$name $version\" $version"'';
42 alias.tag-cabal = ''"!set -x; for cabal in $(git ls-files | grep '.*\\.cabal$'); do name=$(sed -ne 's/^name: *\\(.*\\)/\\1/p' \"$cabal\"); version=$(sed -ne 's/^version: *\\(.*\\)/\\1/p' \"$cabal\"); git tag --merged | grep -Fqx \"$name-$version\" || git tag -f -s -m \"$name v$version\" $name-$version; done"'';
43 alias.cl = "notes --ref=changelog append";
44 alias.cl-bug = "notes --ref=changelogs/bugs append";
45 alias.cl-feature = "notes --ref=changelogs/features append";
46 alias.wip = "for-each-ref --sort='authordate:iso8601' --format=' %(color:green)%(authordate:relative)%09%(color:white)%(refname:short)' refs/heads";
47 diff.algorithm = "histogram";
48 diff.sqldiff.command = "sqldiff";
49 format.pretty = "oneline";
50 web.browser = "elinks";
51 browser.elinks.cmd = "elinks";
52 sendemail.chainreplyto = "false";
53 sendemail.composeencoding = "UTF-8";
54 sendemail.confirm = "always";
55 sendemail.envelopesender = "auto";
56 sendemail.multiedit = "yes";
57 sendemail.suppressfrom = "false";
58 sendemail.thread = "true";
59 sendemail.validate = "true";
60 merge.tool = "vimdiff";
61 protocol.version = 2;
62 rebase.autosquash = "true";
63 };
64 };
65 }