mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-22 10:39:39 -05:00
95024494f3
* gnu/packages/games.scm (bsd-games): New variable. New patches, taken from Arch and Debian: * gnu/packages/patches/bsd-games-2.17-64bit.patch * gnu/packages/patches/bsd-games-bad-ntohl-cast.patch * gnu/packages/patches/bsd-games-gamescreen.h.patch * gnu/packages/patches/bsd-games-getline.patch * gnu/packages/patches/bsd-games-null-check.patch * gnu/packages/patches/bsd-games-number.c-and-test.patch * gnu/packages/patches/bsd-games-prevent-name-collisions.patch * gnu/packages/patches/bsd-games-stdio.h.patch New patches with our customizations (configure-config built after Arch's): * gnu/packages/patches/bsd-games-add-configure-config.patch * gnu/packages/patches/bsd-games-add-wrapper.patch * gnu/packages/patches/bsd-games-dont-install-empty-files.patch Signed-off-by: Nicolas Goaziou <mail@nicolasgoaziou.fr>
251 lines
10 KiB
Diff
251 lines
10 KiB
Diff
As we cannot install outside the Store, and those games do not create the
|
|
needed writable files on their own, we need a wrapper script.
|
|
|
|
diff -Naur bsd-games-2.17/atc/Makefrag bsd-games-patch/atc/Makefrag
|
|
--- bsd-games-2.17/atc/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/atc/Makefrag 2020-04-23 20:24:04.446176222 +0700
|
|
@@ -47,7 +47,8 @@
|
|
mv atc/lex.yy.c $@
|
|
|
|
atc_install: atc_all
|
|
- $(INSTALL_SCORE_GAME) atc/atc $(INSTALL_PREFIX)$(GAMESDIR)/atc
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/atc
|
|
+ $(INSTALL_SCORE_GAME) atc/atc $(INSTALL_PREFIX)$(GAMESDIR)/.atc-real
|
|
$(HIDE_GAME) atc
|
|
$(INSTALL_SCORE_FILE) $(ATC_SCOREFILE)
|
|
$(INSTALL_MANUAL) atc/atc.6
|
|
diff -Naur bsd-games-2.17/battlestar/Makefrag bsd-games-patch/battlestar/Makefrag
|
|
--- bsd-games-2.17/battlestar/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/battlestar/Makefrag 2020-04-23 20:24:04.482175771 +0700
|
|
@@ -32,7 +32,8 @@
|
|
battlestar_all: battlestar/battlestar battlestar/battlestar.6
|
|
|
|
battlestar_install: battlestar_all
|
|
- $(INSTALL_SCORE_GAME) battlestar/battlestar $(INSTALL_PREFIX)$(GAMESDIR)/battlestar
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/battlestar
|
|
+ $(INSTALL_SCORE_GAME) battlestar/battlestar $(INSTALL_PREFIX)$(GAMESDIR)/.battlestar-real
|
|
$(HIDE_GAME) battlestar
|
|
$(INSTALL_MANUAL) battlestar/battlestar.6
|
|
$(INSTALL_SCORE_FILE) $(BATTLESTAR_SCOREFILE)
|
|
diff -Naur bsd-games-2.17/canfield/canfield/Makefrag bsd-games-patch/canfield/canfield/Makefrag
|
|
--- bsd-games-2.17/canfield/canfield/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/canfield/canfield/Makefrag 2020-04-23 20:24:04.522175270 +0700
|
|
@@ -31,7 +31,8 @@
|
|
canfield_canfield_all: canfield/canfield/canfield canfield/canfield/canfield.6
|
|
|
|
canfield_canfield_install: canfield_canfield_all
|
|
- $(INSTALL_SCORE_GAME) canfield/canfield/canfield $(INSTALL_PREFIX)$(GAMESDIR)/canfield
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/canfield
|
|
+ $(INSTALL_SCORE_GAME) canfield/canfield/canfield $(INSTALL_PREFIX)$(GAMESDIR)/.canfield-real
|
|
$(HIDE_GAME) canfield
|
|
$(INSTALL_MANUAL) canfield/canfield/canfield.6
|
|
$(INSTALL_SCORE_FILE) $(CANFIELD_SCOREFILE)
|
|
diff -ur bsd-games-2.17.orig/canfield/cfscores/Makefrag bsd-games-2.17/canfield/cfscores/Makefrag
|
|
--- bsd-games-2.17.orig/canfield/cfscores/Makefrag 1970-01-01 07:00:01.000000000 +0700
|
|
+++ bsd-games-2.17/canfield/cfscores/Makefrag 2020-08-06 12:20:10.592076477 +0700
|
|
@@ -32,6 +32,7 @@
|
|
canfield_cfscores_all: canfield/cfscores/cfscores
|
|
|
|
canfield_cfscores_install: canfield_cfscores_all
|
|
- $(INSTALL_BINARY) canfield/cfscores/cfscores $(INSTALL_PREFIX)$(GAMESDIR)/cfscores
|
|
+ $(INSTALL_BINARY) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/cfscores
|
|
+ $(INSTALL_BINARY) canfield/cfscores/cfscores $(INSTALL_PREFIX)$(GAMESDIR)/.cfscores-real
|
|
$(HIDE_GAME) cfscores
|
|
$(INSTALL_MANUAL) canfield.6 cfscores.6
|
|
diff -Naur bsd-games-2.17/cribbage/Makefrag bsd-games-patch/cribbage/Makefrag
|
|
--- bsd-games-2.17/cribbage/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/cribbage/Makefrag 2020-04-23 20:24:04.534175120 +0700
|
|
@@ -31,7 +31,8 @@
|
|
cribbage_all: cribbage/cribbage cribbage/cribbage.n cribbage/cribbage.6
|
|
|
|
cribbage_install: cribbage_all
|
|
- $(INSTALL_SCORE_GAME) cribbage/cribbage $(INSTALL_PREFIX)$(GAMESDIR)/cribbage
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/cribbage
|
|
+ $(INSTALL_SCORE_GAME) cribbage/cribbage $(INSTALL_PREFIX)$(GAMESDIR)/.cribbage-real
|
|
$(HIDE_GAME) cribbage
|
|
$(INSTALL_DATA) cribbage/cribbage.n $(INSTALL_PREFIX)$(CRIBBAGE_INSTRFILE)
|
|
$(INSTALL_SCORE_FILE) $(CRIBBAGE_SCOREFILE)
|
|
diff -Naur bsd-games-2.17/hack/Makefrag bsd-games-patch/hack/Makefrag
|
|
--- bsd-games-2.17/hack/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/hack/Makefrag 2020-04-23 20:24:04.590174419 +0700
|
|
@@ -53,7 +53,8 @@
|
|
hack/hack.zap.d hack/rnd.d: hack/hack.onames.h
|
|
|
|
hack_install: hack_all
|
|
- $(INSTALL_SCORE_GAME) hack/hack $(INSTALL_PREFIX)$(GAMESDIR)/hack
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/hack
|
|
+ $(INSTALL_SCORE_GAME) hack/hack $(INSTALL_PREFIX)$(GAMESDIR)/.hack-real
|
|
$(HIDE_GAME) hack
|
|
$(INSTALL_HACK_DIR) $(INSTALL_PREFIX)$(HACK_DIR)
|
|
set -e; for f in data help hh rumors; do $(INSTALL_DATA) hack/$$f $(INSTALL_PREFIX)$(HACK_DIR)/$$f; done
|
|
diff -Naur bsd-games-2.17/phantasia/Makefrag bsd-games-patch/phantasia/Makefrag
|
|
--- bsd-games-2.17/phantasia/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/phantasia/Makefrag 2020-04-23 20:24:04.650173667 +0700
|
|
@@ -38,7 +38,8 @@
|
|
touch phantasia/scorefiles.stamp
|
|
|
|
phantasia_install: phantasia_all
|
|
- $(INSTALL_SCORE_GAME) phantasia/phantasia $(INSTALL_PREFIX)$(GAMESDIR)/phantasia
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/phantasia
|
|
+ $(INSTALL_SCORE_GAME) phantasia/phantasia $(INSTALL_PREFIX)$(GAMESDIR)/.phantasia-real
|
|
$(HIDE_GAME) phantasia
|
|
(set -e; for f in $(phantasia_VFILES1); do \
|
|
cp phantasia/$$f $(INSTALL_PREFIX)$(PHANTASIA_DIR)/$$f; \
|
|
diff -Naur bsd-games-2.17/robots/Makefrag bsd-games-patch/robots/Makefrag
|
|
--- bsd-games-2.17/robots/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/robots/Makefrag 2020-04-23 20:24:04.702173016 +0700
|
|
@@ -32,7 +32,8 @@
|
|
robots_all: robots/robots robots/robots.6
|
|
|
|
robots_install: robots_all
|
|
- $(INSTALL_SCORE_GAME) robots/robots $(INSTALL_PREFIX)$(GAMESDIR)/robots
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/robots
|
|
+ $(INSTALL_SCORE_GAME) robots/robots $(INSTALL_PREFIX)$(GAMESDIR)/.robots-real
|
|
$(HIDE_GAME) robots
|
|
$(INSTALL_SCORE_FILE) $(ROBOTS_SCOREFILE)
|
|
$(INSTALL_MANUAL) robots/robots.6
|
|
diff -Naur bsd-games-2.17/sail/Makefrag bsd-games-patch/sail/Makefrag
|
|
--- bsd-games-2.17/sail/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/sail/Makefrag 2020-04-23 20:24:04.710172917 +0700
|
|
@@ -31,7 +31,8 @@
|
|
sail_all: sail/sail sail/sail.6
|
|
|
|
sail_install: sail_all
|
|
- $(INSTALL_SCORE_GAME) sail/sail $(INSTALL_PREFIX)$(GAMESDIR)/sail
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/sail
|
|
+ $(INSTALL_SCORE_GAME) sail/sail $(INSTALL_PREFIX)$(GAMESDIR)/.sail-real
|
|
$(HIDE_GAME) sail
|
|
$(INSTALL_SCORE_FILE) $(SAIL_SCOREFILE)
|
|
$(INSTALL_SAIL_DIR) $(INSTALL_PREFIX)$(SAIL_DIR)
|
|
diff -Naur bsd-games-2.17/snake/snake/Makefrag bsd-games-patch/snake/snake/Makefrag
|
|
--- bsd-games-2.17/snake/snake/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/snake/snake/Makefrag 2020-04-23 20:24:04.722172766 +0700
|
|
@@ -31,7 +31,8 @@
|
|
snake_snake_all: snake/snake/snake snake/snake/snake.6
|
|
|
|
snake_snake_install: snake_snake_all
|
|
- $(INSTALL_SCORE_GAME) snake/snake/snake $(INSTALL_PREFIX)$(GAMESDIR)/snake
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/snake
|
|
+ $(INSTALL_SCORE_GAME) snake/snake/snake $(INSTALL_PREFIX)$(GAMESDIR)/.snake-real
|
|
$(HIDE_GAME) snake
|
|
$(INSTALL_SCORE_FILE) $(SNAKE_SCOREFILE)
|
|
$(INSTALL_SCORE_FILE) $(SNAKE_RAWSCOREFILE)
|
|
--- bsd-games-2.17.orig/snake/snscore/Makefrag 1970-01-01 07:00:01.000000000 +0700
|
|
+++ bsd-games-2.17/snake/snscore/Makefrag 2020-08-06 12:33:09.636089394 +0700
|
|
@@ -32,6 +32,7 @@
|
|
snake_snscore_all: snake/snscore/snscore
|
|
|
|
snake_snscore_install: snake_snscore_all
|
|
- $(INSTALL_BINARY) snake/snscore/snscore $(INSTALL_PREFIX)$(GAMESDIR)/snscore
|
|
+ $(INSTALL_BINARY) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/snscore
|
|
+ $(INSTALL_BINARY) snake/snscore/snscore $(INSTALL_PREFIX)$(GAMESDIR)/.snscore-real
|
|
$(HIDE_GAME) snscore
|
|
$(INSTALL_MANUAL) snake.6 snscore.6
|
|
diff -Naur bsd-games-2.17/tetris/Makefrag bsd-games-patch/tetris/Makefrag
|
|
--- bsd-games-2.17/tetris/Makefrag 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/tetris/Makefrag 2020-04-23 20:24:04.734172616 +0700
|
|
@@ -32,7 +32,8 @@
|
|
tetris_all: tetris/tetris tetris/tetris.6
|
|
|
|
tetris_install: tetris_all
|
|
- $(INSTALL_SCORE_GAME) tetris/tetris $(INSTALL_PREFIX)$(GAMESDIR)/tetris-bsd
|
|
+ $(INSTALL_SCORE_GAME) wrapper $(INSTALL_PREFIX)$(GAMESDIR)/tetris-bsd
|
|
+ $(INSTALL_SCORE_GAME) tetris/tetris $(INSTALL_PREFIX)$(GAMESDIR)/.tetris-bsd-real
|
|
$(HIDE_GAME) tetris-bsd
|
|
$(INSTALL_SCORE_FILE) $(TETRIS_SCOREFILE)
|
|
ln -f tetris/tetris.6 tetris/tetris-bsd.6
|
|
diff -Naur bsd-games-2.17/wrapper bsd-games-patch/wrapper
|
|
--- bsd-games-2.17/wrapper 1970-01-01 07:00:00.000000000 +0700
|
|
+++ bsd-games-patch/wrapper 2020-04-23 20:24:37.153766719 +0700
|
|
@@ -0,0 +1,91 @@
|
|
+#!/bin/sh
|
|
+# This file works around limitations of our read-only Store.
|
|
+
|
|
+set -e
|
|
+
|
|
+check_empty_files () {
|
|
+ # those start empty
|
|
+ for f in ${@}
|
|
+ do
|
|
+ if [[ ! -f ${f} ]]
|
|
+ then
|
|
+ touch ${f}
|
|
+ echo "$(pwd)/${f} RESTORED"
|
|
+ fi
|
|
+ done
|
|
+}
|
|
+check_data_files () {
|
|
+ # those start with some initial data
|
|
+ for f in ${@}
|
|
+ do
|
|
+ if [[ ! -f ${f} ]]
|
|
+ then
|
|
+ cp STATIC_DATA/${game}/${f} ${f}
|
|
+ chmod u+w ${f}
|
|
+ echo "$(pwd)/${f} RESTORED"
|
|
+ fi
|
|
+ done
|
|
+}
|
|
+visit_dir () {
|
|
+ mkdir -p ${1}
|
|
+ cd ${1}
|
|
+}
|
|
+exit_with_variable_error () {
|
|
+ variables="${1}${2:+ or ${2}}"
|
|
+ echo "Guix: Please set up the ${variables} variable."
|
|
+ echo "Examples:"
|
|
+ echo " export ${1}=/var/multiplayer"
|
|
+ echo " export ${2:-${1}}=~/.local/share/bsd-games"
|
|
+ echo "You can place this in ~/.bashrc or a similar file for Your shell."
|
|
+ echo "For multiplayer this directory should be writable for all players."
|
|
+ exit 1
|
|
+}
|
|
+
|
|
+game=$(basename $0)
|
|
+if [[ ${game} == "hack" ]]
|
|
+then
|
|
+ if [[ -n ${HACKDIR} ]]; then visit_dir "${HACKDIR}"
|
|
+ elif [[ -n ${BSD_GAMES_DIR} ]]; then visit_dir "${BSD_GAMES_DIR}/hack"
|
|
+ else exit_with_variable_error "HACKDIR" "BSD_GAMES_DIR"
|
|
+ fi
|
|
+else
|
|
+ if [[ -n ${BSD_GAMES_DIR} ]]; then visit_dir "${BSD_GAMES_DIR}"
|
|
+ else exit_with_variable_error "BSD_GAMES_DIR"
|
|
+ fi
|
|
+fi
|
|
+
|
|
+case ${game} in
|
|
+ ### Games with score-files
|
|
+ atc)
|
|
+ check_empty_files "atc_score";;
|
|
+ battlestar)
|
|
+ check_empty_files "battlestar.log";;
|
|
+ canfield)
|
|
+ check_empty_files "cfscores";;
|
|
+ cribbage)
|
|
+ check_empty_files "criblog";;
|
|
+ robots)
|
|
+ check_empty_files "robots_roll";;
|
|
+ snake)
|
|
+ check_empty_files "snakerawscores" "snake.log";;
|
|
+ tetris)
|
|
+ check_empty_files "tetris-bsd.scores";;
|
|
+ ### Games with saved state
|
|
+ hack)
|
|
+ check_empty_files "record" "perm"
|
|
+ check_data_files "data" "help" "hh" "rumors"
|
|
+ visit_dir "save"
|
|
+ cd ../../;;
|
|
+ phantasia)
|
|
+ visit_dir "phantasia"
|
|
+ check_empty_files "characs" "gold" "lastdead"\
|
|
+ "mess" "motd" "scoreboard" "void"
|
|
+ check_data_files "monsters"
|
|
+ cd ../;;
|
|
+ sail)
|
|
+ visit_dir "sail"
|
|
+ check_empty_files "log" "syncfile"
|
|
+ cd ../;;
|
|
+esac
|
|
+
|
|
+exec .${game}-real ${@}
|