commit:     bdc98b2ac3b1948e5fa197fbef055358cd0bb125
Author:     Paul Zander <negril.nx+gentoo <AT> gmail <DOT> com>
AuthorDate: Fri Aug 23 16:53:41 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sun Aug 25 15:43:06 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bdc98b2a

media-libs/x265: add 3.6

Closes: https://bugs.gentoo.org/937756
Signed-off-by: Paul Zander <negril.nx+gentoo <AT> gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/38267
Signed-off-by: Sam James <sam <AT> gentoo.org>

 media-libs/x265/Manifest                       |   1 +
 media-libs/x265/files/x265-3.6-test-ns_2.patch |  30 ++++
 media-libs/x265/x265-3.6.ebuild                | 195 +++++++++++++++++++++++++
 3 files changed, 226 insertions(+)

diff --git a/media-libs/x265/Manifest b/media-libs/x265/Manifest
index c27eb2713e67..2ea6fb64ce0a 100644
--- a/media-libs/x265/Manifest
+++ b/media-libs/x265/Manifest
@@ -1 +1,2 @@
+DIST x265-3.6.tar.gz 1655889 BLAKE2B 
2598421e2e21974998b0b20895dc7e12dbf6ebe1b6c23bb5a7710b575d3db773335cd1f0b3ef110b79cf4d6dd01e543e9807a0509963497edc25f617f80c29f3
 SHA512 
570429c3f0b560b2f946ac9baba97d66d7d6485e46eb695b17003b5913028f62d35822477633e911cd3ea60e6ce0ecc7d9d82de7d8257272f9ca7b43761438be
 DIST x265_3.5.tar.gz 1537044 BLAKE2B 
4fe15b762eda08a4379f69df622bef603fed784a237381d5c95876412020c113d053af829fa1eb66468462a6edc0de32dc597b1a98a63e9aa0250a47f4e76d05
 SHA512 
230e683239c3e262096ba96246c6f67229a1625d163f86647a411733bb1cf349685858aee3017bce818bb6992448d0abaa9241615a5b620561ce47ecb164f997

diff --git a/media-libs/x265/files/x265-3.6-test-ns_2.patch 
b/media-libs/x265/files/x265-3.6-test-ns_2.patch
new file mode 100644
index 000000000000..63308e5bb48d
--- /dev/null
+++ b/media-libs/x265/files/x265-3.6-test-ns_2.patch
@@ -0,0 +1,30 @@
+--- source.orig/encoder/encoder.cpp
++++ source/encoder/encoder.cpp
+@@ -1478,7 +1478,7 @@ int Encoder::encode(const x265_picture* pic_in, 
x265_picture* pic_out)
+     if (m_exportedPic)
+     {
+         if (!m_param->bUseAnalysisFile && m_param->analysisSave)
+-            x265_free_analysis_data(m_param, &m_exportedPic->m_analysisData);
++            PARAM_NS::x265_free_analysis_data(m_param, 
&m_exportedPic->m_analysisData);
+ 
+         ATOMIC_DEC(&m_exportedPic->m_countRefEncoders);
+ 
+--- a/common/threadpool.cpp
++++ b/common/threadpool.cpp
+@@ -25,6 +25,7 @@
+ #include "common.h"
+ #include "threadpool.h"
+ #include "threading.h"
++#include "param.h"
+ 
+ #include <new>
+ 
+@@ -314,7 +315,7 @@ ThreadPool* ThreadPool::allocThreadPools(x265_param* p, 
int& numPools, bool isTh
+                    sprintf(nextCount, "%d", cpusPerNode[i]);
+              strcat(poolString, nextCount);
+          }
+-         x265_param_parse(p, "pools", poolString);
++         PARAM_NS::x265_param_parse(p, "pools", poolString);
+      }
+ #endif
+     if (p->numaPools && *p->numaPools)

