glfs/pst/typesetting/texlive.xml
Douglas R. Reno 17e976e3a4 Texlive: convert to 'initialize'
git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@22074 af4574ff-66df-0310-9fd7-8a98e5e911e0
2019-08-30 22:33:12 +00:00

479 lines
18 KiB
XML

<?xml version="1.0" encoding="ISO-8859-1"?>
<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
<!ENTITY % general-entities SYSTEM "../../general.ent">
%general-entities;
<!ENTITY texlive-download-http " ">
<!ENTITY texlive-download-ftp "ftp://tug.org/texlive/historic/&texlive-year;/texlive-&texlive-version;-source.tar.xz">
<!ENTITY texlive-md5sum "be4b20aa60861bc510bcbc5b228bcb51">
<!ENTITY texlive-size "52 MB">
<!ENTITY texlive-buildsize "7.2 GB including the additional download and the tests, 6.0 GB installed">
<!ENTITY texlive-time "5.6 SBU including the additional download and the tests, building with parallelism=4">
<!ENTITY texlive-texmf-download-http " ">
<!ENTITY texlive-texmf-download-ftp "ftp://tug.org/texlive/historic/&texlive-year;/texlive-&texmf-version;-texmf.tar.xz">
<!ENTITY texlive-texmf-md5sum "586bb6cb6c30ce7efba256b956df6bc2">
<!ENTITY texlive-texmf-size "2.5 GB">
]>
<sect1 id="texlive" xreflabel="texlive-&texlive-version;">
<?dbhtml filename="texlive.html"?>
<sect1info>
<othername>$LastChangedBy$</othername>
<date>$Date$</date>
</sect1info>
<title>texlive-&texlive-version;-source</title>
<indexterm zone="texlive">
<primary sortas="a-texlive">texlive</primary>
</indexterm>
<sect2 role="package">
<title>Introduction to TeX Live from source</title>
<para>Most of TeX Live can be built from source without a pre-existing
installation, but <application>xindy</application> (for indexing) needs
working versions of <command>latex</command> and <command>pdflatex</command>
when configure is run, and the testsuite and install for
<command>asy</command> (for vector graphics) will fail if TeX has not
already been installed. Additionally, <application>biber</application> is
not provided within the <application>texlive</application> source.</para>
<para>All of those packages are dealt with on their own pages and can be
built after installing this package. If you have not already done so, you
should start at <xref linkend="tex-path"/> so that the final commands to
initialise the new installation will be found.</para>
&lfs90_checked;
<bridgehead renderas="sect3">Package Information</bridgehead>
<itemizedlist spacing="compact">
<listitem>
<para>Download (HTTP): <ulink url="&texlive-download-http;"/></para>
</listitem>
<listitem>
<para>Download (FTP): <ulink url="&texlive-download-ftp;"/></para>
</listitem>
<listitem>
<para>Download MD5 sum: &texlive-md5sum;</para>
</listitem>
<listitem>
<para>Download size: &texlive-size;</para>
</listitem>
<listitem>
<para>Estimated disk space required: &texlive-buildsize;</para>
</listitem>
<listitem>
<para>Estimated build time: &texlive-time;</para>
</listitem>
</itemizedlist>
<bridgehead renderas="sect3">Required Additional Downloads</bridgehead>
<para>Much of the texlive environment (including scripts, documentation,
fonts and various other files) is not part of the source tarball. You must
download it separately. This will give you all of the additional files
which are provided by a full install of the binary version, there is no
realistic way to restrict which parts get installed.</para>
<para>
Because of the size of this package, it is unlikely to be mirrored by
BLFS mirrors. In case of difficulty, go to http://www.ctan.org/mirrors/
to find a more-accessible mirror.
</para>
<itemizedlist spacing="compact">
<listitem>
<para>Download (HTTP): <ulink url="&texlive-texmf-download-http;"/></para>
</listitem>
<listitem>
<para>Download (FTP): <ulink url="&texlive-texmf-download-ftp;"/></para>
</listitem>
<listitem>
<para>Download MD5 sum: &texlive-texmf-md5sum;</para>
</listitem>
<listitem>
<para>Download size: &texlive-texmf-size;</para>
</listitem>
<listitem>
<para>Required patch: <ulink
url="&patch-root;/texlive-&texlive-version;-source-upstream_fixes-1.patch"/></para>
</listitem>
</itemizedlist>
<bridgehead renderas="sect3">TeX Live from source Dependencies</bridgehead>
<bridgehead renderas="sect4">Recommended</bridgehead>
<para role="recommended">
<xref linkend="gs"/> <emphasis>including
<filename>libgs.so</filename></emphasis>, <!--(for dvisvgm, which is used by e.g.
<xref role="nodep" linkend="asymptote"/>), : still referenced for dynamic loading,
even without dvisvgm - e.fg. by dvipsk -->
<xref linkend="x-window-system"/>
</para>
<!-- text for recommended libraries -->
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/texrecommendlibs.xml"/>
<!-- the following ensures jhalfs will set paths before running texlive -->
<para role="recommended">
Furthermore, the instructions below assume you are using the layout
described in <xref linkend="tex-path"/>.
</para>
<bridgehead renderas="sect4">Optional</bridgehead>
<!-- text for optional deps -->
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/texoptional.xml"/>
<bridgehead renderas="sect4">Runtime dependencies</bridgehead>
<!-- text for runtime deps, shared with tl-installer -->
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/texruntime.xml"/>
<para condition="html" role="usernotes">User Notes:
<ulink url="&blfs-wiki;/texlive"/></para>
</sect2>
<sect2 role="installation">
<title>Installation of TeX Live</title>
<para>
Install TeX Live by running the following commands:
</para>
<para>The shared libraries will be installed into a texlive directory.
As the <systemitem class="username">root</systemitem> user, add it to
your <filename>/etc/ld.so.conf</filename>:</para>
<screen role="root"><userinput>cat &gt;&gt; /etc/ld.so.conf &lt;&lt; EOF
<literal># Begin texlive &texlive-year; addition
/opt/texlive/&texlive-year;/lib
# End texlive &texlive-year; addition</literal>
EOF</userinput></screen>
<note>
<para>
From 2015 onwards, a successful install requires some texlive
commands to be run as the root user, so we will export the TEXARCH
variable to let <systemitem class="username">root</systemitem> use it.
</para>
<!--
<para>
If you came here to update an old system (because of the recent
vulnerability) where the poppler version is before 0.62.0, such as
BLFS-8.1, do NOT use the commands in the <literal>MYPOPPLER</literal>
block of instructions, nor the <literal>\-\-with-system-poppler</literal>
or <literal>\-\-with-system-xpdf</literal> options when configuring.
</para>-->
<para>
In the 2019 release, <application>dvisvgm</application> cannot be built
if shared system libraries are used. This means that <xref linkend="asymptote"/>
will not be able to create svg files.
</para>
</note>
<para>
Now, as a normal user:
</para>
<screen><userinput>export TEXARCH=$(uname -m | sed -e 's/i.86/i386/' -e 's/$/-linux/') &amp;&amp;
patch -Np1 -i ../texlive-&texlive-version;-source-upstream_fixes-1.patch &amp;&amp;
<!--
let MYPOPPLER=$(pkg-config \-\-modversion poppler | cut -d '.' -f2)
mv -v texk/web2c/pdftexdir/pdftosrc{-newpoppler,}.cc
if [ $MYPOPPLER -lt 68 ]; then
mv -v texk/web2c/pdftexdir/pdftoepdf{-newpoppler,}.cc
elif [ $MYPOPPLER -lt 69 ]; then
mv -v texk/web2c/pdftexdir/pdftoepdf{-poppler0.68.0,}.cc
else
mv -v texk/web2c/pdftexdir/pdftoepdf{-poppler0.69.0,}.cc
fi &amp;&amp;
unset MYPOPPLER &amp;&amp;-->
mkdir texlive-build &amp;&amp;
cd texlive-build &amp;&amp;
<!--
\-\-with-system-poppler \
\-\-with-system-xpdf \
potrace was only used by dvisvgm
\-\-with-system-potrace \
-->
../configure \
--prefix=/opt/texlive/&texlive-year; \
--bindir=/opt/texlive/&texlive-year;/bin/$TEXARCH \
--datarootdir=/opt/texlive/&texlive-year; \
--includedir=/opt/texlive/&texlive-year;/include \
--infodir=/opt/texlive/&texlive-year;/texmf-dist/doc/info \
--libdir=/opt/texlive/&texlive-year;/lib \
--mandir=/opt/texlive/&texlive-year;/texmf-dist/doc/man \
--disable-native-texlive-build \
--disable-static --enable-shared \
--disable-dvisvgm \
--with-system-cairo \
--with-system-fontconfig \
--with-system-freetype2 \
--with-system-gmp \
--with-system-graphite2 \
--with-system-harfbuzz \
--with-system-icu \
--with-system-libgs \
--with-system-libpaper \
--with-system-libpng \
--with-system-mpfr \
--with-system-pixman \
--with-system-zlib \
--with-banner-add=" - BLFS" &amp;&amp;
make</userinput></screen>
<para>To test the results, issue: <command>make check</command>
A few tests may SKIP because kpathsea
has not yet been installed.</para>
<para>Now, as the <systemitem class="username">root</systemitem>
user:</para>
<!-- Editors, you can run 'make texlinks' in a DESTDIR by passing
DESTDIR#some/where -->
<screen role="root"><userinput>make install-strip &amp;&amp;
/sbin/ldconfig &amp;&amp;
make texlinks &amp;&amp;
mkdir -pv /opt/texlive/&texlive-year;/tlpkg/TeXLive/ &amp;&amp;
install -v -m644 ../texk/tests/TeXLive/* /opt/texlive/&texlive-year;/tlpkg/TeXLive/</userinput></screen>
<note>
<para>
Only run <command>make texlinks</command> once. If it is rerun,
it can change all the program symlinks so that they point to
themselves and are useless.
</para>
</note>
<para>Now install the additional files as the
<systemitem class="username">root</systemitem> user:</para>
<!-- if texmf does not need to be patched, remove &amp;&amp; from first line,
close userinput, screen, comment pushd, patch, popd -->
<screen role="root"><userinput>tar -xf ../../texlive-&texmf-version;-texmf.tar.xz -C /opt/texlive/&texlive-year; --strip-components=1</userinput></screen>
<para>Still as the <systemitem class="username">root</systemitem> user,
initialise the new system (the commands <command>fmtutil-sys --all</command>
and <command>mtxrun --generate</command> will produce a
<emphasis>lot</emphasis> of output):</para>
<!-- Editors, fmtutil-sys and mtxrun \-\-generate can apparently only be run on
a real install, as root. But mktexlsr can be run in a DESTDIR with
cd /YOUR/TEXMF/ROOT ; ls -LAR ./ >ls-R -->
<screen role="root"><userinput>mktexlsr &amp;&amp;
fmtutil-sys --all &amp;&amp;
mtxrun --generate</userinput></screen>
<para>You can now proceed to <xref linkend="asymptote"/>,
<xref linkend="biber"/> and / or <xref linkend="xindy"/> if you
wish to install them.</para>
</sect2>
<sect2 role="commands">
<title>Command Explanations</title>
<para>
<command>patch -Np1 -i ../texlive-&texlive-version;-source-upstream_fixes-1.patch</command>:
various problems have come to light since the shipped source was frozen to
be committed to DVDs.
</para>
<!--
<para>
<command>let MYPOPPLER=...</command>: Because the vulnerability fix applies to
many past years of <application>texlive</application>, the tests aim to allow
updating using system versions of poppler since 0.62.0. The amended files for
newer versions of poppler need to be copied over the original versions,
depending on which version is being used.
</para>-->
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/tex-prefix.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/tex-lib.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/static-libraries.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/tex-shared.xml"/>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/tex-system.xml"/>
<!--
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/tex-xpdf.xml"/>-->
<para>
<command>--disable-dvisvgm</command>: As noted above, the shipped version
of dvisvgm, which has modified configuration files, cannot be built with
shared system libraries.
</para>
<para>
<option>--without-x</option>: use this if you do not have Xorg installed.
</para>
<para>
<command>/sbin/ldconfig</command>: this has to be run here so that <command>make
texlinks</command> can use kpsewhich.
</para>
<para>
<command>make texlinks</command> : this runs the texlinks.sh script
to create symbolic links from formats to engines. In
practice, several of the targets such as <command>xetex</command> are now
separate binaries and for these it will report "file already exists".
</para>
<para>
<command>tar -xf texlive-&texmf-version;-texmf.tar.xz -C /opt/texlive/&texlive-year; --strip-components=1</command>:
the tarball contains the files for the texmf-dist directory, and because
of its size we do not want to waste time and space untarring it and then
copying the files.
</para>
<para>
<command>install -v -m644 ../texk/tests/TeXLive/*
/opt/texlive/&texlive-year;/tlpkg/TeXLive/</command>: This puts the perl
modules <filename>TLConfig.pm</filename> and <filename>TLUtils.pm</filename>
into the directory where the binary installer puts them - it is at the
start of the perl @INC@ PATH within texlive when installed using the above
configure switches. Without these modules, texlive is unusable.
</para>
<para>
<command>mktexlsr</command>: Create an <filename>ls-R</filename> file
which lists what was installed - this is used by kpathsea to find files.
</para>
<para>
<command>fmtutil-sys --all</command>: This initializes the TeX formats,
Metafont bases and Metapost mems.
</para>
<para>
<command>mtxrun --generate</command>: This initializes the ConTeXt system.
</para>
</sect2>
<sect2 role="content">
<title>Contents</title>
<segmentedlist>
<segtitle>Installed Programs</segtitle>
<segtitle>Installed Libraries</segtitle>
<segtitle>Installed Directories</segtitle>
<seglistitem>
<seg>Over 300 binaries and symlinks to scripts</seg>
<seg>libkpathsea.so, libptexenc.so, libsynctex.so, libtexlua52.so,
libtexluajit.so</seg>
<seg>/opt/texlive/&texlive-year;/bin, /opt/texlive/&texlive-year;/include,
/opt/texlive/&texlive-year;/lib, /opt/texlive/&texlive-year;/texmf-dist</seg>
</seglistitem>
</segmentedlist>
<variablelist>
<bridgehead renderas="sect3">Short Descriptions</bridgehead>
<?dbfo list-presentation="list"?>
<?dbhtml list-presentation="table"?>
<varlistentry id="texlive-programs">
<term><command>TeX&nbsp;programs</command></term>
<listitem>
<xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
href="../../xincludes/texprogs.xml"/>
<indexterm zone="texlive texlive-programs">
<primary sortas="b-texlive-programs">TeX Live programs</primary>
</indexterm>
</listitem>
</varlistentry>
<varlistentry id="libkpathsea">
<term><filename class="libraryfile">libkpathsea.so</filename></term>
<listitem>
<para>
(kpathsearch) exists to look up a file in a list of directories
and is used by <command>kpsewhich</command>.
</para>
<indexterm zone="texlive libkpathsea">
<primary sortas="c-libkpathsea">libkpathsea.so</primary>
</indexterm>
</listitem>
</varlistentry>
<varlistentry id="libptexenc">
<term><filename class="libraryfile">libptexenc.so</filename></term>
<listitem>
<para>
is a library for Japanese pTeX (publishing TeX).
</para>
<indexterm zone="texlive libptexenc">
<primary sortas="c-libptexenc">libptexenc.so</primary>
</indexterm>
</listitem>
</varlistentry>
<varlistentry id="libsynctex">
<term><filename class="libraryfile">libsynctex.so</filename></term>
<listitem>
<para>
is the SyncTeX (Synchronize TeXnology) parser library.
</para>
<indexterm zone="texlive libsynctex">
<primary sortas="c-libsynctex">libsynctex.so</primary>
</indexterm>
</listitem>
</varlistentry>
<varlistentry id="libtexlua52">
<term><filename class="libraryfile">libtexlua52.so</filename></term>
<listitem>
<para>
provides Lua 5.2, modified for use with LuaTeX.
</para>
<indexterm zone="texlive libtexlua52">
<primary sortas="c-libtexlua52">libtexlua52.so</primary>
</indexterm>
</listitem>
</varlistentry>
<varlistentry id="libtexluajit">
<term><filename class="libraryfile">libtexluajit.so</filename></term>
<listitem>
<para>
provides LuaJIT, modified for use with LuaJITTeX.
</para>
<indexterm zone="texlive libtexluajit">
<primary sortas="c-libtexluajit">libtexluajit.so</primary>
</indexterm>
</listitem>
</varlistentry>
</variablelist>
</sect2>
</sect1>