X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=src%2Fmodules%2Favformat%2Fconfigure;h=ea28196cc37ee62f0a110b43430eb312ce1745bc;hb=36a97c4faa81ca406114b74d91912129e8703e3b;hp=c80628f7982e379fe1f42ef7df299ad390a73a3a;hpb=2a04e5dceebd174e24be42da8643a815640db27d;p=melted diff --git a/src/modules/avformat/configure b/src/modules/avformat/configure index c80628f..ea28196 100755 --- a/src/modules/avformat/configure +++ b/src/modules/avformat/configure @@ -6,11 +6,13 @@ then cat << EOF FFMPEG/avformat options: - --avformat-cvs - Obtain ffmpeg from CVS + --avformat-svn - Obtain ffmpeg from Subversion + --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-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 EOF @@ -27,21 +29,25 @@ else ;; esac + bits=$(uname -m) + case $bits in + x86_64) + [ -d /usr/lib/lib64 ] && export LIBDIR=lib64 || export LIBDIR=lib + ;; + *) + export LIBDIR=lib + ;; + esac + echo > config.mak export static_ffmpeg= - export shared_ffmpeg=`which ffmpeg` + export shared_ffmpeg=$(pkg-config --variable=prefix libavformat) export extra_libs= - export cvs_ffmpeg= + export svn_ffmpeg= + export svn_ffmpeg_extra= export avformat_suffix= - - if [ "$shared_ffmpeg" != "" ] - then - # Chop ffmpeg - shared_ffmpeg=`dirname $shared_ffmpeg` - # Chop bin - shared_ffmpeg=`dirname $shared_ffmpeg` - fi + export swscale= for i in "$@" do @@ -49,67 +55,81 @@ else --avformat-static=* ) static_ffmpeg="${i#--avformat-static=}" ;; --avformat-shared=* ) shared_ffmpeg="${i#--avformat-shared=}" ;; --avformat-ldextra=* ) extra_libs="${i#--avformat-ldextra=}" ;; - --avformat-cvs ) cvs_ffmpeg=true ;; + --avformat-svn ) svn_ffmpeg=true ;; + --avformat-svn-extra=* ) svn_ffmpeg_extra="${i#--avformat-svn-extra=}" ;; + --avformat-cvs ) svn_ffmpeg=true ;; --avformat-suffix=* ) avformat_suffix="${i#--avformat-suffix=}" ;; + --avformat-swscale ) swscale=true ;; + --avformat-swscaler ) swscale=true ;; esac done - if [ "$cvs_ffmpeg" != "" ] + if [ "$svn_ffmpeg" != "" ] then - [ ! -d "ffmpeg" ] && ( + if [ "$gpl" = "true" ] + then + enable_gpl="--enable-gpl" + if [ "$swscale" != "" ] + then + enable_swscale="--enable-swscaler" + 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 + fi + if [ ! -d "ffmpeg" ] + then echo echo "Checking out ffmpeg/avformat - no password required" echo - cvs -z9 -d:pserver:anonymous@mplayerhq.hu:/cvsroot/ffmpeg login - cvs -z9 -d:pserver:anonymous@mplayerhq.hu:/cvsroot/ffmpeg co ffmpeg - ) - [ -d "ffmpeg" ] && ( cd ffmpeg ; ./configure --enable-shared --build-suffix="$avformat_suffix" ) + svn checkout svn://svn.mplayerhq.hu/ffmpeg/trunk ffmpeg + 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/libavformat -I`pwd`/ffmpeg/libavcodec -I`pwd`/ffmpeg/libavutil" >> config.mak + echo "CFLAGS+=-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 + [ $targetos = "Darwin" ] && + echo "LDFLAGS+=-single_module" >> config.mak echo "LOCAL_FFMPEG=1" >> config.mak extra_libs="$extra_libs -lz" elif [ "$static_ffmpeg" != "" ] then if [ -d "$static_ffmpeg" ] then - echo "CFLAGS+=-I$static_ffmpeg/libavformat -I$static_ffmpeg/libavcodec -I$static_ffmpeg/libavutil" >> config.mak - echo "LDFLAGS+=-L$static_ffmpeg/libavformat -L$static_ffmpeg/libavcodec -L$static_ffmpeg/libavutil" >> config.mak + echo "CFLAGS+=-I$static_ffmpeg/libavformat -I$static_ffmpeg/libavcodec -I$static_ffmpeg/libavutil -I$static_ffmpeg/libavdevice" >> config.mak + echo "LDFLAGS+=-L$static_ffmpeg/libavformat -L$static_ffmpeg/libavcodec -L$static_ffmpeg/libavutil -L$static_ffmpeg/libavdevice" >> config.mak [ $targetos = "Darwin" ] && echo "LDFLAGS+=-single_module" >> config.mak + if [ "$swscale" != "" ] + then + echo "CFLAGS+=-I$static_ffmpeg/libswscale" >> config.mak + echo "LDFLAGS+=-L$static_ffmpeg/libswscale" >> config.mak + echo "SWSCALE=1" >> config.mak + fi else echo "avformat: Invalid path specified: $static_ffmpeg" touch ../disable-avformat echo 0 fi - else - if [ -d "$shared_ffmpeg/include/ffmpeg" -a -f "$shared_ffmpeg/lib/libavformat$LIBSUF" ] - then - echo "CFLAGS+=-I$shared_ffmpeg/include/ffmpeg " >> config.mak - echo "LDFLAGS+=-L$shared_ffmpeg/lib" >> config.mak - else - echo "avformat: No build environment found. " - echo " Try configuring mlt with --avformat-cvs." - touch ../disable-avformat - exit 0 - fi + elif [ "$shared_ffmpeg" != "" ] + then + echo "CFLAGS+=$(pkg-config --cflags libavformat)" >> config.mak + echo "LDFLAGS+=$(pkg-config --libs libavformat)" >> config.mak + [ "$swscale" != "" ] && echo "SWSCALE=1" >> config.mak + else + echo "avformat: No build environment found. " + echo " Try configuring mlt with --avformat-svn." + touch ../disable-avformat + exit 0 fi echo "EXTRA_LIBS=$extra_libs" >> config.mak echo "AVFORMAT_SUFFIX=$avformat_suffix" >> config.mak -cat << EOF >> ../producers.dat -avformat libmltavformat$LIBSUF -EOF - -cat << EOF >> ../filters.dat -avdeinterlace libmltavformat$LIBSUF -avresample libmltavformat$LIBSUF -avcolour_space libmltavformat$LIBSUF -EOF - -cat << EOF >> ../consumers.dat -avformat libmltavformat$LIBSUF -EOF - fi