mirror of
https://git.minetest.land/dn42/registry
synced 2025-10-24 08:46:33 +02:00

- more consistent use of quotes - add additional feedback when signature is already detected - add --force option - only select latest signature if multiple signature headers found Fix squash-my-commit when signature not requested
185 lines
4.5 KiB
Bash
Executable file
185 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
|
|
do_sign=0
|
|
|
|
for arg
|
|
do
|
|
case "$arg" in
|
|
|
|
-S)
|
|
do_sign=1
|
|
;;
|
|
--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
|
|
if [ "$do_sign" -eq 1 ]
|
|
then
|
|
git commit -S -m "$comment"
|
|
else
|
|
git commit -m "$comment"
|
|
fi
|
|
|
|
# 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
|