1
0
Fork 0

Correction du cas où on a des commits locaux donc le fetch indique quelque chose

Gestion de plusieurs dépôts par un script
Changements utilitaires pour le wall
This commit is contained in:
Teo-CD 2019-05-20 15:55:09 +02:00 committed by trotFunky
parent a26a4e5eaa
commit 27776d5a12

View file

@ -1,37 +1,40 @@
#!/bin/bash #!/bin/bash
export LC_ALL=POSIX
GIT_REPO="."
WORK_DIR=$HOME"/.gitAutoPull" WORK_DIR=$HOME"/.gitAutoPull"
work_array="."
if [ $# -gt 0 ]; then if [ $# -gt 0 ]; then
GIT_REPO="$1" work_array=$@
fi fi
GIT_REPO_NAME="$(echo '$GIT_REPO' | tr '/' '_' | tr -d '~')" for GIT_REPO in $work_array ; do
CHECK_TIMER_FILE=$WORK_DIR/localCommitsCheck"$GIT_REPO_NAME"
cd $GIT_REPO > /dev/null GIT_REPO_NAME="$(echo '$GIT_REPO' | tr '/' '_' | tr -d '~')"
CHECK_TIMER_FILE=$WORK_DIR/localCommitsCheck"$GIT_REPO_NAME"
if [ $? -ne 0 ]; then cd $GIT_REPO > /dev/null
if [ $? -ne 0 ]; then
echo $GIT_REPO" Does not exist or is not a directory" echo $GIT_REPO" Does not exist or is not a directory"
exit -2 exit -2
fi fi
if [ -z "$(git rev-parse --git-dir 2>/dev/null)" ]; then if [ -z "$(git rev-parse --git-dir 2>/dev/null)" ]; then
echo $GIT_REPO" is not a git repository" echo $GIT_REPO" is not a git repository"
exit -2 exit -2
fi fi
if [ ! -d $WORK_DIR ]; then if [ ! -d $WORK_DIR ]; then
mkdir $WORK_DIR > /dev/null mkdir $WORK_DIR > /dev/null
fi fi
if [ ! -d $WORK_DIR ]; then if [ ! -d $WORK_DIR ]; then
echo "Could not create work directory, aborting" echo "Could not create work directory, aborting"
exit -4 exit -4
fi fi
if [ -e $CHECK_TIMER_FILE ]; then if [ -e $CHECK_TIMER_FILE ]; then
read count < $CHECK_TIMER_FILE read count < $CHECK_TIMER_FILE
if [ $cout -ne 0 ]; then if [ $cout -ne 0 ]; then
echo $(( $count - 1 )) > $CHECK_TIMER_FILE echo $(( $count - 1 )) > $CHECK_TIMER_FILE
@ -39,27 +42,30 @@ if [ -e $CHECK_TIMER_FILE ]; then
else else
rm -f $CHECK_TIMER_FILE rm -f $CHECK_TIMER_FILE
fi fi
fi fi
remoteStatus="$(git fetch --dry-run 2>&1)" # Empty if there are no commits to fetch remoteStatus="$(git fetch --dry-run 2>&1 | tail -n 1 | grep -v -e'+')" # Empty if there are no commits to fetch
localStatus="$(git push -n --porcelain | grep -e'up to date')" # Empty if there are commits to push localStatus="$(git push -n --porcelain | grep -e'up to date')" # Empty if there are commits to push
if [ -z "$remoteStatus" ]; then {
if [ -z "$remoteStatus" ]; then
if [ -z "$localStatus" ]; then if [ -z "$localStatus" ]; then
echo "Pushing "$GIT_REPO" updates to origin" | wall echo "Pushing "$GIT_REPO" updates to origin"
git push 2>&1 | wall git push 2>&1
exit 1 exit 1
fi fi
else else
if [ -z "localStatus" ]; then if [ -z "localStatus" ]; then
echo "Local and remote diverged, stopping auto-update for 30 iterations..." | wall echo "Local and remote diverged, stopping auto-update for 30 iterations..."
echo 30 > $WORK_DIR/localCommitsCheck"$GIT_REPO_NAME" echo 30 > $WORK_DIR/localCommitsCheck"$GIT_REPO_NAME"
else else
echo "Updating "$GIT_REPO" with remote commits" | wall echo "Updating "$GIT_REPO" with remote commits"
git fetch --all 2>&1 | wall git fetch --all 2>&1
git remote update 2>&1 | wall git remote update 2>&1
exit 1 exit 1
fi fi
fi fi } | wall
done
exit 0 exit 0