gstreamer/scripts/git-update.sh

150 lines
2.8 KiB
Bash
Raw Normal View History

#!/bin/bash
# update all known gstreamer modules
# build them one by one
# report failures at the end
# run this from a directory that contains the checkouts for each of the
# modules
2010-01-28 06:27:49 +00:00
PIDS=
2010-01-28 06:27:49 +00:00
CORE="\
gstreamer gst-plugins-base"
MODULES="\
gst-plugins-good gst-plugins-ugly gst-plugins-bad \
gst-libav"
EXTRA_MODULES="\
gst-editing-services \
gst-rtsp-server \
gst-python \
gnonlin"
2010-01-28 06:27:49 +00:00
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"
ERROR_RETURN=255
2010-01-28 06:27:49 +00:00
for m in $CORE $MODULES $EXTRA_MODULES; do
if test -d $m; then
echo "+ updating $m"
cd $m
git pull --rebase
if test $? -ne 0
then
2010-01-28 06:27:49 +00:00
echo "$m: update (trying stash, pull, stash apply)" >> $ERROR_LOG
git stash
git pull --rebase
if test $? -ne 0
then
2010-01-28 06:27:49 +00:00
echo "$m: update" >> $ERROR_LOG
cd ..
continue
fi
2010-01-28 06:27:49 +00:00
git stash apply
fi
2010-01-28 06:27:49 +00:00
git submodule update
if test $? -ne 0
then
2010-01-28 06:27:49 +00:00
echo "$m: update (submodule)" >> $ERROR_LOG
cd ..
continue
fi
cd ..
fi
done
2010-01-28 06:27:49 +00:00
build()
{
if test -d $1; then
cd $1
2010-03-24 12:33:58 +00:00
if test ! -e Makefile
then
2010-03-24 12:33:58 +00:00
if test -e autoregen.sh
then
2010-03-24 12:33:58 +00:00
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 $ERROR_RETURN
fi
echo "+ $1: autoregen.sh done"
else
echo "+ $1: autogen.sh"
./autogen.sh > "$tmp/$1-gen.log" 2>&1
if test $? -ne 0
then
echo "$1: autogen.sh [$tmp/$1-gen.log]" >> $ERROR_LOG
cd ..
return $ERROR_RETURN
fi
echo "+ $1: autogen.sh done"
fi
fi
2010-01-28 06:27:49 +00:00
echo "+ $1: make"
make > "$tmp/$1-make.log" 2>&1
if test $? -ne 0
then
2010-01-28 06:27:49 +00:00
echo "$1: make [$tmp/$1-make.log]" >> $ERROR_LOG
cd ..
return $ERROR_RETURN
fi
2010-01-28 06:27:49 +00:00
echo "+ $1: make done"
2010-01-28 06:27:49 +00:00
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
2010-01-28 06:27:49 +00:00
}
2010-01-28 06:27:49 +00:00
beach()
{
if test -e $ERROR_LOG; then
echo "Failures:"
echo
2010-01-28 06:27:49 +00:00
cat $ERROR_LOG
else
echo "Update done"
2010-01-28 06:27:49 +00:00
rm -rf "$tmp"
fi
exit
2010-01-28 06:27:49 +00:00
}
# build core and base plugins sequentially
# exit if build fails (excluding checks)
for m in $CORE; do
build $m
if [ $? -eq $ERROR_RETURN ]; then
2010-01-28 06:27:49 +00:00
beach
fi
done
# build other modules in parallel
for m in $MODULES; do
build $m &
PIDS="$PIDS $!"
done
wait $PIDS
beach