gitconfig 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. [user]
  2. name = Fabian Peter Hammerle
  3. email = fabian@hammerle.me
  4. signingkey = 8D2902FE7DF47DDEDA2802F9456B9A0399A5DA2F
  5. [core]
  6. excludesfile = ~/.config/git/gitignore
  7. # hooksPath = ~/.config/git/hooks
  8. [interactive]
  9. singleKey = true
  10. [init]
  11. defaultBranch = main
  12. [status]
  13. branch = true
  14. short = true
  15. showUntrackedFiles = normal
  16. [grep]
  17. lineNumber = true
  18. [diff]
  19. tool = vimdiff
  20. [diff "cat"]
  21. textconv = cat
  22. [diff "csv-to-yaml"]
  23. textconv = csv-to-yaml
  24. [diff "db_dump"]
  25. textconv = db_dump
  26. [diff "gpg-show-keys"]
  27. textconv = gpg --show-keys --with-subkey-fingerprint --with-keygrip --
  28. [diff "gpg-verify"]
  29. textconv = gpg --verify --output=- 2>&1 --
  30. [diff "hexdump"]
  31. textconv = od -t x1z --
  32. [diff "yq"]
  33. textconv = yq --yaml-output --indentless-lists . --
  34. [diff "openssl-x509-text"]
  35. textconv = "sh -c 'while openssl x509 -noout -text; do echo; done' <\"$1\" 2>&1"
  36. [diff "pandas-parquet-to-json"]
  37. # g+r for podman container
  38. # https://git.hammerle.me/fphammerle/setup/commit/9c7167b9a9f7e5829d1fba5006b104ab72f6d13a
  39. textconv = "chmod g+r \"$1\" && env --debug -- pandas-parquet-to-json"
  40. [diff "pgpdump"]
  41. textconv = pgpdump
  42. [diff "xzcat"]
  43. textconv = xzcat
  44. [diff "zcat"]
  45. textconv = zcat
  46. [filter "ipynb"]
  47. clean = jq --indent 1 '.cells[].id? = null | (.cells[].outputs[].data[\"application/vnd.jupyter.widget-view+json\"]|objects|select(has(\"model_id\"))).model_id |= null'
  48. [filter "lfs"]
  49. clean = git-lfs clean -- %f
  50. smudge = git-lfs smudge -- %f
  51. process = git-lfs filter-process
  52. required = true
  53. [commit]
  54. gpgsign = true
  55. verbose = true
  56. [rebase]
  57. instructionFormat = %G? %s (%an <%ae>, %ai)
  58. autostash = true
  59. [push]
  60. default = current
  61. [url "git@git.hammerle.me:"]
  62. pushInsteadOf = https://git.hammerle.me/
  63. [url "git@github.com:"]
  64. pushInsteadOf = https://github.com/
  65. [tag]
  66. forceSignAnnotated = true
  67. [log]
  68. date = iso8601-strict
  69. [gcrypt]
  70. participants = 8D2902FE7DF47DDEDA2802F9456B9A0399A5DA2F
  71. publish-participants = false
  72. [annex]
  73. securehashesonly = true
  74. autocommit = false
  75. synccontent = true
  76. # copy instead of hard-linking when unlocking
  77. thin = false
  78. # assistant: do not auto delete unused files
  79. expireunused = false
  80. # fixes sync of repos inside encfs mounts
  81. ssh-options = -S~/.ssh/%r@%n:%p
  82. [alias]
  83. a = add
  84. c = commit
  85. # git curl-github-api /commits/master/statuses | jq '.[].state'
  86. curl-github-api = "!f() { path="$1"; shift; git github-repo-names | xargs -I{} --verbose curl --header 'Accept: application/vnd.github.v3+json' 'https://api.github.com/repos/{}'\"$path\" "$@"; }; f"
  87. # git curl-github-ref-status dev | jq '{state, statuses, commit_url}'
  88. curl-github-ref-status = "!f() { ref="$1"; shift; git curl-github-api "/commits/$ref/status" "$@"; }; f"
  89. d = diff
  90. f = fetch --prune
  91. github-repo-names = !git github-urls | grep --only-matching --perl-regexp 'github.com/\\K.+(?=\\.git)'
  92. github-urls = !git remote-urls | grep ^https://github.com/
  93. p = push --verbose
  94. remote-urls = !git remote | xargs -L1 git remote get-url
  95. s = status
  96. t = for-each-ref --sort taggerdate --format '%(taggerdate:iso) %(objectname) %(tag)' refs/tags
  97. tree = log --graph --format=format:'%C(red)%G?%C(reset) %C(yellow)%h%C(reset)%C(blue)%d%C(reset) %C(dim green)%ar%C(reset) %C(white)%s%C(reset) %C(dim cyan)(%an, %ai)%C(reset)' --all
  98. x = annex