diff options
author | Michał Górny <mgorny@gentoo.org> | 2014-06-11 20:54:53 +0000 |
---|---|---|
committer | Michał Górny <mgorny@gentoo.org> | 2014-06-11 20:54:53 +0000 |
commit | 07b63dc5eb9bd6efb330ca9602b3941343a13276 (patch) | |
tree | 1bfef0eedf9ff587bb611084c4071a652fb5bdaf /media-video | |
parent | Mask multilib media-video/ffmpeg. (diff) | |
download | gentoo-2-07b63dc5eb9bd6efb330ca9602b3941343a13276.tar.gz gentoo-2-07b63dc5eb9bd6efb330ca9602b3941343a13276.tar.bz2 gentoo-2-07b63dc5eb9bd6efb330ca9602b3941343a13276.zip |
Enable multilib support, bug #489816.
(Portage version: 2.2.10/cvs/Linux x86_64, signed Manifest commit with key EFB4464E!)
Diffstat (limited to 'media-video')
-rw-r--r-- | media-video/ffmpeg/ChangeLog | 8 | ||||
-rw-r--r-- | media-video/ffmpeg/ffmpeg-2.2.3-r1.ebuild | 366 | ||||
-rw-r--r-- | media-video/ffmpeg/ffmpeg-9999.ebuild | 274 |
3 files changed, 525 insertions, 123 deletions
diff --git a/media-video/ffmpeg/ChangeLog b/media-video/ffmpeg/ChangeLog index 7fb6fc078e01..4cdb1d4b6998 100644 --- a/media-video/ffmpeg/ChangeLog +++ b/media-video/ffmpeg/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for media-video/ffmpeg # Copyright 1999-2014 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-video/ffmpeg/ChangeLog,v 1.746 2014/06/08 13:01:45 ago Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/ffmpeg/ChangeLog,v 1.747 2014/06/11 20:54:53 mgorny Exp $ + +*ffmpeg-2.2.3-r1 (11 Jun 2014) + + 11 Jun 2014; Michał Górny <mgorny@gentoo.org> +ffmpeg-2.2.3-r1.ebuild, + ffmpeg-9999.ebuild: + Enable multilib support, bug #489816. 08 Jun 2014; Agostino Sarubbo <ago@gentoo.org> ffmpeg-1.2.6.ebuild: Stable for sparc, wrt bug #508372 diff --git a/media-video/ffmpeg/ffmpeg-2.2.3-r1.ebuild b/media-video/ffmpeg/ffmpeg-2.2.3-r1.ebuild new file mode 100644 index 000000000000..6211124cfcf2 --- /dev/null +++ b/media-video/ffmpeg/ffmpeg-2.2.3-r1.ebuild @@ -0,0 +1,366 @@ +# Copyright 1999-2014 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-video/ffmpeg/ffmpeg-2.2.3-r1.ebuild,v 1.1 2014/06/11 20:54:53 mgorny Exp $ + +EAPI="5" + +# Subslot: libavutil major.libavcodec major.libavformat major +# Since FFmpeg ships several libraries, subslot is kind of limited here. +# Most consumers will use those three libraries, if a "less used" library +# changes its soname, consumers will have to be rebuilt the old way +# (preserve-libs). +# If, for example, a package does not link to libavformat and only libavformat +# changes its ABI then this package will be rebuilt needlessly. Hence, such a +# package is free _not_ to := depend on FFmpeg but I would strongly encourage +# doing so since such a case is unlikely. +FFMPEG_SUBSLOT=52.55.55 + +SCM="" +if [ "${PV#9999}" != "${PV}" ] ; then + SCM="git-2" + EGIT_REPO_URI="git://source.ffmpeg.org/ffmpeg.git" +fi + +inherit eutils flag-o-matic multilib multilib-minimal toolchain-funcs ${SCM} + +DESCRIPTION="Complete solution to record, convert and stream audio and video. Includes libavcodec." +HOMEPAGE="http://ffmpeg.org/" +if [ "${PV#9999}" != "${PV}" ] ; then + SRC_URI="" +elif [ "${PV%_p*}" != "${PV}" ] ; then # Snapshot + SRC_URI="mirror://gentoo/${P}.tar.bz2" +else # Release + SRC_URI="http://ffmpeg.org/releases/${P/_/-}.tar.bz2" +fi +FFMPEG_REVISION="${PV#*_p}" + +LICENSE="GPL-2 amr? ( GPL-3 ) encode? ( aac? ( GPL-3 ) )" +SLOT="0/${FFMPEG_SUBSLOT}" +if [ "${PV#9999}" = "${PV}" ] ; then + KEYWORDS="~amd64 ~hppa ~mips ~x86-fbsd ~amd64-linux ~arm-linux ~x86-linux" +fi +IUSE=" + aac aacplus alsa amr amrenc bindist bluray +bzip2 cdio celt + cpudetection debug doc +encode examples faac fdk flite fontconfig frei0r + gme gnutls gsm +hardcoded-tables +iconv iec61883 ieee1394 jack jpeg2k + ladspa libass libcaca libsoxr libv4l modplug mp3 +network openal opengl + openssl opus oss pic pulseaudio quvi rtmp schroedinger sdl speex ssh + static-libs test theora threads truetype twolame v4l vaapi vdpau vorbis vpx + wavpack webp X x264 x265 xvid +zlib zvbi + " + +ARM_CPU_FEATURES="armv5te armv6 armv6t2 neon armvfp:vfp" +MIPS_CPU_FEATURES="mips32r2 mipsdspr1 mipsdspr2 mipsfpu" +PPC_CPU_FEATURES="altivec" +X86_CPU_FEATURES="3dnow:amd3dnow 3dnowext:amd3dnowext avx avx2 fma3 fma4 mmx mmxext sse sse2 sse3 ssse3 sse4 sse4_2:sse42" + +# String for CPU features in the useflag[:configure_option] form +# if :configure_option isn't set, it will use 'useflag' as configure option +CPU_FEATURES=" + ${ARM_CPU_FEATURES} + ${MIPS_CPU_FEATURES} + ${PPC_CPU_FEATURES} + ${X86_CPU_FEATURES} +" + +for i in ${CPU_FEATURES}; do + IUSE="${IUSE} ${i%:*}" +done + +FFTOOLS="aviocat cws2fws ffescape ffeval ffhash fourcc2pixfmt graph2dot ismindex pktdumper qt-faststart trasher" + +for i in ${FFTOOLS}; do + IUSE="${IUSE} +fftools_$i" +done + +RDEPEND=" + alsa? ( media-libs/alsa-lib[${MULTILIB_USEDEP}] ) + amr? ( media-libs/opencore-amr[${MULTILIB_USEDEP}] ) + bluray? ( media-libs/libbluray[${MULTILIB_USEDEP}] ) + bzip2? ( app-arch/bzip2[${MULTILIB_USEDEP}] ) + cdio? ( + || ( + dev-libs/libcdio-paranoia[${MULTILIB_USEDEP}] + <dev-libs/libcdio-0.90[-minimal,${MULTILIB_USEDEP}] + ) + ) + celt? ( >=media-libs/celt-0.11.1[${MULTILIB_USEDEP}] ) + encode? ( + aac? ( media-libs/vo-aacenc[${MULTILIB_USEDEP}] ) + aacplus? ( media-libs/libaacplus[${MULTILIB_USEDEP}] ) + amrenc? ( media-libs/vo-amrwbenc[${MULTILIB_USEDEP}] ) + faac? ( media-libs/faac[${MULTILIB_USEDEP}] ) + mp3? ( >=media-sound/lame-3.98.3[${MULTILIB_USEDEP}] ) + theora? ( + >=media-libs/libtheora-1.1.1[encode,${MULTILIB_USEDEP}] + media-libs/libogg[${MULTILIB_USEDEP}] + ) + twolame? ( media-sound/twolame[${MULTILIB_USEDEP}] ) + wavpack? ( media-sound/wavpack[${MULTILIB_USEDEP}] ) + webp? ( media-libs/libwebp[${MULTILIB_USEDEP}] ) + x264? ( >=media-libs/x264-0.0.20111017:=[${MULTILIB_USEDEP}] ) + x265? ( media-libs/x265:=[${MULTILIB_USEDEP}] ) + xvid? ( >=media-libs/xvid-1.1.0[${MULTILIB_USEDEP}] ) + ) + fdk? ( >=media-libs/fdk-aac-0.1.3[${MULTILIB_USEDEP}] ) + flite? ( app-accessibility/flite[${MULTILIB_USEDEP}] ) + fontconfig? ( media-libs/fontconfig[${MULTILIB_USEDEP}] ) + frei0r? ( media-plugins/frei0r-plugins ) + gme? ( media-libs/game-music-emu[${MULTILIB_USEDEP}] ) + gnutls? ( >=net-libs/gnutls-2.12.16[${MULTILIB_USEDEP}] ) + gsm? ( >=media-sound/gsm-1.0.12-r1[${MULTILIB_USEDEP}] ) + iconv? ( virtual/libiconv[${MULTILIB_USEDEP}] ) + iec61883? ( + media-libs/libiec61883[${MULTILIB_USEDEP}] + sys-libs/libraw1394[${MULTILIB_USEDEP}] + sys-libs/libavc1394[${MULTILIB_USEDEP}] + ) + ieee1394? ( + media-libs/libdc1394[${MULTILIB_USEDEP}] + sys-libs/libraw1394[${MULTILIB_USEDEP}] + ) + jack? ( media-sound/jack-audio-connection-kit[${MULTILIB_USEDEP}] ) + jpeg2k? ( >=media-libs/openjpeg-1.3-r2:0[${MULTILIB_USEDEP}] ) + libass? ( media-libs/libass[${MULTILIB_USEDEP}] ) + libcaca? ( media-libs/libcaca[${MULTILIB_USEDEP}] ) + libsoxr? ( media-libs/soxr[${MULTILIB_USEDEP}] ) + libv4l? ( media-libs/libv4l[${MULTILIB_USEDEP}] ) + modplug? ( media-libs/libmodplug[${MULTILIB_USEDEP}] ) + openal? ( >=media-libs/openal-1.1[${MULTILIB_USEDEP}] ) + opengl? ( virtual/opengl[${MULTILIB_USEDEP}] ) + openssl? ( dev-libs/openssl[${MULTILIB_USEDEP}] ) + opus? ( media-libs/opus[${MULTILIB_USEDEP}] ) + pulseaudio? ( media-sound/pulseaudio[${MULTILIB_USEDEP}] ) + quvi? ( media-libs/libquvi:0.4 ) + rtmp? ( >=media-video/rtmpdump-2.2f[${MULTILIB_USEDEP}] ) + sdl? ( >=media-libs/libsdl-1.2.13-r1[sound,video,${MULTILIB_USEDEP}] ) + schroedinger? ( media-libs/schroedinger[${MULTILIB_USEDEP}] ) + speex? ( >=media-libs/speex-1.2_beta3[${MULTILIB_USEDEP}] ) + ssh? ( net-libs/libssh[${MULTILIB_USEDEP}] ) + truetype? ( media-libs/freetype:2[${MULTILIB_USEDEP}] ) + vaapi? ( >=x11-libs/libva-0.32[${MULTILIB_USEDEP}] ) + vdpau? ( x11-libs/libvdpau[${MULTILIB_USEDEP}] ) + vorbis? ( + media-libs/libvorbis[${MULTILIB_USEDEP}] + media-libs/libogg[${MULTILIB_USEDEP}] + ) + vpx? ( >=media-libs/libvpx-0.9.6[${MULTILIB_USEDEP}] ) + X? ( + x11-libs/libX11[${MULTILIB_USEDEP}] + x11-libs/libXext[${MULTILIB_USEDEP}] + x11-libs/libXfixes[${MULTILIB_USEDEP}] + ) + zlib? ( sys-libs/zlib[${MULTILIB_USEDEP}] ) + zvbi? ( media-libs/zvbi[${MULTILIB_USEDEP}] ) + !media-video/qt-faststart + !media-libs/libpostproc +" + +DEPEND="${RDEPEND} + >=sys-devel/make-3.81 + doc? ( app-text/texi2html ) + fontconfig? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + gnutls? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + ieee1394? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + ladspa? ( media-libs/ladspa-sdk[${MULTILIB_USEDEP}] ) + libv4l? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + mmx? ( >=dev-lang/yasm-1.2 ) + rtmp? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + schroedinger? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + test? ( net-misc/wget ) + truetype? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + v4l? ( sys-kernel/linux-headers ) +" +# faac is license-incompatible with ffmpeg +REQUIRED_USE="bindist? ( encode? ( !faac !aacplus ) !openssl ) + libv4l? ( v4l ) + fftools_cws2fws? ( zlib ) + test? ( encode )" + +S=${WORKDIR}/${P/_/-} + +src_prepare() { + if [[ "${PV%_p*}" != "${PV}" ]] ; then # Snapshot + export revision=git-N-${FFMPEG_REVISION} + fi + epatch "${FILESDIR}/ladspadl.patch" + epatch_user +} + +multilib_src_configure() { + local myconf=( ${EXTRA_FFMPEG_CONF} ) + + # options to use as use_enable in the foo[:bar] form. + # This will feed configure with $(use_enable foo bar) + # or $(use_enable foo foo) if no :bar is set. + local ffuse=( + bzip2:bzlib cpudetection:runtime-cpudetect debug doc + gnutls hardcoded-tables iconv network openssl sdl:ffplay vaapi + vdpau zlib + ) + use openssl && myconf+=( --enable-nonfree ) + + # Encoders + if use encode + then + ffuse+=( aac:libvo-aacenc amrenc:libvo-amrwbenc mp3:libmp3lame ) + for i in aacplus faac theora twolame wavpack webp x264 x265 xvid; do + ffuse+=( ${i}:lib${i} ) + done + + # Licensing. + if use aac || use amrenc ; then + myconf+=( --enable-version3 ) + fi + if use aacplus || use faac ; then + myconf+=( --enable-nonfree ) + fi + else + myconf+=( --disable-encoders ) + fi + + # libavdevice options + ffuse+=( cdio:libcdio iec61883:libiec61883 ieee1394:libdc1394 libcaca openal opengl ) + + # Indevs + use v4l || myconf+=( --disable-indev=v4l2 --disable-outdev=v4l2 ) + for i in alsa oss jack ; do + use ${i} || myconf+=( --disable-indev=${i} ) + done + ffuse+=( libv4l:libv4l2 pulseaudio:libpulse X:x11grab ) + + # Outdevs + for i in alsa oss sdl ; do + use ${i} || myconf+=( --disable-outdev=${i} ) + done + + # libavfilter options + ffuse+=( flite:libflite frei0r fontconfig ladspa libass truetype:libfreetype ) + + # libswresample options + ffuse+=( libsoxr ) + + # Threads; we only support pthread for now but ffmpeg supports more + ffuse+=( threads:pthreads ) + + # Decoders + ffuse+=( amr:libopencore-amrwb amr:libopencore-amrnb fdk:libfdk-aac jpeg2k:libopenjpeg ) + use amr && myconf+=( --enable-version3 ) + for i in bluray celt gme gsm modplug opus quvi rtmp ssh schroedinger speex vorbis vpx zvbi; do + ffuse+=( ${i}:lib${i} ) + done + use fdk && myconf+=( --enable-nonfree ) + + for i in "${ffuse[@]}" ; do + myconf+=( $(use_enable ${i%:*} ${i#*:}) ) + done + + # (temporarily) disable non-multilib deps + if ! multilib_is_native_abi; then + for i in frei0r libquvi; do + myconf+=( --disable-${i} ) + done + fi + + # CPU features + for i in ${CPU_FEATURES}; do + use ${i%:*} || myconf+=( --disable-${i#*:} ) + done + if use pic ; then + myconf+=( --enable-pic ) + # disable asm code if PIC is required + # as the provided asm decidedly is not PIC for x86. + [[ ${ABI} == x86 ]] && myconf+=( --disable-asm ) + fi + [[ ${ABI} == x32 ]] && myconf+=( --disable-asm ) #427004 + + # Try to get cpu type based on CFLAGS. + # Bug #172723 + # We need to do this so that features of that CPU will be better used + # If they contain an unknown CPU it will not hurt since ffmpeg's configure + # will just ignore it. + for i in $(get-flag march) $(get-flag mcpu) $(get-flag mtune) ; do + [[ ${i} = native ]] && i="host" # bug #273421 + myconf+=( --cpu=${i} ) + break + done + + # Mandatory configuration + myconf=( + --enable-gpl + --enable-postproc + --enable-avfilter + --enable-avresample + --disable-stripping + "${myconf[@]}" + ) + + # cross compile support + if tc-is-cross-compiler ; then + myconf+=( --enable-cross-compile --arch=$(tc-arch-kernel) --cross-prefix=${CHOST}- ) + case ${CHOST} in + *freebsd*) + myconf+=( --target-os=freebsd ) + ;; + mingw32*) + myconf+=( --target-os=mingw32 ) + ;; + *linux*) + myconf+=( --target-os=linux ) + ;; + esac + fi + + "${S}/configure" \ + --prefix="${EPREFIX}/usr" \ + --libdir="${EPREFIX}/usr/$(get_libdir)" \ + --shlibdir="${EPREFIX}/usr/$(get_libdir)" \ + --mandir="${EPREFIX}/usr/share/man" \ + --enable-shared \ + --cc="$(tc-getCC)" \ + --cxx="$(tc-getCXX)" \ + --ar="$(tc-getAR)" \ + --optflags="${CFLAGS}" \ + --extra-cflags="${CFLAGS}" \ + --extra-cxxflags="${CXXFLAGS}" \ + $(use_enable static-libs static) \ + "${myconf[@]}" || die +} + +multilib_src_compile() { + emake V=1 + + if multilib_is_native_abi; then + for i in ${FFTOOLS} ; do + if use fftools_${i} ; then + emake V=1 tools/${i} + fi + done + fi +} + +multilib_src_install() { + emake V=1 DESTDIR="${D}" install install-man + + if multilib_is_native_abi; then + for i in ${FFTOOLS} ; do + if use fftools_${i} ; then + dobin tools/${i} + fi + done + fi +} + +multilib_src_install_all() { + dodoc Changelog README CREDITS doc/*.txt doc/APIchanges doc/RELEASE_NOTES + use doc && dohtml -r doc/* + if use examples ; then + dodoc -r doc/examples + docompress -x /usr/share/doc/${PF}/examples + fi +} + +multilib_src_test() { + LD_LIBRARY_PATH="${BUILD_DIR}/libpostproc:${BUILD_DIR}/libswscale:${BUILD_DIR}/libswresample:${BUILD_DIR}/libavcodec:${BUILD_DIR}/libavdevice:${BUILD_DIR}/libavfilter:${BUILD_DIR}/libavformat:${BUILD_DIR}/libavutil:${BUILD_DIR}/libavresample" \ + emake V=1 fate +} diff --git a/media-video/ffmpeg/ffmpeg-9999.ebuild b/media-video/ffmpeg/ffmpeg-9999.ebuild index 54d96a6eef2f..17d04a794743 100644 --- a/media-video/ffmpeg/ffmpeg-9999.ebuild +++ b/media-video/ffmpeg/ffmpeg-9999.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2014 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/media-video/ffmpeg/ffmpeg-9999.ebuild,v 1.154 2014/06/03 06:20:53 aballier Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/ffmpeg/ffmpeg-9999.ebuild,v 1.155 2014/06/11 20:54:53 mgorny Exp $ EAPI="5" @@ -21,7 +21,7 @@ if [ "${PV#9999}" != "${PV}" ] ; then EGIT_REPO_URI="git://source.ffmpeg.org/ffmpeg.git" fi -inherit eutils flag-o-matic multilib toolchain-funcs ${SCM} +inherit eutils flag-o-matic multilib multilib-minimal toolchain-funcs ${SCM} DESCRIPTION="Complete solution to record, convert and stream audio and video. Includes libavcodec." HOMEPAGE="http://ffmpeg.org/" @@ -74,62 +74,84 @@ for i in ${FFTOOLS}; do done RDEPEND=" - alsa? ( media-libs/alsa-lib ) - amr? ( media-libs/opencore-amr ) - bluray? ( media-libs/libbluray ) - bzip2? ( app-arch/bzip2 ) - cdio? ( || ( dev-libs/libcdio-paranoia <dev-libs/libcdio-0.90[-minimal] ) ) - celt? ( >=media-libs/celt-0.11.1 ) + alsa? ( media-libs/alsa-lib[${MULTILIB_USEDEP}] ) + amr? ( media-libs/opencore-amr[${MULTILIB_USEDEP}] ) + bluray? ( media-libs/libbluray[${MULTILIB_USEDEP}] ) + bzip2? ( app-arch/bzip2[${MULTILIB_USEDEP}] ) + cdio? ( + || ( + dev-libs/libcdio-paranoia[${MULTILIB_USEDEP}] + <dev-libs/libcdio-0.90[-minimal,${MULTILIB_USEDEP}] + ) + ) + celt? ( >=media-libs/celt-0.11.1[${MULTILIB_USEDEP}] ) encode? ( - aac? ( media-libs/vo-aacenc ) - aacplus? ( media-libs/libaacplus ) - amrenc? ( media-libs/vo-amrwbenc ) - faac? ( media-libs/faac ) - mp3? ( >=media-sound/lame-3.98.3 ) - theora? ( >=media-libs/libtheora-1.1.1[encode] media-libs/libogg ) - twolame? ( media-sound/twolame ) - wavpack? ( media-sound/wavpack ) - webp? ( media-libs/libwebp ) - x264? ( >=media-libs/x264-0.0.20111017:= ) - x265? ( >=media-libs/x265-0.9:= ) - xvid? ( >=media-libs/xvid-1.1.0 ) + aac? ( media-libs/vo-aacenc[${MULTILIB_USEDEP}] ) + aacplus? ( media-libs/libaacplus[${MULTILIB_USEDEP}] ) + amrenc? ( media-libs/vo-amrwbenc[${MULTILIB_USEDEP}] ) + faac? ( media-libs/faac[${MULTILIB_USEDEP}] ) + mp3? ( >=media-sound/lame-3.98.3[${MULTILIB_USEDEP}] ) + theora? ( + >=media-libs/libtheora-1.1.1[encode,${MULTILIB_USEDEP}] + media-libs/libogg[${MULTILIB_USEDEP}] + ) + twolame? ( media-sound/twolame[${MULTILIB_USEDEP}] ) + wavpack? ( media-sound/wavpack[${MULTILIB_USEDEP}] ) + webp? ( media-libs/libwebp[${MULTILIB_USEDEP}] ) + x264? ( >=media-libs/x264-0.0.20111017:=[${MULTILIB_USEDEP}] ) + x265? ( >=media-libs/x265-0.9:=[${MULTILIB_USEDEP}] ) + xvid? ( >=media-libs/xvid-1.1.0[${MULTILIB_USEDEP}] ) ) - fdk? ( >=media-libs/fdk-aac-0.1.3 ) - flite? ( app-accessibility/flite ) - fontconfig? ( media-libs/fontconfig ) + fdk? ( >=media-libs/fdk-aac-0.1.3[${MULTILIB_USEDEP}] ) + flite? ( app-accessibility/flite[${MULTILIB_USEDEP}] ) + fontconfig? ( media-libs/fontconfig[${MULTILIB_USEDEP}] ) frei0r? ( media-plugins/frei0r-plugins ) - gme? ( media-libs/game-music-emu ) - gnutls? ( >=net-libs/gnutls-2.12.16 ) - gsm? ( >=media-sound/gsm-1.0.12-r1 ) - iconv? ( virtual/libiconv ) - iec61883? ( media-libs/libiec61883 sys-libs/libraw1394 sys-libs/libavc1394 ) - ieee1394? ( media-libs/libdc1394 sys-libs/libraw1394 ) - jack? ( media-sound/jack-audio-connection-kit ) - jpeg2k? ( >=media-libs/openjpeg-1.3-r2:0 ) - libass? ( media-libs/libass ) - libcaca? ( media-libs/libcaca ) - libsoxr? ( media-libs/soxr ) - libv4l? ( media-libs/libv4l ) - modplug? ( media-libs/libmodplug ) - openal? ( >=media-libs/openal-1.1 ) - opengl? ( virtual/opengl ) - openssl? ( dev-libs/openssl ) - opus? ( media-libs/opus ) - pulseaudio? ( media-sound/pulseaudio ) + gme? ( media-libs/game-music-emu[${MULTILIB_USEDEP}] ) + gnutls? ( >=net-libs/gnutls-2.12.16[${MULTILIB_USEDEP}] ) + gsm? ( >=media-sound/gsm-1.0.12-r1[${MULTILIB_USEDEP}] ) + iconv? ( virtual/libiconv[${MULTILIB_USEDEP}] ) + iec61883? ( + media-libs/libiec61883[${MULTILIB_USEDEP}] + sys-libs/libraw1394[${MULTILIB_USEDEP}] + sys-libs/libavc1394[${MULTILIB_USEDEP}] + ) + ieee1394? ( + media-libs/libdc1394[${MULTILIB_USEDEP}] + sys-libs/libraw1394[${MULTILIB_USEDEP}] + ) + jack? ( media-sound/jack-audio-connection-kit[${MULTILIB_USEDEP}] ) + jpeg2k? ( >=media-libs/openjpeg-1.3-r2:0[${MULTILIB_USEDEP}] ) + libass? ( media-libs/libass[${MULTILIB_USEDEP}] ) + libcaca? ( media-libs/libcaca[${MULTILIB_USEDEP}] ) + libsoxr? ( media-libs/soxr[${MULTILIB_USEDEP}] ) + libv4l? ( media-libs/libv4l[${MULTILIB_USEDEP}] ) + modplug? ( media-libs/libmodplug[${MULTILIB_USEDEP}] ) + openal? ( >=media-libs/openal-1.1[${MULTILIB_USEDEP}] ) + opengl? ( virtual/opengl[${MULTILIB_USEDEP}] ) + openssl? ( dev-libs/openssl[${MULTILIB_USEDEP}] ) + opus? ( media-libs/opus[${MULTILIB_USEDEP}] ) + pulseaudio? ( media-sound/pulseaudio[${MULTILIB_USEDEP}] ) quvi? ( media-libs/libquvi:0.4 ) - rtmp? ( >=media-video/rtmpdump-2.2f ) - sdl? ( >=media-libs/libsdl-1.2.13-r1[sound,video] ) - schroedinger? ( media-libs/schroedinger ) - speex? ( >=media-libs/speex-1.2_beta3 ) - ssh? ( net-libs/libssh ) - truetype? ( media-libs/freetype:2 ) - vaapi? ( >=x11-libs/libva-0.32 ) - vdpau? ( x11-libs/libvdpau ) - vorbis? ( media-libs/libvorbis media-libs/libogg ) - vpx? ( >=media-libs/libvpx-0.9.6 ) - X? ( x11-libs/libX11 x11-libs/libXext x11-libs/libXfixes ) - zlib? ( sys-libs/zlib ) - zvbi? ( media-libs/zvbi ) + rtmp? ( >=media-video/rtmpdump-2.2f[${MULTILIB_USEDEP}] ) + sdl? ( >=media-libs/libsdl-1.2.13-r1[sound,video,${MULTILIB_USEDEP}] ) + schroedinger? ( media-libs/schroedinger[${MULTILIB_USEDEP}] ) + speex? ( >=media-libs/speex-1.2_beta3[${MULTILIB_USEDEP}] ) + ssh? ( net-libs/libssh[${MULTILIB_USEDEP}] ) + truetype? ( media-libs/freetype:2[${MULTILIB_USEDEP}] ) + vaapi? ( >=x11-libs/libva-0.32[${MULTILIB_USEDEP}] ) + vdpau? ( x11-libs/libvdpau[${MULTILIB_USEDEP}] ) + vorbis? ( + media-libs/libvorbis[${MULTILIB_USEDEP}] + media-libs/libogg[${MULTILIB_USEDEP}] + ) + vpx? ( >=media-libs/libvpx-0.9.6[${MULTILIB_USEDEP}] ) + X? ( + x11-libs/libX11[${MULTILIB_USEDEP}] + x11-libs/libXext[${MULTILIB_USEDEP}] + x11-libs/libXfixes[${MULTILIB_USEDEP}] + ) + zlib? ( sys-libs/zlib[${MULTILIB_USEDEP}] ) + zvbi? ( media-libs/zvbi[${MULTILIB_USEDEP}] ) !media-video/qt-faststart !media-libs/libpostproc " @@ -137,16 +159,16 @@ RDEPEND=" DEPEND="${RDEPEND} >=sys-devel/make-3.81 doc? ( app-text/texi2html ) - fontconfig? ( virtual/pkgconfig ) - gnutls? ( virtual/pkgconfig ) - ieee1394? ( virtual/pkgconfig ) - ladspa? ( media-libs/ladspa-sdk ) - libv4l? ( virtual/pkgconfig ) + fontconfig? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + gnutls? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + ieee1394? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + ladspa? ( media-libs/ladspa-sdk[${MULTILIB_USEDEP}] ) + libv4l? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) mmx? ( >=dev-lang/yasm-1.2 ) - rtmp? ( virtual/pkgconfig ) - schroedinger? ( virtual/pkgconfig ) + rtmp? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) + schroedinger? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) test? ( net-misc/wget ) - truetype? ( virtual/pkgconfig ) + truetype? ( virtual/pkgconfig[${MULTILIB_USEDEP}] ) v4l? ( sys-kernel/linux-headers ) " # faac is license-incompatible with ffmpeg @@ -156,95 +178,100 @@ REQUIRED_USE="bindist? ( encode? ( !faac !aacplus ) !openssl ) test? ( encode )" S=${WORKDIR}/${P/_/-} -BUILD_DIR=${S}_build src_prepare() { - if [ "${PV%_p*}" != "${PV}" ] ; then # Snapshot + if [[ "${PV%_p*}" != "${PV}" ]] ; then # Snapshot export revision=git-N-${FFMPEG_REVISION} fi epatch_user } -src_configure() { - mkdir -p "${BUILD_DIR}" - cd "${BUILD_DIR}" - - local myconf="${EXTRA_FFMPEG_CONF}" +multilib_src_configure() { + local myconf=( ${EXTRA_FFMPEG_CONF} ) # options to use as use_enable in the foo[:bar] form. # This will feed configure with $(use_enable foo bar) # or $(use_enable foo foo) if no :bar is set. - local ffuse="bzip2:bzlib cpudetection:runtime-cpudetect debug doc - gnutls hardcoded-tables iconv network openssl sdl:ffplay vaapi - vdpau X:xlib zlib" - use openssl && myconf="${myconf} --enable-nonfree" + local ffuse=( + bzip2:bzlib cpudetection:runtime-cpudetect debug doc + gnutls hardcoded-tables iconv network openssl sdl:ffplay vaapi + vdpau X:xlib zlib + ) + use openssl && myconf+=( --enable-nonfree ) # Encoders if use encode then - ffuse="${ffuse} aac:libvo-aacenc amrenc:libvo-amrwbenc mp3:libmp3lame" + ffuse+=( aac:libvo-aacenc amrenc:libvo-amrwbenc mp3:libmp3lame ) for i in aacplus faac theora twolame wavpack webp x264 x265 xvid; do - ffuse="${ffuse} ${i}:lib${i}" + ffuse+=( ${i}:lib${i} ) done # Licensing. if use aac || use amrenc ; then - myconf="${myconf} --enable-version3" + myconf+=( --enable-version3 ) fi if use aacplus || use faac ; then - myconf="${myconf} --enable-nonfree" + myconf+=( --enable-nonfree ) fi else - myconf="${myconf} --disable-encoders" + myconf+=( --disable-encoders ) fi # libavdevice options - ffuse="${ffuse} cdio:libcdio iec61883:libiec61883 ieee1394:libdc1394 libcaca openal opengl" + ffuse+=( cdio:libcdio iec61883:libiec61883 ieee1394:libdc1394 libcaca openal opengl ) # Indevs - use v4l || myconf="${myconf} --disable-indev=v4l2 --disable-outdev=v4l2" + use v4l || myconf+=( --disable-indev=v4l2 --disable-outdev=v4l2 ) for i in alsa oss jack ; do - use ${i} || myconf="${myconf} --disable-indev=${i}" + use ${i} || myconf+=( --disable-indev=${i} ) done - ffuse="${ffuse} libv4l:libv4l2 pulseaudio:libpulse X:x11grab" + ffuse+=( libv4l:libv4l2 pulseaudio:libpulse X:x11grab ) # Outdevs for i in alsa oss sdl ; do - use ${i} || myconf="${myconf} --disable-outdev=${i}" + use ${i} || myconf+=( --disable-outdev=${i} ) done # libavfilter options - ffuse="${ffuse} flite:libflite frei0r fontconfig ladspa libass truetype:libfreetype" + ffuse+=( flite:libflite frei0r fontconfig ladspa libass truetype:libfreetype ) # libswresample options - ffuse="${ffuse} libsoxr" + ffuse+=( libsoxr ) # Threads; we only support pthread for now but ffmpeg supports more - ffuse="${ffuse} threads:pthreads" + ffuse+=( threads:pthreads ) # Decoders - ffuse="${ffuse} amr:libopencore-amrwb amr:libopencore-amrnb fdk:libfdk-aac jpeg2k:libopenjpeg" - use amr && myconf="${myconf} --enable-version3" + ffuse+=( amr:libopencore-amrwb amr:libopencore-amrnb fdk:libfdk-aac jpeg2k:libopenjpeg ) + use amr && myconf+=( --enable-version3 ) for i in bluray celt gme gsm modplug opus quvi rtmp ssh schroedinger speex vorbis vpx zvbi; do - ffuse="${ffuse} ${i}:lib${i}" + ffuse+=( ${i}:lib${i} ) done - use fdk && myconf="${myconf} --enable-nonfree" + use fdk && myconf+=( --enable-nonfree ) - for i in ${ffuse} ; do - myconf="${myconf} $(use_enable ${i%:*} ${i#*:})" + for i in "${ffuse[@]}" ; do + myconf+=( $(use_enable ${i%:*} ${i#*:}) ) done + # (temporarily) disable non-multilib deps + if ! multilib_is_native_abi; then + for i in frei0r libquvi; do + myconf+=( --disable-${i} ) + done + fi + # CPU features for i in ${CPU_FEATURES}; do - use ${i%:*} || myconf="${myconf} --disable-${i#*:}" + use ${i%:*} || myconf+=( --disable-${i#*:} ) done if use pic ; then - myconf="${myconf} --enable-pic" + myconf+=( --enable-pic ) # disable asm code if PIC is required # as the provided asm decidedly is not PIC for x86. - use x86 && myconf="${myconf} --disable-asm" + [[ ${ABI} == x86 ]] && myconf+=( --disable-asm ) fi - [[ ${ABI} == "x32" ]] && myconf+=" --disable-asm" #427004 + [[ ${ABI} == x32 ]] && myconf+=( --disable-asm ) #427004 # Try to get cpu type based on CFLAGS. # Bug #172723 @@ -252,32 +279,33 @@ src_configure() { # If they contain an unknown CPU it will not hurt since ffmpeg's configure # will just ignore it. for i in $(get-flag march) $(get-flag mcpu) $(get-flag mtune) ; do - [ "${i}" = "native" ] && i="host" # bug #273421 - myconf="${myconf} --cpu=${i}" + [[ ${i} = native ]] && i="host" # bug #273421 + myconf+=( --cpu=${i} ) break done # Mandatory configuration - myconf=" + myconf=( --enable-gpl --enable-postproc --enable-avfilter --enable-avresample --disable-stripping - ${myconf}" + "${myconf[@]}" + ) # cross compile support if tc-is-cross-compiler ; then - myconf="${myconf} --enable-cross-compile --arch=$(tc-arch-kernel) --cross-prefix=${CHOST}-" + myconf+=( --enable-cross-compile --arch=$(tc-arch-kernel) --cross-prefix=${CHOST}- ) case ${CHOST} in *freebsd*) - myconf="${myconf} --target-os=freebsd" + myconf+=( --target-os=freebsd ) ;; mingw32*) - myconf="${myconf} --target-os=mingw32" + myconf+=( --target-os=mingw32 ) ;; *linux*) - myconf="${myconf} --target-os=linux" + myconf+=( --target-os=linux ) ;; esac fi @@ -295,31 +323,34 @@ src_configure() { --extra-cflags="${CFLAGS}" \ --extra-cxxflags="${CXXFLAGS}" \ $(use_enable static-libs static) \ - ${myconf} || die + "${myconf[@]}" || die } -src_compile() { - cd "${BUILD_DIR}" +multilib_src_compile() { emake V=1 - for i in ${FFTOOLS} ; do - if use fftools_$i ; then - emake V=1 tools/$i - fi - done + if multilib_is_native_abi; then + for i in ${FFTOOLS} ; do + if use fftools_${i} ; then + emake V=1 tools/${i} + fi + done + fi } -src_install() { - cd "${BUILD_DIR}" +multilib_src_install() { emake V=1 DESTDIR="${D}" install install-man - for i in ${FFTOOLS} ; do - if use fftools_$i ; then - dobin tools/$i - fi - done + if multilib_is_native_abi; then + for i in ${FFTOOLS} ; do + if use fftools_${i} ; then + dobin tools/${i} + fi + done + fi +} - cd "${S}" +multilib_src_install_all() { dodoc Changelog README.md CREDITS doc/*.txt doc/APIchanges doc/RELEASE_NOTES use doc && dohtml -r doc/* if use examples ; then @@ -328,8 +359,7 @@ src_install() { fi } -src_test() { - cd "${BUILD_DIR}" +multilib_src_test() { LD_LIBRARY_PATH="${BUILD_DIR}/libpostproc:${BUILD_DIR}/libswscale:${BUILD_DIR}/libswresample:${BUILD_DIR}/libavcodec:${BUILD_DIR}/libavdevice:${BUILD_DIR}/libavfilter:${BUILD_DIR}/libavformat:${BUILD_DIR}/libavutil:${BUILD_DIR}/libavresample" \ emake V=1 fate } |