gnu: fish: Update to 3.2.2.

* gnu/packages/shells.scm (fish): Update to 3.2.2.
[source]: Adjust to PCRE subdirectory move.
[native-inputs]: Add procps.
[arguments]: Adjust 'patch-tests phase to new failures.
This commit is contained in:
Tobias Geerinckx-Rice 2021-05-06 21:48:21 +02:00
parent f285b31522
commit 2d51775c2c
No known key found for this signature in database
GPG key ID: 0DB0FF884F556D79

View file

@ -112,19 +112,20 @@ (define-public dash
(define-public fish (define-public fish
(package (package
(name "fish") (name "fish")
(version "3.1.2") (version "3.2.2")
(source (source
(origin (origin
(method url-fetch) (method url-fetch)
(uri (string-append "https://github.com/fish-shell/fish-shell/" (uri (string-append "https://github.com/fish-shell/fish-shell/"
"releases/download/" version "/" "releases/download/" version "/"
"fish-" version ".tar.gz")) "fish-" version ".tar.xz"))
(sha256 (sha256
(base32 "1vblmb3x2k2cb0db5jdyflppnlqsm7i6jjaidyhmvaaw7ch2gffm")) (base32 "02a0dgz5cy4iv3ysvl5kzzd4ji8pxqv93zd45041plcki0ddli2r"))
(modules '((guix build utils))) (modules '((guix build utils)))
(snippet (snippet
'(begin '(begin
(delete-file-recursively "pcre2-10.32") #t)))) ;; Remove bundled software.
(delete-file-recursively "pcre2")))))
(build-system cmake-build-system) (build-system cmake-build-system)
(inputs (inputs
`(("fish-foreign-env" ,fish-foreign-env) `(("fish-foreign-env" ,fish-foreign-env)
@ -133,8 +134,8 @@ (define-public fish
("python" ,python))) ; for fish_config and manpage completions ("python" ,python))) ; for fish_config and manpage completions
(native-inputs (native-inputs
`(("doxygen" ,doxygen) `(("doxygen" ,doxygen)
; for 'fish --help' ("groff" ,groff) ; for 'fish --help'
("groff" ,groff))) ("procps" ,procps))) ; for the test suite
(arguments (arguments
'(#:phases '(#:phases
(modify-phases %standard-phases (modify-phases %standard-phases
@ -147,12 +148,15 @@ (define-public fish
(lambda* (#:key inputs #:allow-other-keys) (lambda* (#:key inputs #:allow-other-keys)
(let ((coreutils (assoc-ref inputs "coreutils")) (let ((coreutils (assoc-ref inputs "coreutils"))
(bash (assoc-ref inputs "bash"))) (bash (assoc-ref inputs "bash")))
;; This test fails ;; This test fails.
(delete-file "tests/checks/pipeline-pgroup.fish") (delete-file "tests/checks/pipeline-pgroup.fish")
;; These try to open a terminal ;; This one tries to open a terminal & can't simply be deleted.
(delete-file "tests/checks/interactive.fish") (substitute* "cmake/Tests.cmake"
(delete-file "tests/checks/login-interactive.fish") ((".* interactive\\.fish.*") ""))
;; These contain absolute path references ;; This one needs to chdir successfully.
(substitute* "tests/checks/vars_as_commands.fish"
(("/usr/bin") "/tmp"))
;; These contain absolute path references.
(substitute* "src/fish_tests.cpp" (substitute* "src/fish_tests.cpp"
(("/bin/echo" echo) (string-append coreutils echo)) (("/bin/echo" echo) (string-append coreutils echo))
(("/bin/ca" ca) (string-append coreutils ca)) (("/bin/ca" ca) (string-append coreutils ca))
@ -165,7 +169,10 @@ (define-public fish
(((string-append (((string-append
"do_test\\(is_potential_path\\(" "do_test\\(is_potential_path\\("
"L\"/usr\", wds, vars, PATH_REQUIRE_DIR\\)\\);")) "L\"/usr\", wds, vars, PATH_REQUIRE_DIR\\)\\);"))
"")) "")
;; Not all mentions of /usr... need to exist, but these do.
(("\"/usr(|/lib)\"" _ subdirectory)
(string-append "\"/tmp" subdirectory "\"")))
(substitute* (substitute*
(append (find-files "tests" ".*\\.(in|out|err)$") (append (find-files "tests" ".*\\.(in|out|err)$")
(find-files "tests/checks" ".*\\.fish")) (find-files "tests/checks" ".*\\.fish"))