mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-16 13:26:36 +00:00
git-update.sh: Fix issues
This commit is contained in:
parent
05e9dd968c
commit
795495519a
1 changed files with 88 additions and 44 deletions
|
@ -6,16 +6,28 @@
|
||||||
# run this from a directory that contains the checkouts for each of the
|
# run this from a directory that contains the checkouts for each of the
|
||||||
# modules
|
# modules
|
||||||
|
|
||||||
FAILURE=
|
PIDS=
|
||||||
|
|
||||||
|
CORE="\
|
||||||
|
gstreamer gst-plugins-base"
|
||||||
MODULES="\
|
MODULES="\
|
||||||
gstreamer gst-plugins-base \
|
|
||||||
gst-plugins-good gst-plugins-ugly gst-plugins-bad \
|
gst-plugins-good gst-plugins-ugly gst-plugins-bad \
|
||||||
gst-ffmpeg \
|
gst-ffmpeg \
|
||||||
gst-python \
|
gst-python \
|
||||||
gnonlin"
|
gnonlin"
|
||||||
|
|
||||||
for m in $MODULES; do
|
tmp=${TMPDIR-/tmp}
|
||||||
|
tmp=$tmp/git-update.$(date +%Y%m%d-%H%M-).$RANDOM.$RANDOM.$RANDOM.$$
|
||||||
|
|
||||||
|
(umask 077 && mkdir "$tmp") || {
|
||||||
|
echo "Could not create temporary directory! Exiting." 1>&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
ERROR_LOG="$tmp/failures.log"
|
||||||
|
touch $ERROR_LOG
|
||||||
|
|
||||||
|
for m in $CORE $MODULES; do
|
||||||
if test -d $m; then
|
if test -d $m; then
|
||||||
echo "+ updating $m"
|
echo "+ updating $m"
|
||||||
cd $m
|
cd $m
|
||||||
|
@ -23,56 +35,22 @@ for m in $MODULES; do
|
||||||
git pull origin master
|
git pull origin master
|
||||||
if test $? -ne 0
|
if test $? -ne 0
|
||||||
then
|
then
|
||||||
|
echo "$m: update (trying stash, pull, stash apply)" >> $ERROR_LOG
|
||||||
git stash
|
git stash
|
||||||
git pull origin master
|
git pull origin master
|
||||||
if test $? -ne 0
|
if test $? -ne 0
|
||||||
then
|
then
|
||||||
git stash apply
|
echo "$m: update" >> $ERROR_LOG
|
||||||
FAILURE="$FAILURE$m: update\n"
|
|
||||||
else
|
|
||||||
git stash apply
|
|
||||||
fi
|
|
||||||
cd ..
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
git submodule update
|
|
||||||
if test $? -ne 0
|
|
||||||
then
|
|
||||||
FAILURE="$FAILURE$m: update\n"
|
|
||||||
cd ..
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
cd ..
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# then build
|
|
||||||
for m in $MODULES; do
|
|
||||||
if test -d $m; then
|
|
||||||
cd $m
|
|
||||||
if test ! -e Makefile
|
|
||||||
then
|
|
||||||
./autoregen.sh
|
|
||||||
if test $? -ne 0
|
|
||||||
then
|
|
||||||
FAILURE="$FAILURE$m: autoregen.sh\n"
|
|
||||||
cd ..
|
cd ..
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
git stash apply
|
||||||
fi
|
fi
|
||||||
|
|
||||||
make $@
|
git submodule update
|
||||||
if test $? -ne 0
|
if test $? -ne 0
|
||||||
then
|
then
|
||||||
FAILURE="$FAILURE$m: make\n"
|
echo "$m: update (submodule)" >> $ERROR_LOG
|
||||||
cd ..
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
make $@ check
|
|
||||||
if test $? -ne 0
|
|
||||||
then
|
|
||||||
FAILURE="$FAILURE$m: check\n"
|
|
||||||
cd ..
|
cd ..
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
@ -80,8 +58,74 @@ for m in $MODULES; do
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if test "x$FAILURE" != "x"; then
|
build()
|
||||||
|
{
|
||||||
|
if test -d $1; then
|
||||||
|
cd $1
|
||||||
|
if test ! -e Makefile
|
||||||
|
then
|
||||||
|
echo "+ $1: autoregen.sh"
|
||||||
|
./autoregen.sh > "$tmp/$1-regen.log" 2>&1
|
||||||
|
if test $? -ne 0
|
||||||
|
then
|
||||||
|
echo "$1: autoregen.sh [$tmp/$1-regen.log]" >> $ERROR_LOG
|
||||||
|
cd ..
|
||||||
|
return -1
|
||||||
|
fi
|
||||||
|
echo "+ $1: autoregen.sh done"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "+ $1: make"
|
||||||
|
make > "$tmp/$1-make.log" 2>&1
|
||||||
|
if test $? -ne 0
|
||||||
|
then
|
||||||
|
echo "$1: make [$tmp/$1-make.log]" >> $ERROR_LOG
|
||||||
|
cd ..
|
||||||
|
return -1
|
||||||
|
fi
|
||||||
|
echo "+ $1: make done"
|
||||||
|
|
||||||
|
if test "x$CHECK" != "x"; then
|
||||||
|
echo "+ $1: make check"
|
||||||
|
make check > "$tmp/$1-check.log" 2>&1
|
||||||
|
if test $? -ne 0
|
||||||
|
then
|
||||||
|
echo "$1: check [$tmp/$1-check.log]" >> $ERROR_LOG
|
||||||
|
cd ..
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo "+ $1: make check done"
|
||||||
|
fi
|
||||||
|
cd ..
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
beach()
|
||||||
|
{
|
||||||
|
if test -e $ERROR_LOG; then
|
||||||
echo "Failures:"
|
echo "Failures:"
|
||||||
echo
|
echo
|
||||||
echo -e $FAILURE
|
cat $ERROR_LOG
|
||||||
|
else
|
||||||
|
rm -rf "$tmp"
|
||||||
fi
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# build core and base plugins sequentially
|
||||||
|
# exit if build fails (excluding checks)
|
||||||
|
for m in $CORE; do
|
||||||
|
build $m
|
||||||
|
if [ $? == -1 ]; then
|
||||||
|
beach
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# build other modules in parallel
|
||||||
|
for m in $MODULES; do
|
||||||
|
build $m &
|
||||||
|
PIDS="$PIDS $!"
|
||||||
|
done
|
||||||
|
wait $PIDS
|
||||||
|
|
||||||
|
beach
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue