Skip to content

iton0/hkup-cli

Repository files navigation

HkUp Logo Your CLI tool with benefits built by iton0 in Go!

GitHub release (latest SemVer) godoc Go Report Card

GitHub watchers GitHub stars

Git hooks automate processes in your workflow, enhancing code quality and consistency. Common use cases include:

  • Commit Message Validation
  • Environment Configuration
  • Formatting
  • Linting
  • Testing

Despite their benefits, many developers avoid Git hooks due to a lack of awareness and perceived setup complexity.

HkUp simplifies Git hook management, allowing you to focus on the logic and functionality of your hooks. Plus, with HkUp, your hooks are version-controlled.

Installation

External Dependencies:

  • git
  • curl
  • grep

Note

Windows users need to install Cygwin and add External Dependencies via the Cygwin setup program.

Install Script

Run the script below:

curl -sSL https://raw.githubusercontent.com/iton0/hkup-cli/main/scripts/install | sh

Tip

To update HkUp, simply rerun the script above. It will automatically replace your current version with the latest release.

Uninstalling HkUp

# Locates and deletes the HkUp binary
sh -c 'rm "$(command -v 'hkup')"'

Usage Quickstart

This section provides basic information about core usage. For detailed usage information run hkup --help.

Initializing hkup

HkUp provides two ways of initializing:

1. Creating a New Repository

After you create a Git repository, run the following command in your Git repository to initialize HkUp:

hkup init

This creates a .hkup directory and sets the local core.hooksPath variable. If the directory already exists, it will simply update the path variable. The path is relative, ensuring that moving your repository won’t affect hook sourcing.

2. Cloning a Repository

The above command also works after cloning a repository but HkUp also provides means to wrap Git-related cloning commands for an easier process. By prepending your Git cloning command with hkup -- you can clone your repository and initialize/reinitialize HkUp in a single command.

# Cloning the HkUp Github repository
# and initializing the .hkup folder
hkup -- git clone [email protected]:iton0/hkup-cli.git

Note

This works even for bare Git repositories!

Adding & Removing hooks

Add or remove hooks easily with:

hkup add <hook-name>
hkup remove <hook-name>

Templates

A template is a pre-configured, reusable Git hook that simplifies and automates the process of setting up hooks in a Git repository. With HkUp, you can create, copy, edit, or remove templates, allowing for consistent and easy application of hooks without needing to rewrite scripts each time.

The templates are stored in the HkUp config templates directory that can either be found at $XDG_CONFIG_HOME/hkup/templates or $HOME/.config/hkup/templates depending on your system.

Naming Convention

Template files follow the naming convention <template-name>#<hook-name> where:

  • <template-name> is the name of the template.
  • # is the separator between template and hook name.
  • <hook-name> is the specific Git hook (e.g., pre-commit, post-merge).

Create a template:

hkup template create
# OR
hkup template create <hook-name>

Copy a template into current working directory:

hkup template copy <template-name>

Edit a template:

hkup template edit <template-name>

Caution

Editing a template will not update its copies.

Remove a template:

hkup template remove <template-name>

Credits

DeAndre Sawyer for the logo.