NAME
Git::Hooks::CheckRewrite - Git::Hooks plugin for checking against unsafe rewrites
VERSION
version 2.0.0
DESCRIPTION
This Git::Hooks plugin hooks itself to the pre-rebase hook to guarantee that it is safe in the sense that no rewritten commit is reachable by other branch than the one being rebased.
It also hooks itself to the pre-commit and the post-commit hooks to detect unsafe git commit --amend commands after the fact. An amend is unsafe if the original commit is still reachable by any branch after being amended. Unfortunately git still does not provide a way to detect unsafe amends before committing them.
To enable it you should add it to the githooks.plugin configuration option:
git config --add githooks.plugin CheckRewrite
NAME
Git::Hooks::CheckRewrite - Git::Hooks plugin for checking against unsafe rewrites
CONFIGURATION
There's no configuration needed or provided.
EXPORTS
This module exports the following routines that can be used directly without using all of Git::Hooks infrastructure.
record_commit_parents GIT
This is the routine used to implement the pre-commit
hook. It needs a Git::Repository
object. It simply record the original commit id and its parents in a file called GITHOOKS_CHECKREWRITE
inside the git repository directory
check_commit_amend GIT
This is the routine used to implement the post-commit
hook. It needs a Git::Repository
object. It reads the original commit id and its parents from a file called GITHOOKS_CHECKREWRITE
inside the git repository directory, which must have been created by the record_commit_parents
routine during the pre-commit
hook. Using this information it detects if this was an unsafe amend and tells the user so.
check_rebase GIT, UPSTREAM [, BRANCH]
This is the routine used to implement the pre-rebase
hook. It needs a Git::Repository object, the name of the upstream branch onto which we're rebasing and the name of the branch being rebased. (If BRANCH is undefined it means that we're rebasing the current branch.
The routine dies with a suitable message if it detects that it will be an unsafe rebase.
REFERENCES
Here are some references about what it means for a rewrite to be unsafe and how to go about detecting them in git:
AUTHOR
Gustavo L. de M. Chaves <gnustavo@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2017 by CPqD <www.cpqd.com.br>.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.