From: nee <nee@cock.li>
To: Arun Isaac <arunisaac@systemreboot.net>
Cc: 26488@debbugs.gnu.org
Subject: bug#26488: [PATCH] gnu: Add crawl.
Date: Fri, 14 Apr 2017 18:10:49 +0200 [thread overview]
Message-ID: <f0593d7a-2db6-fad7-99c9-3b180c55e068@cock.li> (raw)
In-Reply-To: <791d5ba7.AEQAJP3OyzEAAAAAAAAAAAO02gcAAAACwQwAAAAAAAW9WABY8IM9@mailjet.com>
[-- Attachment #1: Type: text/plain, Size: 3661 bytes --]
Hello, thank you for reviewing my patch.
Am 14.04.2017 um 10:07 schrieb Arun Isaac:
>
> Thanks for the patch!
>
>>> + (uri (list
>>> + ;; Older releases get moved into a versioned directory
>>> + (string-append "http://crawl.develz.org/release/"
>>> + (version-major+minor version) "/stone_soup-"
>>> + version "-nodeps.tar.xz")
>>> + ;; Only the latest release is in this directory
>>> + (string-append "http://crawl.develz.org/release/stone_soup-"
>>> + version "-nodeps.tar.xz")))
>
> Why do we need two URIs? Shouldn't the latest release alone be enough?
> Isn't that the only release we need to build?
>
My thought is that this way the build won't break in the same moment a
new version is released, since the referenced tar 404s when they move it.
>>> + (arguments
>>> + '(#:tests? #f
>
> The release tarball does seem to come with tests. Could you package them
> as well?
>
Ah, I missed those because they are in make test and not make check.
I tried to package them now, but the tests need to create a directory in
home. This fails and I don't know how to handle this with guix.
I need some help here.
>>> + #:phases
>>> + (modify-phases
>>> + %standard-phases
>
> Please put modify-phases and %standard-phases on the same line like:
>
> (modify-phases %standard-phases
>
Okay, done.
>>> + (add-after
>>> + 'unpack 'prepare-before-make
>>> + (lambda* (#:key inputs #:allow-other-keys)
>>> + (chdir "source")))
>
> I haven't actually tried building the package, but is this phase
> necessary? If you do want to change directory before running make, you
> can pass "-C" and "source" as #:make-flags.
>
Yes, it works great!
I didn't know about that before, thank you.
>>> + (add-before
>>> + 'configure 'patch-makefile
>>> + (lambda* (#:key inputs #:allow-other-keys)
>>> + (substitute*
>>> + "Makefile"
>>> + (("SQLITE_INCLUDE_DIR := /usr/include")
>>> + "SQLITE_INCLUDE_DIR := ${sqlite}/include"))
>>> + (substitute*
>>> + "Makefile"
>>> + (("/usr/share/fonts /usr/local/share/fonts /usr/*/lib/X11/fonts;")
>>> + "${dejavu_fonts}/share/fonts;"))))
>>> + (delete 'configure))))
>
> You should be able to do this using #:make-flags. See
> https://www.gnu.org/software/make/manual/html_node/Overriding.html
>
100% right!
I also removed the second substitute, since fonts are only required for
the graphical version.
I started packaging this more than half a year ago and only recently
decided to give it another try and remove the graphical version. Seems
like I still missed out on removing a lot of the mess.
>>> + (description "A roguelike adventure through dungeons filled with dangerous
>>> +monsters in a quest to find the mystifyingly fabulous Orb of Zot.
>>> +The game is also known under the name 'Dungeon Crawl Stone Soup'.")
>
> Could you make this "Dungeon Crawl Stone Soup is a roguelike adventure
> ... "? Also, remove the last sentence "The game is also known as ...".
>
>>> + (license license:gpl2+)))
>
> licence.txt mentions multiple licenses. Could you mention them all as a
> list of licenses?
>
>
>
I did both now. I hope this is the right way.
I'm appending my current WIP version.
The test phase is broken and I'll need help, as I said above.
When I disable the tests, the game builds and can be played.
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-gnu-Add-crawl.patch --]
[-- Type: text/x-patch; name="0001-gnu-Add-crawl.patch", Size: 3851 bytes --]
From ddb53e51bbc8592e32b81cfcc4773de1a6ba2b6c Mon Sep 17 00:00:00 2001
From: nee <nee.git@cock.li>
Date: Thu, 13 Apr 2017 22:45:18 +0200
Subject: [PATCH] gnu: Add crawl.
* gnu/packages/games.scm (crawl): New variable.
---
gnu/packages/games.scm | 70 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 70 insertions(+)
diff --git a/gnu/packages/games.scm b/gnu/packages/games.scm
index 710b2746c..c145ba830 100644
--- a/gnu/packages/games.scm
+++ b/gnu/packages/games.scm
@@ -115,6 +115,8 @@
#:use-module (gnu packages messaging)
#:use-module (gnu packages upnp)
#:use-module (gnu packages wxwidgets)
+ #:use-module (gnu packages bison)
+ #:use-module (gnu packages flex)
#:use-module (guix build-system gnu)
#:use-module (guix build-system haskell)
#:use-module (guix build-system python)
@@ -3649,3 +3651,71 @@ small robot living in the nano world, repair its maker.")
;; kiki-the-nano-bot/kiki-the-nano-bot_1.0.2+dfsg1-4_copyright>
;; for a statement from the author.
(license license:public-domain)))
+
+(define-public crawl
+ (package
+ (name "crawl")
+ (version "0.19.5")
+ (source (origin
+ (method url-fetch)
+ (uri (list
+ ;; Older releases get moved into a versioned directory
+ (string-append "http://crawl.develz.org/release/"
+ (version-major+minor version) "/stone_soup-"
+ version "-nodeps.tar.xz")
+ ;; Only the latest release is in this directory
+ (string-append "http://crawl.develz.org/release/stone_soup-"
+ version "-nodeps.tar.xz")))
+ (sha256
+ (base32
+ "00yl2lb2shglxlxzpyk99zvglfx4amjybqwnzdcasvbiggb4cj18"))))
+ (arguments
+ '(#:make-flags
+ (let* ((sqlite (assoc-ref %build-inputs "sqlite"))
+ (out (assoc-ref %outputs "out")))
+ (list (string-append "SQLITE_INCLUDE_DIR=" sqlite "/include")
+ (string-append "prefix=" out)
+ "SAVEDIR=~/.crawl"
+ "TILES="
+ "BUILD_LUA="
+ "BUILD_SQLITE="
+ "BUILD_ZLIB="
+ "-Csource"))
+ #:phases
+ (modify-phases %standard-phases
+ (delete 'configure)
+ (replace
+ 'check
+ (lambda* (#:key inputs outputs #:allow-other-keys)
+ (let* ((out (assoc-ref outputs "out")))
+ (and
+ (mkdir-p "~/.crawl/saves")
+ (zero? (system*
+ "make" "test"
+ (string-append "prefix=" out)
+ "TILES="
+ "BUILD_LUA="
+ "BUILD_SQLITE="
+ "BUILD_ZLIB="
+ "-Csource")))))))))
+ (build-system gnu-build-system)
+ (inputs `(("ncurses" ,ncurses)
+ ("sqlite" ,sqlite)
+ ("bison" ,bison)
+ ("flex" ,flex)
+ ("zlib" ,zlib)
+ ("lua51" ,lua-5.1)))
+ (native-inputs `(("pkg-config" ,pkg-config)
+ ("perl" ,perl)))
+ (synopsis "Roguelike dungeon crawler game")
+ (description "Dungeon Crawl Stone Soup is a roguelike adventure through
+dungeons filled with dangerous monsters in a quest to find the mystifyingly
+fabulous Orb of Zot.")
+ (home-page "https://crawl.develz.org")
+ (license (list license:gpl2+
+ license:bsd-2
+ license:bsd-3
+ license:cc0
+ license:x11
+ license:zlib
+ license:asl2.0))))
--
2.12.2
next prev parent reply other threads:[~2017-04-14 16:54 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-04-13 21:26 bug#26488: [PATCH] gnu: Add crawl nee
[not found] ` <cu7shlbed1g.fsf@systemreboot.net>
2017-04-14 8:07 ` Arun Isaac
2017-04-14 16:10 ` nee [this message]
2017-04-14 17:23 ` Danny Milosavljevic
2017-04-14 18:04 ` Arun Isaac
[not found] ` <c09ea559.AEMAJMF3UlcAAAAAAAAAAAO0_XAAAAACwQwAAAAAAAW9WABY8Q9P@mailjet.com>
2017-04-17 4:46 ` nee
2017-04-17 18:37 ` Arun Isaac
2017-04-18 22:15 ` nee
2017-04-19 6:11 ` Arun Isaac
2017-04-21 17:10 ` Christopher Allan Webber
2017-04-21 20:25 ` Arun Isaac
2017-04-17 19:29 ` Arun Isaac
2017-04-17 21:29 ` nee
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://guix.gnu.org/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=f0593d7a-2db6-fad7-99c9-3b180c55e068@cock.li \
--to=nee@cock.li \
--cc=26488@debbugs.gnu.org \
--cc=arunisaac@systemreboot.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/guix.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).