Skip to content

erkanzileli/co-author

Repository files navigation

co-author

A TUI that saves time from writing Co-authored-by lines to the commits in a fancy way. It works as a Git hook.

Motivation

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.

Demo

Watch the record below. Thanks to terminalizer.

demo

Features

Thanks to charmbracelet community for providing such a nice and easy TUI framework.

  • Filter
  • Selectable
  • Reset selections
  • Git hook template

Usage

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.

Installation

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

Per project

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

Global

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

Migrate with the existing hook

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

Customizations

You can customize it for your needs.

Load Config

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

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.

Contributing

Feel free to add anything useful or fix something.

License

MIT