uboot: (firmwareOdroidC2/C4) don't invoke patch tool, use patches = [] instead
https://github.com/NixOS/nixpkgs/blob/master/pkgs/stdenv/generic/setup.sh#L948 this can do it nicely. Signed-off-by: Anton Arapov <anton@deadbeef.mx>
This commit is contained in:
commit
56de2bcd43
30691 changed files with 3076956 additions and 0 deletions
95
pkgs/tools/misc/man-db/default.nix
Normal file
95
pkgs/tools/misc/man-db/default.nix
Normal file
|
|
@ -0,0 +1,95 @@
|
|||
{ buildPackages
|
||||
, db
|
||||
, fetchurl
|
||||
, groff
|
||||
, lib
|
||||
, libiconv
|
||||
, libpipeline
|
||||
, makeWrapper
|
||||
, nixosTests
|
||||
, pkg-config
|
||||
, stdenv
|
||||
, zstd
|
||||
, autoreconfHook
|
||||
}:
|
||||
|
||||
stdenv.mkDerivation rec {
|
||||
pname = "man-db";
|
||||
version = "2.10.2";
|
||||
|
||||
src = fetchurl {
|
||||
url = "mirror://savannah/man-db/man-db-${version}.tar.xz";
|
||||
sha256 = "sha256-7peVTUkqE3MZA8nQcnubAeUIntvWlfDNtY1AWlr1UU0=";
|
||||
};
|
||||
|
||||
outputs = [ "out" "doc" ];
|
||||
outputMan = "out"; # users will want `man man` to work
|
||||
|
||||
strictDeps = true;
|
||||
nativeBuildInputs = [ autoreconfHook groff makeWrapper pkg-config zstd ];
|
||||
buildInputs = [ libpipeline db groff ]; # (Yes, 'groff' is both native and build input)
|
||||
checkInputs = [ libiconv /* for 'iconv' binary */ ];
|
||||
|
||||
patches = [ ./systemwide-man-db-conf.patch ];
|
||||
|
||||
postPatch = ''
|
||||
# Remove all mandatory manpaths. Nixpkgs makes no requirements on
|
||||
# these directories existing.
|
||||
sed -i 's/^MANDATORY_MANPATH/# &/' src/man_db.conf.in
|
||||
|
||||
# Add Nix-related manpaths
|
||||
echo "MANPATH_MAP /nix/var/nix/profiles/default/bin /nix/var/nix/profiles/default/share/man" >> src/man_db.conf.in
|
||||
|
||||
# Add mandb locations for the above
|
||||
echo "MANDB_MAP /nix/var/nix/profiles/default/share/man /var/cache/man/nixpkgs" >> src/man_db.conf.in
|
||||
'';
|
||||
|
||||
configureFlags = [
|
||||
"--disable-setuid"
|
||||
"--disable-cache-owner"
|
||||
"--localstatedir=/var"
|
||||
"--with-config-file=${placeholder "out"}/etc/man_db.conf"
|
||||
"--with-systemdtmpfilesdir=${placeholder "out"}/lib/tmpfiles.d"
|
||||
"--with-systemdsystemunitdir=${placeholder "out"}/lib/systemd/system"
|
||||
"--with-pager=less"
|
||||
] ++ lib.optional stdenv.hostPlatform.isDarwin [
|
||||
"ac_cv_func__set_invalid_parameter_handler=no"
|
||||
"ac_cv_func_posix_fadvise=no"
|
||||
"ac_cv_func_mempcpy=no"
|
||||
];
|
||||
|
||||
preConfigure = ''
|
||||
configureFlagsArray+=("--with-sections=1 n l 8 3 0 2 5 4 9 6 7")
|
||||
'';
|
||||
|
||||
postInstall = ''
|
||||
# apropos/whatis uses program name to decide whether to act like apropos or whatis
|
||||
# (multi-call binary). `apropos` is actually just a symlink to whatis. So we need to
|
||||
# make sure that we don't wrap symlinks (since that changes argv[0] to the -wrapped name)
|
||||
find "$out/bin" -type f | while read file; do
|
||||
wrapProgram "$file" \
|
||||
--prefix PATH : "${lib.getBin groff}/bin" \
|
||||
--prefix PATH : "${lib.getBin zstd}/bin"
|
||||
done
|
||||
'';
|
||||
|
||||
disallowedReferences = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
|
||||
buildPackages.groff
|
||||
];
|
||||
|
||||
enableParallelBuilding = true;
|
||||
|
||||
doCheck = !stdenv.hostPlatform.isMusl /* iconv binary */ && !stdenv.hostPlatform.isDarwin;
|
||||
|
||||
passthru.tests = {
|
||||
nixos = nixosTests.man;
|
||||
};
|
||||
|
||||
meta = with lib; {
|
||||
homepage = "http://man-db.nongnu.org";
|
||||
description = "An implementation of the standard Unix documentation system accessed using the man command";
|
||||
license = licenses.gpl2;
|
||||
platforms = lib.platforms.unix;
|
||||
mainProgram = "man";
|
||||
};
|
||||
}
|
||||
39
pkgs/tools/misc/man-db/systemwide-man-db-conf.patch
Normal file
39
pkgs/tools/misc/man-db/systemwide-man-db-conf.patch
Normal file
|
|
@ -0,0 +1,39 @@
|
|||
commit 9089291006a4258c39c75a920ad536b61504251a
|
||||
Author: rnhmjoj <rnhmjoj@inventati.org>
|
||||
Date: Fri May 1 19:32:15 2020 +0200
|
||||
|
||||
check for systemwide man_db.conf before the bundled one
|
||||
|
||||
diff --git a/src/manp.c b/src/manp.c
|
||||
index 5441339..0bbf566 100644
|
||||
--- a/src/manp.c
|
||||
+++ b/src/manp.c
|
||||
@@ -841,18 +841,24 @@ void read_config_file (bool optional)
|
||||
}
|
||||
|
||||
if (getenv ("MAN_TEST_DISABLE_SYSTEM_CONFIG") == NULL) {
|
||||
- config_file = fopen (CONFIG_FILE, "r");
|
||||
+ const char *config_filepath;
|
||||
+ if (access ("/etc/man_db.conf", F_OK) != -1) {
|
||||
+ config_filepath = "/etc/man_db.conf";
|
||||
+ } else {
|
||||
+ config_filepath = CONFIG_FILE;
|
||||
+ }
|
||||
+ config_file = fopen (config_filepath, "r");
|
||||
if (config_file == NULL) {
|
||||
if (optional)
|
||||
debug ("can't open %s; continuing anyway\n",
|
||||
- CONFIG_FILE);
|
||||
+ config_filepath);
|
||||
else
|
||||
error (FAIL, 0,
|
||||
_("can't open the manpath "
|
||||
"configuration file %s"),
|
||||
- CONFIG_FILE);
|
||||
+ config_filepath);
|
||||
} else {
|
||||
- debug ("From the config file %s:\n", CONFIG_FILE);
|
||||
+ debug ("From the config file %s:\n", config_filepath);
|
||||
|
||||
add_to_dirlist (config_file, 0);
|
||||
fclose (config_file);
|
||||
Loading…
Add table
Add a link
Reference in a new issue