commit: 39d42eebf2b56c63b5e7c233f656306af4d66a3f Author: Paul Zander <negril.nx+gentoo <AT> gmail <DOT> com> AuthorDate: Wed Nov 5 14:54:47 2025 +0000 Commit: Sam James <sam <AT> gentoo <DOT> org> CommitDate: Fri Nov 28 02:53:01 2025 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=39d42eeb
media-gfx/blender-bin: add 4.2.16 Signed-off-by: Paul Zander <negril.nx+gentoo <AT> gmail.com> Part-of: https://github.com/gentoo/gentoo/pull/44694 Signed-off-by: Sam James <sam <AT> gentoo.org> media-gfx/blender-bin/Manifest | 1 + media-gfx/blender-bin/blender-bin-4.2.16.ebuild | 202 ++++++++++++++++++++++++ 2 files changed, 203 insertions(+) diff --git a/media-gfx/blender-bin/Manifest b/media-gfx/blender-bin/Manifest index e9cbf3412f88..ff31261a1d6a 100644 --- a/media-gfx/blender-bin/Manifest +++ b/media-gfx/blender-bin/Manifest @@ -1,4 +1,5 @@ DIST blender-3.6.22-linux-x64.tar.xz 272633304 BLAKE2B 20751b784bce4808807d074b1d08d48160e7227c36cd36b8980420c934956e4aebe66d054b06cd62fcd5cab89fbb5e6fa870e386a75ba29af08f07118bc844f9 SHA512 16a804fd550b275ebfb945aab2685d65528ae9b49a7ffaf76e7b338a8d073f2215dc3adad9b2142cd222e1f7dd9c40a75924c5783b93ace663063f486869d279 DIST blender-3.6.23-linux-x64.tar.xz 272819000 BLAKE2B 99cec0fe547b32dbee7c0024474a0a51224f53131b613eebbc4c7b28cf54948fbd742a09e63c37700913a3c764a85cb0d1fd0932faa95e7a61d48dfdf4c5adb1 SHA512 073cf218c74796e22afe0fb4d9d781fa92d42d38f29becde650a87bae625ede0ca77af2d935783e5e44f40802948012589f5ca173e287102a8abb3197817baeb +DIST blender-4.2.16-linux-x64.tar.xz 350677256 BLAKE2B b1c13cbfd441dd11480fb2edbfe4cad11d518148b134aa3112cd6c09c0d5b6711d5e0dd08d1a7966ac2181de131c0061e2ce9622aeba31d23de5348fb6968d85 SHA512 304ae514bd9ffe47b2859513877abd83834f3790caac3b087c12d4381ec0ff7938681cb83f616dfdd3c660c65f5f0fec0759a6dea69d538e2b9a96f4a864919d DIST blender-4.2.9-linux-x64.tar.xz 355259956 BLAKE2B c009c1f992ceaac8a5671d8d34cc4775d27771e9c9af79ca1a98cf4cdce6f0fcaa0225755c7fc80e4cdc3e9abce64707ba19b9bbbf28ebb7a200549efe446e9d SHA512 4cce94a7b399d17a74f2cab5f82cb9adc44ad9c09275460771041aa195c6e9f9c4d9793a942e00ad5a9b86da85bacf6a666d76e0b6b06842f7692028419824e6 DIST blender-4.4.3-linux-x64.tar.xz 363316148 BLAKE2B c450e74cf748e523581ac60346ca4ff57fb202ab43f3a18c2c5e4122be8fbc5b6ec646146d4c0f72ada121e5b3ac35e9eccfe46aa5780f7c2e512cba086c025d SHA512 792f936a0fbabbfc2a107895f80c89a35fc2ca9b20e3f6dd0fc264c16b17a89145078e5630467a3f5511a3d1a43a5da7e6eebfda2f0e3034e5a2cb65c64badfa diff --git a/media-gfx/blender-bin/blender-bin-4.2.16.ebuild b/media-gfx/blender-bin/blender-bin-4.2.16.ebuild new file mode 100644 index 000000000000..a6d1f0b2717b --- /dev/null +++ b/media-gfx/blender-bin/blender-bin-4.2.16.ebuild @@ -0,0 +1,202 @@ +# Copyright 1999-2025 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +inherit desktop xdg-utils + +DESCRIPTION="3D Creation/Animation/Publishing System" +HOMEPAGE="https://www.blender.org" + +LICENSE="GPL-3+ Apache-2.0" +SLOT="$(ver_cut 1-2)" + +if [[ ${PV} == *9999* ]] ; then + # BLENDER_BIN_URL can be used to point to the url of an upstream release archive. + PROPERTIES="live" +else + SRC_URI=" + https://download.blender.org/release/Blender${SLOT}/blender-${PV}-linux-x64.tar.xz + " + KEYWORDS="~amd64" +fi + +IUSE="cuda hip oneapi" +RESTRICT="strip test" + +QA_PREBUILT="opt/${P}/*" + +if [[ ${PV} == *9999* ]] ; then + BDEPEND=" + app-misc/jq + " +fi + +# no := here, this is prebuilt +RDEPEND=" + app-arch/zstd + media-libs/libglvnd[X] + sys-apps/util-linux + sys-libs/glibc + sys-libs/ncurses + virtual/libcrypt + virtual/zlib:0/1 + x11-base/xorg-server + x11-libs/libICE + x11-libs/libSM + x11-libs/libX11 + x11-libs/libXext + x11-libs/libXfixes + x11-libs/libXi + x11-libs/libXrender + x11-libs/libXt + x11-libs/libXxf86vm + x11-libs/libdrm + x11-libs/libxcb + x11-libs/libxkbcommon + cuda? ( + x11-drivers/nvidia-drivers + ) + hip? ( + =dev-util/hip-6* + ) + oneapi? ( + dev-libs/level-zero + ) +" + +src_unpack() { + local my_A + if [[ ${PV} == *9999* ]] ; then + local file_name url + if [[ -n "${BLENDER_BIN_URL}" ]]; then + einfo "Using ${BLENDER_BIN_URL} as SRC_URI. You are on your own." + file_name="$(basename "${BLENDER_BIN_URL}")" + url="${BLENDER_BIN_URL}" + else + wget "https://builder.blender.org/download/daily/?format=json&v=2" -O "${T}/release.json" \ + || die "failed to retrieve release.json" + + local branch commit rel_json release_cycle version + rel_json=$( + jq -r 'map(select(.platform == "linux" and .branch == "'"${EGIT_BRANCH:-main}"'" and .file_extension == "xz")) + | .[0]' \ + "${T}/release.json" + ) + branch=$( echo "${rel_json}" | jq -r '.branch' ) + commit=$( echo "${rel_json}" | jq -r '.hash' ) + file_name=$( echo "${rel_json}" | jq -r '.file_name' ) + release_cycle=$( echo "${rel_json}" | jq -r '.release_cycle' ) + url=$( echo "${rel_json}" | jq -r '.url' ) + version=$( echo "${rel_json}" | jq -r '.version' ) + + einfo "Fetching blender-${version}-${release_cycle}-${branch}-${commit}" + einfo " url: ${url}" + einfo " version: ${version}" + einfo " release_cycle: ${release_cycle}" + einfo " branch: ${branch}" + einfo " commit: ${commit}" + einfo + fi + + wget -c "${url}"{,.sha256} -P "${T}" || die "failed to fetch ${url}" + + my_A="${T}/${file_name}" + + # Check sha256sum + local sha256sum_exp sha256sum_is + sha256sum_exp="$(cat "${T}/${file_name}.sha256")" + sha256sum_is="$(sha256sum "${T}/${file_name}" | cut -d ' ' -f 1)" + if [[ "${sha256sum_exp}" != "${sha256sum_is}" ]]; then + eerror "sha256sum mismatch for ${file_name}" + eerror " expected ${sha256sum_exp}" + eerror " found ${sha256sum_is}" + die "sha256sum mismatch" + fi + else + my_A="blender-${PV}-linux-x64.tar.xz" + fi + + unpack "${my_A}" + + local dirs + dirs="$(find "${WORKDIR}" -mindepth 1 -maxdepth 1 | wc -l)" + if [[ "${dirs}" -ne 1 ]]; then + die "unpack resulted in ${dirs} dirs in ${WORKDIR}" + fi + + mv "${WORKDIR}"/* "${S}" || die "mv" +} + +src_prepare() { + default + + # Remove unused gpu libraries so we don't get missing libraries from QA + if ! use cuda; then + rm \ + lib/libOpenImageDenoise_device_cuda* \ + || eqawarn "failed cleaning cuda" + fi + + if ! use hip; then + rm \ + lib/libOpenImageDenoise_device_hip* \ + || eqawarn "failed cleaning hip" + fi + + if ! use oneapi; then + rm \ + lib/libOpenImageDenoise_device_sycl* \ + lib/libpi_level_zero* \ + || eqawarn "failed cleaning oneapi" + fi + + # Prepare icons and .desktop for menu entry + mv blender.desktop "${P}.desktop" || die + mv blender.svg "${P}.svg" || die + mv blender-symbolic.svg "${P}-symbolic.svg" || die + + # X-KDE-RunOnDiscreteGpu is obsolete, so trim it + sed \ + -e "s/=blender/=${P}/" \ + -e "s/Name=Blender/Name=Blender Bin ${PV}/" \ + -e "/X-KDE-RunOnDiscreteGpu.*/d" \ + -i "${P}.desktop" || die +} + +src_configure() { + :; +} + +src_compile() { + :; +} + +src_install() { + # We could use the version from the release.json instead of PN here + local BLENDER_OPT_HOME="/opt/${P}" + + # Install icons and .desktop for menu entry + doicon -s scalable "${S}"/blender*.svg + domenu "${P}.desktop" + + # Install all the blender files in /opt + dodir "${BLENDER_OPT_HOME%/*}" + mv "${S}" "${ED}${BLENDER_OPT_HOME}" || die + + # Create symlink /usr/bin/blender-bin + dodir "/usr/bin" + dosym -r "${BLENDER_OPT_HOME}/blender" "/usr/bin/${P}" +} + +pkg_postinst() { + xdg_icon_cache_update + xdg_mimeinfo_database_update + xdg_desktop_database_update +} + +pkg_postrm() { + xdg_icon_cache_update + xdg_mimeinfo_database_update + xdg_desktop_database_update +}
