A TUI that saves time from writing Co-authored-by lines to the commits in a fancy way. It works as a Git hook.
When doing pair programming, it's a good practice that add your pair's contact information to the commit message. You do that by the following format
Co-authored-by: Your Pair <[email protected]>
So your pair appear as a contributor of the commit. But sometimes writing this line over and over feels like a hard thing to do. At this point, this tool helps you to search, select and add the contributor to the commit message easily.
Watch the record below. Thanks to terminalizer.
Thanks to charmbracelet community for providing such a nice and easy TUI framework.
- Filter
- Selectable
- Reset selections
- Git hook template
It works with the prepare-commit-msg
Git hook. You can configure it per project or globally.
Caution: Before running the commands below, consider checking your hook configurations for saving them instead of overwriting.
Go to the releases or just install the latest version.
go install github.com/erkanzileli/co-author@latest # Install to your GOBIN directory
Check it is accessible from your terminal
co-author version
If it's not, then check your PATH variable because it should include the binaries installed with Go.
It might be on some places like the following
~/go/bin
ls $(go env GOPATH)/bin
You can enable it for a specific project. Open a terminal in your project directory and run the commands below.
co-author hook >.git/hooks/prepare-commit-msg # Create the hook
chmod +x .git/hooks/prepare-commit-msg # Make it executable
You can also enable it globally. In this way, you don't have to enable it every project you have. Run the commands below.
cd ~ # Go to your home directory
mkdir -pv .git/hooks # Create a global Git hooks directory if it doesn't exist
git config --global --add core.hooksPath ~/.git/hooks # Set the global Git hooks directory
co-author hook > .git/hooks/prepare-commit-msg # Create the hook
chmod +x .git/hooks/prepare-commit-msg # Make it executable
If you already have a prepare-commit-msg
hook defined, then take necessary output from the command below. The rest is
up to you.
co-author hook # This will print the hook template
You can customize it for your needs.
You usually see the previous committers. If you want to always see a couple of person, provide a configuration file. It will only load the committers from the file.
Create a file named .git-co-authors.yaml
. You can use the snippet below as a template.
committers:
- name: user
email: [email protected]
pre-commit helps you integrate various Git hooks to your project with a simple file. You use co-author with pre-commit.
Add the snippet below to your .pre-commit-config.yaml
default_install_hook_types:
- prepare-commit-msg # it must exist
repos:
- repo: https://github.com/erkanzileli/co-author.git
rev: v0.0.2 # use the latest version
hooks:
- id: co-author
stages:
- prepare-commit-msg
After you configured the .pre-commit-config.yaml
file, run command below to install the hooks.
pre-commit install
Now you can start using co-author with pre-commit.
Feel free to add anything useful or fix something.
MIT