commit:     2291e2d6f10a012e4d9552be97b81f843278524f
Author:     Ralph Sennhauser <ralph.sennhauser <AT> gmail <DOT> com>
AuthorDate: Tue Feb 17 17:38:19 2026 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Feb 21 13:26:05 2026 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2291e2d6

games-strategy/0ad: add 0.28.0

There no longer are any font atlati as pyrogenesis switched to rendering
fonts using freetype.

Signed-off-by: Ralph Sennhauser <ralph.sennhauser <AT> gmail.com>
Part-of: https://github.com/gentoo/gentoo/pull/45838
Closes: https://github.com/gentoo/gentoo/pull/45838
Signed-off-by: Sam James <sam <AT> gentoo.org>

 games-strategy/0ad/0ad-0.28.0.ebuild | 226 +++++++++++++++++++++++++++++++++++
 games-strategy/0ad/Manifest          |   4 +
 2 files changed, 230 insertions(+)

diff --git a/games-strategy/0ad/0ad-0.28.0.ebuild 
b/games-strategy/0ad/0ad-0.28.0.ebuild
new file mode 100644
index 000000000000..c025390902af
--- /dev/null
+++ b/games-strategy/0ad/0ad-0.28.0.ebuild
@@ -0,0 +1,226 @@
+# Copyright 2014-2026 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{12,13,14} )
+WX_GTK_VER="3.2-gtk3"
+inherit desktop flag-o-matic python-any-r1 toolchain-funcs multiprocessing 
wxwidgets xdg
+
+if [[ ${PV} != 9999 && ${PV} != *_pre* ]]; then
+       VERIFY_SIG_METHOD=minisig
+       # The public key can be found upstream - last update was w/ alpha 26:
+       # https://gitea.wildfiregames.com/0ad/0ad/wiki/VerifyingYourDownloads
+       VERIFY_SIG_OPENPGP_KEY_PATH=${FILESDIR}/0ad-minisign.pub
+       inherit verify-sig
+fi
+
+DESCRIPTION="A free, real-time strategy game"
+HOMEPAGE="https://play0ad.com/";
+LICENSE="BitstreamVera CC-BY-SA-3.0 GPL-2 LGPL-2.1 LPPL-1.3c MIT ZLIB"
+
+if [[ ${PV} == *9999 ]]; then
+       inherit git-r3
+       EGIT_REPO_URI="https://github.com/0ad/0ad";
+       S="${WORKDIR}/${P}"
+elif [[ ${PV} == *_pre* ]]; then
+       ZEROAD_GIT_REVISION=""
+       
SRC_URI="https://github.com/0ad/0ad/archive/${ZEROAD_GIT_REVISION}.tar.gz -> 
${P}.tar.gz"
+       S="${WORKDIR}/${PN}-${ZEROAD_GIT_REVISION}"
+elif [[ ${PV} == *_rc* ]]; then
+       MY_P="0ad-${PV/_/-}"
+       SRC_URI="
+               https://releases.wildfiregames.com/rc/${MY_P}-unix-build.tar.xz
+               https://releases.wildfiregames.com/rc/${MY_P}-unix-data.tar.xz
+               verify-sig? (
+                       
https://releases.wildfiregames.com/rc/${MY_P}-unix-build.tar.xz.minisig
+                       
https://releases.wildfiregames.com/rc/${MY_P}-unix-data.tar.xz.minisig
+               )
+       "
+       S="${WORKDIR}/${MY_P/-rc*/}"
+else
+       MY_P="0ad-${PV/_/-}"
+       SRC_URI="
+               https://releases.wildfiregames.com/${MY_P}-unix-build.tar.xz
+               https://releases.wildfiregames.com/${MY_P}-unix-data.tar.xz
+               verify-sig? (
+                       
https://releases.wildfiregames.com/${MY_P}-unix-build.tar.xz.minisig
+                       
https://releases.wildfiregames.com/${MY_P}-unix-data.tar.xz.minisig
+               )
+       "
+       S="${WORKDIR}/${MY_P}"
+fi
+SLOT="0"
+KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86"
+IUSE="editor +lobby nvtt pch test"
+
+RESTRICT="!test? ( test )"
+CHECKREQS_DISK_BUILD="4000M" # 3842680 KiB (3.6 GiB) for alpha 27
+CHECKREQS_DISK_USR="3500M" # 3452564 KiB (3.2 GiB)
+
+BDEPEND="
+       >=dev-util/premake-5.0.0_beta5:5
+       virtual/pkgconfig
+       test? ( ${PYTHON_DEPS} )
+"
+
+# Removed dependency on nvtt as we use the bundled one.
+# bug #768930
+# TODO: use system cxxtest
+DEPEND="
+       dev-lang/spidermonkey:128
+       dev-libs/boost:=
+       dev-libs/icu:=
+       dev-libs/libfmt:0=
+       dev-libs/libsodium:=
+       dev-libs/libxml2:=
+       media-libs/freetype
+       media-libs/libpng:0
+       media-libs/libsdl2[X,opengl,video]
+       media-libs/libvorbis
+       media-libs/openal
+       net-libs/enet:1.3
+       net-libs/miniupnpc:=
+       net-misc/curl
+       virtual/zlib:=
+       virtual/opengl
+       x11-libs/libX11
+       editor? ( x11-libs/wxGTK:${WX_GTK_VER}=[X,opengl] )
+       lobby? ( net-libs/gloox )
+"
+RDEPEND="
+       ${DEPEND}
+"
+
+src_prepare() {
+       default
+
+       # bundled nvtt: -Wodr
+       filter-lto
+
+       # Delete test needing network access
+       rm source/network/tests/test_StunClient.h || die
+}
+
+src_configure() {
+       # 0AD uses premake:5 to generate the Makefiles, so let's
+       # 1. configure the configure args,
+       # 2. export some toolchain args,
+       # 3. configure premake args,
+       # 4. run premake5.
+       local myconf=(
+               --minimal-flags
+               --with-system-mozjs
+               $(usex nvtt "" "--without-nvtt")
+               $(usex pch "" "--without-pch")
+               $(usex test "" "--without-tests")
+               $(usex editor "" "--without-atlas")
+               $(usex lobby "" "--without-lobby")
+               --bindir="/usr/bin"
+               --libdir="/usr/$(get_libdir)"/${PN}
+               --datadir="/usr/share/${PN}"
+       )
+
+       tc-export AR CC CXX PKG_CONFIG RANLIB
+
+       local mypremakeargs=(
+               --file=build/premake/premake5.lua
+               --os=linux
+               --verbose
+       )
+
+       use editor && setup-wxwidgets
+
+       premake5 "${mypremakeargs[@]}" "${myconf[@]}" gmake \
+               || die "Premake failed"
+}
+
+src_compile() {
+       # Build 3rd party fcollada
+       einfo "Building bundled fcollada"
+       JOBS="-j$(makeopts_jobs)" ./libraries/source/fcollada/build.sh || die 
"Failed to build bundled fcollada"
+
+       # Build bundled NVTT
+       # nvtt is abandoned upstream and 0ad has forked it and added fixes.
+       # Use their copy. bug #768930
+       if use nvtt; then
+               elog "Building bundled NVTT (bug #768930)"
+               JOBS="-j$(makeopts_jobs)" ./libraries/source/nvtt/build.sh || 
die "Failed to build bundled NVTT"
+       fi
+
+       # Shouldn't be needed with tests disabled, unfortunatly it still is for 
a27
+       # https://gitea.wildfiregames.com/0ad/0ad/issues/7537
+       einfo "Building bundled cxxtest"
+       JOBS="-j$(makeopts_jobs)" ./libraries/source/cxxtest-4.4/build.sh || 
die "Failed to build bundled cxxtest"
+
+       # Build 0ad itself!
+       elog "Building 0ad"
+       emake -C build/workspaces/default config=release verbose=1
+
+       # Build assets
+       # (We only do this if we're using a snapshot/non-release)
+       # See bug #771147 (comment 3) and the old 0ad-data ebuild
+       # Warning: fragile!
+       if [[ ${PV} == 9999 || ${PV} == *_pre* ]]; then
+               # source/lib/sysdep/os/linux/ldbg.cpp:debug_SetThreadName() 
tries to open /proc/self/task/${TID}/comm for writing.
+               addpredict /proc/self/task
+
+               # Based on source/tools/dist/build-archives.sh used by 
source/tools/dist/build.sh.
+               local archivebuild_input archivebuild_output mod_name
+               for archivebuild_input in binaries/data/mods/[A-Za-z0-9]*; do
+                       mod_name="${archivebuild_input##*/}"
+                       archivebuild_output="archives/${mod_name}"
+
+                       mkdir -p "${archivebuild_output}" || die
+
+                       einfo pyrogenesis -archivebuild="${archivebuild_input}" 
\
+                               
-archivebuild-output="${archivebuild_output}/${mod_name}.zip"
+                       LD_LIBRARY_PATH="binaries/system" 
binaries/system/pyrogenesis \
+                               -archivebuild="${archivebuild_input}" \
+                               
-archivebuild-output="${archivebuild_output}/${mod_name}.zip" \
+                       || die "Failed to build assets"
+
+                       if [[ -f "${archivebuild_input}/mod.json" ]]; then
+                               cp "${archivebuild_input}/mod.json" 
"${archivebuild_output}" || die
+                       fi
+
+                       rm -r "${archivebuild_input}" || die
+                       mv "${archivebuild_output}" "${archivebuild_input}" || 
die
+               done
+
+               # Based on source/tools/dist/build-unix-win32.sh used by 
source/tools/dist/build.sh.
+               rm binaries/data/config/dev.cfg || die
+       fi
+}
+
+# Removed test requiring network access in src_configure
+src_test() {
+       LD_LIBRARY_PATH=$(realpath libraries/source/nvtt/lib/) \
+               ./binaries/system/test --libdir "${S}/binaries/system" || die 
"Failed tests"
+}
+
+src_install() {
+       # Remove transifex tooling configuration
+       rm -r binaries/data/l10n/{.tx,messages.json} || die
+       # Remove test only data
+       rm -r binaries/data/mods/_test.* || die
+
+       newbin binaries/system/pyrogenesis 0ad
+       use editor && newbin binaries/system/ActorEditor 0ad-ActorEditor
+
+       # Merged from 0ad-data
+       # bug #771147 (comment 3)
+       insinto /usr/share/${PN}
+       doins -r binaries/data/{l10n,config,mods,tools}
+
+       # Install bundled nvtt
+       # bug #771147 (comment 1)
+       exeinto /usr/$(get_libdir)/${PN}
+       doexe binaries/system/libCollada.so
+       use nvtt && doexe 
libraries/source/nvtt/lib/{libnvtt,libnvcore,libnvimage,libnvmath}.so
+       use editor && doexe binaries/system/libAtlasUI.so
+
+       dodoc binaries/system/readme.txt
+       doicon -s 128 build/resources/${PN}.png
+       make_desktop_entry ${PN}
+}

