Git Blame (gb) is a powerful CLI tool that helps you analyze the top contributors to any file in a Git repository. This tool automates the git blame command and provides enhanced features such as contributor rankings, commit timestamps, and support for both Linux and macOS.
- Top Contributors: Analyze the top contributors to any file in a Git repository.
- Commit Timestamp: Display the most recent commit date for each contributor.
- Cross-Platform: Supports both Linux and macOS for timestamp conversion.
- Flexible Input: Allows input either through command-line arguments or interactive prompts.
- Configurable Output: Customize the number of top contributors to display.
- Ensure you have Git installed on your system.
- The tool is designed to work with Unix-based systems (Linux, macOS) and requires bashorzsh.
git clone https://github.com/brendancopley/git-blame-cli.git
cd git-blame-clichmod +x gb
To make the gb command available globally, move it to a directory in your system's PATH. You can also add a custom directory to your PATH and move the script there.
sudo mv gb /usr/local/bin/
If you want to use a custom bin directory (like ~/bin), add it to your PATH:
# Create bin directory if not already created mkdir -p ~/bin # Move the script mv gb ~/bin/ # Add to PATH in .zshrc or .bashrc echo 'export PATH=$PATH:~/bin' >> ~/.zshrc # Reload .zshrc source ~/.zshrc
To analyze a file and display the top 3 contributors with their most recent commit dates:
gb path/to/file
To display a custom number of top contributors (e.g., top 5):
gb path/to/file 5
$ gb src/main.cpp Processing file: src/main.cpp 40 contributions by john.doe@example.com (Last commit: 2023年09月01日 12:34:56) 35 contributions by jane.smith@example.com (Last commit: 2023年08月28日 09:12:34) 25 contributions by alice.johnson@example.com (Last commit: 2023年07月15日 17:45:23) Operation completed successfully.
The tool automatically detects if it's running on macOS or Linux and adjusts the timestamp conversion process accordingly:
- Linux: Uses date -d @<timestamp>to convert UNIX timestamps to a human-readable date.
- macOS: Uses date -r <timestamp>for the same conversion.
If no file path is provided, gb will prompt you to enter one interactively:
gb
On the first run, the tool automatically configures the .git-blame-ignore-revs file to make use of the Git blame ignore functionality. This file will store commit hashes to ignore during the blame analysis.
$ gb path/to/file
Setting up git blame ignoreRevsFile...
Git blame ignoreRevsFile is now set to .git-blame-ignore-revs
Processing file: path/to/file
Operation completed successfully.- Fork the repository.
- Create a feature branch: git checkout -b feature/my-feature.
- Commit your changes: git commit -m 'Add my feature'.
- Push to the branch: git push origin feature/my-feature.
- Create a new Pull Request.
This project is licensed under the MIT License. See the LICENSE file for details.