Add support for dry run, add more error handling, fix rename script calling
This commit is contained in:
parent
6feef0a435
commit
a9c2b22d96
70
update.sh
70
update.sh
@ -5,6 +5,7 @@
|
||||
# then copy the files to the main mod directory.
|
||||
|
||||
SCRIPT_PATH=$(dirname "${BASH_SOURCE[0]}")
|
||||
RSYNC_CMD="rsync -r --exclude='.git' --stats"
|
||||
|
||||
show_help() {
|
||||
printf 'Usage: update.sh -s "path to mods" -d "destination"\n'
|
||||
@ -29,14 +30,41 @@ log() {
|
||||
printf '%s\n' "$line"
|
||||
fi >&2
|
||||
}
|
||||
|
||||
update_self() {
|
||||
log INFO 'Updating the script'
|
||||
dry_run $FUNCNAME && return
|
||||
cd ${SCRIPT_PATH}
|
||||
git pull \
|
||||
&& log INFO 'OK' \
|
||||
|| log WARN 'fail'
|
||||
}
|
||||
|
||||
update_mod() {
|
||||
dry_run $FUNCNAME && return 0
|
||||
# check if there is remote-tracking branch
|
||||
if git branch -v | grep 'remote-tracking'; then
|
||||
# placeholder for interactive
|
||||
# merging of forks
|
||||
:
|
||||
else
|
||||
if git pull; then
|
||||
# TODO add check if it actually updated
|
||||
log INFO 'OK'
|
||||
else
|
||||
log ERROR 'pull failed'
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
dry_run() {
|
||||
if [[ $DRY_RUN -eq 1 ]]; then
|
||||
log INFO "dry run (called from $1)"
|
||||
return 0
|
||||
fi
|
||||
return 1
|
||||
}
|
||||
|
||||
# Set variables accordingly to passed arguments or show help
|
||||
[[ ${#@} -eq 0 ]] && show_help && exit 0
|
||||
while :
|
||||
@ -47,22 +75,33 @@ do
|
||||
exit 0
|
||||
;;
|
||||
-s | --source)
|
||||
MODS_PATH="${2}"
|
||||
MODS_PATH="${2}/"
|
||||
[[ ! -d "${2}" ]] \
|
||||
&& log ERROR 'Source directory does not exist' \
|
||||
&& exit 1
|
||||
shift 2
|
||||
;;
|
||||
-d | --destination)
|
||||
DESTINATION_PATH="${2}"
|
||||
DESTINATION_PATH="${2}/"
|
||||
[[ ! -d "${2}" ]] \
|
||||
&& log ERROR 'Destination directory does not exist' \
|
||||
&& exit 1
|
||||
shift 2
|
||||
;;
|
||||
-u | --update)
|
||||
-u | --update) # update the script
|
||||
AUTO_UPDATE=1
|
||||
shift
|
||||
;;
|
||||
--dry-run) # test run without changes
|
||||
DRY_RUN=1
|
||||
shift
|
||||
;;
|
||||
*)
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
dry_run && RSYNC_CMD="${RSYNC_CMD} --dry-run"
|
||||
|
||||
# update the script
|
||||
if [[ ${AUTO_UPDATE} -eq 1 ]]; then
|
||||
@ -76,31 +115,18 @@ do
|
||||
[[ ! -d .git ]] && continue
|
||||
|
||||
log INFO "Updating mod $(basename "$dir"):"
|
||||
# check if there is remote-tracking branch
|
||||
if git branch -v | grep 'remote-tracking'; then
|
||||
# placeholder for interactive
|
||||
# merging of forks
|
||||
:
|
||||
else
|
||||
if git pull; then
|
||||
# TODO add check if it actually updated
|
||||
log INFO 'OK'
|
||||
git reflog | head -3
|
||||
else
|
||||
log ERROR 'pull failed'
|
||||
fi
|
||||
fi
|
||||
update_mod
|
||||
done
|
||||
|
||||
# Now that all files are updated copy them to the main directory.
|
||||
rsync -r --exclude='.git' \
|
||||
"${MODS_PATH}" \
|
||||
"${DESTINATION_PATH}"
|
||||
eval "${RSYNC_CMD} '${MODS_PATH}' '${DESTINATION_PATH}'"
|
||||
|
||||
#Move to the minetest/mods folder this should be default on all installs.
|
||||
cd "${DESTINATION_PATH}"
|
||||
|
||||
#Run an external script to find out which files to rename and do it.
|
||||
if [[ -f ${SCRIPT_PATH}/rename.sh ]]; then
|
||||
exec ${SCRIPT_PATH}/rename.sh
|
||||
if [[ -f ${DESTINATION_PATH}/rename.sh ]]; then
|
||||
dry_run 'rename' && exit 0
|
||||
exec ${DESTINATION_PATH}/rename.sh \
|
||||
|| log ERROR 'cannot execute rename script'
|
||||
fi
|
||||
|
Loading…
x
Reference in New Issue
Block a user