2020-04-24 23:36:52 +00:00
|
|
|
{ version, sha256 }:
|
|
|
|
|
2021-02-05 17:12:51 +00:00
|
|
|
{ lib, stdenv, buildPackages, fetchurl, perl, xz, gettext
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# we are a dependency of gcc, this simplifies bootstraping
|
|
|
|
, interactive ? false, ncurses, procps
|
|
|
|
}:
|
|
|
|
|
2020-08-20 17:08:02 +00:00
|
|
|
# Note: this package is used for bootstrapping fetchurl, and thus
|
|
|
|
# cannot use fetchpatch! All mutable patches (generated by GitHub or
|
|
|
|
# cgit) that are needed here should be included directly in Nixpkgs as
|
|
|
|
# files.
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
let
|
2020-09-25 04:45:31 +00:00
|
|
|
crossBuildTools = stdenv.hostPlatform != stdenv.buildPlatform;
|
2020-04-24 23:36:52 +00:00
|
|
|
in
|
|
|
|
|
2021-02-05 17:12:51 +00:00
|
|
|
with lib;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation {
|
|
|
|
name = "texinfo-${optionalString interactive "interactive-"}${version}";
|
|
|
|
inherit version;
|
|
|
|
|
|
|
|
src = fetchurl {
|
|
|
|
url = "mirror://gnu/texinfo/texinfo-${version}.tar.xz";
|
|
|
|
inherit sha256;
|
|
|
|
};
|
|
|
|
|
2020-09-25 04:45:31 +00:00
|
|
|
patches = optional crossBuildTools ./cross-tools-flags.patch;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# ncurses is required to build `makedoc'
|
|
|
|
# this feature is introduced by the ./cross-tools-flags.patch
|
|
|
|
NATIVE_TOOLS_CFLAGS = if crossBuildTools then "-I${getDev buildPackages.ncurses}/include" else null;
|
|
|
|
NATIVE_TOOLS_LDFLAGS = if crossBuildTools then "-L${getLib buildPackages.ncurses}/lib" else null;
|
|
|
|
|
|
|
|
# We need a native compiler to build perl XS extensions
|
|
|
|
# when cross-compiling.
|
|
|
|
depsBuildBuild = [ buildPackages.stdenv.cc perl ];
|
|
|
|
|
|
|
|
buildInputs = [ xz.bin ]
|
|
|
|
++ optionals stdenv.isSunOS [ libiconv gawk ]
|
2020-10-16 20:44:37 +00:00
|
|
|
++ optionals stdenv.isDarwin [ gettext ]
|
2020-04-24 23:36:52 +00:00
|
|
|
++ optional interactive ncurses;
|
|
|
|
|
|
|
|
configureFlags = [ "PERL=${buildPackages.perl}/bin/perl" ]
|
2021-02-05 17:12:51 +00:00
|
|
|
++ lib.optional stdenv.isSunOS "AWK=${gawk}/bin/awk";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
installFlags = [ "TEXMF=$(out)/texmf-dist" ];
|
|
|
|
installTargets = [ "install" "install-tex" ];
|
|
|
|
|
|
|
|
checkInputs = [ procps ];
|
|
|
|
|
|
|
|
doCheck = interactive
|
|
|
|
&& !stdenv.isDarwin
|
|
|
|
&& !stdenv.isSunOS; # flaky
|
|
|
|
|
|
|
|
meta = {
|
|
|
|
homepage = "https://www.gnu.org/software/texinfo/";
|
|
|
|
description = "The GNU documentation system";
|
|
|
|
license = licenses.gpl3Plus;
|
|
|
|
platforms = platforms.all;
|
|
|
|
maintainers = with maintainers; [ vrthra oxij ];
|
|
|
|
|
|
|
|
longDescription = ''
|
|
|
|
Texinfo is the official documentation format of the GNU project.
|
|
|
|
It was invented by Richard Stallman and Bob Chassell many years
|
|
|
|
ago, loosely based on Brian Reid's Scribe and other formatting
|
|
|
|
languages of the time. It is used by many non-GNU projects as
|
|
|
|
well.
|
|
|
|
|
|
|
|
Texinfo uses a single source file to produce output in a number
|
|
|
|
of formats, both online and printed (dvi, html, info, pdf, xml,
|
|
|
|
etc.). This means that instead of writing different documents
|
|
|
|
for online information and another for a printed manual, you
|
|
|
|
need write only one document. And when the work is revised, you
|
|
|
|
need revise only that one document. The Texinfo system is
|
|
|
|
well-integrated with GNU Emacs.
|
|
|
|
'';
|
|
|
|
branch = version;
|
|
|
|
};
|
|
|
|
}
|