diff --git a/games-strategy/0ad/Manifest b/games-strategy/0ad/Manifest
index 2e9086d14e81..584e215d86db 100644
--- a/games-strategy/0ad/Manifest
+++ b/games-strategy/0ad/Manifest
@@ -2,3 +2,7 @@ DIST 0ad-0.27.1-unix-build.tar.xz 153554512 BLAKE2B 
b593a86e6deaeb747d6f2f3b13d0
 DIST 0ad-0.27.1-unix-build.tar.xz.minisig 323 BLAKE2B 
0195cbd966cffa3b2a75eeed6a30d6e65906c7ff5c5435b015716e81ce0636cf04926a7d079ee3a0b5e28268a82cf4a9c75ceac835bf4195f6d489fdf57238e4
 SHA512 
5ffb716aea31e7c4d7a4a49f4fca05b74d2b31d6b4f467d1c53597e35e792c124563aa603ca6f44f989a931b9bbddb0e830381c1b0ffdb3902dd54e25db472bf
 DIST 0ad-0.27.1-unix-data.tar.xz 1367955136 BLAKE2B 
508d43fba489ffdd1d6b5b51127d4a92a75f7b086f10d5673fddb99a33ff9d5007b393ec0e53e97b1401c0cc21794c00cdcab052023be715add29f3a35bc6981
 SHA512 