diff --git a/media-libs/x265/x265-3.6.ebuild b/media-libs/x265/x265-3.6.ebuild
new file mode 100644
index 000000000000..55b794f17e42
--- /dev/null
+++ b/media-libs/x265/x265-3.6.ebuild
@@ -0,0 +1,195 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit cmake flag-o-matic multilib-minimal multibuild
+
+DESCRIPTION="Library for encoding video streams into the H.265/HEVC format"
+HOMEPAGE="http://x265.org/ https://bitbucket.org/multicoreware/x265_git/";
+
+if [[ ${PV} = 9999* ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://bitbucket.org/multicoreware/x265_git/";
+       MY_P="${PN}-${PV}"
+else
+       
SRC_URI="https://bitbucket.org/multicoreware/x265_git/downloads/${PN}_${PV}.tar.gz
 -> ${PN}-${PV}.tar.gz"
+       KEYWORDS="~amd64 ~arm ~arm64 ~hppa ~loong ~mips ~ppc ~ppc64 ~riscv ~x86"
+       MY_P="${PN}_${PV}"
+fi
+
+S="${WORKDIR}/${MY_P}/source"
+unset MY_P
+
+LICENSE="GPL-2"
+# subslot = libx265 soname
+SLOT="0/209"
+IUSE="+10bit +12bit cpu_flags_ppc_vsx2 numa test"
+RESTRICT="!test? ( test )"
+
+RDEPEND="numa? ( >=sys-process/numactl-2.0.10-r1[${MULTILIB_USEDEP}] )"
+DEPEND="${RDEPEND}"
+ASM_DEPEND=">=dev-lang/nasm-2.13"
+BDEPEND="
+       abi_x86_32? ( ${ASM_DEPEND} )
+       abi_x86_64? ( ${ASM_DEPEND} )"
+
+PATCHES=(
+       "${FILESDIR}/${PN}-9999-arm.patch"
+       "${FILESDIR}/neon.patch"
+       "${FILESDIR}/tests.patch"
+       "${FILESDIR}/test-ns.patch"
+       "${FILESDIR}/${PN}-3.5-r5-cpp-std.patch"
+       "${FILESDIR}/${PN}-3.5-r5-gcc15.patch"
+       "${FILESDIR}/${PN}-3.6-test-ns_2.patch"
+)
+
+pkg_setup() {
+       variants=(
+               $(usev 12bit "main12")
+               $(usev 10bit "main10")
+       )
+}
+
+# By default, the library and the encoder is configured for only one output bit
+# depth. Meaning, one has to rebuild libx265 if (s)he wants to produce HEVC
+# files with a different bit depth, which is annoying. However, upstream
+# supports proper namespacing for 8bits, 10bits & 12bits HEVC and linking all
+# that together so that the resulting library can produce all three of them
+# instead of only one.
+# The API requires the bit depth parameter, so that libx265 can then chose 
which
+# variant of the encoder to use.
+# To achieve this, we have to build one (static) library for each non-main
+# variant, and link it into the main library.
+# Upstream documents using the 8bit variant as main library, hence we do not
+# allow disabling it
+
+x265_variant_src_configure() {
+       einfo "Configuring variant: ${MULTIBUILD_VARIANT} for ABI: ${ABI}"
+
+       local mycmakeargs=(
+               "${mycmakeargs[@]}"
+               -DHIGH_BIT_DEPTH=ON
+               -DEXPORT_C_API=OFF
+               -DENABLE_SHARED=OFF
+               -DENABLE_CLI=OFF
+       )
+
+       case "${MULTIBUILD_VARIANT}" in
+               "main12")
+                       mycmakeargs+=(
+                               -DMAIN12=ON
+                       )
+                       ;;
+               "main10")
+                       mycmakeargs+=(
+                               -DENABLE_HDR10_PLUS=ON
+                       )
+                       ;;
+               *)
+                       die "Unknown variant: ${MULTIBUILD_VARIANT}";;
+       esac
+       cmake_src_configure
+}
+
+multilib_src_configure() {
+       # -Werror=odr
+       # https://bugs.gentoo.org/875854
+       # 
https://bitbucket.org/multicoreware/x265_git/issues/937/build-fails-with-lto
+       filter-lto
+
+       local mycmakeargs=(
+               $(multilib_is_native_abi || echo "-DENABLE_CLI=OFF")
+               -DENABLE_PIC=ON
+               -DENABLE_LIBNUMA="$(usex numa)"
+               -DENABLE_MULTIVIEW="yes"
+               -DENABLE_SVT_HEVC="no" # missing
+               -DENABLE_VTUNE="no" # missing
+               -DGIT_ARCHETYPE=1 #814116
+               -DLIB_INSTALL_DIR="$(get_libdir)"
+       )
+
+       # Unfortunately, the asm for x86/x32/arm isn't PIC-safe.
+       # x86 # Bug #528202, bug #913412
+       # x32 # bug #510890
+       if [[ ${ABI} = x86 ]] || [[ ${ABI} = x32 ]] || [[ ${ABI} = arm ]] ; then
+               mycmakeargs+=(
+                       -DENABLE_ASSEMBLY=OFF
+                       -DENABLE_TESTS="no" #728748
+               )
+       else
+               mycmakeargs+=(
+                       -DENABLE_TESTS="$(usex test)"
+               )
+       fi
+
+       if [[ ${ABI} = ppc* ]] ; then
+               # upstream uses mix of altivec + power8 vectors
+               # it's impossible to enable altivec without CPU_POWER8
+               # and it does not work on ppc32
+               # so we toggle both variables together
+               mycmakeargs+=(
+                       -DCPU_POWER8="$(usex cpu_flags_ppc_vsx2)"
+                       -DENABLE_ALTIVEC="$(usex cpu_flags_ppc_vsx2)"
+               )
+       fi
+
+       local MULTIBUILD_VARIANTS=( "${variants[@]}" )
+       if [[ "${#MULTIBUILD_VARIANTS[@]}" -gt 1 ]] ; then
+               multibuild_foreach_variant x265_variant_src_configure
+
+               local liblist="" v=
+               for v in "${MULTIBUILD_VARIANTS[@]}" ; do
+                       ln -sf "${BUILD_DIR}-${v}/libx265.a" 
"${BUILD_DIR%-*}/libx265_${v}.a" || die
+                       liblist+="libx265_${v}.a;"
+               done
+
+               mycmakeargs+=(
+                       -DEXTRA_LIB="${liblist}"
+                       -DEXTRA_LINK_FLAGS="-L${BUILD_DIR%-*}"
+                       -DLINKED_10BIT"=$(usex 10bit)"
+                       -DLINKED_12BIT="$(usex 12bit)"
+               )
+       fi
+
+       cmake_src_configure
+}
+
+multilib_src_compile() {
+       local MULTIBUILD_VARIANTS=( "${variants[@]}" )
+       if [[ "${#MULTIBUILD_VARIANTS[@]}" -gt 1 ]] ; then
+               multibuild_foreach_variant cmake_src_compile
+       fi
+       cmake_src_compile
+}
+
+x265_variant_src_test() {
+       if [[ -x "${BUILD_DIR}/test/TestBench" ]] ; then
+               "${BUILD_DIR}/test/TestBench" || die
+       else
+               einfo "Unit tests check only assembly."
+               einfo "You do not seem to have any for ABI=${ABI}, x265 
variant=${MULTIBUILD_VARIANT}"
+               einfo "Skipping tests."
+       fi
+}
+
+multilib_src_test() {
+       local MULTIBUILD_VARIANTS=( "${variants[@]}" )
+       if [[ "${#MULTIBUILD_VARIANTS[@]}" -gt 1 ]] ; then
+               multibuild_foreach_variant x265_variant_src_test
+       fi
+       x265_variant_src_test
+}
+
+multilib_src_install() {
+       cmake_src_install
+}
+
+multilib_src_install_all() {
+       dodoc -r "${S}/../doc/"*
+
+       # we don't install *.a files for all variants,
+       # so just delete these files instead of pretending
+       # real USE=static-libs support
+       find "${ED}" -name "*.a" -delete || die
+}

Reply via email to