summaryrefslogtreecommitdiff
path: root/media-libs/sdl3-image
diff options
context:
space:
mode:
Diffstat (limited to 'media-libs/sdl3-image')
-rw-r--r--media-libs/sdl3-image/Manifest3
-rw-r--r--media-libs/sdl3-image/metadata.xml25
-rw-r--r--media-libs/sdl3-image/sdl3-image-3.2.4.ebuild145
3 files changed, 173 insertions, 0 deletions
diff --git a/media-libs/sdl3-image/Manifest b/media-libs/sdl3-image/Manifest
new file mode 100644
index 000000000000..79b7af4bd515
--- /dev/null
+++ b/media-libs/sdl3-image/Manifest
@@ -0,0 +1,3 @@
+DIST SDL3_image-3.2.4.tar.gz 10756063 BLAKE2B 9ea311a83c833d61c097c8728491fe08497500116dbf5c931703b32d4e335213a6927a1f7e3532ecc8fb03882341cb2732877bdf161f7fee103180f8fcbbfce3 SHA512 397ff126f6f95351d9addb3ac2d2c228fa2e4c513ca46525b326a64c6e73c40fd651d232d503fd757a03c55a7fa372a885f07d5f72d80dd17a2850816295d82e
+EBUILD sdl3-image-3.2.4.ebuild 4648 BLAKE2B 3f4b4ce0518f63428702905805a6a02f8c8b2c2491e30095c82aa2b55d75776bb907e0cc31a05eb03929dd99357837f567c7d0f2293f01571e189f6b41ad3ddf SHA512 2d2df097e8191701de4dea2a5a16b954349623ff4157a1e0372b4ea068df35c94de123fea69b82807e80c724e76250f12f00f1c4a10b73f5aefbecabbcaa8f55
+MISC metadata.xml 1036 BLAKE2B eed23ca44901cffb2d50ae9c6685b1d6f17bbdd10a725d64b1579e4c9f47888f4e6f54e22e3299e1930208210f88027199fe1b15cbf27fbc6afd7fdd0f7b0fca SHA512 cd108d122e0b744e51de03cf5aa9d795381e08d42bc6bbdde5261fba58939ee7759725fda6f57fa6f869198cd28abeccb272a7090c8ab41490e0e2faf764c6f7
diff --git a/media-libs/sdl3-image/metadata.xml b/media-libs/sdl3-image/metadata.xml
new file mode 100644
index 000000000000..263bcadc80eb
--- /dev/null
+++ b/media-libs/sdl3-image/metadata.xml
@@ -0,0 +1,25 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd">
+<pkgmetadata>
+ <maintainer type="project">
+ <email>games@gentoo.org</email>
+ <name>Gentoo Games Project</name>
+ </maintainer>
+ <maintainer type="person">
+ <email>kangie@gentoo.org</email>
+ <name>Matt Jolly</name>
+ </maintainer>
+ <longdescription>
+ This is a simple library to load images of various formats as SDL surfaces.
+ It can load BMP, GIF, JPEG, LBM, PCX, PNG, PNM (PPM/PGM/PBM), QOI, TGA, XCF, XPM, and simple SVG format images.
+ It can also load AVIF, JPEG-XL, TIFF, and WebP images, depending on build options
+ </longdescription>
+ <use>
+ <flag name="samples">Install sample programs</flag>
+ <flag name="stb">Use stb_image from vendored <pkg>dev-libs/stb</pkg> for JPEG and PNG image loading to reduce external dependencies</flag>
+ </use>
+ <upstream>
+ <remote-id type="github">libsdl-org/SDL_image</remote-id>
+ <bugs-to>https://github.com/libsdl-org/SDL_image/issues</bugs-to>
+ </upstream>
+</pkgmetadata>
diff --git a/media-libs/sdl3-image/sdl3-image-3.2.4.ebuild b/media-libs/sdl3-image/sdl3-image-3.2.4.ebuild
new file mode 100644
index 000000000000..48fcdbb55029
--- /dev/null
+++ b/media-libs/sdl3-image/sdl3-image-3.2.4.ebuild
@@ -0,0 +1,145 @@
+# Copyright 1999-2025 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"
+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}]
+ >=sys-libs/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
+}