<pre style='margin:0'>
Mohamed Akram (mohd-akram) pushed a commit to branch master
in repository macports-ports.
</pre>
<p><a href="https://github.com/macports/macports-ports/commit/e89ed58c1f555adb472c6d4e291c281efbac1eae">https://github.com/macports/macports-ports/commit/e89ed58c1f555adb472c6d4e291c281efbac1eae</a></p>
<pre style="white-space: pre; background: #F8F8F8">The following commit(s) were added to refs/heads/master by this push:
<span style='display:block; white-space:pre;color:#404040;'> new e89ed58c1f5 ffmpeg4: new port
</span>e89ed58c1f5 is described below
<span style='display:block; white-space:pre;color:#808000;'>commit e89ed58c1f555adb472c6d4e291c281efbac1eae
</span>Author: Mohamed Akram <makr@macports.org>
AuthorDate: Thu Dec 19 17:13:50 2024 +0400
<span style='display:block; white-space:pre;color:#404040;'> ffmpeg4: new port
</span>---
multimedia/ffmpeg4/Portfile | 553 +++++++++++++++++++++
.../ffmpeg4/files/patch-add-pixeldensity.diff | 91 ++++
...h-configure-no-error-on-missing-prototypes.diff | 10 +
.../patch-issue-9439-non-b-frame-encoding.diff | 18 +
.../files/patch-libavcodec-audiotoolboxenc.c.diff | 13 +
.../files/patch-libavcodec-videotoolboxenc.c.diff | 10 +
6 files changed, 695 insertions(+)
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/multimedia/ffmpeg4/Portfile b/multimedia/ffmpeg4/Portfile
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..bfd66bf4bc2
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/multimedia/ffmpeg4/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,553 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# -*- coding: utf-8; mode: tcl; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- vim:fenc=utf-8:ft=tcl:et:sw=4:ts=4:sts=4
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortSystem 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup xcodeversion 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup muniversal 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup compiler_blacklist_versions 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup active_variants 1.1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# For 'TARGET_OS_OSX', 'TARGET_CPU_ARM64' macros
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup legacysupport 1.1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://trac.macports.org/ticket/59246
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://trac.macports.org/ticket/59308
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup xcode_workaround 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+name ffmpeg4
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set my_name ffmpeg
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Please increase the revision of mpv whenever ffmpeg's version is updated.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+version 4.4.5
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+revision 0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+license LGPL-2.1+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+categories multimedia
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+maintainers {makr @mohd-akram} openmaintainer
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+description FFmpeg is a complete solution to play, record, convert and \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ stream audio and video.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+long_description FFmpeg is a complete solution to record, convert and \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ stream audio and video. It includes libavcodec, the \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ leading audio/video codec library. \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ The project is made of several components: \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ffmpeg is a command line tool to convert one video \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ file format to another. It also supports grabbing and \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ encoding in real time from a TV card. \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ffserver is an HTTP (RTSP is being developed) \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ multimedia streaming server for live broadcasts. Time \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ shifting of live broadcast is also supported. \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ffplay is a simple media player based on SDL and on \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ the ffmpeg libraries. \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ffprobe gathers information from multimedia streams and \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ prints it in human- and machine-readable fashion. \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ libavcodec is a library containing all the ffmpeg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ audio/video encoders and decoders. Most codecs were \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ developed from scratch to ensure best performance \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ and high code reusability. \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ libavformat is a library containing parsers and \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ generators for all common audio/video formats.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+homepage https://ffmpeg.org/
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+master_sites ${homepage}releases/
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+distname ${my_name}-${version}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+dist_subdir ${my_name}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+use_xz yes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+checksums rmd160 51d7e4cd1beec0c44c93f466732d11c2573fd77a \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ sha256 f9514e0d3515aee5a271283df71636e1d1ff7274b15853bcd84e144be416ab07 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ size 9575596
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+depends_build-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:cctools \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:gmake \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:bin/pkg-config:pkgconfig \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:texinfo
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:bzip2 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:dav1d \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:fontconfig \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:freetype \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:fribidi \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/gnutls.pc:gnutls \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/harfbuzz.pc:harfbuzz \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:lame \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/libass.pc:libass \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libbluray \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libiconv \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libmodplug \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libogg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libopus \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/librsvg-2.0.pc:librsvg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libtheora \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libvorbis \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/vpx.pc:libvpx \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:lzo2 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:openjpeg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:soxr \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/libspeex.dylib:speex \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:webp \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:xz \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:zimg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:zlib \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:zvbi
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles-append patch-libavcodec-audiotoolboxenc.c.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Fix an upstream bug that overrides the max_b_frames setting
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://trac.ffmpeg.org/ticket/9231
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Fixed via upstream commit: 55d9d6767967794edcdd6e1bbd8840fc6f4e9315
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles-append patch-libavcodec-videotoolboxenc.c.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Patch for upstream bug related to non-B-frame encoding
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://trac.ffmpeg.org/ticket/9439
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Fixed via upstream commit: b786bc7433dfe082441a57c1ba9ae9ea47904b78
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles-append patch-issue-9439-non-b-frame-encoding.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# add retina resolution capabilities via -movflags write_pixeldensity flag
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# this patch is by daniel kaiser who posted on the ffmpeg bugtracker:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://fftrac-bg.ffmpeg.org/ticket/7045
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# but he never formally submitted it to the FFMpeg mailing list, which i did
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://ffmpeg.org/pipermail/ffmpeg-devel/2024-July/331470.html
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# so the FFMpeg team does not seem to care to include this functionality
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+patchfiles-append patch-add-pixeldensity.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# enable auto configure of asm optimizations
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# requires Xcode 3.1 or better on Leopard
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+minimum_xcodeversions {9 3.1}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# requires a C11 compiler
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+compiler.c_standard 2011
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# clang-3.1 hits https://trac.macports.org/ticket/30137 (<rdar://problem/11542429>)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# clang-139 hits https://trac.macports.org/ticket/38141
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# warning: unknown warning option '-Werror=partial-availability'; did you mean '-Werror=availability'? [-Wunknown-warning-option]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# warning: unknown warning option '-Wno-bool-operation'; did you mean '-Wno-bool-conversion'? [-Wunknown-warning-option]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+compiler.blacklist-append {clang < 800}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# The old ffmpeg port was GPL-2+ as base and had a no_gpl variant, so this keeps us consistent
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Also, -gpl2 causes other ports to fail to build due to the missing libpostproc (#35473)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+default_variants-append +gpl2
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {[tbool configure.ccache]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ set ccache_path ${prefix}/bin/ccache
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.cc-prepend \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ${ccache_path}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.cxx-prepend \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ${ccache_path}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+configure.cflags-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ -DHAVE_LRINTF \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ -Wno-deprecated-declarations \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ${configure.cppflags}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set port_ver_major [lindex [split ${version} .] 0]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set port_alias ${my_name}${port_ver_major}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set port_prefix ${prefix}/libexec/${port_alias}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set port_sharedir ${port_prefix}/share
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set port_docdir ${port_sharedir}/doc
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+configure.pre_args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --cc="${configure.cc}" \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --prefix=${port_prefix} \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --mandir=${port_prefix}/share/man \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --progs-suffix=${port_ver_major}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-audiotoolbox \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-indev=jack \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libjack \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libopencore-amrnb \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libopencore-amrwb \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libxcb \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libxcb-shm \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libxcb-xfixes \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-opencl \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-outdev=xv \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-sdl2 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-securetransport \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-videotoolbox \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-avfilter \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-avresample \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-fontconfig \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-gnutls \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libass \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libbluray \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libdav1d \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libfreetype \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libfribidi \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libmodplug \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libmp3lame \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libopenjpeg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libopus \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-librsvg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libsoxr \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libspeex \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libtheora \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libvorbis \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libvpx \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libwebp \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libzimg \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libzvbi \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-lzma \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-pthreads \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-shared \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-swscale \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-zlib
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+post-extract {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # fix file perms; tarball contents deny group and world read
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ system "find ${worksrcpath} -type d -print0 | xargs -0 chmod a+rx"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ system "find ${worksrcpath} -type f -print0 | xargs -0 chmod a+r"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+platform darwin 8 {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ post-patch {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ reinplace "s:,-compatibility_version,$\(LIBMAJOR\)::" ${worksrcpath}/configure
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+platform darwin {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # disable asm on Tiger
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # libblueray doesn't build on Tiger so disable for now (#39442)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} < 9} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libbluray
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libbluray \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libbluray
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-asm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # as of 1.6.0 libvpx only supports darwin 10 or later
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} < 10} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/vpx.pc:libvpx
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libvpx \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libvpx
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # filters coreimage and coreimagesrc don't build on 10.6
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # and earlier due to use of bridged casts in Objective C (#51823)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} < 11} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-filter=coreimage \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-filter=coreimagesrc
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # AudioToolbox support requires CoreMedia Framework available on 10.7+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} > 10} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-audiotoolbox \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-audiotoolbox
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} > 9 && ${build_arch} ni [list ppc ppc64]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # libsdl2 requires minimum Xcode 10.7 SDK to build successfully
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # but builds on Snow Leopard x86. Exclude ppc until fixed.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-sdl2 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-sdl2
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libsdl2
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # VideoToolbox, a new hardware acceleration framework, is supported on 10.8+ and "here to stay".
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # It provides support for H265, H264, H263, MPEG1, MPEG2 and MPEG4.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} > 11} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-videotoolbox \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-videotoolbox
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # OpenCL support requires version 1.2 available 10.8+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} > 11} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-opencl \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-opencl
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # Apple GCC has problems with SIMD intrinsics and -Werror=no-missing-prototypes.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} < 11} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ patchfiles-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ patch-configure-no-error-on-missing-prototypes.diff
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # avfoundation is only available on 10.7+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # as of ffmpeg 3.4.1 build fails on 10.7 as well
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # libavdevice/avfoundation.m:207:14: error: expected method to read dictionary element not found on object of type 'NSDictionary *'
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} < 12} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-indev=avfoundation
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # av1 codecs, available on 10.5+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${os.major} >= 9} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libaom \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libsvtav1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:aom \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:svt-av1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # rav1e available on 10.6+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {(${os.major} < 10) || (${configure.build_arch} eq "ppc")} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {[variant_isset rav1e]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ error "Variant rav1e not supported for macOS 10.5 and earlier, or PPC"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # due to the new linker (which was introduced in Xcode 15: https://developer.apple.com/documentation/xcode-release-notes/xcode-15-release-notes),
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # this port requires '-ld_classic' to build successfully with the toolchains from Xcode 15 or Command Line Tools 15.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # TODO: This is a temporary solution, the classic linker will be removed in a future release by Apple.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if { ( [vercmp ${xcodeversion} 15 ] >= 0 ) || ( [vercmp ${xcodecltversion} 15 ] >= 0 ) } {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.ldflags-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ -Wl,-ld_classic
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# libavcodec/pcm-bluray.c:172:45: error: passing argument 2 of 'bytestream2_get_buffer' from incompatible pointer type [-Wincompatible-pointer-types]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# libavcodec/pcm-dvd.c:155:37: error: passing argument 2 of 'bytestream2_get_buffer' from incompatible pointer type [-Wincompatible-pointer-types]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {[string match *gcc* ${configure.compiler}]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.cflags-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ -Wno-error=incompatible-pointer-types
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+platform powerpc {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # absence of altivec is not automatically detected
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {[catch {sysctl hw.vectorunit} result] || $result == 0} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-altivec
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # as this machine is a G3, force a local build so we don't download a buildbot-built
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # version possibly built on a G4+ or cross-compiled from an Intel system
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ archive_sites
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # might be needed for any gcc build...
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #Undefined symbols:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # "___atomic_fetch_sub_8", referenced from:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # _fifo_thread_dispatch_message.part.4 in fifo.o
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.ldflags-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ -latomic
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# configure isn't autoconf and they do use a dep cache
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+configure.universal_args-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-dependency-tracking
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {${universal_possible} && [variant_isset universal]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ foreach arch ${configure.universal_archs} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ set merger_host($arch) ""
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ lappend merger_configure_args($arch) \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --arch=${arch}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ lappend merger_configure_env($arch) \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ "ASFLAGS=-arch ${arch}"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {[string match "*86*" ${configure.universal_archs}]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_build-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:nasm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ lappend merger_configure_args(i386) \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-x86asm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ lappend merger_configure_args(x86_64) \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-x86asm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+} else {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --arch=${configure.build_arch}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.env-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ASFLAGS=[get_canonical_archflags]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {${build_arch} eq "i386" || ${build_arch} eq "x86_64"} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_build-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:nasm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-x86asm
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+build.cmd ${prefix}/bin/gmake
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+build.env-append V=1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+test.run yes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+destroot.env-append V=1
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+post-destroot {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # Copy docs
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ file mkdir ${destroot}${port_docdir}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ file copy ${worksrcpath}/doc/APIchanges ${destroot}${port_docdir}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ foreach f [glob ${worksrcpath}/doc/*.txt] {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ file copy $f ${destroot}${port_docdir}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant x11 {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # enable x11grab_xcb input device
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # Re libXv see: https://trac.macports.org/ticket/58617
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:xorg-libxcb \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:xorg-libXext \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:xorg-libXfixes \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:xorg-libXv
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-xlib \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libxcb \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libxcb-shm \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libxcb-xfixes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# On PowerPC libsdl2 is a stub for libsdl2-powerpc, which is always built
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# with X11 backend. It is meaningless to require it as a variant there.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {${configure.build_arch} ni [list ppc ppc64]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if {[variant_isset x11]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ require_active_variants libsdl2 x11
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ } else {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ require_active_variants libsdl2 "" x11
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant libdc1394 description {Enable IIDC-1394 frame grabbing using libdc1394 (experimental)} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libdc1394
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libdc1394
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Allow use of librtmp instead of ffmpeg's internal rtmp implementation
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# May address interoperability issues with CRtmpServer and others
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://trac.macports.org/ticket/32219
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://groups.google.com/forum/#!topic/c-rtmp-server/ywQPjvciPgc
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://trac.ffmpeg.org/ticket/1700
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant librtmp description {Use librtmp (from rtmpdump) as rtmp[t][es]:// protocol handler} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-librtmp
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:rtmpdump
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant jack description {Enable jack library and indev support} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ # jack will autoconfigure if not disabled
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:jack
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-libjack \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libjack
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-replace \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-indev=jack \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-indev=jack
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant darwinssl description {Enable https support using Apple built-in TLS library instead of GNU TLS} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --disable-securetransport
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-gnutls
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-delete \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/gnutls.pc:gnutls
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant gpl2 description {Enable GPL code, license will be GPL-2+} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ license GPL-2+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-gpl \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libvidstab \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libx264 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libx265 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libxvid \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-postproc
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libvidstab \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:x264 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:x265 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:XviD
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant gpl3 requires gpl2 description {Enable GPL code, license will be GPL-3+} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ license GPL-3+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libaribb24 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libsmbclient \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-version3
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libaribb24 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ path:lib/pkgconfig/smbclient.pc:samba3
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# the build server uses the default variants, and we want distributable binaries
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# nonfree code is disabled by default but can be enabled using the +nonfree variant
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant nonfree description {enable nonfree code, libraries and binaries will not be redistributable} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ license Restrictive
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libfdk-aac \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-nonfree
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:libfdk-aac
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant rav1e description {Enable codec rav1e} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-librav1e
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:rav1e
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+variant flite description {Enable flite audio source} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ configure.args-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ --enable-libflite
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ depends_lib-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ port:flite
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {![variant_isset rav1e]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ notes-append "Support for rav1e now disabled by default; enable via +rav1e"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {[variant_isset nonfree]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+notes-append "
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+This build of ${name} includes nonfree code as follows:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ libfdk-aac
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+The following libraries and binaries may not be redistributed:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ ffmpeg libavcodec libavdevice libavfilter libavformat libavutil
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+To remove this restriction remove the variant +nonfree
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+} elseif {[variant_isset gpl3]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+notes-append "
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+This build of ${name} includes GPLed code and is therefore licensed under GPL v3 or later.\
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+The following modules are GPLed:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ libsambaclient libvidstab libx264 libx265 libxvid postproc
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+To include all nonfree, GPLed and LGPL code use variant +nonfree.\
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+To remove nonfree and GPLed code leaving only LGPL code remove the +gpl2 and +gpl3 variants.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+} elseif {[variant_isset gpl2]} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+notes-append "
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+This build of ${name} includes GPLed code and is therefore licensed under GPL v2 or later.\
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+The following modules are GPLed:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ libvidstab libx264 libx265 libxvid postproc
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+To include all nonfree, GPLed and LGPL code use variant +nonfree.\
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+To remove nonfree and GPLed code leaving only LGPL code remove the +gpl2 variant.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+} else {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+notes-append "
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+This build of ${name} includes no GPLed or nonfree code and is therefore licensed under LGPL v2.1 or later.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+livecheck.type regex
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+livecheck.url ${master_sites}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+livecheck.regex "${my_name}-(4(?:\\.\\d+)*)${extract.suffix}"
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/multimedia/ffmpeg4/files/patch-add-pixeldensity.diff b/multimedia/ffmpeg4/files/patch-add-pixeldensity.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..cba9c7c0395
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/multimedia/ffmpeg4/files/patch-add-pixeldensity.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,91 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git libavformat/movenc.c libavformat/movenc.c
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index a961390..c5eb12d 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- libavformat/movenc.c
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ libavformat/movenc.c
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -78,6 +78,7 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ { "delay_moov", "Delay writing the initial moov until the first fragment is cut, or until the first fragment flush", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_DELAY_MOOV}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ { "global_sidx", "Write a global sidx index at the start of the file", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_GLOBAL_SIDX}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ { "skip_sidx", "Skip writing of sidx atom", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_SKIP_SIDX}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ { "write_pixeldensity", "Write pixeldensity metdata for HiDPI videos in QT", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_PIXELDENSITY}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ { "write_colr", "Write colr atom even if the color info is unspecified (Experimental, may be renamed or changed, do not use from scripts)", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_WRITE_COLR}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ { "prefer_icc", "If writing colr atom prioritise usage of ICC profile if it exists in stream packet side data", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_PREFER_ICC}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ { "write_gama", "Write deprecated gama atom", 0, AV_OPT_TYPE_CONST, {.i64 = FF_MOV_FLAG_WRITE_GAMA}, INT_MIN, INT_MAX, AV_OPT_FLAG_ENCODING_PARAM, "movflags" },
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -3413,6 +3414,56 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ return size;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++static int mov_write_pixeldensity_meta_tag(AVIOContext *pb, MOVMuxContext *mov, MOVTrack *track, AVFormatContext *s)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++{
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ int size = 0;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ int64_t pos = avio_tell(pb);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0); /* meta atom size */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "meta");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ /* Metadata atom information as described in
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ * https://developer.apple.com/library/archive/documentation/QuickTime/QTFF/Metadata/Metadata.html#//apple_ref/doc/uid/TP40000939-CH1-SW9
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 33); /* hdlr atom size: size (4) + 'hdlr' (4) + version/flags (4) + predefined (4) + 'mdta' (4) +
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ reserved (3*4) + name (1) = 33 */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "hdlr");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0); /* version (1 Byte) and flags (3 Bytes), must be zero */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0); /* "predefined", must be zero */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "mdta");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0); /* Reseverved, uint32_t[3] */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_w8(pb, 0); /* Empty name (NULL-terminated) */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 56); /* keys atom size: size (4) + 'keys' (4) + version/flasgs (4) + entry_count (4) +
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ keys (32+8) = 56 */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "keys");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0); /* version (1 Byte) and flags (3 Bytes), must be zero */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 1); /* entry count */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 32 + 8); /* key size: size (4) + 'mdta' (4) + strlen(key) */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "mdta");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_write(pb, "com.apple.quicktime.pixeldensity", 32);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 48); /* ilst atom size: size (4) + 'ilst' (4) + value atom size (40) = 48 */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "ilst");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 40); /* value atom size: size (4) + key (4) + data atom (32) = 40 */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 1); /* metadata key index */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 32); /* data atom size: size (4) + 'data' (4) + data_type (4) + locale (4) + value (4 * 4) = 32 */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ ffio_wfourcc(pb, "data");
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0x1e); /* data type */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, 0); /* locale */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ /* actual data (value): consisting of 4 uint32_t: pixel width, pixel height, display width, display height */
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, track->par->width);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, track->par->height);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, track->par->width / 2);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ avio_wb32(pb, track->par->height / 2);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ size = update_size(pb, pos);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ return size;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ static int mov_write_trak_tag(AVFormatContext *s, AVIOContext *pb, MOVMuxContext *mov,
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ MOVTrack *track, AVStream *st)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -3460,6 +3511,9 @@ static int mov_write_trak_tag(AVFormatContext *s, AVIOContext *pb, MOVMuxContext
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ mov_write_tapt_tag(pb, track);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ if (mov->flags & FF_MOV_FLAG_PIXELDENSITY) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ mov_write_pixeldensity_meta_tag(pb, mov, track, st);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ mov_write_track_udta_tag(pb, mov, st);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ track->entry = entry_backup;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ track->chunkCount = chunk_backup;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+diff --git libavformat/movenc.h libavformat/movenc.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+index 68d6f23..ed7ea41 100644
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- libavformat/movenc.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ libavformat/movenc.h
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -265,6 +265,7 @@ typedef struct MOVMuxContext {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #define FF_MOV_FLAG_SKIP_SIDX (1 << 21)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #define FF_MOV_FLAG_CMAF (1 << 22)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ #define FF_MOV_FLAG_PREFER_ICC (1 << 23)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++#define FF_MOV_FLAG_PIXELDENSITY (1 << 24)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ int ff_mov_write_packet(AVFormatContext *s, AVPacket *pkt);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/multimedia/ffmpeg4/files/patch-configure-no-error-on-missing-prototypes.diff b/multimedia/ffmpeg4/files/patch-configure-no-error-on-missing-prototypes.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..473b2207fe2
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/multimedia/ffmpeg4/files/patch-configure-no-error-on-missing-prototypes.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,10 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- configure.old 2015-09-27 18:43:30.000000000 +0200
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ configure 2015-09-27 18:44:18.000000000 +0200
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -6788,7 +6788,6 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ check_optflags -fno-tree-vectorize
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ check_cflags -Werror=format-security
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ check_cflags -Werror=implicit-function-declaration
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- check_cflags -Werror=missing-prototypes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ check_cflags -Werror=return-type
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ check_cflags -Werror=vla
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ check_cflags -Wformat
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/multimedia/ffmpeg4/files/patch-issue-9439-non-b-frame-encoding.diff b/multimedia/ffmpeg4/files/patch-issue-9439-non-b-frame-encoding.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..25fa01d79ae
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/multimedia/ffmpeg4/files/patch-issue-9439-non-b-frame-encoding.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,18 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- libavcodec/videotoolboxenc.c.orig 2021-12-11 09:44:23.000000000 -0500
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ libavcodec/videotoolboxenc.c 2021-12-11 09:42:05.000000000 -0500
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+avcodec/videotoolboxenc: Fix non-B-Frame encoding
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+* Sets vtctx->has_b_frames to 0 if the VideoToolbox compression session will not emit B-frames (and, in consequence, no valid DTSs).
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+* Required for the handling of invalid DTSs in 'vtenc_cm_to_avpacket' (line 2018ff) to work correctly and not abort encoding with "DTS is invalid" when no B-frames are generated.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+* See: https://trac.ffmpeg.org/ticket/9439
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -1516,7 +1516,10 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if (!status && has_b_frames_cfbool) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ //Some devices don't output B-frames for main profile, even if requested.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ // HEVC has b-pyramid
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- vtctx->has_b_frames = (CFBooleanGetValue(has_b_frames_cfbool) && avctx->codec_id == AV_CODEC_ID_HEVC) ? 2 : 1;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ if (CFBooleanGetValue(has_b_frames_cfbool))
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ vtctx->has_b_frames = avctx->codec_id == AV_CODEC_ID_HEVC ? 2 : 1;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ else
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++ vtctx->has_b_frames = 0;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ CFRelease(has_b_frames_cfbool);
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ avctx->has_b_frames = vtctx->has_b_frames;
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/multimedia/ffmpeg4/files/patch-libavcodec-audiotoolboxenc.c.diff b/multimedia/ffmpeg4/files/patch-libavcodec-audiotoolboxenc.c.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..a592a07edc3
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/multimedia/ffmpeg4/files/patch-libavcodec-audiotoolboxenc.c.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,13 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- libavcodec/audiotoolboxenc.c.orig 2016-05-18 05:07:43.000000000 -0700
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ libavcodec/audiotoolboxenc.c 2016-05-18 05:09:16.000000000 -0700
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -66,8 +66,10 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ return kAudioFormatMPEG4AAC_HE_V2;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ case FF_PROFILE_AAC_LD:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ return kAudioFormatMPEG4AAC_LD;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++#if MAC_OS_X_VERSION_MAX_ALLOWED >= 1070
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ case FF_PROFILE_AAC_ELD:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ return kAudioFormatMPEG4AAC_ELD;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++#endif
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ case AV_CODEC_ID_ADPCM_IMA_QT:
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ return kAudioFormatAppleIMA4;
</span><span style='display:block; white-space:pre;color:#808080;'>diff --git a/multimedia/ffmpeg4/files/patch-libavcodec-videotoolboxenc.c.diff b/multimedia/ffmpeg4/files/patch-libavcodec-videotoolboxenc.c.diff
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..7b907bdd5e8
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/multimedia/ffmpeg4/files/patch-libavcodec-videotoolboxenc.c.diff
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,10 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+--- libavcodec/videotoolboxenc.c
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>++++ libavcodec/videotoolboxenc.c
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+@@ -1398,7 +1398,6 @@ static int vtenc_configure_encoder(AVCodecContext *avctx)
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ vtctx->codec_id = avctx->codec_id;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+- avctx->max_b_frames = 16;
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if (vtctx->codec_id == AV_CODEC_ID_H264) {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ vtctx->get_param_set_func = CMVideoFormatDescriptionGetH264ParameterSetAtIndex;
</span></pre><pre style='margin:0'>
</pre>