# Determine whether to recommend/use the HEAD revision of FFmpeg (unreleased)
# or a specific revision based upon whether the last digit of our version
# is even or odd. An odd MLT version number always represents unreleased.
-svn_rev="16313"
+svn_rev="21322"
micro_version=$(echo $version | cut -d . -f 3)
odd_version=$(($micro_version % 2))
[ "$odd_version" -eq "1" ] && svn_rev="HEAD"
if [ "$help" = "1" ]
then
cat << EOF
-FFMPEG/avformat options:
+FFmpeg/avformat options:
- --avformat-svn - Obtain ffmpeg from Subversion
+ --avformat-svn - Obtain FFmpeg from its Subversion repository
+ --avformat-svn-version - Specify a particular revision for --avformat-svn
--avformat-svn-extra - Add extra configure options for --avformat-svn
- --avformat-shared=path - Link against a shared installation of ffmpeg (default)
- --avformat-static=path - Link against a static ffmpeg dev tree
+ --avformat-shared=path - Link against a shared installation of FFmpeg (default)
+ --avformat-static=path - Link against a static FFmpeg development tree
--avformat-ldextra=libs - Provide additional libs to link with
- --avformat-suffix=suff - Specify a custom suffix for an ffmpeg shared build
- --avformat-swscale - Use ffmpeg libswcale instead of img_convert
+ --avformat-suffix=suff - Specify a custom suffix for a shared build of FFmpeg
+ --avformat-swscale - Use libswcale instead of img_convert
--avformat-no-codecs - Disable the producer and consumer to avoid the FFmpeg codecs
--avformat-no-filters - Disable the filters to make a codecs+muxers-only plugin
- NOTE: The recommended version of FFmpeg is SVN-r$svn_rev.
+ NOTE: The recommended version of FFmpeg is $([ "$svn_rev" = "0.5" ] && echo $svn_rev || echo SVN-r$svn_rev).
EOF
Darwin)
export LIBSUF=.dylib
;;
- Linux)
+ Linux|FreeBSD)
export LIBSUF=.so
;;
*)
export swscale=
export codecs=true
export filters=true
+ pkg-config x11 > /dev/null 2>&1
+ export x11=$?
for i in "$@"
do
--avformat-ldextra=* ) extra_libs="${i#--avformat-ldextra=}" ;;
--avformat-svn ) svn_ffmpeg=true ;;
--avformat-svn-extra=* ) svn_ffmpeg_extra="${i#--avformat-svn-extra=}" ;;
+ --avformat-svn-version=* ) svn_rev="${i#--avformat-svn-version=}" ;;
--avformat-cvs ) svn_ffmpeg=true ;;
--avformat-suffix=* ) avformat_suffix="${i#--avformat-suffix=}" ;;
--avformat-swscale ) swscale=true ;;
if [ "$gpl" = "true" ]
then
enable_gpl="--enable-gpl"
- if [ "$swscale" != "" ]
- then
- enable_swscale="--enable-swscale"
- echo "SWSCALE=1" >> config.mak
- fi
- elif [ "$swscale" != "" ]
- then
- echo
- echo "ERROR ERROR ERROR ERROR ERROR ERROR"
- echo "--enable-gpl is required to use --avformat-swscale with --avformat-svn!"
- echo
- exit
+ [ "$swscale" != "" ] && [ "$svn_rev" = "0.5" ] &&
+ enable_swscale="--enable-swscale"
fi
if [ ! -d "ffmpeg" ]
then
echo
echo "Checking out ffmpeg/avformat revision $svn_rev - no password required"
echo
- svn checkout -r $svn_rev svn://svn.mplayerhq.hu/ffmpeg/trunk ffmpeg
+ if [ "$svn_rev" = "0.5" ]; then
+ svn checkout svn://svn.mplayerhq.hu/ffmpeg/branches/$svn_rev ffmpeg
+ else
+ svn checkout -r $svn_rev svn://svn.mplayerhq.hu/ffmpeg/trunk ffmpeg
+ fi
fi
[ -d "ffmpeg" ] && ( cd ffmpeg ; ./configure $enable_gpl $enable_swscale $svn_ffmpeg_extra )
#[ ! -f "ffmpeg/ffmpeg.patch" ] && ( cd ffmpeg ; cp ../ffmpeg.patch . ; patch -p0 < ffmpeg.patch )
- echo "CFLAGS+=-I`pwd`/ffmpeg -I`pwd`/ffmpeg/libavformat -I`pwd`/ffmpeg/libavcodec -I`pwd`/ffmpeg/libavutil -I`pwd`/ffmpeg/libavdevice -I`pwd`/ffmpeg/libswscale" >> config.mak
- echo "LDFLAGS+=-L`pwd`/ffmpeg/libavformat -L`pwd`/ffmpeg/libavcodec -L`pwd`/ffmpeg/libavutil -L`pwd`/ffmpeg/libavdevice -L`pwd`/ffmpeg/libswscale" >> config.mak
+ echo "CFLAGS+=-I`pwd`/ffmpeg -I`pwd`/ffmpeg/libavformat -I`pwd`/ffmpeg/libavcodec -I`pwd`/ffmpeg/libavutil -I`pwd`/ffmpeg/libavdevice" >> config.mak
+ echo "LDFLAGS+=-L`pwd`/ffmpeg/libavformat -L`pwd`/ffmpeg/libavcodec -L`pwd`/ffmpeg/libavutil -L`pwd`/ffmpeg/libavdevice" >> config.mak
+ if [ "$swscale" != "" ] || [ "$svn_rev" = "HEAD" ]
+ then
+ echo "CFLAGS+=-I`pwd`/ffmpeg/libswscale" >> config.mak
+ echo "LDFLAGS+=-L`pwd`/ffmpeg/libswscale" >> config.mak
+ echo "SWSCALE=1" >> config.mak
+ fi
[ $targetos = "Darwin" ] &&
echo "LDFLAGS+=-single_module" >> config.mak
echo "LOCAL_FFMPEG=1" >> config.mak
echo "LDFLAGS+=-Wl,-Bsymbolic" >> config.mak
- extra_libs="$extra_libs -lz"
+ extra_libs="$extra_libs -lm -lz -lbz2"
+
+ echo -e "#include <libavcodec/vdpau.h>\n int main(){ VdpBitstreamBuffer test; test.struct_version; return 0;}" | gcc -I"`pwd`/ffmpeg" $CFLAGS -c -x c - >/dev/null 2>&1
+ [ "$x11" = "0" -a "$?" = "0" ] && echo "VDPAU=1" >> config.mak
elif [ "$static_ffmpeg" != "" ]
then
if [ -d "$static_ffmpeg" ]
echo "SWSCALE=1" >> config.mak
fi
echo "LDFLAGS+=-Wl,-Bsymbolic" >> config.mak
- extra_libs="$extra_libs -lz"
+ extra_libs="$extra_libs -lm -lz -lbz2"
+
+ echo -e "#include <libavcodec/vdpau.h>\n int main(){ VdpBitstreamBuffer test; test.struct_version; return 0;}" | gcc -I"$static_ffmpeg" $CFLAGS -c -x c - >/dev/null 2>&1
+ [ "$x11" = "0" -a "$?" = "0" ] && echo "VDPAU=1" >> config.mak
else
echo "avformat: Invalid path specified: $static_ffmpeg"
touch ../disable-avformat
elif [ "$shared_ffmpeg" != "" ]
then
echo "PREFIX=$shared_ffmpeg" >> config.mak
- echo "CFLAGS+=$(pkg-config --cflags libavformat) $TMP_CFLAGS" >> config.mak
- echo "LDFLAGS+=$(pkg-config --libs libavformat)" >> config.mak
+ echo "CFLAGS+=$(pkg-config --cflags libavformat libavdevice) $TMP_CFLAGS" >> config.mak
+ echo "LDFLAGS+=$(pkg-config --libs-only-L libavformat libavdevice)" >> config.mak
[ -d "$shared_ffmpeg/include/ffmpeg/libavformat" ] &&
- echo "CFLAGS+=-I$shared_ffmpeg/include/ffmpeg/libavformat -I$shared_ffmpeg/include/ffmpeg/libavcodec" >> config.mak
+ echo "CFLAGS+=-I$shared_ffmpeg/include/ffmpeg/libavformat -I$shared_ffmpeg/include/ffmpeg/libavcodec -I$shared_ffmpeg/include/ffmpeg/libavdevice" >> config.mak
[ -d "$shared_ffmpeg/include/libavformat" ] &&
- echo "CFLAGS+=-I$shared_ffmpeg/include/libavformat -I$shared_ffmpeg/include/libavcodec" >> config.mak
- if [ "$swscale" != "" ]
+ echo "CFLAGS+=-I$shared_ffmpeg/include/libavformat -I$shared_ffmpeg/include/libavcodec -I$shared_ffmpeg/include/libavdevice" >> config.mak
+ avcodec_version=$(pkg-config --modversion libavcodec)
+ if [ "$swscale" != "" ] || ( [ $(echo $avcodec_version | cut -d. -f1) -ge 52 ] && [ $(echo $avcodec_version | cut -d. -f2) -ge 21 ] )
then
[ -d "$shared_ffmpeg/include/ffmpeg/libswscale" ] &&
echo "CFLAGS+=-I$shared_ffmpeg/include/ffmpeg/libswscale" >> config.mak
echo "CFLAGS+=-I$shared_ffmpeg/include/libswscale" >> config.mak
echo "SWSCALE=1" >> config.mak
fi
+
+ echo -e "#include <libavcodec/vdpau.h>\n int main(){ VdpBitstreamBuffer test; test.struct_version; return 0;}" | gcc -I"$(pkg-config --cflags libavformat)" -I"$shared_ffmpeg/include" $CFLAGS -c -x c - >/dev/null 2>&1
+ [ "$x11" = "0" -a "$?" = "0" ] && echo "VDPAU=1" >> config.mak
else
echo "avformat: No build environment found. "
echo " Try configuring mlt with --avformat-svn."