diff options
author | V3n3RiX <venerix@koprulu.sector> | 2025-04-11 08:43:59 +0100 |
---|---|---|
committer | V3n3RiX <venerix@koprulu.sector> | 2025-04-11 08:43:59 +0100 |
commit | bb59556b3302a941db4630613c604644d5f7a617 (patch) | |
tree | 42e60b7ae227b0fe3af52dfac08d59653066a2db /media-libs/sdl3-image | |
parent | 3cd09a18bad26aad2645241b868755cfdf41b6ae (diff) |
Diffstat (limited to 'media-libs/sdl3-image')
-rw-r--r-- | media-libs/sdl3-image/Manifest | 3 | ||||
-rw-r--r-- | media-libs/sdl3-image/metadata.xml | 25 | ||||
-rw-r--r-- | media-libs/sdl3-image/sdl3-image-3.2.4.ebuild | 145 |
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 +} |