8d286d4c39bd79f634a71a7959cbc407299ffc1ad53fa27be0fca94195360d8a0c238f64137c1e32a4b5ba66a3a11b86aa8eeed8501253e91ec4767f1054a1d3
 DIST 0ad-0.27.1-unix-data.tar.xz.minisig 322 BLAKE2B 
143d51b6c6c76f4d4a3410a5fb434724b08d5865a454b80b9e7b24540140392c92824918291149a29d8492b36c4e77206f34f68bec01a8b5907b0ee77d68a2dd
 SHA512 
767d8d1c1159dceefb1712883130500f9e5808d3950766fe3e15a101c459d9d29afcbe4222d95809fa0dad759c253ff94394309d2f3ebd3fd5b8a49ff91bd37e
+DIST 0ad-0.28.0-unix-build.tar.xz 164975536 BLAKE2B 
2a2ce580f026c056b3ae97c6539757dd6afea44d7398292eee129a41e36030795ee6fc66a62a71f74bfa7da1aef081ba30bee7fa53b8389ab7e79bce691fbff9
 SHA512 
6b5d7893d27d5fa71ce4cad1b424a7d4b36e8bc438c590cbd86d9872148d5051cd3215f8f8f4b817e48d4fe386d8902ecc0dcd612ca779306ef35dfa2898a878
+DIST 0ad-0.28.0-unix-build.tar.xz.minisig 323 BLAKE2B 
7f4365da1e1e2d027674f524bd3456764b509e99e93801cc8e08acedeaf7b7082e4cbb670d0e0b1429c963a6f8a317e95920eaa82d1dadf45bf38f678fd15595
 SHA512 
