commit:     3573d92fa871018928bac60ffd00683942cdc126
Author:     Matt Jolly <kangie <AT> gentoo <DOT> org>
AuthorDate: Mon Mar  9 02:27:16 2026 +0000
Commit:     Matt Jolly <kangie <AT> gentoo <DOT> org>
CommitDate: Mon Mar  9 02:27:16 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3573d92f

media-libs/sdl3-image: add 3.4.0

Signed-off-by: Matt Jolly <kangie <AT> gentoo.org>

 media-libs/sdl3-image/Manifest                |   1 +
 media-libs/sdl3-image/sdl3-image-3.4.0.ebuild | 145 ++++++++++++++++++++++++++
 2 files changed, 146 insertions(+)

diff --git a/media-libs/sdl3-image/Manifest b/media-libs/sdl3-image/Manifest
index 94385989715c..feced583b660 100644
--- a/media-libs/sdl3-image/Manifest
+++ b/media-libs/sdl3-image/Manifest
@@ -1 +1,2 @@
 DIST SDL3_image-3.2.4.tar.gz 10756063 BLAKE2B 
9ea311a83c833d61c097c8728491fe08497500116dbf5c931703b32d4e335213a6927a1f7e3532ecc8fb03882341cb2732877bdf161f7fee103180f8fcbbfce3
 SHA512 
397ff126f6f95351d9addb3ac2d2c228fa2e4c513ca46525b326a64c6e73c40fd651d232d503fd757a03c55a7fa372a885f07d5f72d80dd17a2850816295d82e
+DIST SDL3_image-3.4.0.tar.gz 11221415 BLAKE2B 
0a4b7a23382e46b41b2a45bb8869fecde54ef5ba0adf5c9ea132f93c299e23d5c75844eccbb5f7aa584df6251c87809b01cbb97aa537584c794c011676e33ec3
 SHA512 
3e98854f92b2fbb3489408b413ce2e0cfbb3e3eea58fa6e7037948a9fa7bf6bf5af38c4087285d4b7340b1115699c2c4b9626ce65a3e3b449bd5d4ec2078c957

