X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=configure;h=430edbdc0c215bc50c7eb0a797a3d86e05175305;hb=7e14f14584939ec0dc822ae6fa91355f9c307913;hp=388512dc291c322fa3e3ca2733917b5d5cd77ed5;hpb=f7679c54dd1de0ebb1aa4adda8863d33ff4ca5c3;p=ffmpeg diff --git a/configure b/configure index 388512dc291..430edbdc0c2 100755 --- a/configure +++ b/configure @@ -12,14 +12,14 @@ try_exec(){ echo "Trying shell $1" - type "$1" >/dev/null 2>&1 && exec "$@" + type "$1" > /dev/null 2>&1 && exec "$@" } unset foo -(: ${foo%%bar}) 2>/dev/null +(: ${foo%%bar}) 2> /dev/null E1="$?" -(: ${foo?}) 2>/dev/null +(: ${foo?}) 2> /dev/null E2="$?" if test "$E1" != 0 || test "$E2" = 0; then @@ -56,11 +56,13 @@ show_help(){ echo echo "Standard options:" echo " --help print this message" - echo " --log[=FILE|yes|no] log tests and output to FILE [config.err]" - echo " --prefix=PREFIX install in PREFIX [$PREFIX]" + echo " --logfile=FILE log tests and output to FILE [config.err]" + echo " --disable-logging do not log configure debug information" + echo " --prefix=PREFIX install in PREFIX [$prefix]" + echo " --bindir=DIR install binaries in DIR [PREFIX/bin]" echo " --libdir=DIR install libs in DIR [PREFIX/lib]" echo " --shlibdir=DIR install shared libs in DIR [PREFIX/lib]" - echo " --incdir=DIR install includes in DIR [PREFIX/include/ffmpeg]" + echo " --incdir=DIR install includes in DIR [PREFIX/include]" echo " --mandir=DIR install man page in DIR [PREFIX/share/man]" echo " --enable-static build static libraries [default=yes]" echo " --disable-static do not build static libraries [default=no]" @@ -70,8 +72,8 @@ show_help(){ echo " and ffmpeg will be under GPL [default=no]" echo " --enable-nonfree allow use of nonfree code, the resulting libav*" echo " and ffmpeg will be unredistributable [default=no]" - echo " --enable-pp enable GPLed postprocessing support [default=no]" - echo " --enable-swscaler software scaler support [default=no]" + echo " --enable-postproc enable GPLed postprocessing support [default=no]" + echo " --enable-swscale software scaler support [default=no]" echo " --enable-avfilter video filter support (replaces vhook) [default=no]" echo " --enable-avfilter-lavf video filters dependant on avformat [default=no]" echo " --enable-beosthreads use BeOS threads [default=no]" @@ -81,7 +83,7 @@ show_help(){ echo " --enable-x11grab enable X11 grabbing [default=no]" echo echo "External library support:" - echo " --enable-sunmlib use Sun medialib [default=no]" + echo " --enable-mlib use Sun medialib [default=no]" echo " --enable-liba52 enable GPLed liba52 support [default=no]" echo " --enable-liba52bin open liba52.so.0 at runtime [default=no]" echo " --enable-avisynth allow reading AVISynth script files [default=no]" @@ -89,6 +91,7 @@ show_help(){ echo " --enable-libamr-wb enable libamr-wb floating point audio codec" echo " --enable-libdc1394 enable IIDC-1394 grabbing using libdc1394" echo " and libraw1394 [default=no]" + echo " --enable-libdirac enable Dirac support via libdirac [default=no]" echo " --enable-libfaac enable FAAC support via libfaac [default=no]" echo " --enable-libfaad enable FAAD support via libfaad [default=no]" echo " --enable-libfaadbin open libfaad.so.0 at runtime [default=no]" @@ -96,6 +99,7 @@ show_help(){ echo " --enable-libmp3lame enable MP3 encoding via libmp3lame [default=no]" echo " --enable-libnut enable NUT (de)muxing via libnut," echo " native demuxer exists [default=no]" + echo " --enable-libschroedinger enable Dirac support via libschroedinger [default=no]" echo " --enable-libtheora enable Theora encoding via libtheora [default=no]" echo " --enable-libvorbis enable Vorbis encoding via libvorbis," echo " native implementation exists [default=no]" @@ -106,10 +110,9 @@ show_help(){ echo "Advanced options (experts only):" echo " --source-path=PATH path to source code [$source_path]" echo " --cross-prefix=PREFIX use PREFIX for compilation tools [$cross_prefix]" - echo " --cross-compile assume a cross-compiler is used" - echo " --target-os=OS compiler targets OS [$targetos]" + echo " --enable-cross-compile assume a cross-compiler is used" + echo " --target-os=OS compiler targets OS [$target_os]" echo " --cc=CC use C compiler CC [$cc]" - echo " --make=MAKE use specified make [$make]" echo " --extra-cflags=ECFLAGS add ECFLAGS to CFLAGS [$CFLAGS]" echo " --extra-ldflags=ELDFLAGS add ELDFLAGS to LDFLAGS [$LDFLAGS]" echo " --extra-libs=ELIBS add ELIBS [$ELIBS]" @@ -120,13 +123,17 @@ show_help(){ echo " --enable-powerpc-perf enable performance report on PPC" echo " (requires enabling PMC)" echo " --disable-mmx disable MMX usage" + echo " --disable-mmx2 disable MMX2 usage" + echo " --disable-ssse3 disable SSSE3 usage" echo " --disable-armv5te disable armv5te usage" echo " --disable-armv6 disable armv6 usage" + echo " --disable-armvfp disable ARM VFP usage" echo " --disable-iwmmxt disable iwmmxt usage" echo " --disable-altivec disable AltiVec usage" echo " --disable-network disable network support [default=no]" echo " --disable-ipv6 disable ipv6 support [default=no]" echo " --disable-zlib disable zlib [default=no]" + echo " --disable-bzlib disable bzlib [default=no]" echo " --disable-vhook disable video hooking support" echo " --disable-debug disable debugging symbols" echo " --disable-mpegaudio-hp faster (but less accurate)" @@ -174,19 +181,19 @@ show_help(){ echo " --enable-gprof enable profiling with gprof [$gprof]" echo " --disable-optimizations disable compiler optimizations" echo " --enable-extra-warnings enable more compiler warnings" - echo " --disable-strip disable stripping of executables and shared libraries" + echo " --disable-stripping disable stripping of executables and shared libraries" echo "" echo "NOTE: Object files are built at the place where configure is launched." exit 1 } log(){ - echo "$@" >>$logfile + echo "$@" >> $logfile } log_file(){ log BEGIN $1 - pr -n -t $1 >>$logfile + pr -n -t $1 >> $logfile log END $1 } @@ -202,18 +209,18 @@ If you think configure made a mistake, make sure you are using the latest version from SVN. If the latest version fails, report the problem to the ffmpeg-user@mplayerhq.hu mailing list or IRC #ffmpeg on irc.freenode.net. EOF - if enabled logging; then + if disabled logging; then cat </dev/null + (: ${SAVE_CFLAGS?}) 2> /dev/null } save_flags(){ @@ -401,19 +408,19 @@ add_extralibs(){ check_cmd(){ log "$@" - "$@" >>$logfile 2>&1 + "$@" >> $logfile 2>&1 } check_cc(){ log check_cc "$@" - cat >$TMPC + cat > $TMPC log_file $TMPC check_cmd $cc $CFLAGS "$@" -c -o $TMPO $TMPC } check_cpp(){ log check_cpp "$@" - cat >$TMPC + cat > $TMPC log_file $TMPC check_cmd $cc $CFLAGS "$@" -E -o $TMPO $TMPC } @@ -424,9 +431,7 @@ check_asm(){ asm="$2" shift 2 check_cc "$@" <>$logfile 2>&1; } + check_ld "$@" && { enabled cross_compile || $TMPE >> $logfile 2>&1; } } check_exec_crash(){ @@ -539,7 +540,7 @@ check_exec_crash(){ # can redirect the "Terminated" message from the shell. SIGBUS # is not defined by standard C so it is used conditionally. - (check_exec "$@") >>$logfile 2>&1 <> $logfile 2>&1 < static void sighandler(int sig){ raise(SIGTERM); @@ -617,12 +618,12 @@ COMPONENT_LIST=" decoders demuxers encoders + filters indevs muxers outdevs parsers protocols - filters " CONFIG_LIST=" @@ -631,6 +632,7 @@ CONFIG_LIST=" avfilter_lavf avisynth beos_netserver + bzlib ffmpeg ffplay ffserver @@ -644,24 +646,27 @@ CONFIG_LIST=" libamr_nb libamr_wb libdc1394 + libdirac libfaac libfaad libfaadbin libgsm libmp3lame libnut + libschroedinger libtheora libvorbis libx264 libxvid memalign_hack + mlib mpegaudio_hp network nonfree + postproc powerpc_perf - pp small - swscaler + swscale vhook x11grab zlib @@ -696,9 +701,11 @@ ARCH_EXT_LIST=' altivec armv5te armv6 + armvfp iwmmxt mmi mmx + mmx2 ssse3 vis ' @@ -708,6 +715,7 @@ HAVE_LIST=" $THREADS_LIST altivec_h arpa_inet_h + bswap byteswap_h closesocket cmov @@ -732,6 +740,7 @@ HAVE_LIST=" getrusage imlib2 inet_aton + inline_asm libdc1394_1 libdc1394_2 llrint @@ -742,7 +751,7 @@ HAVE_LIST=" malloc_h memalign mkstemp - mlib + pld ppc64 round roundf @@ -751,6 +760,8 @@ HAVE_LIST=" socklen_t soundcard_h poll_h + sys_mman_h + sys_resource_h sys_select_h sys_soundcard_h termios_h @@ -762,12 +773,31 @@ CMDLINE_SELECT=" $ARCH_EXT_LIST $CONFIG_LIST $THREADS_LIST + cross_compile debug extra_warnings + logging optimizations shared static + stripping " +CMDLINE_SET=' + arch + bindir + build_suffix + cc + cpu + cross_prefix + incdir + libdir + logfile + mandir + prefix + shlibdir + source_path + target_os +' # code dependency declarations @@ -775,9 +805,11 @@ CMDLINE_SELECT=" altivec_deps="powerpc" armv5te_deps="armv4l" armv6_deps="armv4l" +armvfp_deps="armv4l" iwmmxt_deps="armv4l" mmi_deps="mips" mmx_deps="x86" +mmx2_deps="x86 mmx" ssse3_deps="x86" vis_deps="sparc" @@ -786,22 +818,9 @@ ac3_decoder_deps="gpl" dxa_decoder_deps="zlib" flashsv_decoder_deps="zlib" flashsv_encoder_deps="zlib" -flv_decoder_deps="h263_decoder" -h263_decoder_deps="h263_parser mpeg4video_parser" -h263i_decoder_deps="h263_decoder" -h264_decoder_deps="h264_parser" mpeg_xvmc_decoder_deps="xvmc" -mpeg4_decoder_deps="h263_decoder" -msmpeg4v1_decoder_deps="h263_decoder" -msmpeg4v2_decoder_deps="h263_decoder" -msmpeg4v3_decoder_deps="h263_decoder" png_decoder_deps="zlib" png_encoder_deps="zlib" -svq3_decoder_deps="h264_parser" -vc1_decoder_deps="h263_decoder" -wmv1_decoder_deps="h263_decoder" -wmv2_decoder_deps="h263_decoder" -wmv3_decoder_deps="h263_decoder" zmbv_decoder_deps="zlib" zmbv_encoder_deps="zlib" @@ -812,6 +831,8 @@ libamr_nb_decoder_deps="libamr_nb" libamr_nb_encoder_deps="libamr_nb" libamr_wb_decoder_deps="libamr_wb" libamr_wb_encoder_deps="libamr_wb" +libdirac_decoder_deps="libdirac" +libdirac_encoder_deps="libdirac" libfaac_encoder_deps="libfaac" libfaad_decoder_deps="libfaad" libfaadbin_decoder_extralibs='$ldl' @@ -820,6 +841,8 @@ libgsm_encoder_deps="libgsm" libgsm_ms_decoder_deps="libgsm" libgsm_ms_encoder_deps="libgsm" libmp3lame_encoder_deps="libmp3lame" +libschroedinger_decoder_deps="libschroedinger" +libschroedinger_encoder_deps="libschroedinger" libtheora_encoder_deps="libtheora" libvorbis_encoder_deps="libvorbis" libx264_encoder_deps="libx264" @@ -834,6 +857,7 @@ audio_beos_muxer_deps="audio_beos" audio_beos_muxer_extralibs="-lmedia -lbe" avisynth_demuxer_deps="avisynth" bktr_demuxer_deps_any="dev_bktr_ioctl_bt848_h machine_ioctl_bt848_h dev_video_bktr_ioctl_bt848_h dev_ic_bt8xx_h" +dirac_demuxer_deps="dirac_parser" dv1394_demuxer_deps="dv1394 dv_demuxer" libdc1394_demuxer_deps="libdc1394" libnut_demuxer_deps="libnut" @@ -845,8 +869,10 @@ redir_demuxer_deps="network" rtp_muxer_deps="network rtp_protocol" rtsp_demuxer_deps="sdp_demuxer" sdp_demuxer_deps="rtp_protocol mpegts_demuxer" -v4l2_demuxer_deps="linux_videodev2_h" v4l_demuxer_deps="linux_videodev_h" +v4l2_demuxer_deps="linux_videodev2_h" +vfwcap_demuxer_deps="capCreateCaptureWindow" +vfwcap_demuxer_extralibs="-lvfw32" x11_grab_device_demuxer_deps="x11grab XShmCreateImage" x11_grab_device_demuxer_extralibs="-lX11 -lXext" @@ -857,7 +883,7 @@ tcp_protocol_deps="network" udp_protocol_deps="network" # filters -vsrc_movie_deps="avfilter_lavf" +movie_filter_deps="avfilter_lavf" # programs ffplay_deps="sdl" @@ -866,28 +892,12 @@ ffserver_extralibs='$ldl' vhook_extralibs='$ldl' -# set temporary file name -if test ! -z "$TMPDIR" ; then - TMPDIR1="${TMPDIR}" -elif test ! -z "$TEMPDIR" ; then - TMPDIR1="${TEMPDIR}" -else - TMPDIR1="/tmp" -fi - -TMPC="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.c" -TMPO="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.o" -TMPE="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}" -TMPS="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.S" -TMPH="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.h" - # default parameters -enable logging logfile="config.err" # installation paths -PREFIX="/usr/local" +prefix="/usr/local" libdir='$(PREFIX)/lib' shlibdir="$libdir" incdir='$(PREFIX)/include' @@ -897,8 +907,8 @@ bindir='$(PREFIX)/bin' # toolchain cc="gcc" ar="ar" +nm="nm" ranlib="ranlib" -make="make" strip="strip" asmalign_pot="unknown" ln_s="ln -sf" @@ -908,27 +918,28 @@ arch=`uname -m` cpu="generic" # OS -targetos=$(tolower $(uname -s)) +target_os=$(tolower $(uname -s)) # libraries +enable bzlib enable zlib # configurable options enable debug -enable dostrip enable ffmpeg enable ffplay enable ffserver enable ipv6 -enable static enable mpegaudio_hp enable network enable optimizations enable protocols +enable static +enable stripping vhook="default" # build settings -SHFLAGS='-shared -Wl,-soname,$@' +SHFLAGS='-shared -Wl,-soname,$$(@F)' VHOOKSHFLAGS='$(SHFLAGS)' LDLATEFLAGS='-Wl,-rpath-link,\$(BUILD_ROOT)/libavcodec -Wl,-rpath-link,\$(BUILD_ROOT)/libavformat -Wl,-rpath-link,\$(BUILD_ROOT)/libavutil' FFSERVERLDFLAGS=-Wl,-E @@ -943,6 +954,9 @@ SLIBNAME_WITH_VERSION='$(SLIBNAME).$(LIBVERSION)' SLIBNAME_WITH_MAJOR='$(SLIBNAME).$(LIBMAJOR)' LIB_INSTALL_EXTRA_CMD='$(RANLIB) "$(LIBDIR)/$(LIBNAME)"' +# gcc stupidly only outputs the basename of targets with -MM +DEPEND_CMD='$(CC) $(CFLAGS) -MM -MG $< | sed -e "/^\#.*/d" -e "1s,^,$(@D)/,"' + # find source path source_path="`dirname \"$0\"`" enable source_path_used @@ -961,7 +975,7 @@ find_things(){ thing=$1 pattern=$2 file=$source_path/$3 - sed -n "s/^[^#]*$pattern.*(.*, *\\(.*\\)).*/\\1_$thing/p" "$file" + sed -n "s/^[^#]*$pattern.*([^,]*, *\([^,]*\)\(,.*\)*).*/\1_$thing/p" "$file" } ENCODER_LIST=$(find_things encoder ENC libavcodec/allcodecs.c) @@ -973,9 +987,7 @@ DEMUXER_LIST=$(find_things demuxer DEMUX libavformat/allformats.c) OUTDEV_LIST=$(find_things muxer _MUX libavdevice/alldevices.c) INDEV_LIST=$(find_things demuxer DEMUX libavdevice/alldevices.c) PROTOCOL_LIST=$(find_things protocol PROTOCOL libavformat/allformats.c) -VIDEO_FILTER_LIST=$(find_things vf_ VF_ libavfilter/allfilters.c) -SRC_FILTER_LIST=$(find_things vsrc_ VSRC_ libavfilter/allfilters.c) -FILTER_LIST="$SRC_FILTER_LIST $VIDEO_FILTER_LIST" +FILTER_LIST=$(find_things filter FILTER libavfilter/allfilters.c) enable $ARCH_EXT_LIST \ $DECODER_LIST \ @@ -1005,78 +1017,32 @@ show_list() { for opt do optval="${opt#*=}" case "$opt" in - --log) - ;; - --log=*) logging="$optval" - ;; - --prefix=*) PREFIX="$optval" - ;; - --libdir=*) libdir="$optval" - ;; - --shlibdir=*) shlibdir="$optval" - ;; - --incdir=*) incdir="$optval" - ;; - --mandir=*) mandir="$optval" - ;; - --source-path=*) source_path="$optval" - ;; - --cross-prefix=*) cross_prefix="$optval" - ;; - --cross-compile) enable cross_compile - ;; - --target-os=*) targetos="$optval" - ;; - --cc=*) cc="$optval" - ;; - --make=*) make="$optval" - ;; --extra-cflags=*) add_cflags "$optval" ;; --extra-ldflags=*) add_ldflags "$optval" ;; --extra-libs=*) add_extralibs "$optval" ;; - --build-suffix=*) BUILDSUF="$optval" - ;; - --arch=*) arch="$optval" - ;; - --cpu=*) cpu="$optval" - ;; - --enable-sunmlib) enable mlib - ;; - --disable-strip) disable dostrip - ;; - --disable-encoders) disable $ENCODER_LIST - ;; - --disable-decoders) disable $DECODER_LIST - ;; - --disable-muxers) disable $MUXER_LIST - ;; - --disable-filters) disable $FILTER_LIST - ;; - --disable-demuxers) disable $DEMUXER_LIST - ;; - --disable-parsers) disable $PARSER_LIST - ;; - --disable-bsfs) disable $BSF_LIST - ;; - --disable-protocols) disable $PROTOCOL_LIST - ;; --disable-devices) disable $INDEV_LIST $OUTDEV_LIST ;; + --enable-debug=*) debuglevel="$optval" + ;; --enable-*=*|--disable-*=*) eval `echo "$opt" | sed 's/=/-/;s/--/action=/;s/-/ thing=/;s/-/ name=/'` case "$thing" in - encoder|decoder|muxer|demuxer|parser|bsf|protocol) $action ${optval}_${thing} ;; - filter) $action ${optval} ;; + encoder|decoder|muxer|demuxer|parser|bsf|protocol|filter) $action ${optval}_${thing} ;; *) die_unknown "$opt" ;; esac ;; --enable-?*|--disable-?*) eval `echo "$opt" | sed 's/--/action=/;s/-/ option=/;s/-/_/g'` - echo "$CMDLINE_SELECT" | grep -q "^ *$option\$" || die_unknown $opt - $action $option + if is_in $option $COMPONENT_LIST; then + eval $action \$$(toupper ${option%s})_LIST + elif is_in $option $CMDLINE_SELECT; then + $action $option + else + die_unknown $opt + fi ;; --list-*) NAME="${opt#--list-}" @@ -1087,11 +1053,42 @@ for opt do --help|-h) show_help ;; *) - die_unknown $opt + optname="${opt%=*}" + optname="${optname#--}" + optname=$(echo "$optname" | sed 's/-/_/g') + is_in $optname $CMDLINE_SET || die_unknown $opt + eval $optname='$optval' ;; esac done +disabled logging && logfile=/dev/null + +echo "# $0 $@" > $logfile +set >> $logfile + +cc="${cross_prefix}${cc}" +ar="${cross_prefix}${ar}" +nm="${cross_prefix}${nm}" +ranlib="${cross_prefix}${ranlib}" +strip="${cross_prefix}${strip}" + +# set temporary file name +if test ! -z "$TMPDIR" ; then + TMPDIR1="${TMPDIR}" +elif test ! -z "$TEMPDIR" ; then + TMPDIR1="${TEMPDIR}" +else + TMPDIR1="/tmp" +fi + +TMPC="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.c" +TMPE="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}${EXESUF}" +TMPH="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.h" +TMPO="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.o" +TMPS="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.S" +TMPSH="${TMPDIR1}/ffmpeg-conf-${RANDOM}-$$-${RANDOM}.sh" + case "$arch" in i386|i486|i586|i686|i86pc|BePC) arch="x86_32" @@ -1100,13 +1097,9 @@ case "$arch" in x86_64|amd64) arch="x86_32" enable fast_unaligned - canon_arch="`$cc -dumpmachine | sed -e 's,\([^-]*\)-.*,\1,'`" - if [ x"$canon_arch" = x"x86_64" -o x"$canon_arch" = x"amd64" ]; then - if [ -z "`echo $CFLAGS | grep -- -m32`" ]; then - arch="x86_64" - enable fast_64bit - fi - fi + check_cc </dev/null); then + if echo $BEINCLUDES | grep -q 'headers/be/bone'; then network_extralibs="-lbind -lsocket" else enable beos_netserver @@ -1195,7 +1188,7 @@ case $targetos in fi ;; sunos) FFSERVERLDFLAGS="" - SHFLAGS='-shared -Wl,-h,$@' + SHFLAGS='-shared -Wl,-h,$$(@F)' network_extralibs="-lsocket -lnsl" ;; netbsd) @@ -1221,8 +1214,8 @@ case $targetos in ;; darwin) disable need_memalign - SHFLAGS='-dynamiclib -Wl,-single_module -Wl,-install_name,$(SHLIBDIR)/$(SLIBNAME),-current_version,$(SPPVERSION),-compatibility_version,$(SPPVERSION) -Wl,-read_only_relocs,suppress' - VHOOKSHFLAGS='-dynamiclib -Wl,-single_module -flat_namespace -undefined suppress -Wl,-install_name,$(SHLIBDIR)/vhook/$@' + SHFLAGS='-dynamiclib -Wl,-single_module -Wl,-install_name,$(SHLIBDIR)/$(SLIBNAME),-current_version,$(LIBVERSION),-compatibility_version,$(LIBMAJOR) -Wl,-read_only_relocs,suppress' + VHOOKSHFLAGS='-dynamiclib -Wl,-single_module -flat_namespace -undefined suppress -Wl,-install_name,$(SHLIBDIR)/vhook/$$(@F)' strip="strip -x" FFLDFLAGS="-Wl,-dynamic,-search_paths_first" SLIBSUF=".dylib" @@ -1231,11 +1224,16 @@ case $targetos in FFSERVERLDFLAGS=-Wl,-bind_at_load ;; mingw32*) - targetos=mingw32 + target_os=mingw32 + LIBTARGET=i386 + if test $arch = x86_64; then + disable need_memalign + LIBTARGET=x64 + fi shlibdir="$bindir" VHOOKSHFLAGS='-shared -L$(BUILD_ROOT)/libavformat -L$(BUILD_ROOT)/libavcodec -L$(BUILD_ROOT)/libavutil' VHOOKLIBS='-lavformat$(BUILDSUF) -lavcodec$(BUILDSUF) -lavutil$(BUILDSUF) $(EXTRALIBS)' - if enabled swscaler; then + if enabled swscale; then VHOOKSHFLAGS="$VHOOKSHFLAGS -L\$(BUILD_ROOT)/libswscale" VHOOKLIBS="$VHOOKLIBS -lswscale\$(BUILDSUF)" fi @@ -1245,17 +1243,18 @@ case $targetos in EXESUF=".exe" SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME)-$(LIBVERSION)$(SLIBSUF)' SLIBNAME_WITH_MAJOR='$(SLIBPREF)$(FULLNAME)-$(LIBMAJOR)$(SLIBSUF)' - SLIB_EXTRA_CMD='-lib /machine:i386 /def:$(@:$(SLIBSUF)=.def)' - SLIB_INSTALL_EXTRA_CMD='-install -m 644 $(SLIBNAME_WITH_MAJOR:$(SLIBSUF)=.lib) "$(SHLIBDIR)/$(SLIBNAME:$(SLIBSUF)=.lib)"' + SLIB_EXTRA_CMD='-lib /machine:$(LIBTARGET) /def:$$(@:$(SLIBSUF)=.def) /out:$(SUBDIR)$(SLIBNAME_WITH_MAJOR:$(SLIBSUF)=.lib)' + SLIB_INSTALL_EXTRA_CMD='-install -m 644 $(SUBDIR)$(SLIBNAME_WITH_MAJOR:$(SLIBSUF)=.lib) "$(SHLIBDIR)/$(SLIBNAME:$(SLIBSUF)=.lib)"; \ + install -m 644 $(SUBDIR)$(SLIBNAME_WITH_MAJOR:$(SLIBSUF)=.lib) "$(SHLIBDIR)/$(SLIBNAME_WITH_MAJOR:$(SLIBSUF)=.lib)"' SLIB_UNINSTALL_EXTRA_CMD='rm -f "$(SHLIBDIR)/$(SLIBNAME:$(SLIBSUF)=.lib)"' - SHFLAGS='-shared -Wl,--output-def,$(@:$(SLIBSUF)=.def) -Wl,--enable-runtime-pseudo-reloc -Wl,--enable-auto-image-base' + SHFLAGS='-shared -Wl,--output-def,$$(@:$(SLIBSUF)=.def) -Wl,--enable-runtime-pseudo-reloc -Wl,--enable-auto-image-base' ;; cygwin*) - targetos=cygwin + target_os=cygwin shlibdir="$bindir" VHOOKSHFLAGS='-shared -L$(BUILD_ROOT)/libavformat -L$(BUILD_ROOT)/libavcodec -L$(BUILD_ROOT)/libavutil' VHOOKLIBS='-lavformat$(BUILDSUF) -lavcodec$(BUILDSUF) -lavutil$(BUILDSUF) $(EXTRALIBS)' - if enabled swscaler; then + if enabled swscale; then VHOOKSHFLAGS="$VHOOKSHFLAGS -L\$(BUILD_ROOT)/libswscale" VHOOKLIBS="$VHOOKLIBS -lswscale\$(BUILDSUF)" fi @@ -1267,7 +1266,6 @@ case $targetos in SHFLAGS='-shared -Wl,--enable-auto-image-base' ;; *-dos|freedos|opendos) - enable memalign_hack disable ffplay ffserver vhook disable $INDEV_LIST $OUTDEV_LIST network_extralibs="-lsocket" @@ -1278,63 +1276,48 @@ case $targetos in enable dv1394 ;; irix*) - targetos=irix + target_os=irix ranlib="echo ignoring ranlib" ;; os/2*) - ar="emxomfar -p256" - ranlib="echo ignoring ranlib" strip="lxlite" ln_s="cp -f" - add_cflags "-Zomf" EXESUF=".exe" FFLDFLAGS="-Zomf -Zbin-files -Zargs-wild -Zmap" - SHFLAGS='$(NAME).def -Zdll -Zomf' + SHFLAGS='$(SUBDIR)$(NAME).def -Zdll -Zomf' FFSERVERLDFLAGS="" - LIBSUF="_s.lib" + LIBSUF="_s.a" SLIBPREF="" SLIBSUF=".dll" SLIBNAME_WITH_VERSION='$(SLIBPREF)$(NAME)-$(LIBVERSION)$(SLIBSUF)' SLIBNAME_WITH_MAJOR='$(SLIBPREF)$(shell echo $(NAME) | cut -c1-6)$(LIBMAJOR)$(SLIBSUF)' - SLIB_CREATE_DEF_CMD='echo LIBRARY $(SLIBNAME_WITH_MAJOR) INITINSTANCE TERMINSTANCE > $(NAME).def; \ - echo PROTMODE >> $(NAME).def; \ - echo CODE PRELOAD MOVEABLE DISCARDABLE >> $(NAME).def; \ - echo DATA PRELOAD MOVEABLE MULTIPLE NONSHARED >> $(NAME).def; \ - echo EXPORTS >> $(NAME).def; \ - emxexp -o $(OBJS) >> $(NAME).def' - SLIB_EXTRA_CMD='emximp -o $(LIBPREF)$(NAME)_dll.a $(NAME).def; \ - emximp -o $(LIBPREF)$(NAME)_dll.lib $(NAME).def;' - SLIB_INSTALL_EXTRA_CMD='install -m 644 $(LIBPREF)$(NAME)_dll.a $(LIBPREF)$(NAME)_dll.lib "$(LIBDIR)"' + SLIB_CREATE_DEF_CMD='echo LIBRARY $(SLIBNAME_WITH_MAJOR) INITINSTANCE TERMINSTANCE > $(SUBDIR)$(NAME).def; \ + echo PROTMODE >> $(SUBDIR)$(NAME).def; \ + echo CODE PRELOAD MOVEABLE DISCARDABLE >> $(SUBDIR)$(NAME).def; \ + echo DATA PRELOAD MOVEABLE MULTIPLE NONSHARED >> $(SUBDIR)$(NAME).def; \ + echo EXPORTS >> $(SUBDIR)$(NAME).def; \ + emxexp -o $(OBJS) >> $(SUBDIR)$(NAME).def' + SLIB_EXTRA_CMD='emximp -o $(SUBDIR)$(LIBPREF)$(NAME)_dll.a $(SUBDIR)$(NAME).def; \ + emximp -o $(SUBDIR)$(LIBPREF)$(NAME)_dll.lib $(SUBDIR)$(NAME).def;' + SLIB_INSTALL_EXTRA_CMD='install -m 644 $(SUBDIR)$(LIBPREF)$(NAME)_dll.a $(SUBDIR)$(LIBPREF)$(NAME)_dll.lib "$(LIBDIR)"' SLIB_UNINSTALL_EXTRA_CMD='rm -f "$(LIBDIR)"/$(LIBPREF)$(NAME)_dll.a "$(LIBDIR)"/$(LIBPREF)$(NAME)_dll.lib' - vhook="no" + disable vhook ;; interix) disable vhook ;; *) - targetos="${targetos}-UNKNOWN" + target_os="${target_os}-UNKNOWN" ;; esac add_extralibs $osextralibs -if ! disabled logging ; then - enabled logging || logfile="$logging" - echo "# $0 $@" >$logfile - set >>$logfile -else - logfile=/dev/null -fi - # Combine FFLDFLAGS and the LDFLAGS environment variable. LDFLAGS="$FFLDFLAGS $LDFLAGS" test -n "$cross_prefix" && enable cross_compile -cc="${cross_prefix}${cc}" -ar="${cross_prefix}${ar}" -ranlib="${cross_prefix}${ranlib}" -strip="${cross_prefix}${strip}" # we need to build at least one lib type if ! enabled_any static shared; then @@ -1371,13 +1354,13 @@ if ! enabled gpl; then shift enabled_any $@ && die "$name is under GPL and --enable-gpl is not specified." } - die_gpl_disabled "The Postprocessing code" pp + die_gpl_disabled "The Postprocessing code" postproc die_gpl_disabled "liba52" liba52 die_gpl_disabled "libx264" libx264 die_gpl_disabled "libxvidcore" libxvid die_gpl_disabled "FAAD2" libfaad2 die_gpl_disabled "The X11 grabber" x11grab - die_gpl_disabled "The software scaler" swscaler + die_gpl_disabled "The software scaler" swscale fi if ! enabled nonfree && enabled_any libamr_nb libamr_wb; then @@ -1389,14 +1372,14 @@ check_deps $ARCH_EXT_LIST test -z "$need_memalign" && need_memalign="$mmx" #Darwin CC versions -if test $targetos = darwin; then - if test -n "`$cc -v 2>&1 | grep xlc`"; then +if test $target_os = darwin; then + if $cc -v 2>&1 | grep -q xlc; then add_cflags "-qpdf2 -qlanglvl=extc99 -qmaxmem=-1 -qarch=auto -qtune=auto" else - add_cflags "-no-cpp-precomp -pipe" + add_cflags "-pipe" check_cflags "-force_cpusubtype_ALL" check_cflags "-Wno-sign-compare" - disabled shared && add_cflags -mdynamic-no-pic + enabled shared || check_cflags -mdynamic-no-pic fi fi @@ -1471,20 +1454,12 @@ if test $cpu != "generic"; then esac fi -gnu_make(){ - $1 --version 2>&1 | grep -q GNU -} - -if ! gnu_make $make; then - gnu_make gmake && make=gmake || die "GNU make not found." -fi - # make sure we can execute files in $TMPDIR -cat >$TMPE 2>>$logfile < $TMPSH 2>> $logfile <>$logfile 2>&1 -if ! $TMPE >>$logfile 2>&1; then +chmod +x $TMPSH >> $logfile 2>&1 +if ! $TMPSH >> $logfile 2>&1; then cat <&1 | grep version | grep Apple`" && - add_cflags "-faltivec" || - add_cflags "-maltivec -mabi=altivec" - - check_header altivec.h + check_cflags -maltivec -mabi=altivec && + check_header altivec.h || + check_cflags -faltivec # check if our compiler supports Motorola AltiVec C API enabled altivec_h && @@ -1566,8 +1548,11 @@ int main(void) { EOF fi +# We have to check if pld is a nop and disable it. +enabled armv4l && check_asm pld '"pld [r0]"' enabled armv5te && check_asm armv5te '"qadd r0, r0, r0"' enabled armv6 && check_asm armv6 '"sadd16 r0, r0, r0"' +enabled armvfp && check_asm armvfp '"fadds s0, s0, s0"' enabled iwmmxt && check_asm iwmmxt '"wunpckelub wr6, wr4"' enabled mmi && check_asm mmi '"lq $2, 0($2)"' enabled vis && check_asm vis '"pdist %f0, %f0, %f0"' -mcpu=ultrasparc @@ -1579,7 +1564,7 @@ enabled vis && add_cflags "-mcpu=ultrasparc -mtune=ultrasparc" check_cc </dev/null 2>&1; then +if "${SDL_CONFIG}" --version > /dev/null 2>&1; then sdl_cflags=`"${SDL_CONFIG}" --cflags` temp_cflags $sdl_cflags temp_extralibs `"${SDL_CONFIG}" --libs` @@ -1735,7 +1733,7 @@ EOF restore_flags fi -texi2html -version >/dev/null 2>&1 && enable texi2html || disable texi2html +texi2html -version > /dev/null 2>&1 && enable texi2html || disable texi2html check_type sys/socket.h socklen_t @@ -1773,6 +1771,8 @@ EOF check_header linux/videodev.h check_header linux/videodev2.h +check_func2 "windows.h vfw.h" capCreateCaptureWindow -lvfw32 + # check for ioctl_meteor.h, ioctl_bt848.h and alternatives { check_header dev/bktr/ioctl_meteor.h && check_header dev/bktr/ioctl_bt848.h; } || @@ -1792,7 +1792,7 @@ check_header X11/extensions/XShm.h && check_func XOpenDisplay -lX11 && check_func XShmCreateImage -lX11 -lXext -enabled debug && add_cflags -g +enabled debug && add_cflags -g"$debuglevel" # add some useful compiler flags if supported check_cflags -Wdeclaration-after-statement @@ -1816,7 +1816,7 @@ if enabled small; then check_cflags -Os # not all compilers support -Os optimizations="small" elif enabled optimizations; then - if test -n "`$cc -v 2>&1 | grep xlc`"; then + if $cc -v 2>&1 | grep -q xlc; then add_cflags "-O5" add_ldflags "-O5" else @@ -1824,6 +1824,23 @@ elif enabled optimizations; then fi fi check_cflags -fno-math-errno +check_cflags -fno-signed-zeros + +# add some flags for Intel C Compiler +if $cc --version | grep -q Intel; then + # Just warnings, no remarks + check_cflags -w1 + # -wd: Disable following warnings + # 144, 167, 556: -Wno-pointer-sign + # 10006: ignoring unknown option -fno-signed-zeros + # 10156: ignoring option '-W'; no argument required + check_cflags -wd144,167,556,10006,10156 + # 11030: Warning unknown option --as-needed + # 10156: ignoring option '-export'; no argument required + check_ldflags -wd10156,11030 + # Allow to compile with optimizations + check_ldflags -march=$cpu +fi # PIC flags for shared library objects where they are needed if enabled shared; then @@ -1874,17 +1891,17 @@ check_deps $CONFIG_LIST \ $PROTOCOL_LIST \ enabled libdc1394 && append pkg_requires "libraw1394" +enabled libdirac && append pkg_requires "dirac" enabled libtheora && append pkg_requires "theora" enabled libvorbis && append pkg_requires "vorbisenc" -echo "install prefix $PREFIX" +echo "install prefix $prefix" echo "source path $source_path" echo "C compiler $cc" -echo "make $make" echo ".align is power-of-two $asmalign_pot" echo "ARCH $arch ($cpu)" -if test "$BUILDSUF" != ""; then - echo "build suffix $BUILDSUF" +if test "$build_suffix" != ""; then + echo "build suffix $build_suffix" fi echo "big-endian ${bigendian-no}" if test $arch = "x86_32" -o $arch = "x86_64"; then @@ -1897,6 +1914,7 @@ fi if test $arch = "armv4l"; then echo "ARMv5TE enabled ${armv5te-no}" echo "ARMv6 enabled ${armv6-no}" + echo "ARM VFP enabled ${armvfp-no}" echo "IWMMXT enabled ${iwmmxt-no}" fi if test $arch = "mips"; then @@ -1908,14 +1926,14 @@ if test $arch = "powerpc"; then fi echo "gprof enabled ${gprof-no}" echo "debug symbols ${debug-no}" -echo "strip symbols ${dostrip-no}" +echo "strip symbols ${stripping-no}" echo "optimizations ${optimizations-no}" echo "static ${static-no}" echo "shared ${shared-no}" -echo "postprocessing support ${pp-no}" -echo "software scaler enabled ${swscaler-no}" +echo "postprocessing support ${postproc-no}" +echo "software scaler enabled ${swscale-no}" echo "new filter support ${avfilter-no}" -echo "filters using lavformat ${avfilter-lavf-no}" +echo "filters using lavformat ${avfilter_lavf-no}" echo "video hooking ${vhook-no}" if enabled vhook; then echo "Imlib2 support ${imlib2-no}" @@ -1937,35 +1955,39 @@ echo "liba52 dlopened ${liba52bin-no}" echo "libamr-nb support ${libamr_nb-no}" echo "libamr-wb support ${libamr_wb-no}" echo "libdc1394 support ${libdc1394-no}" +echo "libdirac enabled ${libdirac-no}" echo "libfaac enabled ${libfaac-no}" echo "libfaad enabled ${libfaad-no}" echo "libfaad dlopened ${libfaadbin-no}" echo "libgsm enabled ${libgsm-no}" echo "libmp3lame enabled ${libmp3lame-no}" echo "libnut enabled ${libnut-no}" +echo "libschroedinger enabled ${libschroedinger-no}" echo "libtheora enabled ${libtheora-no}" echo "libvorbis enabled ${libvorbis-no}" -echo "x264 enabled ${libx264-no}" -echo "XviD enabled ${libxvid-no}" +echo "libx264 enabled ${libx264-no}" +echo "libxvid enabled ${libxvid-no}" echo "zlib enabled ${zlib-no}" +echo "bzlib enabled ${bzlib-no}" +echo for type in decoder encoder parser demuxer muxer protocol filter bsf indev outdev; do echo "Enabled ${type}s:" - ucname="\$`toupper $type`_LIST" - list="`eval echo $ucname`" - partlist="" + eval list=\$$(toupper $type)_LIST for part in $list; do - enabled $part && partlist="$partlist $part" - done - partlist=`echo $partlist | sed s/_$type//g | tr ' ' '\n' | sort` - echo $partlist + enabled $part && echo ${part%_*} + done | sort | pr -3 -t + echo done -enabled nonfree && - echo "License: unredistributable" || - (enabled gpl && - echo "License: GPL" || - echo "License: LGPL") +license="LGPL" +if enabled nonfree; then + license="unredistributable" +elif enabled gpl; then + license="GPL" +fi + +echo "License: $license" echo "Creating config.mak and config.h..." @@ -1975,24 +1997,22 @@ echo "#ifndef FFMPEG_CONFIG_H" >> $TMPH echo "#define FFMPEG_CONFIG_H" >> $TMPH echo "#define FFMPEG_CONFIGURATION \"$FFMPEG_CONFIGURATION\"" >> $TMPH -echo "PREFIX=$PREFIX" >> config.mak -echo "prefix=\$(DESTDIR)\$(PREFIX)" >> config.mak +echo "PREFIX=$prefix" >> config.mak echo "LIBDIR=\$(DESTDIR)$libdir" >> config.mak echo "SHLIBDIR=\$(DESTDIR)$shlibdir" >> config.mak echo "INCDIR=\$(DESTDIR)$incdir" >> config.mak echo "BINDIR=\$(DESTDIR)$bindir" >> config.mak echo "MANDIR=\$(DESTDIR)$mandir" >> config.mak -echo "MAKE=$make" >> config.mak echo "CC=$cc" >> config.mak echo "AR=$ar" >> config.mak echo "RANLIB=$ranlib" >> config.mak echo "LN_S=$ln_s" >> config.mak -enabled dostrip && +enabled stripping && echo "STRIP=$strip" >> config.mak || echo "STRIP=echo ignoring strip" >> config.mak echo "OPTFLAGS=$CFLAGS" >> config.mak -echo "VHOOKCFLAGS=$VHOOKCFLAGS">>config.mak +echo "VHOOKCFLAGS=$VHOOKCFLAGS" >> config.mak echo "LDFLAGS=$LDFLAGS" >> config.mak echo "FFSERVERLDFLAGS=$FFSERVERLDFLAGS" >> config.mak echo "SHFLAGS=$SHFLAGS" >> config.mak @@ -2000,7 +2020,7 @@ echo "VHOOKSHFLAGS=$VHOOKSHFLAGS" >> config.mak echo "VHOOKLIBS=$VHOOKLIBS" >> config.mak echo "LIBOBJFLAGS=$LIBOBJFLAGS" >> config.mak echo "BUILD_STATIC=$static" >> config.mak -echo "BUILDSUF=$BUILDSUF" >> config.mak +echo "BUILDSUF=$build_suffix" >> config.mak echo "FULLNAME=$FULLNAME" >> config.mak echo "LIBPREF=$LIBPREF" >> config.mak echo "LIBSUF=$LIBSUF" >> config.mak @@ -2008,14 +2028,12 @@ echo "LIBNAME=$LIBNAME" >> config.mak echo "SLIBPREF=$SLIBPREF" >> config.mak echo "SLIBSUF=$SLIBSUF" >> config.mak echo "EXESUF=$EXESUF" >> config.mak +echo "DEPEND_CMD=$DEPEND_CMD" >> config.mak if enabled bigendian; then echo "WORDS_BIGENDIAN=yes" >> config.mak echo "#define WORDS_BIGENDIAN 1" >> $TMPH fi -if enabled mmx; then - echo "#define __CPU__ 586" >> $TMPH -fi if enabled sdl; then echo "SDL_LIBS=`"${SDL_CONFIG}" --libs`" >> config.mak @@ -2030,6 +2048,9 @@ get_version(){ file=$source_path/$2 eval $(grep "#define ${name}_VERSION_M" "$file" | awk '{ print $2"="$3 }') eval ${name}_VERSION=\$${name}_VERSION_MAJOR.\$${name}_VERSION_MINOR.\$${name}_VERSION_MICRO + lcname=$(tolower $name) + eval echo "${lcname}_VERSION=\$${name}_VERSION" >> config.mak + eval echo "${lcname}_VERSION_MAJOR=\$${name}_VERSION_MAJOR" >> config.mak } get_version LIBSWSCALE libswscale/swscale.h @@ -2038,25 +2059,12 @@ get_version LIBAVCODEC libavcodec/avcodec.h get_version LIBAVDEVICE libavdevice/avdevice.h get_version LIBAVFORMAT libavformat/avformat.h get_version LIBAVUTIL libavutil/avutil.h -lavfi_version=$(get_version LIBAVFILTER libavfilter/avfilter.h) +get_version LIBAVFILTER libavfilter/avfilter.h if enabled shared; then echo "BUILD_SHARED=yes" >> config.mak echo "PIC=-fPIC -DPIC" >> config.mak - echo "SPPMAJOR=$LIBPOSTPROC_VERSION_MAJOR" >> config.mak - echo "SPPVERSION=$LIBPOSTPROC_VERSION" >> config.mak - echo "LAVCMAJOR=$LIBAVCODEC_VERSION_MAJOR" >> config.mak - echo "LAVCVERSION=$LIBAVCODEC_VERSION" >> config.mak - echo "LAVDMAJOR=$LIBAVDEVICE_VERSION_MAJOR" >> config.mak - echo "LAVDVERSION=$LIBAVDEVICE_VERSION" >> config.mak - echo "LAVFMAJOR=$LIBAVFORMAT_VERSION_MAJOR" >> config.mak - echo "LAVFVERSION=$LIBAVFORMAT_VERSION" >> config.mak - echo "LAVUMAJOR=$LIBAVUTIL_VERSION_MAJOR" >> config.mak - echo "LAVUVERSION=$LIBAVUTIL_VERSION" >> config.mak - echo "LAVFIMAJOR=$LIBAVFILTER_VERSION_MAJOR" >> config.mak - echo "LAVFIVERSION=$LIBAVFILTER_VERSION" >> config.mak - echo "SWSMAJOR=$LIBSWSCALE_VERSION_MAJOR" >> config.mak - echo "SWSVERSION=$LIBSWSCALE_VERSION" >> config.mak + echo "LIBTARGET=${LIBTARGET}" >> config.mak echo "SLIBNAME=${SLIBNAME}" >> config.mak echo "SLIBNAME_WITH_VERSION=${SLIBNAME_WITH_VERSION}" >> config.mak echo "SLIBNAME_WITH_MAJOR=${SLIBNAME_WITH_MAJOR}" >> config.mak @@ -2097,15 +2105,16 @@ enabled asmalign_pot && printf '#define ASMALIGN(ZEROBITS) ".align " #ZEROBITS "\\n\\t"\n' >> $TMPH || printf '#define ASMALIGN(ZEROBITS) ".align 1<<" #ZEROBITS "\\n\\t"\n' >> $TMPH +echo "#define EXTERN_PREFIX \"${extern_prefix}\"" >> $TMPH echo "#endif /* FFMPEG_CONFIG_H */" >> $TMPH -# Do not overwrite config.h if unchanged to avoid superfluous rebuilds. +# Do not overwrite an unchanged config.h to avoid superfluous rebuilds. cmp -s $TMPH config.h && echo "config.h is unchanged" || mv -f $TMPH config.h -rm -f $TMPO $TMPC $TMPE $TMPS $TMPH +rm -f $TMPC $TMPE $TMPH $TMPO $TMPS $TMPSH # build tree in object directory if source path is different from current one if enabled source_path_used; then @@ -2133,6 +2142,7 @@ if enabled source_path_used; then FILES="\ Makefile \ common.mak \ + subdir.mak \ doc/texi2pod.pl \ libavcodec/Makefile \ libavdevice/Makefile \ @@ -2152,38 +2162,31 @@ fi # build pkg-config files -# FIXME: libdir and includedir are hardcoded and may differ from the real path. pkgconfig_generate(){ name=$1 +shortname=${name#lib} comment=$2 version=$3 libs=$4 requires=$5 -cat <$name.pc -prefix=$PREFIX +cat < $name.pc +prefix=$prefix exec_prefix=\${prefix} -libdir=\${exec_prefix}/lib -includedir=\${prefix}/include +libdir=$libdir +includedir=$incdir Name: $name Description: $comment Version: $version -Requires: $requires +Requires: $(disabled shared && echo $requires) +Requires.private: $(enabled shared && echo $requires) Conflicts: -Libs: -L\${libdir} $libs +Libs: -L\${libdir} -l${shortname} $(disabled shared && echo $libs) +Libs.private: $(enabled shared && echo $libs) Cflags: -I\${includedir} EOF -} - -pkgconfig_generate_uninstalled(){ -name=$1 -shortname=${name#lib} -comment=$2 -version=$3 -libs=$4 -requires=$5 -cat <$name-uninstalled.pc +cat < $name-uninstalled.pc prefix= exec_prefix= libdir=\${pcfiledir}/$name @@ -2199,33 +2202,17 @@ Cflags: -I\${includedir} EOF } -pkgconfig_generate libavutil "FFmpeg utility library" "$lavu_version" -lavutil "" -pkgconfig_generate_uninstalled libavutil "FFmpeg utility library" "$lavu_version" - -pkgconfig_generate libavcodec "FFmpeg codec library" "$lavc_version" "-lavcodec $extralibs" "$pkg_requires libavutil = $lavu_version" -pkgconfig_generate_uninstalled libavcodec "FFmpeg codec library" "$lavc_version" "$extralibs" "$pkg_requires libavutil = $lavu_version" - -pkgconfig_generate libavformat "FFmpeg container format library" "$lavf_version" "-lavformat $extralibs" "$pkg_requires libavcodec = $lavc_version" -pkgconfig_generate_uninstalled libavformat "FFmpeg container format library" "$lavf_version" "$extralibs" "$pkg_requires libavcodec = $lavc_version" - -pkgconfig_generate libavdevice "FFmpeg device handling library" "$lavd_version" "-lavdevice $extralibs" "$pkg_requires libavformat = $lavf_version" -pkgconfig_generate_uninstalled libavdevice "FFmpeg device handling library" "$lavd_version" "$extralibs" "$pkg_requires libavformat = $lavf_version" -if enabled pp; then - pkgconfig_generate libpostproc "FFmpeg post processing library" "$pp_version" -lpostproc "" - pkgconfig_generate_uninstalled libpostproc "FFmpeg post processing library" "$pp_version" -fi - -if enabled swscaler; then - pkgconfig_generate libswscale "FFmpeg image rescaling library" "$sws_version" -lswscale "libavutil = $lavu_version" - pkgconfig_generate_uninstalled libswscale "FFmpeg image rescaling library" "$sws_version" "" "libavutil = $lavu_version" +pkgconfig_generate libavutil "FFmpeg utility library" "$LIBAVUTIL_VERSION" +pkgconfig_generate libavcodec "FFmpeg codec library" "$LIBAVCODEC_VERSION" "$extralibs" "$pkg_requires libavutil = $LIBAVUTIL_VERSION" +pkgconfig_generate libavformat "FFmpeg container format library" "$LIBAVFORMAT_VERSION" "$extralibs" "$pkg_requires libavcodec = $LIBAVCODEC_VERSION" +pkgconfig_generate libavdevice "FFmpeg device handling library" "$LIBAVDEVICE_VERSION" "$extralibs" "$pkg_requires libavformat = $LIBAVFORMAT_VERSION" +enabled avfilter && \ + pkgconfig_generate libavfilter "FFmpeg video filtering library" "$LIBAVFILTER_VERSION" "$extralibs" "$pkg_requires libavutil = $LIBAVUTIL_VERSION" +enabled postproc && \ + pkgconfig_generate libpostproc "FFmpeg post processing library" "$LIBPOSTPROC_VERSION" +if enabled swscale; then + pkgconfig_generate libswscale "FFmpeg image rescaling library" "$LIBSWSCALE_VERSION" "" "libavutil = $LIBAVUTIL_VERSION" else - pkgconfig_generate libswscale "FFmpeg image rescaling library" "$sws_version" "" "$pkg_requires libavcodec = $lavc_version" - pkgconfig_generate_uninstalled libswscale "FFmpeg image rescaling library" "$sws_version" "" "$pkg_requires libavcodec = $lavc_version" + pkgconfig_generate libswscale "FFmpeg image rescaling library" "$LIBSWSCALE_VERSION" "" "$pkg_requires libavcodec = $LIBAVCODEC_VERSION" apply libswscale.pc sed s/^Libs:.*$/Libs:/ - apply libswscale-uninstalled.pc sed s/^Libs:.*$/Libs:/ -fi - -if enabled avfilter; then - pkgconfig_generate libavfilter "FFmpeg video filtering library" "$avfilter_version" "-lavfilter $extralibs" "$pkg_requires libavutil = $lavu=version" ffmpeg - pkgconfig_generate_uninstalled libavfilter "FFmpeg video filtering library" "$avfilter_version" "$extralibs" "$pkg_requires libavutil = $libavu_version" fi