Gentoo Archives: gentoo-commits

From: Erik Mackdanz <stasibear@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: games-roguelike/stone-soup/files/, games-roguelike/stone-soup/
Date: Sun, 29 Jan 2023 23:41:52
Message-Id: 1675035682.b4cc770e07d3e3df6513b53f9bedc5122f803451.stasibear@gentoo
1 commit: b4cc770e07d3e3df6513b53f9bedc5122f803451
2 Author: Erik Mackdanz <stasibear <AT> gentoo <DOT> org>
3 AuthorDate: Sun Jan 29 23:41:14 2023 +0000
4 Commit: Erik Mackdanz <stasibear <AT> gentoo <DOT> org>
5 CommitDate: Sun Jan 29 23:41:22 2023 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=b4cc770e
7
8 games-roguelike/stone-soup: add 0.30.0_pre20230129
9
10 Signed-off-by: Erik Mackdanz <stasibear <AT> gentoo.org>
11
12 games-roguelike/stone-soup/Manifest | 3 +
13 games-roguelike/stone-soup/files/make-v2.patch | 120 +++++++++++
14 .../stone-soup-0.30.0_pre20230129.ebuild | 238 +++++++++++++++++++++
15 3 files changed, 361 insertions(+)
16
17 diff --git a/games-roguelike/stone-soup/Manifest b/games-roguelike/stone-soup/Manifest
18 index 6935f1e8d89e..e44b6493bc06 100644
19 --- a/games-roguelike/stone-soup/Manifest
20 +++ b/games-roguelike/stone-soup/Manifest
21 @@ -9,6 +9,9 @@ DIST stone-soup-0.28.svg 68546 BLAKE2B 7c66286c9e8a3516e8483b3edb628a59fce29d8d2
22 DIST stone-soup-0.29.1.tar.gz 17510846 BLAKE2B 65b84797c8d8a268a3ce95de9d928e131bf6e21a1ea6ac3e72263c75f9d6288e9d95f9df6401528c06aefbda9bb642c79bf78065a65224297d33c050abf37056 SHA512 2ca49c4cd228526d47e4ad7e9556b6c26566595458423cd8e6b762298f229eb7ba273770ae1e12939ba66574a5b55e44812d06c4809d4327ed9bfd738501af04
23 DIST stone-soup-0.29.png 1351 BLAKE2B cc31abd59701aa6f0fb0bdcd90630ceebf7b3cb8b60f0e2817f8800c5bc4b3a5b9fef63c90a97b6248f306e7e3da0df3863a2195b8771863344d2443e7956d59 SHA512 4695204c8b936f7aac1ba15b02a6115a955fb2c56aa9a0b968ff007bc9a1a59b608110d60cce5625a9b92cd2c869bbea7e15433a53c1a338622809477a5846bc
24 DIST stone-soup-0.29.svg 68546 BLAKE2B 7c66286c9e8a3516e8483b3edb628a59fce29d8d248c3fd5b06e308782bbc651814f21ec958b30c36074a2576ced4bb10f291b5236da6f6e865ce1d7cefdf96d SHA512 dca555271faf704eb8ecdf5ee8a763df42cdeba94e9c163608c438cfc73c6fbf53416547050cad57f477ade191842e701785b65b7a9f18e27ceab05df8f2f75f
25 +DIST stone-soup-0.30.0_pre20230129.tar.gz 20929296 BLAKE2B 4ca826d5157c3530c3d7a1f36aa10cc8fbf961a33aca06e2dcd3afc1896e12babdc8e2e33fd937397d72cded0f208422f21757d95ad70171f4938237f6d4f034 SHA512 9d27d209eaee58bf33eaf84288e3f48b72bfb701496d8c3ac98f6207ef761d23134270a837194e0f18c9a6e64774949b4668929614db1f9a7334e7abbb5db4ea
26 +DIST stone-soup-0.30.png 1351 BLAKE2B cc31abd59701aa6f0fb0bdcd90630ceebf7b3cb8b60f0e2817f8800c5bc4b3a5b9fef63c90a97b6248f306e7e3da0df3863a2195b8771863344d2443e7956d59 SHA512 4695204c8b936f7aac1ba15b02a6115a955fb2c56aa9a0b968ff007bc9a1a59b608110d60cce5625a9b92cd2c869bbea7e15433a53c1a338622809477a5846bc
27 +DIST stone-soup-0.30.svg 68546 BLAKE2B 7c66286c9e8a3516e8483b3edb628a59fce29d8d248c3fd5b06e308782bbc651814f21ec958b30c36074a2576ced4bb10f291b5236da6f6e865ce1d7cefdf96d SHA512 dca555271faf704eb8ecdf5ee8a763df42cdeba94e9c163608c438cfc73c6fbf53416547050cad57f477ade191842e701785b65b7a9f18e27ceab05df8f2f75f
28 DIST stone_soup-0.25.1.zip 95477710 BLAKE2B 0b38a6c7cb7c4c87acccb861b5aae665cd2b6b532f6e86d4a9fa594e0d363b86b4af1ea47275f7fd026ea69d85215be8cdf46258bd620e738b4850e5eceed006 SHA512 fa7e8be582c5c6615531884ade4c113542c06c164b6912095c1adf2f16a31cb2ecce057d74132b11b1b1c256a77433037948d4e54819739b7e222cc896cd5220
29 DIST stone_soup-0.26.1.zip 95585384 BLAKE2B 6d1cb99fc44e918cad4144608f259e67a26df444b93c8501590ff209e8856fd08c514d4c8c78cb0848d8e6127cdf4360b47d21ced5d919da982421934b46102d SHA512 637f1a07e9f35e18eda10c17dc28449364c56aee8456497e30552acb55608a9433cff8b64af877049c21cb2a42eb2fcad28f58a7e57a1d835eb8c252e580205d
30 DIST stone_soup-0.27.1.zip 96934633 BLAKE2B 8821920a4faad9474f08a34ae3c272cb9dcd3ddeb9029e033c22eb8e6650ef20bbc30e0c0ca1556d08c1b7b898fdbdd3667a3ac9a8527e0c322cd8c78ab391bb SHA512 845dafc9895ada3712903de63b95cca9eeb66160e4a04ba21193d916447fca8e7248b851f1e938f43b8d3937cf4f4437443bdc4fe2da893fe3918fed4e0b5204
31
32 diff --git a/games-roguelike/stone-soup/files/make-v2.patch b/games-roguelike/stone-soup/files/make-v2.patch
33 new file mode 100644
34 index 000000000000..7813fa1aebc1
35 --- /dev/null
36 +++ b/games-roguelike/stone-soup/files/make-v2.patch
37 @@ -0,0 +1,120 @@
38 +--- a/Makefile 2023-01-29 16:54:29.445857641 -0600
39 ++++ b/Makefile 2023-01-29 16:55:57.363274244 -0600
40 +@@ -92,7 +92,7 @@
41 + # processes. Not supported for MSYS2/cygwin builds, and will be overridden for
42 + # mac universal builds. This does not count as a change in build flags.
43 + ifndef GAME
44 +- GAME = crawl
45 ++ GAME = crawl-0.30
46 + endif
47 +
48 + # Disable GNU Make implicit rules and variables. Leaving them enabled will slow
49 +@@ -206,7 +206,7 @@
50 + uname_S := $(shell sh -c 'uname -s 2>/dev/null || echo not')
51 + uname_M := $(shell sh -c 'uname -m 2>/dev/null || echo not')
52 +
53 +-HOST := $(shell sh -c 'cc -dumpmachine || echo unknown')
54 ++HOST :=
55 + ARCH := $(HOST)
56 +
57 + ifdef CROSSHOST
58 +@@ -509,15 +509,7 @@
59 + GCC_VER_SUFFIX:=-$(GCC_VER)
60 + endif
61 +
62 +-# Attempt to use a full compiler name, to make
63 +-# distcc builds work nicely.
64 +-LMACH := $(shell gcc -dumpmachine)-
65 +-ifeq ($(LMACH),-)
66 + LMACH :=
67 +-endif
68 +-ifeq ($(shell which $(LMACH)gcc$(GCC_VER_SUFFIX) > /dev/null 2> /dev/null && echo "Yes"),)
69 +-LMACH :=
70 +-endif
71 +
72 + ifneq ($(FORCE_CC),)
73 + GCC := $(FORCE_CC)
74 +@@ -862,10 +854,11 @@
75 + COVERAGE=YesPlease
76 + # current catch2 doesn't support c++11
77 + STDFLAG = -std=c++14
78 ++ # tests require this
79 ++ LIBS += -lgcov
80 + endif
81 +
82 + ifdef HURRY
83 +- NO_OPTIMIZE=YesPlease
84 + endif
85 +
86 + ifdef COVERAGE
87 +@@ -1017,7 +1010,7 @@
88 + INSTALL_FONTS += "$(PROPORTIONAL_FONT)"
89 + endif
90 + else
91 +- SYS_PROPORTIONAL_FONT = $(shell util/find_font "$(OUR_PROPORTIONAL_FONT)")
92 ++ SYS_PROPORTIONAL_FONT = /usr/share/fonts/dejavu/DejaVuSans.ttf
93 + ifneq (,$(SYS_PROPORTIONAL_FONT))
94 + ifeq (,$(COPY_FONTS))
95 + DEFINES += -DPROPORTIONAL_FONT=\"$(SYS_PROPORTIONAL_FONT)\"
96 +@@ -1037,7 +1030,7 @@
97 + INSTALL_FONTS += "$(MONOSPACED_FONT)"
98 + endif
99 + else
100 +- SYS_MONOSPACED_FONT = $(shell util/find_font "$(OUR_MONOSPACED_FONT)")
101 ++ SYS_MONOSPACED_FONT = /usr/share/fonts/dejavu/DejaVuSansMono.ttf
102 + ifneq (,$(SYS_MONOSPACED_FONT))
103 + ifeq (,$(COPY_FONTS))
104 + DEFINES += -DMONOSPACED_FONT=\"$(SYS_MONOSPACED_FONT)\"
105 +@@ -1177,14 +1170,8 @@
106 +
107 + ifdef TILES_ANY
108 + ifndef NO_OPTIMIZE
109 +- ifneq (,$(shell which advpng))
110 +- USE_ADVPNG = y
111 +- else
112 +- ifneq (,$(shell which pngcrush))
113 + PNGCRUSH = pngcrush -q -m 113
114 + PNGCRUSH_LABEL = PNGCRUSH
115 +- endif
116 +- endif
117 + endif
118 + endif
119 +
120 +@@ -1280,9 +1266,8 @@
121 +
122 + LANGUAGES = $(filter-out en, $(notdir $(wildcard dat/descript/??)))
123 + SRC_PKG_BASE := stone_soup
124 +-SRC_VERSION := $(shell git describe $(MERGE_BASE) 2>/dev/null || cat util/release_ver)
125 ++SRC_VERSION := $(shell cat util/release_ver)
126 + MAJOR_VERSION = $(shell echo "$(SRC_VERSION)"|$(SED) -r 's/-.*//;s/^([^.]+\.[^.]+).*/\1/')
127 +-RECENT_TAG := $(shell git describe --abbrev=0 $(MERGE_BASE))
128 + WINARCH := $(shell $(GXX) -dumpmachine | grep -q x64_64 && echo win64 || echo win32)
129 +
130 + export SRC_VERSION
131 +@@ -1644,7 +1629,7 @@
132 + $(COPY) dat/tiles/stone_soup_icon-512x512.png $(prefix_fp)/share/icons/hicolor/512x512/apps/$(XDG_NAME).png
133 + $(COPY) dat/tiles/stone_soup_icon.svg $(prefix_fp)/share/icons/hicolor/scalable/apps/$(XDG_NAME).svg
134 +
135 +-install: all install-data
136 ++install: install-data
137 + [ -d $(prefix_fp)/$(bin_prefix) ] || mkdir -p $(prefix_fp)/$(bin_prefix)
138 + $(COPY) $(GAME) $(prefix_fp)/$(bin_prefix)/
139 + $(STRIP) $(prefix_fp)/$(bin_prefix)/$(GAME)
140 +@@ -1667,7 +1652,6 @@
141 + +$(MAKE) -C contrib clean
142 +
143 + clean-android:
144 +- $(RM) -r $(datadir_fp)
145 + +cd android-project && rm -f local.properties && rm -f app/build.gradle
146 +
147 + distclean: clean clean-contrib clean-rltiles
148 +@@ -1899,9 +1883,6 @@
149 +
150 + dat/tiles/%.png: $(RLTILES)/%.png
151 + $(QUIET_PNGCRUSH)$(PNGCRUSH) $< $@
152 +-ifdef USE_ADVPNG
153 +- $(QUIET_ADVPNG)$(ADVPNG) $@
154 +-endif
155 +
156 + clean-rltiles:
157 + $(RM) $(DESTTILEFILES)
158
159 diff --git a/games-roguelike/stone-soup/stone-soup-0.30.0_pre20230129.ebuild b/games-roguelike/stone-soup/stone-soup-0.30.0_pre20230129.ebuild
160 new file mode 100644
161 index 000000000000..7d2e05402a44
162 --- /dev/null
163 +++ b/games-roguelike/stone-soup/stone-soup-0.30.0_pre20230129.ebuild
164 @@ -0,0 +1,238 @@
165 +# Copyright 1999-2023 Gentoo Authors
166 +# Distributed under the terms of the GNU General Public License v2
167 +
168 +# There are many slots for this package because people in the community
169 +# like to play old versions. Every release includes content changes
170 +# where species/spells/monsters are added or removed. The public
171 +# servers (e.g. http://crawl.akrasiac.org:8080) usually support playing
172 +# versions back to 0.11.
173 +
174 +# It's not necessary for Gentoo to support these old version but it's
175 +# something nice that our distro can offer that others don't. If the
176 +# maintenance burden becomes excessive than we can revisit that
177 +# position.
178 +
179 +EAPI=8
180 +
181 +LUA_COMPAT=( lua5-1 )
182 +LUA_REQ_USE="deprecated"
183 +PYTHON_COMPAT=( python3_{9,10,11} )
184 +VIRTUALX_REQUIRED="manual"
185 +inherit desktop python-any-r1 lua-single xdg-utils toolchain-funcs
186 +
187 +DESCRIPTION="Role-playing roguelike game of exploration and treasure-hunting in dungeons"
188 +HOMEPAGE="https://crawl.develz.org"
189 +SLOT="0.30"
190 +
191 +# Leave empty string if not a _pre release
192 +COMMITSHA="c68057be0a1ad1b17d0337fd8baed0213a428039"
193 +if [ -z "${COMMITSHA}" ]; then
194 + # This is a tagged release
195 + # Note the archive URI and file layout changed upstream between 0.29.0 and 0.29.1
196 + SRC_URI="
197 + https://github.com/crawl/crawl/archive/refs/tags/${PV}.tar.gz -> ${P}.tar.gz
198 + "
199 + MY_P="crawl-${PV}/crawl-ref"
200 +else
201 + # This is a _pre release
202 + SRC_URI="
203 + https://github.com/crawl/crawl/archive/${COMMITSHA}.tar.gz -> ${P}.tar.gz
204 + "
205 + MY_P="crawl-${COMMITSHA}/crawl-ref"
206 +fi
207 +SRC_URI="
208 + ${SRC_URI}
209 + https://dev.gentoo.org/~stasibear/distfiles/${PN}.png -> ${PN}-${SLOT}.png
210 + https://dev.gentoo.org/~stasibear/distfiles/${PN}.svg -> ${PN}-${SLOT}.svg
211 +"
212 +
213 +# 3-clause BSD: mt19937ar.cc, MSVC/stdint.h
214 +# 2-clause BSD: all contributions by Steve Noonan and Jesse Luehrs
215 +# Public Domain|CC0: most of tiles
216 +# MIT: json.cc/json.h, some .js files in webserver/static/scripts/contrib/
217 +LICENSE="GPL-2 BSD BSD-2 public-domain CC0-1.0 MIT"
218 +KEYWORDS="~amd64 ~x86"
219 +IUSE="advpng debug ncurses sound test +tiles"
220 +RESTRICT="!test? ( test )"
221 +REQUIRED_USE="${LUA_REQUIRED_USE}"
222 +
223 +S=${WORKDIR}/${MY_P}/source
224 +RDEPEND="
225 + ${LUA_DEPS}
226 + dev-db/sqlite:3
227 + sys-libs/zlib
228 + !ncurses? ( !tiles? ( sys-libs/ncurses:0 ) )
229 + ncurses? ( sys-libs/ncurses:0 )
230 + tiles? (
231 + media-fonts/dejavu
232 + media-libs/freetype:2
233 + media-libs/libpng:0
234 + sound? (
235 + media-libs/libsdl2[X,opengl,sound,video]
236 + media-libs/sdl2-mixer
237 + )
238 + !sound? ( media-libs/libsdl2[X,opengl,video] )
239 + media-libs/sdl2-image[png]
240 + virtual/glu
241 + virtual/opengl
242 + )"
243 +DEPEND="${RDEPEND}
244 + test? ( <dev-cpp/catch-3.0.0:0 )
245 + tiles? (
246 + sys-libs/ncurses:0
247 + )
248 + "
249 +BDEPEND="
250 + app-arch/unzip
251 + dev-lang/perl
252 + ${PYTHON_DEPS}
253 + $(python_gen_any_dep 'dev-python/pyyaml[${PYTHON_USEDEP}]')
254 + sys-devel/flex
255 + tiles? (
256 + advpng? (
257 + app-arch/advancecomp
258 + )
259 + !advpng? (
260 + media-gfx/pngcrush
261 + )
262 + )
263 + virtual/pkgconfig
264 + app-alternatives/yacc
265 + "
266 +
267 +PATCHES=(
268 + "${FILESDIR}"/make-v2.patch
269 + "${FILESDIR}"/rltiles-make.patch
270 +)
271 +
272 +python_check_deps() {
273 + python_has_version "dev-python/pyyaml[${PYTHON_USEDEP}]"
274 +}
275 +
276 +pkg_setup() {
277 + python-any-r1_pkg_setup
278 +
279 + if use !ncurses && use !tiles ; then
280 + ewarn "Neither ncurses nor tiles frontend"
281 + ewarn "selected, choosing ncurses only."
282 + ewarn "Note that you can also enable both."
283 + fi
284 +
285 + if use sound && use !tiles ; then
286 + ewarn "Sound support is only available with tiles."
287 + fi
288 +}
289 +
290 +src_prepare() {
291 + default
292 + python_fix_shebang "${S}/util/species-gen.py"
293 +
294 + if use advpng; then
295 + eapply "${FILESDIR}/make-advpng.patch"
296 + fi
297 +
298 + sed -i -e "s/GAME = crawl$/GAME = crawl-${SLOT}/" "${S}/Makefile" \
299 + || die "Couldn't append slot to executable name"
300 +
301 + # File required for a _pre build
302 + if ! [ -f "${S}/util/release_ver" ]; then
303 + echo "${SLOT}" >"${S}/util/release_ver" || die "Couldn't write release_ver"
304 + fi
305 +
306 + # Replace bundled catch2 package with system implementation
307 + # https://bugs.gentoo.org/829950
308 + if use test; then
309 + cp /usr/include/catch2/catch.hpp "${S}/catch2-tests" || die "Couldn't substitute system catch2"
310 + fi
311 +}
312 +
313 +src_compile() {
314 +
315 + # Insurance that we're not using bundled lib sources
316 + rm -rf contrib || die "Couldn't delete contrib directory"
317 +
318 + myemakeargs=(
319 + $(usex debug "FULLDEBUG=y DEBUG=y" "")
320 + BUILD_LUA=
321 + AR="$(tc-getAR)"
322 + CFOPTIMIZE=''
323 + # -DLUA_COMPAT_OPENLIB=1 is required to enable the
324 + # deprecated (in 5.1) luaL_openlib API (#869671)
325 + CFOTHERS="${CXXFLAGS} -DLUA_COMPAT_OPENLIB=1"
326 + CONTRIBS=
327 + DATADIR="/usr/share/${PN}-${SLOT}"
328 + FORCE_CC="$(tc-getCC)"
329 + FORCE_CXX="$(tc-getCXX)"
330 + LDFLAGS="${LDFLAGS}"
331 + MAKEOPTS="${MAKEOPTS}"
332 + PKGCONFIG="$(tc-getPKG_CONFIG)"
333 + RANLIB="$(tc-getRANLIB)"
334 + SAVEDIR="~/.crawl-${SLOT}"
335 + SOUND=$(usex sound "y" "")
336 + STRIP=touch
337 + USE_LUAJIT=
338 + V=1
339 + prefix="/usr"
340 + )
341 +
342 + if use ncurses || (use !ncurses && use !tiles) ; then
343 + emake "${myemakeargs[@]}"
344 + # move it in case we build both variants
345 + use tiles && { mv "crawl-${SLOT}" "${WORKDIR}"/crawl-ncurses-${SLOT} || die ;}
346 + fi
347 +
348 + if use tiles ; then
349 + emake "${myemakeargs[@]}" clean
350 + emake "${myemakeargs[@]}" "TILES=y"
351 + fi
352 +}
353 +
354 +src_test() {
355 + emake "${myemakeargs[@]}" \
356 + $(usex tiles "TILES=y" "") \
357 + catch2-tests
358 +}
359 +
360 +src_install() {
361 + emake "${myemakeargs[@]}" \
362 + $(usex tiles "TILES=y" "") \
363 + DESTDIR="${D}" \
364 + prefix_fp="" \
365 + bin_prefix="${D}/usr/bin" \
366 + install
367 +
368 + [[ -e "${WORKDIR}/crawl-ncurses-${SLOT}" ]] && dobin "${WORKDIR}/crawl-ncurses-${SLOT}"
369 +
370 + # don't relocate docs, needed at runtime
371 + rm -rf "${D}/usr/share/${PN}-${SLOT}"/docs/license
372 +
373 + mv "${WORKDIR}/${MY_P}"/docs/crawl.6 "${WORKDIR}/${MY_P}/docs/crawl-${SLOT}.6" \
374 + || die "Couldn't append slot to man page name"
375 + doman "${WORKDIR}/${MY_P}/docs/crawl-${SLOT}.6"
376 +
377 + # icons and menu for graphical build
378 + if use tiles ; then
379 + doicon -s 48 "${DISTDIR}"/${PN}-${SLOT}.png
380 + doicon -s scalable "${DISTDIR}"/${PN}-${SLOT}.svg
381 + make_desktop_entry "crawl-${SLOT}" "crawl-${SLOT}" "crawl-${SLOT}"
382 + fi
383 +}
384 +
385 +pkg_postinst() {
386 + xdg_icon_cache_update
387 +
388 + elog "crawl is a slotted install that supports having"
389 + elog "multiple versions installed. The binary has the"
390 + elog "slot appended, e.g. 'crawl-"${SLOT}"'."
391 +
392 + if use tiles && use ncurses ; then
393 + elog
394 + elog "Since you have enabled both tiles and ncurses frontends"
395 + elog "the ncurses binary is called 'crawl-ncurses-"${SLOT}"' and the"
396 + elog "tiles binary is called 'crawl-"${SLOT}"'."
397 + fi
398 +}
399 +
400 +pkg_postrm() {
401 + xdg_icon_cache_update
402 +}