|
|
@ -25,8 +25,35 @@ say() |
|
|
|
fi |
|
|
|
fi |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# |
|
|
|
# |
|
|
|
# Run clone + checkout on missing submodules |
|
|
|
# Clone a submodule |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
module_clone() |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
path=$1 |
|
|
|
|
|
|
|
url=$2 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# If there already is a directory at the submodule path, |
|
|
|
|
|
|
|
# expect it to be empty (since that is the default checkout |
|
|
|
|
|
|
|
# action) and try to remove it. |
|
|
|
|
|
|
|
# Note: if $path is a symlink to a directory the test will |
|
|
|
|
|
|
|
# succeed but the rmdir will fail. We might want to fix this. |
|
|
|
|
|
|
|
if test -d "$path" |
|
|
|
|
|
|
|
then |
|
|
|
|
|
|
|
rmdir "$path" 2>/dev/null || |
|
|
|
|
|
|
|
die "Directory '$path' exist, but is neither empty nor a git repository" |
|
|
|
|
|
|
|
fi |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test -e "$path" && |
|
|
|
|
|
|
|
die "A file already exist at path '$path'" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
git-clone -n "$url" "$path" || |
|
|
|
|
|
|
|
die "Clone of submodule '$path' failed" |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# Register submodules in .git/config |
|
|
|
# |
|
|
|
# |
|
|
|
# $@ = requested paths (default to all) |
|
|
|
# $@ = requested paths (default to all) |
|
|
|
# |
|
|
|
# |
|
|
@ -35,52 +62,23 @@ modules_init() |
|
|
|
git ls-files --stage -- "$@" | grep -e '^160000 ' | |
|
|
|
git ls-files --stage -- "$@" | grep -e '^160000 ' | |
|
|
|
while read mode sha1 stage path |
|
|
|
while read mode sha1 stage path |
|
|
|
do |
|
|
|
do |
|
|
|
# Skip submodule paths that already contain a .git directory. |
|
|
|
# Skip already registered paths |
|
|
|
# This will also trigger if $path is a symlink to a git |
|
|
|
url=$(git-config submodule."$path".url) |
|
|
|
# repository |
|
|
|
test -z "$url" || continue |
|
|
|
test -d "$path"/.git && continue |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# If there already is a directory at the submodule path, |
|
|
|
|
|
|
|
# expect it to be empty (since that is the default checkout |
|
|
|
|
|
|
|
# action) and try to remove it. |
|
|
|
|
|
|
|
# Note: if $path is a symlink to a directory the test will |
|
|
|
|
|
|
|
# succeed but the rmdir will fail. We might want to fix this. |
|
|
|
|
|
|
|
if test -d "$path" |
|
|
|
|
|
|
|
then |
|
|
|
|
|
|
|
rmdir "$path" 2>/dev/null || |
|
|
|
|
|
|
|
die "Directory '$path' exist, but is neither empty nor a git repository" |
|
|
|
|
|
|
|
fi |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
test -e "$path" && |
|
|
|
|
|
|
|
die "A file already exist at path '$path'" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
url=$(GIT_CONFIG=.gitmodules git-config module."$path".url) |
|
|
|
url=$(GIT_CONFIG=.gitmodules git-config module."$path".url) |
|
|
|
test -z "$url" && |
|
|
|
test -z "$url" && |
|
|
|
die "No url found for submodule '$path' in .gitmodules" |
|
|
|
die "No url found for submodule '$path' in .gitmodules" |
|
|
|
|
|
|
|
|
|
|
|
# MAYBE FIXME: this would be the place to check GIT_CONFIG |
|
|
|
git-config submodule."$path".url "$url" || |
|
|
|
# for a preferred url for this submodule, possibly like this: |
|
|
|
die "Failed to register url for submodule '$path'" |
|
|
|
# |
|
|
|
|
|
|
|
# modname=$(GIT_CONFIG=.gitmodules git-config module."$path".name) |
|
|
|
|
|
|
|
# alturl=$(git-config module."$modname".url) |
|
|
|
|
|
|
|
# |
|
|
|
|
|
|
|
# This would let the versioned .gitmodules file use the submodule |
|
|
|
|
|
|
|
# path as key, while the unversioned GIT_CONFIG would use the |
|
|
|
|
|
|
|
# logical modulename (if present) as key. But this would need |
|
|
|
|
|
|
|
# another fallback mechanism if the module wasn't named. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
git-clone -n "$url" "$path" || |
|
|
|
|
|
|
|
die "Clone of submodule '$path' failed" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
(unset GIT_DIR && cd "$path" && git-checkout -q "$sha1") || |
|
|
|
say "Submodule '$path' registered with url '$url'" |
|
|
|
die "Checkout of submodule '$path' failed" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
say "Submodule '$path' initialized" |
|
|
|
|
|
|
|
done |
|
|
|
done |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
# |
|
|
|
# |
|
|
|
# Checkout correct revision of each initialized submodule |
|
|
|
# Update each submodule path to correct revision, using clone and checkout as needed |
|
|
|
# |
|
|
|
# |
|
|
|
# $@ = requested paths (default to all) |
|
|
|
# $@ = requested paths (default to all) |
|
|
|
# |
|
|
|
# |
|
|
@ -89,14 +87,21 @@ modules_update() |
|
|
|
git ls-files --stage -- "$@" | grep -e '^160000 ' | |
|
|
|
git ls-files --stage -- "$@" | grep -e '^160000 ' | |
|
|
|
while read mode sha1 stage path |
|
|
|
while read mode sha1 stage path |
|
|
|
do |
|
|
|
do |
|
|
|
if ! test -d "$path"/.git |
|
|
|
url=$(git-config submodule."$path".url) |
|
|
|
|
|
|
|
if test -z "$url" |
|
|
|
then |
|
|
|
then |
|
|
|
# Only mention uninitialized submodules when its |
|
|
|
# Only mention uninitialized submodules when its |
|
|
|
# path have been specified |
|
|
|
# path have been specified |
|
|
|
test "$#" != "0" && |
|
|
|
test "$#" != "0" && |
|
|
|
say "Submodule '$path' not initialized" |
|
|
|
say "Submodule '$path' not initialized" |
|
|
|
continue; |
|
|
|
continue |
|
|
|
fi |
|
|
|
fi |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if ! test -d "$path"/.git |
|
|
|
|
|
|
|
then |
|
|
|
|
|
|
|
module_clone "$path" "$url" || exit |
|
|
|
|
|
|
|
fi |
|
|
|
|
|
|
|
|
|
|
|
subsha1=$(unset GIT_DIR && cd "$path" && |
|
|
|
subsha1=$(unset GIT_DIR && cd "$path" && |
|
|
|
git-rev-parse --verify HEAD) || |
|
|
|
git-rev-parse --verify HEAD) || |
|
|
|
die "Unable to find current revision of submodule '$path'" |
|
|
|
die "Unable to find current revision of submodule '$path'" |
|
|
|