94 lines
2.1 KiB
Plaintext
94 lines
2.1 KiB
Plaintext
|
#!/bin/bash
|
||
|
|
||
|
SCRIPT_DIR=$(dirname $(realpath ${BASH_SOURCE[0]}))
|
||
|
GIT_DIR=$(git rev-parse --git-dir)
|
||
|
GIT_ROOT=$(git rev-parse --show-toplevel)
|
||
|
|
||
|
MSG_FILE="$GIT_DIR/SUBSYSTEMS_SPLIT_MSG"
|
||
|
|
||
|
usage() {
|
||
|
cat >&$1 <<EOF
|
||
|
git subsystems-split [OPTIONS]
|
||
|
|
||
|
Ardupilot's git extension.
|
||
|
|
||
|
Split HEAD commit into commits separated by subsystems (vehicles, libraries and
|
||
|
folders in the project's root). Basically, reset and call commit-subsystems.
|
||
|
|
||
|
If neither --copy or --edit is passed, then subsystems-split will try to make
|
||
|
the original commit's message into a template for commit-subsystems.
|
||
|
|
||
|
Options:
|
||
|
--copy
|
||
|
Make all commits have exactly the same message as the HEAD commit.
|
||
|
|
||
|
--edit
|
||
|
Edit the commit message as a template for commit-subsystems.
|
||
|
EOF
|
||
|
}
|
||
|
|
||
|
option_copy=false
|
||
|
option_edit=false
|
||
|
|
||
|
while [[ -n "$1" ]]; do
|
||
|
opt="$1"
|
||
|
case "$opt" in
|
||
|
-h|--help)
|
||
|
usage 1
|
||
|
exit 0
|
||
|
;;
|
||
|
--copy)
|
||
|
option_copy=true
|
||
|
;;
|
||
|
--edit)
|
||
|
option_edit=true
|
||
|
;;
|
||
|
*)
|
||
|
usage 2
|
||
|
exit 1
|
||
|
;;
|
||
|
esac
|
||
|
shift
|
||
|
done
|
||
|
|
||
|
if $option_copy && $option_edit; then
|
||
|
echo "Options --copy and --edit can't be combined." >&2
|
||
|
exit 1
|
||
|
fi
|
||
|
|
||
|
author=$(git log -n 1 --format=%ae)
|
||
|
git log -n 1 --format=%B > "$MSG_FILE"
|
||
|
|
||
|
if $option_edit; then
|
||
|
if [[ -z $EDITOR ]]; then
|
||
|
echo "Environment variable EDITOR is required for option --edit." >&2
|
||
|
exit 1
|
||
|
fi
|
||
|
($EDITOR "$MSG_FILE")
|
||
|
elif ! $option_copy; then
|
||
|
if head -n 1 "$MSG_FILE" | grep "^[^: ]\+\s*:" -q; then
|
||
|
sed '1 s,^[^: ]\+\s*,$subsystem,' -i "$MSG_FILE"
|
||
|
else
|
||
|
buff_file="$(mktemp)"
|
||
|
awk '
|
||
|
NR == 1 {
|
||
|
l=sub(/^\s\+/, "", $line);
|
||
|
print "$subsystem: " \
|
||
|
tolower(substr($l, 1, 1)) \
|
||
|
substr($l, 2);
|
||
|
}
|
||
|
NR != 1
|
||
|
' "$MSG_FILE" > "$buff_file"
|
||
|
mv "$buff_file" "$MSG_FILE"
|
||
|
rm "$buff_file"
|
||
|
fi
|
||
|
fi
|
||
|
|
||
|
HEAD=$(git rev-parse HEAD)
|
||
|
git reset HEAD~1 --soft
|
||
|
if ! "$SCRIPT_DIR/git-commit-subsystems" -F "$MSG_FILE" --author=$author; then
|
||
|
echo "Error on calling git-commit-subsystems." >&2
|
||
|
git reset $HEAD
|
||
|
exit 1
|
||
|
fi
|