Skip to content

Instantly share code, notes, and snippets.

@ckorn
Last active September 17, 2016 16:51
Show Gist options
  • Select an option

  • Save ckorn/5024196 to your computer and use it in GitHub Desktop.

Select an option

Save ckorn/5024196 to your computer and use it in GitHub Desktop.
#!/bin/sh
#
# An example hook script to prepare the commit log message.
# Called by "git commit" with the name of the file that has the
# commit message, followed by the description of the commit
# message's source. The hook's purpose is to edit the commit
# message file. If the hook fails with a non-zero status,
# the commit is aborted.
#
# To enable this hook, rename this file to "prepare-commit-msg".
# This hook includes three examples. The first comments out the
# "Conflicts:" part of a merge commit.
#
# The second includes the output of "git diff --name-status -r"
# into the message, just before the "git status" output. It is
# commented because it doesn't cope with --amend or with squashed
# commits.
#
# The third example adds a Signed-off-by line to the message, that can
# still be edited. This is rarely a good idea.
#case "$2,$3" in
# merge,)
# /usr/bin/perl -i.bak -ne 's/^/# /, s/^# #/#/ if /^Conflicts/ .. /#/; print' "$1" ;;
# ,|template,)
# /usr/bin/perl -i.bak -pe '
# print "\n" . `git diff --cached --name-status -r`
# if /^#/ && $first++ == 0' "$1" ;;
# *) ;;
#esac
# SOB=$(git var GIT_AUTHOR_IDENT | sed -n 's/^\(.*>\).*$/Signed-off-by: \1/p')
# grep -qs "^$SOB" "$1" || echo "$SOB" >> "$1"
case "$2" in
message)
exit 0;;
esac
tmpFile=`tempfile`
commitFile=`tempfile`
changelog=`git diff --cached --name-only | grep "^[^/]*/changelog$"`
python3 $HOME/workspace/getdeb\:\ debfactory/bin/getchangelog.py -m $changelog -o $tmpFile
cat $tmpFile > $commitFile
cat $1 >> $commitFile
rm $1
mv $commitFile $1
rm $tmpFile
exit 0
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment