mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-15 11:51:33 +00:00
20e1829dad
The install directory being deleted might not be present if the build failed. This can lead to annoying error output if the FATE client is run as a cronjob.
113 lines
3.0 KiB
Bash
Executable File
113 lines
3.0 KiB
Bash
Executable File
#! /bin/sh
|
|
|
|
config=$1
|
|
|
|
die(){
|
|
echo "$@"
|
|
exit 1
|
|
}
|
|
|
|
test -r "$config" || die "usage: fate.sh <config>"
|
|
|
|
workdir=$(cd $(dirname $config) && pwd)
|
|
make=make
|
|
tar='tar c'
|
|
|
|
. "$config"
|
|
|
|
test -n "$slot" || die "slot not specified"
|
|
test -n "$repo" || die "repo not specified"
|
|
test -d "$samples" || die "samples location not specified"
|
|
|
|
lock(){
|
|
lock=$1/fate.lock
|
|
(set -C; exec >$lock) 2>/dev/null || return
|
|
trap 'rm $lock' EXIT
|
|
}
|
|
|
|
checkout(){
|
|
case "$repo" in
|
|
file:*|/*) src="${repo#file:}" ;;
|
|
git:*) git clone "$repo" "$src" ;;
|
|
esac
|
|
}
|
|
|
|
update()(
|
|
cd ${src} || return
|
|
case "$repo" in
|
|
git:*) git pull --quiet ;;
|
|
esac
|
|
)
|
|
|
|
configure()(
|
|
cd ${build} || return
|
|
${src}/configure \
|
|
--prefix="${inst}" \
|
|
--samples="${samples}" \
|
|
--enable-gpl \
|
|
${arch:+--arch=$arch} \
|
|
${cpu:+--cpu="$cpu"} \
|
|
${cross_prefix:+--cross-prefix="$cross_prefix"} \
|
|
${cc:+--cc="$cc"} \
|
|
${target_os:+--target-os="$target_os"} \
|
|
${sysroot:+--sysroot="$sysroot"} \
|
|
${target_exec:+--target-exec="$target_exec"} \
|
|
${target_path:+--target-path="$target_path"} \
|
|
${extra_cflags:+--extra-cflags="$extra_cflags"} \
|
|
${extra_ldflags:+--extra-ldflags="$extra_ldflags"} \
|
|
${extra_libs:+--extra-libs="$extra_libs"} \
|
|
${extra_conf}
|
|
)
|
|
|
|
compile()(
|
|
cd ${build} || return
|
|
${make} ${makeopts} && ${make} install
|
|
)
|
|
|
|
fate()(
|
|
cd ${build} || return
|
|
${make} ${makeopts} -k fate
|
|
)
|
|
|
|
clean(){
|
|
rm -rf ${build} ${inst}
|
|
}
|
|
|
|
report(){
|
|
date=$(date -u +%Y%m%d%H%M%S)
|
|
echo "fate:0:${date}:${slot}:${version}:$1:$2:${comment}" >report
|
|
cat ${build}/config.fate ${build}/tests/data/fate/*.rep >>report
|
|
test -n "$fate_recv" && $tar report *.log | gzip | $fate_recv
|
|
}
|
|
|
|
fail(){
|
|
report "$@"
|
|
clean
|
|
exit
|
|
}
|
|
|
|
mkdir -p ${workdir} || die "Error creating ${workdir}"
|
|
lock ${workdir} || die "${workdir} locked"
|
|
cd ${workdir} || die "cd ${workdir} failed"
|
|
|
|
src=${workdir}/src
|
|
: ${build:=${workdir}/build}
|
|
: ${inst:=${workdir}/install}
|
|
|
|
test -d "$src" && update || checkout || die "Error fetching source"
|
|
|
|
cd ${workdir}
|
|
|
|
version=$(${src}/version.sh ${src})
|
|
test "$version" = "$(cat version-$slot 2>/dev/null)" && exit 0
|
|
echo ${version} >version-$slot
|
|
|
|
rm -rf "${build}" *.log
|
|
mkdir -p ${build}
|
|
|
|
configure >configure.log 2>&1 || fail $? "error configuring"
|
|
compile >compile.log 2>&1 || fail $? "error compiling"
|
|
fate >test.log 2>&1 || fail $? "error testing"
|
|
report 0 success
|
|
clean
|