git:ssync: Add --new flag

I sometimes do not want to change the working tree of submodules I
changed locally.
This commit is contained in:
2025-01-28 17:25:29 +01:00
parent b1a21fbdb0
commit 0c0231a2ef

View File

@@ -3,4 +3,24 @@
emulate -L zsh -o err_return
git submodule sync --recursive
git submodule update --init --recursive
if [[ "$1" == "--new" ]]; then
# Only checkout new submodules
local toplevel
toplevel="$(git rev-parse --show-toplevel)"
cd "$toplevel"
grep path .gitmodules \
| cut -d= -f2 \
| sed 's/^\s*//' \
| while read -r line; do
# keep only empty ones
find "$line" -maxdepth 0 -empty
done \
| while read -r line; do
git submodule update --init --recursive -- "$line"
done
else
git submodule update --init --recursive
fi