Hacker Newsnew | past | comments | ask | show | jobs | submitlogin
My .gitconfig File Dissected (kiranrao.ca)
49 points by KiranRao0 on June 27, 2024 | hide | past | favorite | 15 comments


One git life hack I adopted is to sign my commits with an SSH key that is stored in 1Password. Anytime a tool like git or vs code (with git under the hood) wants to sign commits, fetch/pull/push a remote, or clone a repo I get a nice pop up from 1P which prompts for TouchID on my macbook. My SSH keys don't not live on my machine as a result. This also works with SSH agent forwarding if you develop inside a VM or remote machine.


For the benefit of others that read this and like the idea, here are instructions: https://developer.1password.com/docs/ssh/git-commit-signing/


Trusting your keys to someone else is already a terrible idea. Anything increasing the importance of those keys is doubling down. Please keep these ideas to yourself.


It would be amazing if 1Password extended that to GPG. I opened a support ticket with them earlier this year for it as well.


I recently just started doing this as well. I love it


Julia Evans blog post [1] on the same topic, contains some more useful options.

[1] https://jvns.ca/blog/2024/02/16/popular-git-config-options/


I'm generally addicted to the oh-my-zsh git plugin aliases[1]. Mostly gswm (git switch main), gswc (git switch --create), gpf (git push --force-with-lease), gcam (git commit all --message), gcan! (git commit all --amend --no-edit), grbm (git rebase main), grbc (git rebase --continue), grba (git rebase --abort)

gwip (git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]") is kinda useful when I want an actual commit before I change branches to do something else (I use this more often than stashing.

I also am a fan of git-brv from git extras (list branches verbose sorted by date - with the option to sort reverse so the last modified branch is the last one on your terminal)

And also git-trim - clean up merged branches

[1]: https://github.com/ohmyzsh/ohmyzsh/tree/master/plugins/git


I’d like to add

  please = push —-force-with-lease
for rebase-heavy workflows


Cool stuff, thanks for sharing. I strongly recommend you add `rerere.enabled true` (makes `git pull --rebase` life easier)


Cool, I haven’t seen that one before!


Really cool, here's mine [0] that's slightly longer. I also have a bunch of other stuff that you may like.

I also have a few handy aliases for commands I never remember [1]. Don't need to have shortcuts like `git co` and others, because I use CMD + R with fzf to find what I need.

[0]: https://github.com/artuross/dotfiles/blob/main/home/dot_conf...

[1]: https://github.com/artuross/dotfiles/blob/main/home/dot_conf...


Should have a setting for autocrlf and safecrlf to avoid shooting yourself in the foot while copying the config between platforms.


There's a bug in here: some git git commands will fail if you are in a subdirectory; i.e. git git add foo, because the behavior of ! Is to run those from the git root. My solution is:

  git = !cd -- ${GIT_PREFIX:-.} && git


If you want an interactive commit graph, among other features, look at tig https://jonas.github.io/tig/


Nice to see other people carrying on with ci and co aliases as well. I don’t really remember, co goes back to cvs no? ci as well I think?




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: