registry/squash-my-commits

180 lines
4.5 KiB
Bash
Executable File

#!/bin/sh
##########################################################################
#
# This script will automatically bring the local git branch up to date
# with any changes in the main registry repository and will then squash
# the local changes together in to a single commit
#
# If the script fails to work, PRs for fixes are always welcome
# and you can always squash your commits manually
#
# use './squash-my-commits -S' to sign the result with your pgp key
#
##########################################################################
usage()
{
echo "Usage: $0 [options]"
echo 'Options:'
echo ' -S, sign the result with your pgp key'
echo ' --push, force push result'
echo ' --ssh, use ssh to fetch from the registry'
echo ' --https, use https to fetch from the registry'
echo ' --verify, check only'
echo 'Environment variables:'
echo ' DN42_REG_URL, set the registry URL to use'
}
##########################################################################
# parse arguments
do_push=0
verify_only=0
for arg
do
case "$arg" in
-S)
do_sign='-S'
;;
--push)
do_push=1
;;
--ssh)
echo 'Forcing use of SSH to fetch from registry'
reg_proto="ssh"
;;
--https)
echo 'Forcing use of HTTPS to fetch from registry'
reg_proto="https"
;;
--verify)
verify_only=1
;;
--help)
usage
exit 0
;;
*)
echo "Unknown option: $arg"
usage
exit 1
;;
esac
done
##########################################################################
# check for dn42registry remote, and add if missing
if ! git remote -v | grep dn42registry > /dev/null 2>&1
then
# was the URL specified directly ?
if [ -n "$DN42_REG_URL" ]
then
reg="$DN42_REG_URL"
else
if [ -z "$reg_proto" ]
then
# if the proto wasn't forced, try to guess it
if git remote -v | grep 'https' > /dev/null 2>&1
then
reg_proto='https'
else
reg_proto='ssh'
fi
fi
case "$reg_proto" in
ssh)
reg='git@git.dn42.dev:dn42/registry.git'
;;
https)
reg='https://git.dn42.dev/dn42/registry.git'
;;
*)
echo 'ERROR: Unknown registry protocol'
exit 1
;;
esac
fi
echo "Adding dn42registry remote: $reg"
git remote add dn42registry "$reg"
fi
##########################################################################
# ensure the local branch is up to date
echo "Fetching dn42registry master"
if ! git fetch dn42registry master
then
echo 'ERROR: Failed to fetch registry master branch'
echo 'Hint: you can use --ssh/--https to force use of ssh or https'
echo 'If all else fails, you can also set the DN42_REG_URL'
echo 'environment variable to directly specify the URL to fetch'
exit 1
fi
# find number of local commits
if ! count=$(git rev-list --count HEAD ^dn42registry/master)
then
echo "ERROR: Failed to find the number of local commits"
echo "Please report this as a bug to the registry maintainters"
exit 1
fi
# if there are less then 2 local commits, there's nothing to do
if [ "$count" -lt 2 ]
then
echo "$count local commits found, no squash is required"
exit 0
fi
if [ "$verify_only" -eq 1 ]
then
echo "$count local commits found"
exit 1
fi
# fail on errors from here onwards
set -e
# do the rebase thing
echo 'Rebasing local changes against the registry master'
git rebase dn42registry/master
echo "Squashing $count commits..."
# construct a new comment based on previous commits
comment="squashed commit:
$(git log --oneline HEAD ^dn42registry/master)"
# and finally squash
git reset --soft dn42registry/master
git commit "$do_sign" -m "$comment"
# show what happened
echo '---'
git log -n 1 --show-signature
echo '---'
##########################################################################
# push changes if requested
if [ "$do_push" -eq 1 ]
then
echo 'Force pushing changes'
git push --force
else
echo 'Remember to sign your commit: ./sign-my-commit FOO-MNT'
echo 'and then push your changes using: git push --force'
fi
##########################################################################
# end of file