diff --git a/media-libs/sdl3-image/sdl3-image-3.4.0.ebuild 
b/media-libs/sdl3-image/sdl3-image-3.4.0.ebuild
new file mode 100644
index 000000000000..640ec39ae9b1
--- /dev/null
+++ b/media-libs/sdl3-image/sdl3-image-3.4.0.ebuild
@@ -0,0 +1,145 @@
+# Copyright 1999-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit cmake-multilib multibuild
+
+DESCRIPTION="A simple library to load images of various formats as SDL 
surfaces."
+HOMEPAGE="https://www.libsdl.org/projects/SDL_image/";
+SRC_URI="https://github.com/libsdl-org/SDL_image/archive/refs/tags/release-${PV}/SDL3_image-${PV}.tar.gz";
+
+S="${WORKDIR}/SDL_image-release-${PV}"
+
+LICENSE="ZLIB"
+SLOT="0"
+KEYWORDS="~amd64 ~ppc ~x86"
+IUSE="avif gif jpeg jpegxl png samples static-libs stb test tiff webp"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="
+       stb? ( jpeg png )
+       test? ( jpeg png )
+"
+
+RDEPEND="
+       >=media-libs/libsdl3-3.0.0[${MULTILIB_USEDEP}]
+       >=virtual/zlib-1.2.8-r1:=[${MULTILIB_USEDEP}]
+       avif? ( >=media-libs/libavif-1.0.0:=[${MULTILIB_USEDEP}] )
+       !stb? (
+               png? ( >=media-libs/libpng-1.6.10:0=[${MULTILIB_USEDEP}] )
+               jpeg? ( media-libs/libjpeg-turbo:=[${MULTILIB_USEDEP}] )
+       )
+       jpegxl? ( media-libs/libjxl:=[${MULTILIB_USEDEP}] )
+       tiff? ( >=media-libs/tiff-3.9.7-r1:=[${MULTILIB_USEDEP}] )
+       webp? ( >=media-libs/libwebp-0.3.0:=[${MULTILIB_USEDEP}] )
+"
+DEPEND="${RDEPEND}"
+
+pkg_setup() {
+       MULTIBUILD_VARIANTS=( shared-libs $(usev static-libs) )
+}
+
+src_prepare() {
+       cmake_src_prepare
+
+       # 1. Install non standard license installation
+       # 2/3. Add suffixes to sample programs
+       sed -i \
+               -e '/install(FILES "LICENSE.txt"/,/\s)$/d' \
+               -e 's/\(\W\)showanim\(\W\)/\1showanim2\2/' \
+               -e 's/\(\W\)showimage\(\W\)/\1showimage2\2/' \
+               CMakeLists.txt || die
+}
+
+multilib_src_configure() {
+       # hack because because of layered multibuilds
+       if [[ -n ${is_shared} ]]; then
+               mycmakeargs+=( -DSDLIMAGE_SAMPLES=$(multilib_native_usex 
samples) )
+       fi
+       cmake_src_configure
+}
+
+src_configure() {
+       myconfigure() {
+               local mycmakeargs=(
+                       -DSDLIMAGE_DEPS_SHARED=ON # Force dynamic loading of 
dependencies
+                       -DSDLIMAGE_INSTALL_MAN=ON
+                       -DSDLIMAGE_STRICT=ON # Fail when a dependency could not 
be found
+                       -DSDLIMAGE_TESTS_INSTALL=OFF
+                       -DSDLIMAGE_TESTS=$(usex test)
+                       -DSDLIMAGE_VENDORED=OFF # Use system libraries instead 
of vendored ones; defualt but let's be explicit
+                       -DSDLIMAGE_BACKEND_STB=$(usex stb)      # jpeg and png 
file support via stb_image; vendored, despite above
+                                                                               
                # likely less performant than using native libraries, less deps.
+                       # formats
+                       -DSDLIMAGE_AVIF=$(usex avif)
+                       -DSDLIMAGE_AVIF_SAVE=$(usex avif)
+                       -DSDLIMAGE_BMP=ON
+                       -DSDLIMAGE_GIF=$(usex gif)
+                       -DSDLIMAGE_JPG=$(usex jpeg)
+                       -DSDLIMAGE_JPG_SAVE=$(usex jpeg)
+                       -DSDLIMAGE_JXL=$(usex jpegxl)
+                       -DSDLIMAGE_LBM=ON
+                       -DSDLIMAGE_PCX=ON
+                       -DSDLIMAGE_PNG=$(usex png)
+                       -DSDLIMAGE_PNG_SAVE=$(usex png)
+                       -DSDLIMAGE_PNM=ON
+                       -DSDLIMAGE_QOI=ON
+                       -DSDLIMAGE_SVG=ON
+                       -DSDLIMAGE_TGA=ON
+                       -DSDLIMAGE_TIF=$(usex tiff)
+                       -DSDLIMAGE_WEBP=$(usex webp)
+                       -DSDLIMAGE_XCF=ON
+                       -DSDLIMAGE_XPM=ON
+                       -DSDLIMAGE_XV=ON
+               )
+               if [[ "${MULTIBUILD_VARIANT}" == "shared-libs" ]]; then
+                       mycmakeargs+=( -DBUILD_SHARED_LIBS=ON )
+                       local is_shared=1
+               else
+                       mycmakeargs+=(
+                               -DBUILD_SHARED_LIBS=OFF
+                               -DSDLIMAGE_SAMPLES=OFF
+                       )
+               fi
+
+               cmake-multilib_src_configure
+       }
+       multibuild_foreach_variant myconfigure
+}
+
+src_compile() {
+       multibuild_foreach_variant cmake-multilib_src_compile
+}
+
+src_test() {
+       # These are only asserts that the formats are supported. They do not 
test
+       # that the formats are actually working. It is advisable to run a game 
or
+       # application that uses SDL_image to sanity check common formats.
+
+       # 
https://github.com/libsdl-org/SDL_image/tree/main/test#asserting-format-support
+       # Match same order as src_configure. The intent is to catch build system
+       # bugs, so it may need updating sometimes for legitimate changes in
+       # SDL_image support.
+       local -x SDL_IMAGE_TEST_REQUIRE_{LOAD,SAVE}_AVIF=$(usex avif 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_BMP=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_GIF=$(usex gif 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_{LOAD,SAVE}_JPG=$(usex jpeg 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_{LOAD,SAVE}_JXL=$(usex jpegxl 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_{LOAD,SAVE}_LBM=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_PCX=1
+       local -x SDL_IMAGE_TEST_REQUIRE_{LOAD,SAVE}_PNG=$(usex png 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_QOI=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_SVG=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_TGA=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_TIF=$(usex tiff 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_WEBP=$(usex webp 1 0)
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_XCF=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_XPM=1
+       local -x SDL_IMAGE_TEST_REQUIRE_LOAD_XV=1
+
+       multibuild_foreach_variant cmake-multilib_src_test
+}
+
+src_install() {
+       multibuild_foreach_variant cmake-multilib_src_install
+}

Reply via email to