gnu: gerbil: Use G-expressions.

* gnu/packages/scheme.scm (gerbil)[source, arguments]: Reindent.
[arguments]: Rewrite using G-expressions. Do not return #t from custom
phases. Use #:tests? instead of deleting the check phase.

Signed-off-by: Ludovic Courtès <ludo@gnu.org>
This commit is contained in:
Juliana Sims 2023-03-28 23:05:15 -04:00 committed by Maxim Cournoyer
parent 5cf4448b5d
commit a9b63e2be1
No known key found for this signature in database
GPG key ID: 1260E46482E63562

View file

@ -1115,30 +1115,32 @@ (define-public gerbil
(package (package
(name "gerbil") (name "gerbil")
(version "0.17.0") (version "0.17.0")
(source (source (origin
(origin
(method git-fetch) (method git-fetch)
(uri (git-reference (uri (git-reference
(url "https://github.com/vyzo/gerbil") (url "https://github.com/vyzo/gerbil")
(commit (string-append "v" version)))) (commit (string-append "v" version))))
(file-name (git-file-name name version)) (file-name (git-file-name name version))
(sha256 (sha256
(base32 "0c0nspm659ybgmqlppdv7sxzll4hwkvcp9qmcsip6d0kz0p8r9c3")))) (base32
"0c0nspm659ybgmqlppdv7sxzll4hwkvcp9qmcsip6d0kz0p8r9c3"))))
(arguments (arguments
`(#:phases (list #:phases
(modify-phases %standard-phases #~(modify-phases %standard-phases
(delete 'bootstrap) (delete 'bootstrap)
(add-before 'configure 'chdir (add-before 'configure 'chdir
(lambda _ (lambda _
(chdir "src") (chdir "src")))
#t))
(replace 'configure (replace 'configure
(lambda* (#:key outputs inputs #:allow-other-keys) (lambda _
(invoke "chmod" "755" "-R" ".") (invoke "chmod" "755" "-R" ".")
;; Otherwise fails when editing an r--r--r-- file. ;; Otherwise fails when editing an r--r--r-- file.
(invoke "gsi-script" "configure" (invoke "gsi-script"
"--prefix" (assoc-ref outputs "out") "configure"
"--with-gambit" (assoc-ref inputs "gambit-c")))) "--prefix"
#$output
"--with-gambit"
#$gambit-c)))
(add-before 'patch-generated-file-shebangs 'fix-gxi-shebangs (add-before 'patch-generated-file-shebangs 'fix-gxi-shebangs
(lambda _ (lambda _
;; Some .ss files refer to gxi using /usr/bin/env gxi ;; Some .ss files refer to gxi using /usr/bin/env gxi
@ -1148,13 +1150,12 @@ (define-public gerbil
;; Doctor Who our fix here before the problem ;; Doctor Who our fix here before the problem
;; happens towards the end of the build.sh script. ;; happens towards the end of the build.sh script.
(let ((abs-srcdir (getcwd))) (let ((abs-srcdir (getcwd)))
(for-each (for-each (lambda (f)
(lambda (f)
(substitute* f (substitute* f
(("#!/usr/bin/env gxi") (("#!/usr/bin/env gxi")
(string-append "#!" abs-srcdir "/../bin/gxi")))) (string-append "#!" abs-srcdir
'("./gerbil/gxc" "/../bin/gxi"))))
"./lang/build.ss" '("./gerbil/gxc" "./lang/build.ss"
"./misc/http-perf/build.ss" "./misc/http-perf/build.ss"
"./misc/rpc-perf/build.ss" "./misc/rpc-perf/build.ss"
"./misc/scripts/docsnarf.ss" "./misc/scripts/docsnarf.ss"
@ -1171,21 +1172,20 @@ (define-public gerbil
"./tutorial/kvstore/build.ss" "./tutorial/kvstore/build.ss"
"./tutorial/lang/build.ss" "./tutorial/lang/build.ss"
"./tutorial/proxy/build-static.ss" "./tutorial/proxy/build-static.ss"
"./tutorial/proxy/build.ss"))) "./tutorial/proxy/build.ss")))))
#t))
(add-after 'configure 'create-gx-version.scm (add-after 'configure 'create-gx-version.scm
(lambda _ (lambda _
(with-output-to-file (string-append (with-output-to-file (string-append (getcwd)
(getcwd)
"/gerbil/runtime/gx-version.scm") "/gerbil/runtime/gx-version.scm")
(lambda _ (lambda _
(write `(define (gerbil-version-string) (write `(define (gerbil-version-string)
,(string-append "v" ,(version-major+minor version)))))))) ,(string-append "v"
(replace #$(version-major+minor
'build version))))))))
(lambda* (replace 'build
(#:key inputs #:allow-other-keys) (lambda _
(setenv "HOME" (getcwd)) (setenv "HOME"
(getcwd))
(invoke (invoke
;; The build script needs a tty or it'll crash on an ioctl ;; The build script needs a tty or it'll crash on an ioctl
;; trying to find the width of the terminal it's running on. ;; trying to find the width of the terminal it's running on.
@ -1193,23 +1193,21 @@ (define-public gerbil
"script" "script"
"-qefc" "-qefc"
"./build.sh"))) "./build.sh")))
(delete 'check)
(replace 'install (replace 'install
(lambda* (#:key outputs #:allow-other-keys) (lambda _
(let* ((out (assoc-ref outputs "out")) (let* ((bin (string-append #$output "/bin"))
(bin (string-append out "/bin")) (lib (string-append #$output "/lib")))
(lib (string-append out "/lib")))
(mkdir-p bin) (mkdir-p bin)
(mkdir-p lib) (mkdir-p lib)
(copy-recursively "../bin" bin) (copy-recursively "../bin" bin)
(copy-recursively "../lib" lib))))))) (copy-recursively "../lib" lib)))))
(native-inputs #:tests? #f))
(list coreutils gambit-c util-linux)) (native-inputs (list coreutils gambit-c util-linux))
(propagated-inputs (propagated-inputs (list gambit-c openssl sqlite zlib))
(list gambit-c zlib openssl sqlite))
(build-system gnu-build-system) (build-system gnu-build-system)
(synopsis "Meta-dialect of Scheme with post-modern features") (synopsis "Meta-dialect of Scheme with post-modern features")
(description "Gerbil is an opinionated dialect of Scheme designed for Systems (description
"Gerbil is an opinionated dialect of Scheme designed for Systems
Programming, with a state of the art macro and module system on top of the Gambit Programming, with a state of the art macro and module system on top of the Gambit
runtime. The macro system is based on quote-syntax, and provides the full meta-syntactic runtime. The macro system is based on quote-syntax, and provides the full meta-syntactic
tower with a native implementation of syntax-case. It also provides a full-blown module tower with a native implementation of syntax-case. It also provides a full-blown module