[__git] Add a --no-updates flag to support old static behaviour.
Users relying on this would probably be better off using tags, but this enables old behaviour with minor changes in existing manifests.
This commit is contained in:
parent
6e3ef60f89
commit
e23e5ffa3c
4 changed files with 17 additions and 1 deletions
|
@ -1,5 +1,10 @@
|
||||||
#!/bin/sh -e
|
#!/bin/sh -e
|
||||||
|
|
||||||
|
if [ -f "$__object/parameter/no-updates" ]; then
|
||||||
|
# User requested explicitly not to have updates
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
destination="/$__object_id"
|
destination="/$__object_id"
|
||||||
|
|
||||||
state_should="$(cat "$__object/parameter/state")"
|
state_should="$(cat "$__object/parameter/state")"
|
||||||
|
|
|
@ -25,6 +25,10 @@ owner_is=$(cat "$__object/explorer/owner")
|
||||||
group_is=$(cat "$__object/explorer/group")
|
group_is=$(cat "$__object/explorer/group")
|
||||||
needs_update=$(cat "$__object/explorer/needs-update")
|
needs_update=$(cat "$__object/explorer/needs-update")
|
||||||
|
|
||||||
|
if [ -f "$__object/parameter/no-updates" ]; then
|
||||||
|
no_updates="YES"
|
||||||
|
fi
|
||||||
|
|
||||||
state_should=$(cat "$__object/parameter/state")
|
state_should=$(cat "$__object/parameter/state")
|
||||||
|
|
||||||
branch_should=$(cat "$__object/parameter/branch")
|
branch_should=$(cat "$__object/parameter/branch")
|
||||||
|
@ -78,7 +82,7 @@ EOF
|
||||||
echo "su -m '$git_user' -c \"git checkout '$branch_should'\""
|
echo "su -m '$git_user' -c \"git checkout '$branch_should'\""
|
||||||
echo "change $branch_is -> $branch_should" >> "$__messages_out"
|
echo "change $branch_is -> $branch_should" >> "$__messages_out"
|
||||||
repo_changed="YES"
|
repo_changed="YES"
|
||||||
elif [ "$needs_update" = "YES" ]; then
|
elif [ -z "$no_updates" ] && [ "$needs_update" = "YES" ]; then
|
||||||
# The remote has newer information than our repository.
|
# The remote has newer information than our repository.
|
||||||
# Fetch was done in the explorer, here we can just pull
|
# Fetch was done in the explorer, here we can just pull
|
||||||
echo "su -m '$git_user' -c \"git -C '$destination' pull\""
|
echo "su -m '$git_user' -c \"git -C '$destination' pull\""
|
||||||
|
|
|
@ -47,6 +47,12 @@ mode-recursive
|
||||||
If present and --mode is passed, the given permissions will be applied
|
If present and --mode is passed, the given permissions will be applied
|
||||||
recursively to the working directory.
|
recursively to the working directory.
|
||||||
|
|
||||||
|
no-updates
|
||||||
|
If present the repository will not be updated after first check out.
|
||||||
|
Notice that this does not affect behaviour if you change the target
|
||||||
|
tag / branch, in which case the type will still ensure the specified one
|
||||||
|
is checked out.
|
||||||
|
|
||||||
recursive
|
recursive
|
||||||
Passes the --recurse-submodules flag to git when cloning the repository.
|
Passes the --recurse-submodules flag to git when cloning the repository.
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
mode-recursive
|
mode-recursive
|
||||||
|
no-updates
|
||||||
recursive
|
recursive
|
||||||
shallow
|
shallow
|
||||||
|
|
Loading…
Reference in a new issue