mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-18 02:44:30 +00:00
fish: 3.1.0 -> 3.1.1
https://github.com/fish-shell/fish-shell/compare/3.1.0...3.1.1 The patch we had to use for Apple SDKs was merged upstream, so it can be dropped. I ran nixpkgs-fmt, and removed the `with stdenv.lib;` scope expander. Additionally, did a little bit of cleanup. I plan on refactoring this more down the line, but this'll do for now. I finally figured out why we use `fetchurl` for the tagged release: the published release tarballs contain a version file, which the `build_tools/git_version_gen.sh` script reads (and uses as the version if it exists). The other thing it contains are pre-generated docs for various `fish` builtins. I've expanded the comment to document this so nobody is as confused as I was when I first saw it. (Though I plan to change this and add sphinx as a native build input in order to build the docs ourselves.)
This commit is contained in:
parent
c52cc1953c
commit
a43ae05369
@ -1,20 +1,27 @@
|
|||||||
{ stdenv, fetchurl, coreutils, utillinux,
|
{ stdenv
|
||||||
which, gnused, gnugrep,
|
, lib
|
||||||
groff, man-db, getent, libiconv, pcre2,
|
, fetchurl
|
||||||
gettext, ncurses, python3,
|
, coreutils
|
||||||
cmake
|
, utillinux
|
||||||
, fetchpatch
|
, which
|
||||||
|
, gnused
|
||||||
, writeText
|
, gnugrep
|
||||||
, nixosTests
|
, groff
|
||||||
, useOperatingSystemEtc ? true
|
, man-db
|
||||||
|
, getent
|
||||||
|
, libiconv
|
||||||
|
, pcre2
|
||||||
|
, gettext
|
||||||
|
, ncurses
|
||||||
|
, python3
|
||||||
|
, cmake
|
||||||
|
|
||||||
|
, writeText
|
||||||
|
, nixosTests
|
||||||
|
, useOperatingSystemEtc ? true
|
||||||
}:
|
}:
|
||||||
|
|
||||||
with stdenv.lib;
|
|
||||||
|
|
||||||
let
|
let
|
||||||
etcConfigAppendixText = ''
|
etcConfigAppendix = writeText "config.fish.appendix" ''
|
||||||
############### ↓ Nix hook for sourcing /etc/fish/config.fish ↓ ###############
|
############### ↓ Nix hook for sourcing /etc/fish/config.fish ↓ ###############
|
||||||
# #
|
# #
|
||||||
# Origin:
|
# Origin:
|
||||||
@ -46,7 +53,7 @@ let
|
|||||||
############### ↑ Nix hook for sourcing /etc/fish/config.fish ↑ ###############
|
############### ↑ Nix hook for sourcing /etc/fish/config.fish ↑ ###############
|
||||||
'';
|
'';
|
||||||
|
|
||||||
fishPreInitHooks = ''
|
fishPreInitHooks = writeText "__fish_build_paths_suffix.fish" ''
|
||||||
# source nixos environment
|
# source nixos environment
|
||||||
# note that this is required:
|
# note that this is required:
|
||||||
# 1. For all shells, not just login shells (mosh needs this as do some other command-line utilities)
|
# 1. For all shells, not just login shells (mosh needs this as do some other command-line utilities)
|
||||||
@ -90,40 +97,45 @@ let
|
|||||||
|
|
||||||
fish = stdenv.mkDerivation rec {
|
fish = stdenv.mkDerivation rec {
|
||||||
pname = "fish";
|
pname = "fish";
|
||||||
version = "3.1.0";
|
version = "3.1.1";
|
||||||
|
|
||||||
etcConfigAppendix = builtins.toFile "etc-config.appendix.fish" etcConfigAppendixText;
|
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
# There are differences between the release tarball and the tarball github packages from the tag
|
# There are differences between the release tarball and the tarball GitHub
|
||||||
# Hence we cannot use fetchFromGithub
|
# packages from the tag. Specifically, it comes with a file containing its
|
||||||
|
# version, which is used in `build_tools/git_version_gen.sh` to determine
|
||||||
|
# the shell's actual version (and what it displays when running `fish
|
||||||
|
# --version`), as well as the local documentation for all builtins (and
|
||||||
|
# maybe other things).
|
||||||
url = "https://github.com/fish-shell/fish-shell/releases/download/${version}/${pname}-${version}.tar.gz";
|
url = "https://github.com/fish-shell/fish-shell/releases/download/${version}/${pname}-${version}.tar.gz";
|
||||||
sha256 = "0s2356mlx7fp9kgqgw91lm5ds2i9iq9hq071fbqmcp3875l1xnz5";
|
sha256 = "1f12c56v7n4s0f9mi9xinviwj6kpwlcjwaig1d4vsk5wlgp7ip07";
|
||||||
};
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ cmake ];
|
nativeBuildInputs = [
|
||||||
buildInputs = [ ncurses libiconv pcre2 ];
|
cmake
|
||||||
|
];
|
||||||
|
|
||||||
|
buildInputs = [
|
||||||
|
ncurses
|
||||||
|
libiconv
|
||||||
|
pcre2
|
||||||
|
];
|
||||||
|
|
||||||
preConfigure = ''
|
preConfigure = ''
|
||||||
patchShebangs ./build_tools/git_version_gen.sh
|
patchShebangs ./build_tools/git_version_gen.sh
|
||||||
'';
|
'';
|
||||||
|
|
||||||
patches = [
|
|
||||||
# Fixes compilation on old Apple SDKs
|
|
||||||
(fetchpatch {
|
|
||||||
url = "https://github.com/fish-shell/fish-shell/commit/10385d422b3e2a823faebfdaf13edd0e7f48a27f.patch";
|
|
||||||
sha256 = "0hj13kyjf5wr9j5afd4mfylcr7mz68ilbncbcf307drk1lv1lvrn";
|
|
||||||
})
|
|
||||||
];
|
|
||||||
|
|
||||||
# Required binaries during execution
|
# Required binaries during execution
|
||||||
# Python: Autocompletion generated from manpages and config editing
|
# Python: Autocompletion generated from manpages and config editing
|
||||||
propagatedBuildInputs = [
|
propagatedBuildInputs = [
|
||||||
coreutils gnugrep gnused
|
coreutils
|
||||||
python3 groff gettext
|
gnugrep
|
||||||
] ++ optional (!stdenv.isDarwin) man-db;
|
gnused
|
||||||
|
python3
|
||||||
|
groff
|
||||||
|
gettext
|
||||||
|
] ++ lib.optional (!stdenv.isDarwin) man-db;
|
||||||
|
|
||||||
postInstall = ''
|
postInstall = with lib; ''
|
||||||
sed -r "s|command grep|command ${gnugrep}/bin/grep|" \
|
sed -r "s|command grep|command ${gnugrep}/bin/grep|" \
|
||||||
-i "$out/share/fish/functions/grep.fish"
|
-i "$out/share/fish/functions/grep.fish"
|
||||||
sed -i "s|which |${which}/bin/which |" \
|
sed -i "s|which |${which}/bin/which |" \
|
||||||
@ -162,14 +174,14 @@ let
|
|||||||
sed -i "s|command manpath|command ${man-db}/bin/manpath|" \
|
sed -i "s|command manpath|command ${man-db}/bin/manpath|" \
|
||||||
"$out/share/fish/functions/man.fish"
|
"$out/share/fish/functions/man.fish"
|
||||||
'' + optionalString useOperatingSystemEtc ''
|
'' + optionalString useOperatingSystemEtc ''
|
||||||
tee -a $out/etc/fish/config.fish < ${(writeText "config.fish.appendix" etcConfigAppendixText)}
|
tee -a $out/etc/fish/config.fish < ${etcConfigAppendix}
|
||||||
'' + ''
|
'' + ''
|
||||||
tee -a $out/share/fish/__fish_build_paths.fish < ${(writeText "__fish_build_paths_suffix.fish" fishPreInitHooks)}
|
tee -a $out/share/fish/__fish_build_paths.fish < ${fishPreInitHooks}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with lib; {
|
||||||
description = "Smart and user-friendly command line shell";
|
description = "Smart and user-friendly command line shell";
|
||||||
homepage = "http://fishshell.com/";
|
homepage = "http://fishshell.com/";
|
||||||
license = licenses.gpl2;
|
license = licenses.gpl2;
|
||||||
@ -188,21 +200,22 @@ let
|
|||||||
# Test the fish_config tool by checking the generated splash page.
|
# Test the fish_config tool by checking the generated splash page.
|
||||||
# Since the webserver requires a port to run, it is not started.
|
# Since the webserver requires a port to run, it is not started.
|
||||||
fishConfig =
|
fishConfig =
|
||||||
let fishScript = writeText "test.fish" ''
|
let
|
||||||
set -x __fish_bin_dir ${fish}/bin
|
fishScript = writeText "test.fish" ''
|
||||||
echo $__fish_bin_dir
|
set -x __fish_bin_dir ${fish}/bin
|
||||||
cp -r ${fish}/share/fish/tools/web_config/* .
|
echo $__fish_bin_dir
|
||||||
chmod -R +w *
|
cp -r ${fish}/share/fish/tools/web_config/* .
|
||||||
# we delete everything after the fileurl is assigned
|
chmod -R +w *
|
||||||
sed -e '/fileurl =/q' -i webconfig.py
|
# we delete everything after the fileurl is assigned
|
||||||
echo "print(fileurl)" >> webconfig.py
|
sed -e '/fileurl =/q' -i webconfig.py
|
||||||
# and check whether the message appears on the page
|
echo "print(fileurl)" >> webconfig.py
|
||||||
cat (${python3}/bin/python ./webconfig.py \
|
# and check whether the message appears on the page
|
||||||
| tail -n1 | sed -ne 's|.*\(/tmp/.*\)|\1|p' \
|
cat (${python3}/bin/python ./webconfig.py \
|
||||||
) | grep 'a href="http://localhost.*Start the Fish Web config'
|
| tail -n1 | sed -ne 's|.*\(/tmp/.*\)|\1|p' \
|
||||||
|
) | grep 'a href="http://localhost.*Start the Fish Web config'
|
||||||
|
|
||||||
# cannot test the http server because it needs a localhost port
|
# cannot test the http server because it needs a localhost port
|
||||||
'';
|
'';
|
||||||
in ''
|
in ''
|
||||||
HOME=$(mktemp -d)
|
HOME=$(mktemp -d)
|
||||||
${fish}/bin/fish ${fishScript}
|
${fish}/bin/fish ${fishScript}
|
||||||
@ -210,6 +223,6 @@ let
|
|||||||
};
|
};
|
||||||
|
|
||||||
# FIXME(Profpatsch) replace withTests stub
|
# FIXME(Profpatsch) replace withTests stub
|
||||||
withTests = flip const;
|
withTests = with lib; flip const;
|
||||||
|
in
|
||||||
in withTests tests fish
|
withTests tests fish
|
||||||
|
Loading…
Reference in New Issue
Block a user