git-absorb
git-cli-tools
git-absorb | git-cli-tools | |
---|---|---|
22 | 6 | |
3,191 | 112 | |
- | - | |
7.5 | 4.3 | |
25 days ago | about 1 month ago | |
Rust | ||
BSD 3-clause "New" or "Revised" License | - |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
git-absorb
- Git Absorb
- Git-absorb: Git commit –fixup but automatic
-
OpenTF Repository is now Public
Nice, no need to look up past commits ! Didn't know about this, I had to look it up.
It's a separate project from git [0].
[0]: https://github.com/tummychow/git-absorb
-
Lazygit: Simple terminal UI for Git commands
Boy have I got the thing for you. git absorb - https://github.com/tummychow/git-absorb
The way to work with it is:
git add file1
- tummychow/git-absorb: git commit --fixup, but automatic
-
What do you use for git integration in neovim?
You can also manage via a holistic UI: - Bisection - Log and reflog, stashes - subtrees, submodules - certain third party subcommands like git-absorb, and extend it with your own - interact with issues and pull requests via forge - pretty much all of the hundreds of CLI flags via a modal UI that got generalized and extracted to a lib called transient - well-integrated diff and conflict resolution (which is mostly just smerge) - the rebase/cherry-pick workflows I liked the best, including support for --update-refs - at any time you can always press a key to see the raw commands and output that it's using, which taught me a ton of corner cases - IMO it has a great manual
-
Move File Changes From One Commit To Another
I sometimes use git-absorb to help me if I made a tonne of changes, and can't be arsed to manually make the fixups
-
Theodore Ts'o on how he uses Git when working on Linux (2017)
If done well, your git history carries the information of your process in a very similar way.
You have to be somewhere in the middle, so I'd say to do a semantic rebase at last step before merge. A fantastic tool that is not so well-known is git-absorb, which helps a lot doing that cleanly and automatically.
https://github.com/tummychow/git-absorb
-
Intern fixes 600 bugs but makes only 1 PR because it's more efficient.
Squash merge is like a sledge hammer, interactive rebase + git reset -N HEAD^ + git-absorb + git add -p (or even better, Magit) are surgical tools.
- git-absorb - git commit --fixup, but automatic
git-cli-tools
-
Lazygit: Simple terminal UI for Git commands
I use IntelliJ IDEA and often rely on their own Git functionality. But it cannot stage specific lines, only whole chunks [1]. For that, I've been using lazygit for a couple of months now. I like its simple UI and that it makes staging specific lines very easy and quick. If you like lazygit, you might also be interested in similar Git CLI clients that I collected here [2].
[1] https://youtrack.jetbrains.com/issue/IDEA-186988/Allow-commi...
[2] https://github.com/frontaid/git-cli-tools#clients
-
(re)Introducing `git trim`- a command to quickly remove merged, pruned, untracked, or stale branches.
Very useful tool! I just added it to https://github.com/frontaid/git-cli-tools
- Magit, the Magical Git Interface
-
Git Command Explorer
bit (https://github.com/chriswalz/bit) is a somewhat similar CLI tool for this. It shows command completion alongside a description.
PS: We maintain a list of helpful Git CLI tools on https://github.com/frontaid/git-cli-tools
-
Wrappers on top of git?
There is also https://github.com/frontaid/git-cli-tools which is categorized and has more tools.
- Git CLI Tools
What are some alternatives?
git-autofixup - create fixup commits for topic branches
git-branchless - High-velocity, monorepo-scale workflow for Git
magit - It's Magit! A Git Porcelain inside Emacs.
legit - Git for Humans, Inspired by GitHub for Mac™.
stgit - Stacked Git
bit - Bit is a modern Git CLI
git-instafix - Amend old git commits with a simple UI.
vimagit - Ease your git workflow within Vim
vim-fugitive - fugitive.vim: A Git wrapper so awesome, it should be illegal
neogit - An interactive and powerful Git interface for Neovim, inspired by Magit
transient - Transient commands
tig - Text-mode interface for git