Merge pull request #65844 from matthewbauer/man-alias
man: use man-db everywhere
This commit is contained in:
commit
c45a990a5d
@ -1,33 +1,47 @@
|
|||||||
{ stdenv, fetchurl, pkgconfig, libpipeline, db, groff, libiconv, makeWrapper, buildPackages }:
|
{ stdenv, fetchurl, pkgconfig, libpipeline, db, groff, libiconv, makeWrapper, buildPackages }:
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "man-db-2.7.5";
|
name = "man-db-2.8.6.1";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://savannah/man-db/${name}.tar.xz";
|
url = "mirror://savannah/man-db/${name}.tar.xz";
|
||||||
sha256 = "056a3il7agfazac12yggcg4gf412yq34k065im0cpfxbcw6xskaw";
|
sha256 = "0a1sh5gxa16k6irzf3q2lli8m204w9ik1xm62wjgf1mzknxs4xrc";
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs = [ "out" "doc" ];
|
outputs = [ "out" "doc" ];
|
||||||
outputMan = "out"; # users will want `man man` to work
|
outputMan = "out"; # users will want `man man` to work
|
||||||
|
|
||||||
nativeBuildInputs = [ pkgconfig makeWrapper groff ]
|
nativeBuildInputs = [ pkgconfig makeWrapper groff ];
|
||||||
++ stdenv.lib.optionals doCheck checkInputs;
|
|
||||||
buildInputs = [ libpipeline db groff ]; # (Yes, 'groff' is both native and build input)
|
buildInputs = [ libpipeline db groff ]; # (Yes, 'groff' is both native and build input)
|
||||||
checkInputs = [ libiconv /* for 'iconv' binary */ ];
|
checkInputs = [ libiconv /* for 'iconv' binary */ ];
|
||||||
|
|
||||||
postPatch = ''
|
postPatch = ''
|
||||||
substituteInPlace src/man_db.conf.in \
|
# Remove all mandatory manpaths. Nixpkgs makes no requirements on
|
||||||
--replace "/usr/local/share" "/run/current-system/sw/share" \
|
# these directories existing.
|
||||||
--replace "/usr/share" "/run/current-system/sw/share"
|
sed -i 's/^MANDATORY_MANPATH/# &/' src/man_db.conf.in
|
||||||
|
|
||||||
|
# Add Nixpkgs and NixOS-related manpaths
|
||||||
|
echo "MANPATH_MAP /run/current-system/sw/bin /run/current-system/sw/share/man" >> src/man_db.conf.in
|
||||||
|
echo "MANPATH_MAP /run/wrappers/bin /run/current-system/sw/share/man" >> src/man_db.conf.in
|
||||||
|
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 /run/current-system/sw/share/man /var/cache/man/nixos" >> src/man_db.conf.in
|
||||||
|
echo "MANDB_MAP /nix/var/nix/profiles/default/share/man /var/cache/man/nixpkgs" >> src/man_db.conf.in
|
||||||
'';
|
'';
|
||||||
|
|
||||||
configureFlags = [
|
configureFlags = [
|
||||||
"--disable-setuid"
|
"--disable-setuid"
|
||||||
|
"--disable-cache-owner"
|
||||||
"--localstatedir=/var"
|
"--localstatedir=/var"
|
||||||
# Don't try /etc/man_db.conf by default, so we avoid error messages.
|
# Don't try /etc/man_db.conf by default, so we avoid error messages.
|
||||||
"--with-config-file=\${out}/etc/man_db.conf"
|
"--with-config-file=${placeholder "out"}/etc/man_db.conf"
|
||||||
"--with-systemdtmpfilesdir=\${out}/lib/tmpfiles.d"
|
"--with-systemdtmpfilesdir=${placeholder "out"}/lib/tmpfiles.d"
|
||||||
|
"--with-systemdsystemunitdir=${placeholder "out"}/lib/systemd/system"
|
||||||
|
] ++ stdenv.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 = ''
|
preConfigure = ''
|
||||||
@ -57,7 +71,7 @@ stdenv.mkDerivation rec {
|
|||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
doCheck = !stdenv.hostPlatform.isMusl; /* iconv binary */
|
doCheck = !stdenv.hostPlatform.isMusl /* iconv binary */ && !stdenv.hostPlatform.isDarwin;
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
meta = with stdenv.lib; {
|
||||||
homepage = http://man-db.nongnu.org;
|
homepage = http://man-db.nongnu.org;
|
||||||
|
@ -1,14 +0,0 @@
|
|||||||
diff -ru -x '*~' man-1.6g-orig/src/man-config.c man-1.6g/src/man-config.c
|
|
||||||
--- man-1.6g-orig/src/man-config.c 2005-08-21 01:26:06.000000000 +0200
|
|
||||||
+++ man-1.6g/src/man-config.c 2012-03-06 11:11:28.159050524 +0100
|
|
||||||
@@ -214,8 +214,9 @@
|
|
||||||
const char *configuration_file = "[no configuration file]";
|
|
||||||
|
|
||||||
char *default_config_files[] = {
|
|
||||||
+ "/etc/man.conf",
|
|
||||||
CONFIG_FILE, /* compiled-in default */
|
|
||||||
- "/etc/man.conf", "/etc/man.config",
|
|
||||||
+ "/etc/man.config",
|
|
||||||
"/usr/lib/man.conf", "/usr/lib/man.config",
|
|
||||||
"/usr/share/misc/man.conf", "/usr/share/misc/man.config"
|
|
||||||
};
|
|
@ -1,50 +0,0 @@
|
|||||||
{ stdenv, fetchurl, groff, less }:
|
|
||||||
|
|
||||||
stdenv.mkDerivation rec {
|
|
||||||
name = "man-1.6g";
|
|
||||||
|
|
||||||
src = fetchurl {
|
|
||||||
url = "http://primates.ximian.com/~flucifredi/man/${name}.tar.gz";
|
|
||||||
sha256 = "17wmp2ahkhl72cvfzshmck22dnq2lbjg0678swihj270yk1vip6c";
|
|
||||||
};
|
|
||||||
|
|
||||||
buildInputs = [ groff less ];
|
|
||||||
|
|
||||||
preBuild = ''
|
|
||||||
makeFlagsArray=(bindir=$out/bin sbindir=$out/sbin libdir=$out/lib mandir=$out/share/man)
|
|
||||||
'';
|
|
||||||
|
|
||||||
patches = [
|
|
||||||
# Search in "share/man" relative to each path in $PATH (in addition to "man").
|
|
||||||
./share.patch
|
|
||||||
|
|
||||||
# Prefer /etc/man.conf over $out/lib/man.conf. Man only reads the
|
|
||||||
# first file that exists, so this is necessary to allow the
|
|
||||||
# builtin config to be overriden.
|
|
||||||
./conf.patch
|
|
||||||
];
|
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
sed 's/^PREPATH=.*/PREPATH=$PATH/' -i configure
|
|
||||||
'';
|
|
||||||
|
|
||||||
postInstall =
|
|
||||||
''
|
|
||||||
# Use UTF-8 by default. Otherwise man won't know how to deal
|
|
||||||
# with certain characters.
|
|
||||||
substituteInPlace $out/lib/man.conf \
|
|
||||||
--replace "nroff -Tlatin1" "nroff" \
|
|
||||||
--replace "eqn -Tlatin1" "eqn -Tutf8"
|
|
||||||
|
|
||||||
# Work around a bug in substituteInPlace. It loses the final
|
|
||||||
# newline, and man requires every line in man.conf to be
|
|
||||||
# terminated by a newline.
|
|
||||||
echo >> $out/lib/man.conf
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = {
|
|
||||||
homepage = http://primates.ximian.com/~flucifredi/man/;
|
|
||||||
description = "Tool to read online Unix documentation";
|
|
||||||
platforms = stdenv.lib.platforms.unix;
|
|
||||||
};
|
|
||||||
}
|
|
@ -1,116 +0,0 @@
|
|||||||
diff -rc man-1.6f-orig/src/manpath.c man-1.6f/src/manpath.c
|
|
||||||
*** man-1.6f-orig/src/manpath.c 2006-08-03 23:18:33.000000000 +0200
|
|
||||||
--- man-1.6f/src/manpath.c 2008-02-07 15:31:43.000000000 +0100
|
|
||||||
***************
|
|
||||||
*** 109,121 ****
|
|
||||||
* or ../man or ../man1 or ../man8 subdirectories.
|
|
||||||
*/
|
|
||||||
static char *
|
|
||||||
! find_man_subdir (char *p) {
|
|
||||||
int len;
|
|
||||||
char *t, *sp;
|
|
||||||
|
|
||||||
len = strlen (p);
|
|
||||||
|
|
||||||
! t = my_malloc ((unsigned) len + 20);
|
|
||||||
|
|
||||||
memcpy (t, p, len);
|
|
||||||
strcpy (t + len, "/man");
|
|
||||||
--- 109,121 ----
|
|
||||||
* or ../man or ../man1 or ../man8 subdirectories.
|
|
||||||
*/
|
|
||||||
static char *
|
|
||||||
! find_man_subdir (char *p, char * maybe_share) {
|
|
||||||
int len;
|
|
||||||
char *t, *sp;
|
|
||||||
|
|
||||||
len = strlen (p);
|
|
||||||
|
|
||||||
! t = my_malloc ((unsigned) len + 30);
|
|
||||||
|
|
||||||
memcpy (t, p, len);
|
|
||||||
strcpy (t + len, "/man");
|
|
||||||
***************
|
|
||||||
*** 139,159 ****
|
|
||||||
}
|
|
||||||
|
|
||||||
/* look for the situation with packagedir/bin and packagedir/man */
|
|
||||||
! strcpy (t + len, "/man");
|
|
||||||
|
|
||||||
if (is_directory (t) == 1)
|
|
||||||
return t;
|
|
||||||
|
|
||||||
/* look for the situation with pkg/bin and pkg/man1 or pkg/man8 */
|
|
||||||
/* (looking for all man[1-9] would probably be a waste of stats) */
|
|
||||||
! strcpy (t + len, "/man1");
|
|
||||||
|
|
||||||
if (is_directory (t) == 1) {
|
|
||||||
t[len] = 0;
|
|
||||||
return t;
|
|
||||||
}
|
|
||||||
|
|
||||||
! strcpy (t + len, "/man8");
|
|
||||||
|
|
||||||
if (is_directory (t) == 1) {
|
|
||||||
t[len] = 0;
|
|
||||||
--- 139,159 ----
|
|
||||||
}
|
|
||||||
|
|
||||||
/* look for the situation with packagedir/bin and packagedir/man */
|
|
||||||
! sprintf (t + len, "%s/man", maybe_share);
|
|
||||||
|
|
||||||
if (is_directory (t) == 1)
|
|
||||||
return t;
|
|
||||||
|
|
||||||
/* look for the situation with pkg/bin and pkg/man1 or pkg/man8 */
|
|
||||||
/* (looking for all man[1-9] would probably be a waste of stats) */
|
|
||||||
! sprintf (t + len, "%s/man1", maybe_share);
|
|
||||||
|
|
||||||
if (is_directory (t) == 1) {
|
|
||||||
t[len] = 0;
|
|
||||||
return t;
|
|
||||||
}
|
|
||||||
|
|
||||||
! sprintf (t + len, "%s/man8", maybe_share);
|
|
||||||
|
|
||||||
if (is_directory (t) == 1) {
|
|
||||||
t[len] = 0;
|
|
||||||
***************
|
|
||||||
*** 341,347 ****
|
|
||||||
if (debug)
|
|
||||||
gripe (IS_NOT_IN_CONFIG);
|
|
||||||
|
|
||||||
! t = find_man_subdir (dir);
|
|
||||||
if (t != NULL) {
|
|
||||||
if (debug)
|
|
||||||
gripe (MAN_NEARBY);
|
|
||||||
--- 341,347 ----
|
|
||||||
if (debug)
|
|
||||||
gripe (IS_NOT_IN_CONFIG);
|
|
||||||
|
|
||||||
! t = find_man_subdir (dir, "");
|
|
||||||
if (t != NULL) {
|
|
||||||
if (debug)
|
|
||||||
gripe (MAN_NEARBY);
|
|
||||||
***************
|
|
||||||
*** 352,357 ****
|
|
||||||
--- 352,370 ----
|
|
||||||
if (debug)
|
|
||||||
gripe (NO_MAN_NEARBY);
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ t = find_man_subdir (dir, "/share");
|
|
||||||
+ if (t != NULL) {
|
|
||||||
+ if (debug)
|
|
||||||
+ gripe (MAN_NEARBY);
|
|
||||||
+
|
|
||||||
+ add_to_mandirlist (t, perrs);
|
|
||||||
+ free (t);
|
|
||||||
+ } else {
|
|
||||||
+ if (debug)
|
|
||||||
+ gripe (NO_MAN_NEARBY);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -4634,12 +4634,7 @@ in
|
|||||||
|
|
||||||
makefile2graph = callPackage ../development/tools/analysis/makefile2graph { };
|
makefile2graph = callPackage ../development/tools/analysis/makefile2graph { };
|
||||||
|
|
||||||
# See https://github.com/NixOS/nixpkgs/issues/15849. I'm switching on isLinux because
|
man = man-db;
|
||||||
# it looks like gnulib is broken on non-linux, so it seems likely that this would cause
|
|
||||||
# trouble on bsd and/or cygwin as well.
|
|
||||||
man = if stdenv.isLinux then man-db else man-old;
|
|
||||||
|
|
||||||
man-old = callPackage ../tools/misc/man { };
|
|
||||||
|
|
||||||
man-db = callPackage ../tools/misc/man-db { };
|
man-db = callPackage ../tools/misc/man-db { };
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user