31bb2c4d8f35ec1a2e83e0426885f5f9c0d6cf0ff6d568777748be564f736d47026f0fe876c03a39cc8de7ab1be025081bc5f985db91f459ffd15f97e223b0ec
+DIST 0ad-0.28.0-unix-data.tar.xz 1415012652 BLAKE2B 
b255acf538eb75ac523de25c767c48ac67de6cc0470c6d1c816581f41128533cb8eff769f987f4146d62ab6f90084fb81308bcf9bfbe3eca455f59466d065f44
 SHA512 
5ad4473d42a5dd0780a5e40b08ba580757d8266c459d7e17e48dd760e7bbdd5fda9d7be32cf1fa8c331d19a2f464a2d7f8fd5e1b09387a62ae9445ef675f18c8
+DIST 0ad-0.28.0-unix-data.tar.xz.minisig 322 BLAKE2B 
3249a5d5c006056a5e749200f9512341622980eb6d0c1b93fbfd2b6df0ed52c55fffbe5eed5892462c942f828c887b43879f1d677c8b3d1e274cd3430222a40d
 SHA512 
13205289bff4f2890f2f2454a35d737355ea1f15c13b6aa69aeb7c0b7c674918b24295696e7bca3ef83110a806df6e389f76df2db19474b63b4ccff96eb1843c

Reply via email to