Stax is a tool that will help you a bit with day-to-day stax-like git workflow. You can read more about it here https://www.stacking.dev/
Main purpose is to make it easier to create smaller PRs. And reduce amount of energy other people need to review them.
Homebrew is a package manager that works on MacOS and Linux systems.
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
See https://docs.brew.sh/Homebrew-on-Linux
brew install TarasMazepa/stax/stax
Clone this repo and put the path to the repo into your PATH variable.
Let me know if you need some help. Create a ticket on the repo.
Will help you to set up everything that stax needs to start working
stax doctor
[V] git config --get user.name # TarasMazepa
[V] git config --get user.email # 6552358+TarasMazepa@users.noreply.github.com
[V] git config --get push.autoSetupRemote # true
Stax will give you advice on how to configure everything.
stax doctor
[X] git config --get user.name # null
X Set your git user name using:
git config --global user.name "<your preferred name>"
[X] git config --get user.email # null
X Set your git user email using:
git config --global user.email "<your preferred email>"
[X] git config --get push.autoSetupRemote # false
X Set git push.autoSetupRemote using:
git config --global push.autoSetupRemote true
Feature | Status |
---|---|
commit | ✅ |
amend | ✅ |
delete-gone-branches | ✅ |
pull | ✅ |
log | ✅ |
rebase | 🚧 |
move | 🚧 |
squash | 🔲 |
Would be an UI tool that will implement all features from v1.
It is a way to reduce the burden of creating commits, branches, and PRs, so it doesn't consume much of your time. As a result, you can start creating more PRs with smaller changes in them and have them reviewed easier and faster at the same time catching more bugs.
To see full list of commands, run:
stax help
Here is the list of commands currently available:
Creates branch, commits current changes with the same name as a branch, and pushes.
stax commit "two-in-one-commit-name-and-branch-name"
Result:
commit 8161c952fbed66672aff80cd3d1233589cdc3c0c (HEAD -> two-in-one-commit-name-and-branch-name, origin/two-in-one-commit-name-and-branch-name)
Author: Taras Mazepa <taras.mazepa@example.com>
Date: Fri Sep 8 14:58:04 2023 -0700
two-in-one-commit-name-and-branch-name
You can see that a branch with two-in-one-commit-name-and-branch-name
name was created as well as
a commit with the same name two-in-one-commit-name-and-branch-name
.
Adds all the files to staging area
Redirects you to a create PR page
Amends to the current commit and force pushes branch
stax amend
Deletes local branches with gone remotes. Useful when you are using stax-commit
which pushes all
the branches. So once they are merged and deleted from the remote you can clean up local branches.
Switching to main branch, pull all the changes, deleting gone branches and switching to original branch.
Outputs tree structure of your branches.
> stax log
x Updates-stax-log-example-in-readme
o Adds-stax-log-example-to-readme
o-┘ origin/main, origin/HEAD, main
| o Promotes-version-command-to-be-not-hidden-command
o-┘
Note
Under construction
Rebase tree of nodes on top of the /head.
Note
Under construction
Allows user to move between log nodes. It supports "up", "down", "top", "bottom", and "head" directions.
Here you will see list of alternatives to stax.