aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBenjamin C Meyer <ben@meyerhome.net>2014-04-29 22:02:24 -0400
committerBenjamin C Meyer <ben@meyerhome.net>2014-04-29 22:02:24 -0400
commit3b89627d5f6a7f32fcda44da81fa203f1fb06ec2 (patch)
treea65ff0fbc40f4db0799064c5f452971eb4b5c1a6
parentfeae1e052ede35ca02a4643e91d60eb33e876bb2 (diff)
parent5880158d39bf29afd22b6b65244d9d33ce683624 (diff)
downloadgit-hooks-master.tar.gz
git-hooks-master.tar.bz2
Merge pull request #36 from Zearin/reorder-funcHEADmaster
Did you happen to enable git-hooks in the git-hooks repo? It should have prevented you from making commits that were not signed off on.
-rwxr-xr-xgit-hooks78
1 files changed, 41 insertions, 37 deletions
diff --git a/git-hooks b/git-hooks
index 8ec9f13..096ae31 100755
--- a/git-hooks
+++ b/git-hooks
@@ -57,6 +57,30 @@ function list_hooks_in_dir
fi
}
+function list_hooks
+{
+ GITDIR=`git rev-parse --git-dir`
+ cat "${GITDIR}/hooks/pre-commit" 2> /dev/null | grep 'git-hooks' > /dev/null 2> /dev/null
+ if [ $? = 0 ] ; then
+ echo "Git hooks ARE installed in this repository."
+ echo ""
+ else
+ echo "Git hooks are NOT installed in this repository. (Run 'git hooks --install' to install it)"
+ echo ""
+ fi
+
+ echo 'Listing User, Project, and Global hooks:'
+ echo '---'
+ for dir in `hook_dirs`; do
+ echo "${dir}:"
+ for hook in `list_hooks_in_dir "${dir}" 2` ; do
+ echo -n `basename \`dirname "${hook}"\``
+ echo -e "/`basename "${hook}"` \t- `${hook} --about`"
+ done
+ echo ""
+ done
+}
+
function run_hooks
{
dir="${1}"
@@ -138,36 +162,8 @@ git-hooks run "$0" "$@"';
fi
}
-function list_hooks
+function install_global
{
- GITDIR=`git rev-parse --git-dir`
- cat "${GITDIR}/hooks/pre-commit" 2> /dev/null | grep 'git-hooks' > /dev/null 2> /dev/null
- if [ $? = 0 ] ; then
- echo "Git hooks ARE installed in this repository."
- echo ""
- else
- echo "Git hooks are NOT installed in this repository. (Run 'git hooks --install' to install it)"
- echo ""
- fi
-
- echo 'Listing User, Project, and Global hooks:'
- echo '---'
- for dir in `hook_dirs`; do
- echo "${dir}:"
- for hook in `list_hooks_in_dir "${dir}" 2` ; do
- echo -n `basename \`dirname "${hook}"\``
- echo -e "/`basename "${hook}"` \t- `${hook} --about`"
- done
- echo ""
- done
-}
-
-function report_error {
- echo "Hook failed: $last_run_hook"
- exit 1
-}
-
-function installglobal {
TEMPLATE="$HOME/.git-template-with-git-hooks"
if [ ! -d "${TEMPLATE}" ] ; then
DEFAULT=/usr/share/git-core/templates
@@ -185,10 +181,18 @@ echo \"git hooks not installed in this repository. Run 'git hooks --install' to
echo "Git global config init.templatedir is now set to ${TEMPLATE}"
}
-function uninstallglobal {
+function uninstall_global
+{
git config --global --unset init.templatedir
}
+function report_error
+{
+ echo "Hook failed: $last_run_hook"
+ exit 1
+
+}
+
case $1 in
run )
if [ ! -z "${GIT_DIR}" ] ; then
@@ -201,11 +205,11 @@ case $1 in
--install|--uninstall )
install_hooks "$1"
;;
- --installglobal )
- installglobal
+ --install-global|--installglobal )
+ install_global
;;
- --uninstallglobal )
- uninstallglobal
+ --uninstall-global|--uninstallglobal )
+ uninstall_global
;;
-h|--help|-? )
echo 'Git Hooks'
@@ -217,13 +221,13 @@ case $1 in
echo ' git hooks run [hook]. Move old hooks directory to hooks.old'
echo ' --uninstall Remove existing hooks in this repository and rename hooks.old'
echo ' back to hooks'
- echo ' --installglobal'
+ echo ' --install-global'
echo ' Create a template .git directory that that will be used whenever'
echo ' a git repository is created or cloned that will remind the user'
echo ' to install git-hooks.'
- echo ' --uninstallglobal'
+ echo ' --uninstall-global'
echo ' Turn off the global .git directory template that has the reminder.'
- echo " run [cmd] Run the hooks for cmd (such as pre-commit)"
+ echo " run <cmd> Run the hooks for <cmd> (such as pre-commit)"
echo " (no arguments) Show currently installed hooks"
;;
* )