git-stack
graphite-cli
git-stack | graphite-cli | |
---|---|---|
12 | 9 | |
11 | 217 | |
- | - | |
0.0 | 7.2 | |
3 days ago | over 1 year ago | |
Rust | TypeScript | |
Apache License 2.0 | GNU Affero General Public License v3.0 |
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-stack
-
[Gitoxide December Update]: a new object database and upcoming multi-pack index support
git-stack is the most complicated, rewriting history, detecting when a branch was squashed, etc
-
Lazygit: A simple terminal UI for Git commands
I used to use aliases but got frustrated with them when dealing with PRs depending on PRs, so I wrote git-stack [0]. Thought I'd share in case you'd find it useful
[0] https://github.com/epage/git-stack/blob/main/docs/reference....
-
Stacked changes: how FB and Google engineers stay unblocked and ship faster
For anyone interested, I've been collecting notes on various tools in this space: https://github.com/epage/git-stack/blob/main/docs/comparison... (granted the page doesn't mention git-stack since that is assumed)
-
Good strategy to follow for small incremental pull request
Personally, I rebase my PR branches on top of each other, rather than merge. It creates a cleaner history (if your merge policy allows maintaining branch history). Tired of managing these branches, I wrote a tool to help though there are other tools in this space, like git-branchless and graphite.
-
Lightning-fast rebases with Git-move
git-move and git-branchless do some great stuff, I wish this wasn't focused on the performance side to distract from the real value.
What I find useful is not the performance but this line
> For example, it can move entire subtrees, not just branches
The referenced docs mention other great quality of life improvements that streamline standard workflows (e.g. deleting local PR branches when merged into upstream)
When performance does matter is when the rebase operation is a small part of a larger operation. In my related tool, git-stack [0], I rebase all branches on top of their latest upstream branches along with re-arranging and squashing fixup commits and soon other features. When automating entire workflows, having each part be fast is important for the whole to still have decent performance.
[0] https://github.com/epage/git-stack
-
Continuous Integration with Github Actions and Rust
audit for security audits - Separate from regular CI since it only matters for specific changes or when new critical issues come out.
-
My favorite git aliases
You might be interested in git-stack that I've previously announced
-
git-stack: Request for feedback / testers
Could you comment on https://github.com/epage/git-stack/issues/25 for why it helps to iterate to find the last non-conflicting commit to rebase onto?
git-stack is the result of me being tired of annoyances in the PR workflow and trying to improve it, like
-
git-stack: Stacked branch management for Git
Fixing branches off of branches when applying a fixup commit (not implemented yet)
graphite-cli
-
Why some of us like "interdiff" code review systems (not GitHub)
We (Graphite) love Jujutsu – comes up in conversation all the time here. A prior version of the CLI is open source, the core data model (using git refs to store some extra data about what a branch's parent is) is still the same. https://github.com/withgraphite/graphite-cli
We've talked about supporting other clients, but don't currently have the bandwidth to build something like that – definitely something I am personally passionate about making sure happens at some point.
- Graphite CLI development is no more open source
-
Stacked changes: how FB and Google engineers stay unblocked and ship faster
This is exactly the problem that graphite-cli solves (https://github.com/screenplaydev/graphite-cli)
It keeps track of branchs and their parents by storing a tiny bit of metadata in the native git refs. It uses that information to perform recursive rebases: https://github.com/screenplaydev/graphite-cli/blob/main/src/...
It ends up working seamlessly - you just modify some branch, and then run `gt stack fix` to recursively rebase everything. (and then `gt stack submit` to sync everything to github :)
docs here: https://docs.graphite.dev/guides/graphite-cli
-
How to use native git as a key-value store
You can read Graphite's full implementation of metadata handing here.
-
Show HN: Stacked diffs / interdependent changes (on GitHub)
We (Screenplay, https://screenplay.dev) built an internal tool (Graphite) to enable stacked diffs on GitHub for an individual (i.e. you can adopt it without your team also having to adopt it). It's inspired by some of the internal tooling we had at bigger companies. Specifically, the tool has two parts:
* The CLI - https://github.com/screenplaydev/graphite-cli: Allows you to create diffs, restack them, submit them to GitHub, etc. It runs locally and stores all the metadata in your .git folder.
What are some alternatives?
ghstack - Submit stacked diffs to GitHub on the command line
git-stack - Stacked branch management for Git
lazygit.nvim - Plugin for calling lazygit from within neovim.
git-branchless - High-velocity, monorepo-scale workflow for Git
feedback - Public feedback discussions for: GitHub for Mobile, GitHub Discussions, GitHub Codespaces, GitHub Sponsors, GitHub Issues and more! [Moved to: https://github.com/github-community/community]
GitUp - The Git interface you've been missing all your life has finally arrived.
cockroach - CockroachDB — the cloud native, distributed SQL database designed for high availability, effortless scale, and control over data placement.
autorebase - Automatically rebase all your branches onto master
Ansible - Ansible is a radically simple IT automation platform that makes your applications and systems easier to deploy and maintain. Automate everything from code deployment to network configuration to cloud management, in a language that approaches plain English, using SSH, with no agents to install on remote systems. https://docs.ansible.com.