2018-04-01 01:00:02 +01:00
|
|
|
{ version, sha256 }:
|
|
|
|
|
|
|
|
{ stdenv, buildPackages, fetchurl, perl, xz
|
|
|
|
|
|
|
|
# we are a dependency of gcc, this simplifies bootstraping
|
|
|
|
, interactive ? false, ncurses, procps
|
|
|
|
}:
|
|
|
|
|
2020-06-26 21:44:45 +01: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.
|
|
|
|
|
2019-12-28 08:51:03 +00:00
|
|
|
let
|
|
|
|
crossBuildTools = interactive && stdenv.hostPlatform != stdenv.buildPlatform;
|
|
|
|
in
|
|
|
|
|
2018-04-01 01:00:02 +01:00
|
|
|
with stdenv.lib;
|
|
|
|
|
2019-08-13 22:52:01 +01:00
|
|
|
stdenv.mkDerivation {
|
2018-04-01 01:00:02 +01:00
|
|
|
name = "texinfo-${optionalString interactive "interactive-"}${version}";
|
|
|
|
inherit version;
|
|
|
|
|
|
|
|
src = fetchurl {
|
|
|
|
url = "mirror://gnu/texinfo/texinfo-${version}.tar.xz";
|
|
|
|
inherit sha256;
|
|
|
|
};
|
|
|
|
|
2019-12-28 08:51:03 +00:00
|
|
|
patches = optional (version == "6.5") ./perl.patch
|
|
|
|
++ optional crossBuildTools ./cross-tools-flags.patch;
|
|
|
|
|
|
|
|
# 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;
|
2018-09-05 01:28:02 +01:00
|
|
|
|
2018-04-01 01:00:02 +01:00
|
|
|
# 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 ]
|
2018-08-05 21:15:21 +01:00
|
|
|
++ optional interactive ncurses;
|
2018-04-01 01:00:02 +01:00
|
|
|
|
|
|
|
configureFlags = [ "PERL=${buildPackages.perl}/bin/perl" ]
|
|
|
|
++ stdenv.lib.optional stdenv.isSunOS "AWK=${gawk}/bin/awk";
|
|
|
|
|
2019-11-03 21:57:05 +00:00
|
|
|
installFlags = [ "TEXMF=$(out)/texmf-dist" ];
|
|
|
|
installTargets = [ "install" "install-tex" ];
|
2018-04-01 01:00:02 +01:00
|
|
|
|
2018-08-05 21:15:21 +01:00
|
|
|
checkInputs = [ procps ];
|
|
|
|
|
2018-04-01 01:00:02 +01:00
|
|
|
doCheck = interactive
|
|
|
|
&& !stdenv.isDarwin
|
|
|
|
&& !stdenv.isSunOS; # flaky
|
|
|
|
|
|
|
|
meta = {
|
2020-04-01 02:11:51 +01:00
|
|
|
homepage = "https://www.gnu.org/software/texinfo/";
|
2018-04-01 01:00:02 +01:00
|
|
|
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;
|
|
|
|
};
|
|
|
|
}
|