![]() |
|
![]() |
| I use `qp`for `quick-push` with a function to provide a comment:
|
![]() |
| I really wanted to add this (I linked it in the last paragraph) but I really wanted to keep the recommendations globally applicable in vanilla git. Delta is awesome though. |
![]() |
| Yeah, I didn't do aliases on purpose, because I wanted everything to be fairly global, where I feel like aliases are more personal. But yes, aliases are great. |
![]() |
| as for me, I want something more. Like git shell. Where I no need to write git, git, git again and again. Strange that there is no something like this yet. |
![]() |
| yes, but I prefer writing status, stash, checkout, commit hand by) So, the more I think about my previous comment the less sense I see in such feature :) |
![]() |
| I agree with the recommendation to use (z)diff3. I think the article massively understates the case! Three way diff makes it possible to resolve some conflicts that are literally impossible to resolve without it. Why impossible? Because with default style adding conflicting things at the same place is indistinguishable from removing the same things at the same place. You need to be able to see the base to determine that.
I wrote up more here: https://stackoverflow.com/a/63739655/997606 I also wrote up how to use diff3 style to make resolving rebase (or merge) conflicts a mechanical procedure: https://h2.jaguarpaw.co.uk/posts/git-rebase-conflicts/ |
![]() |
| I wonder why commit signing is not part of these configs... it is pretty easy to do with a modern ssh key:
On github you can add the ssh key for authentication but also for signing. Unfortunately you have to add the key twice but once you've done it, you get rid of the `unverified` label within a commit. |
![]() |
| How much of this is for a noob like me that just uses vscode? I hardly ever see the git command line, and when I do see it, its trouble beyond what anybody can fix... |
![]() |
| I wouldn't like to be this kind of person, but, in the case of git, the best you can do you is forcing yourself little by little to use the Git CLI. It's far from being beginner friendly, but it shows the things the way the really are. GUI git tools hide things under their hood, which is ok for most cases but when you need a little more complex thing you are limited to their capabilities.
For instance, I wrote this post last year about how you can use Git as a powerful debugging tool: https://news.ycombinator.com/item?id=39877637 |
![]() |
| Nothing wrong with a gui. Esp with git imo. The process doesn’t require blazing fast agility, but careful review and selection.
Graphical diff viewers are way better anyway. |
![]() |
| I have something almost identical, except for the `—-graph` part. That way I have the flexibility to get either the linear view or the graph view by adding that single flag. |
![]() |
| I use `defaultBranch = master`, because the prude trend of forbidding words based on obvious miscontextualization is more harmful than helpful. |
![]() |
| Happy to notice I already use most of these. The only ones I didn't know are diff.mnemonicPrefix, diff.renames and commit.verbose.
My config if you'd like to steal it, also here: https://github.com/silvanocerza/dotfiles/blob/master/git/git... Mind that you need diff-so-fancy for this work correctly. https://github.com/so-fancy/diff-so-fancy
|
![]() |
| this is amazing. I've been swearing at diffs which I now know are myers algorithm and histogram diffs are exactly what I've been wanting!! |
![]() |
| i know that my comment is not related to the post, but i just want say that the image is really cool! who is the designer/artist? |
![]() |
| I just add .envrc and shell.nix to my global gitignore. Along with docker-compose.override.yml. You can always force-add an ignored file, it'll be tracked from then on. |
![]() |
| While your comment is in jest, I agree with the sentiment. The whole "main" debacle sucks and, to this day, still breaks everyone's git usage. |
![]() |
| Honest question: What has it broken about your git usage? I haven’t really noticed a problem.
Sometimes a repo uses “main” and sometimes “master”. It’s not like “master” was the only option before |
Now I want to do: `git to-da-choppa`