source: pst/typesetting/texlive.xml@ 496ad8e

12.1 ken/TL2024 lazarus rahul/power-profiles-daemon trunk xry111/llvm18
Last change on this file since 496ad8e was 496ad8e, checked in by Xi Ruoyao <xry111@…>, 3 months ago

texlive: Remove ldconfig command

It's not needed which embedded rpath.

  • Property mode set to 100644
File size: 22.3 KB
Line 
1<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
2 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
3 <!ENTITY % general-entities SYSTEM "../../general.ent">
4 %general-entities;
5
6 <!-- utah -->
7 <!ENTITY texlive-download-http "https://ftp.math.utah.edu/pub/tex/historic/systems/texlive/&texlive-year;/texlive-&texlive-version;-source.tar.xz">
8 <!ENTITY texlive-download-ftp " ">
9 <!ENTITY texlive-md5sum "bec84c5d6e340967783302f432c78efe">
10 <!ENTITY texlive-size "66 MB">
11
12 <!ENTITY texlive-buildsize "8.5 GB including the additional download and the tests, 7.7 GB installed">
13 <!ENTITY texlive-time "2.3 SBU including the additional download and the tests, building with parallelism=4">
14
15 <!-- utah -->
16 <!ENTITY texlive-texmf-download-http "https://ftp.math.utah.edu/pub/tex/historic/systems/texlive/&texlive-year;/texlive-&texlive-version;-texmf.tar.xz">
17 <!ENTITY texlive-texmf-download-ftp " ">
18 <!ENTITY texlive-texmf-md5sum "704fb39c69e3710b8e9e9158cec5047a">
19 <!ENTITY texlive-texmf-size "3.7 GB">
20
21 <!ENTITY texlive-tlpdb-download-http "https://ftp.tu-chemnitz.de/pub/tug/historic/systems/texlive/&texlive-year;/texlive-&tex-tlpdb-version;-tlpdb-full.tar.gz">
22 <!ENTITY texlive-tlpdb-download-ftp " ">
23 <!ENTITY texlive-tlpdb-md5sum "5078a7ddaa7b309b7392e33916b817f7">
24 <!ENTITY texlive-tlpdb-size "3.2 MB">
25
26]>
27
28
29<sect1 id="texlive" xreflabel="texlive-&texlive-version;">
30 <?dbhtml filename="texlive.html"?>
31
32
33 <title>texlive-&texlive-version;-source</title>
34
35 <indexterm zone="texlive">
36 <primary sortas="a-texlive">texlive</primary>
37 </indexterm>
38
39 <sect2 role="package">
40 <title>Introduction to TeX Live from source</title>
41
42 <note>
43 <para>
44 According to <ulink url="https://www.tug.org/historic/"/> the master
45 site in France only supports ftp and rsync. Now that ftp is generally
46 deprecated, that page has links to mirrors, some of which support https,
47 e.g. in Utah and Chemnitz as well as in China. If you prefer to use a
48 different mirror from the example links here, you will need to navigate
49 to systems/historic/texlive/&texlive-year; or systems/texlive/&texlive-year;
50 as the case may be.
51 <!-- the chinese mirros do not use a 'historic' subdirectory. -->
52 </para>
53 </note>
54
55 <para>
56 Most of TeX Live can be built from source without a pre-existing
57 installation, but <application>xindy</application> (for indexing) needs
58 working versions of <command>latex</command> and
59 <command>pdflatex</command> when configure is run, and the test suite
60 and install for <command>asy</command> (for vector graphics) will fail
61 if TeX has not already been installed. Additionally,
62 <application>biber</application> is not provided within the
63 <application>texlive</application> source and the version of
64 <application>dvisvgm</application> in the
65 <application>texlive</application> tree cannot be built
66 if shared system libraries are used.
67 </para>
68
69 <para>
70 </para>
71 <para>
72 All of those packages are dealt with on their own pages and can be
73 built after installing this package. If you have not already done so, you
74 should start at <xref linkend="tex-path"/> so that the final commands to
75 initialize the new installation will be found.
76 </para>
77
78 &lfs120_checked;
79
80 <bridgehead renderas="sect3">Package Information</bridgehead>
81 <itemizedlist spacing="compact">
82 <listitem>
83 <para>
84 Download (HTTP): <ulink url="&texlive-download-http;"/>
85 </para>
86 </listitem>
87 <listitem>
88 <para>
89 Download (FTP): <ulink url="&texlive-download-ftp;"/>
90 </para>
91 </listitem>
92 <listitem>
93 <para>
94 Download MD5 sum: &texlive-md5sum;
95 </para>
96 </listitem>
97 <listitem>
98 <para>
99 Download size: &texlive-size;
100 </para>
101 </listitem>
102 <listitem>
103 <para>
104 Estimated disk space required: &texlive-buildsize;
105 </para>
106 </listitem>
107 <listitem>
108 <para>
109 Estimated build time: &texlive-time;
110 </para>
111 </listitem>
112 </itemizedlist>
113
114 <bridgehead renderas="sect3">Required Additional Downloads</bridgehead>
115
116 <para>
117 Much of the texlive environment (including scripts, documentation,
118 fonts, and various other files) is not part of the source tarball.
119 You must download it separately. This will give you all of the
120 additional files which are provided by a full install of the binary
121 version, there is no realistic way to restrict which parts get
122 installed.
123 </para>
124
125 <para>
126 Because of the size of this package, it is unlikely to be mirrored by
127 BLFS mirrors. In case of difficulty, go to http://www.ctan.org/mirrors/
128 to find a more-accessible mirror.
129 </para>
130
131 <itemizedlist spacing="compact">
132 <listitem>
133 <para>
134 Download (HTTP): <ulink url="&texlive-texmf-download-http;"/>
135 </para>
136 </listitem>
137 <listitem>
138 <para>
139 Download (FTP): <ulink url="&texlive-texmf-download-ftp;"/>
140 </para>
141 </listitem>
142 <listitem>
143 <para>
144 Download MD5 sum: &texlive-texmf-md5sum;
145 </para>
146 </listitem>
147 <listitem>
148 <para>
149 Download size: &texlive-texmf-size;
150 </para>
151 </listitem>
152 </itemizedlist>
153
154 <para>
155 From the 2019 year, the tlpdb database of the packages within texlive is
156 no-longer installed with the source. But <command>texdoc</command> needs
157 a cache file derived from this (and will create the cache on its first
158 run).
159 </para>
160
161 <itemizedlist spacing="compact">
162 <listitem>
163 <para>
164 Download (HTTP): <ulink url="&texlive-tlpdb-download-http;"/>
165 </para>
166 </listitem>
167 <listitem>
168 <para>
169 Download (FTP): <ulink url="&texlive-tlpdb-download-ftp;"/>
170 </para>
171 </listitem>
172 <listitem>
173 <para>
174 Download MD5 sum: &texlive-tlpdb-md5sum;
175 </para>
176 </listitem>
177 <listitem>
178 <para>
179 Download size: &texlive-tlpdb-size;
180 </para>
181 </listitem>
182
183 <listitem>
184 <para>
185 Required patch: <ulink url=
186 "&patch-root;/texlive-&texlive-version;-source-security_fix-1.patch"/>
187 </para>
188 </listitem>
189 </itemizedlist>
190
191 <bridgehead renderas="sect3">TeX Live from source Dependencies</bridgehead>
192
193 <bridgehead renderas="sect4">Recommended</bridgehead>
194 <para role="recommended">
195 <xref linkend="x-window-system"/>
196 </para>
197
198 <!-- text for recommended libraries -->
199 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
200 href="../../xincludes/texrecommendlibs.xml"/>
201
202<!-- the following ensures jhalfs will set paths before running texlive -->
203
204 <para role="recommended">
205 Furthermore, the instructions below assume you are using the layout
206 described in <xref linkend="tex-path"/>.
207 </para>
208
209 <bridgehead renderas="sect4">Optional</bridgehead>
210 <!-- text for optional deps -->
211 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
212 href="../../xincludes/texoptional.xml"/>
213
214 <bridgehead renderas="sect4">Runtime dependencies</bridgehead>
215 <!-- text for runtime deps, shared with tl-installer -->
216 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
217 href="../../xincludes/texruntime.xml"/>
218
219 </sect2>
220
221 <sect2 role="installation">
222 <title>Installation of TeX Live</title>
223
224 <para>
225 Install TeX Live by running the following commands:
226 </para>
227
228 <caution>
229 <para>
230 If you wish to upgrade to current <application>texlive</application>
231 on an older system where extra packages (<application>asymptote</application>,
232 <application>biber</application>, <application>dvisvgm</application>, or
233 <application>xindy</application>) have been installed, you will need to
234 reinstall those as well as fixing up your <literal>PATH</literal> for
235 <literal>$TEXLIVE_PREFIX</literal>.
236 </para>
237 </caution>
238
239 <note>
240 <para>
241 A successful install requires some texlive
242 commands to be run as the root user, so we will export the TEXARCH
243 variable to let <systemitem class="username">root</systemitem> use it.
244 </para>
245 </note>
246
247 <para>
248 Now, as a normal user:
249 </para>
250
251<screen><userinput>export TEXARCH=$(uname -m | sed -e 's/i.86/i386/' -e 's/$/-linux/') &amp;&amp;
252
253patch -Np1 -i ../texlive-&texlive-version;-source-security_fix-1.patch &amp;&amp;
254
255mkdir texlive-build &amp;&amp;
256cd texlive-build &amp;&amp;
257
258../configure -C \
259 --prefix=$TEXLIVE_PREFIX \
260 --bindir=$TEXLIVE_PREFIX/bin/$TEXARCH \
261 --datarootdir=$TEXLIVE_PREFIX \
262 --includedir=$TEXLIVE_PREFIX/include \
263 --infodir=$TEXLIVE_PREFIX/texmf-dist/doc/info \
264 --libdir=$TEXLIVE_PREFIX/lib \
265 --mandir=$TEXLIVE_PREFIX/texmf-dist/doc/man \
266 --disable-native-texlive-build \
267 --disable-static --enable-shared \
268 --disable-dvisvgm \
269 --with-system-cairo \
270 --with-system-fontconfig \
271 --with-system-freetype2 \
272 --with-system-gmp \
273 --with-system-graphite2 \
274 --with-system-harfbuzz \
275 --with-system-icu \
276 --with-system-libgs \
277 --with-system-libpaper \
278 --with-system-libpng \
279 --with-system-mpfr \
280 --with-system-pixman \
281 --with-system-zlib \
282 --with-banner-add=" - BLFS" &amp;&amp;
283
284make</userinput></screen>
285
286 <para>
287 To test the results, issue: <command>make -k check</command>.
288 <!-- It started to fail with libpaper-2.0.10 which rounds differently
289 in the 6th place of decimals, causing diff to fail -->
290 Two tests, <filename>psutils.test</filename> and
291 <!-- Upstream say that encoding conversion procedure Encode::from_to()
292 failed in fn-generate.perl, test now skips if that errors: possibly
293 related to changes in perl-5.36 since I understand current slackware
294 also sees this - ken -->
295 <filename>eptexdir/wcfname.test</filename> are known to fail.
296 </para>
297
298 <para>
299 Now, as the <systemitem class="username">root</systemitem> user:
300 </para>
301
302<!-- Editors, you can run 'make texlinks' in a DESTDIR by passing
303DESTDIR#some/where -->
304<screen role="root"><userinput>make install-strip &amp;&amp;
305make texlinks &amp;&amp;
306mkdir -pv $TEXLIVE_PREFIX/tlpkg/TeXLive/ &amp;&amp;
307install -v -m644 ../texk/tests/TeXLive/* $TEXLIVE_PREFIX/tlpkg/TeXLive/ &amp;&amp;
308tar -xf ../../texlive-&tex-tlpdb-version;-tlpdb-full.tar.gz -C $TEXLIVE_PREFIX/tlpkg</userinput></screen>
309
310 <note>
311 <para>
312 Only run <command>make texlinks</command> once. If it is rerun,
313 it can change all the program symlinks so that they point to
314 themselves and are useless.
315 </para>
316 </note>
317
318 <para>
319 Now install the additional files as the
320 <systemitem class="username">root</systemitem> user:
321 </para>
322
323<!-- if texmf does not need to be patched, remove &amp;&amp; from first line,
324 close userinput, screen, comment pushd, patch, popd -->
325<screen role="root"><userinput>tar -xf ../../texlive-&texmf-version;-texmf.tar.xz -C $TEXLIVE_PREFIX --strip-components=1</userinput></screen>
326
327 <para>
328 Still as the <systemitem class="username">root</systemitem> user,
329 initialize the new system (the command <command>fmtutil-sys
330 --all</command> will produce
331 a <emphasis>lot</emphasis> of output):
332 </para>
333
334<!-- Editors, fmtutil-sys can apparently only be run on
335a real install, as root. But mktexlsr can be run in a DESTDIR with
336cd /YOUR/TEXMF/ROOT ; ls -LAR ./ >ls-R -->
337
338<screen role="root"><userinput>mktexlsr &amp;&amp;
339fmtutil-sys --all</userinput></screen>
340
341 <para>
342 To allow <xref linkend="evince"/> or <xref linkend="dvisvgm"/> to
343 link to <filename class="libraryfile">libkpathsea.so</filename>,
344 as the &root; user (re)create a symlink from
345 <filename class="directory">/usr/lib</filename>:
346 </para>
347
348<screen role="root"><userinput>ln -svf $TEXLIVE_PREFIX/lib/libkpathsea.so{,.6} /usr/lib</userinput></screen>
349
350 <note>
351 <!-- following based on fedora, but amended to run in the BLFS
352 layout, where adapting fedora's script for mtxrun did not
353 reliably work. ken -->
354 <para>
355 TeXLive includes some files for ConTeXt but the source of that is
356 separate and has moved on from using luatex in the previous 'mkiv'
357 version to using luametatex which can be pulled with git from <ulink
358 url="https://github.com/contextgarden/luametatex/tags">github luametatex</ulink>.
359 LuaMetaTeX uses meson and ninja, but it does not fit easily into
360 the BLFS layout of TeXLive.
361 <!-- FIXME - when removing, keep that link to luametatex tags, and note
362 that building and installing that to fit with a BLFS install of TeXLive
363 will not be a trivial exercise.-->
364 </para>
365 <para>
366 However, with a little extra work 'mkiv' files can still be processed
367 using the files shipped in texmf.
368 </para>
369
370 <para>
371 <emphasis>Fixes to use ConTeXt will be removed when the texlive source next
372 has to be updated for either a vulnerability fix which requires backporting
373 luatex changes, or for TeXLive 2024. If you are a BLFS user of ConTeXt you
374 should be prepared to use the latest tag from github (the link is
375 in first paragraph of this Note). Building and installing that to work with
376 a BLFS install of TeXLive will not be a trivial exercise.</emphasis>
377 </para>
378 </note>
379
380 <para>
381 The following steps, run as the
382 <systemitem class="username">root</systemitem> user, will create
383 <command>mtxrun</command> and <command>context</command>.
384 </para>
385
386<!-- I've put blank lines in this to make it a little less hard to read. ken -->
387<screen role="root"><userinput>sed -e '/local template=\[\[--ini/s/\(primaryflags%\)\(.*\)/\1 --socket --shell-escape \2/' \
388 -e '/local template=\[\[%primaryflags%/s/\(primaryflags%\)\(.*\)/\1 --socket --shell-escape \2/' \
389 -i $TEXLIVE_PREFIX/texmf-dist/scripts/context/lua/mtxrun.lua &amp;&amp;
390
391mkdir -pv $TEXLIVE_PREFIX/texmf-var/luatex-cache/context/ &amp;&amp;
392
393ln -sfv /$TEXLIVE_PREFIX/texmf-dist/scripts/context/lua/mtxrun.lua \
394 /$TEXLIVE_PREFIX/bin/$TEXARCH/mtxrun &amp;&amp;
395
396cat > $TEXLIVE_PREFIX/bin/$TEXARCH/context &lt;&lt; EOF
397#!/bin/sh
398export TEXMF=$TEXLIVE_PREFIX/texmf-dist;
399export TEXMFCNF=$TEXLIVE_PREFIX/texmf-dist/web2c;
400export TEXMFCACHE=$TEXLIVE_PREFIX/texmf-var/luatex-cache/context/;
401$TEXLIVE_PREFIX/bin/$TEXARCH/mtxrun --script context "\$@"
402EOF
403chmod -v 0755 $TEXLIVE_PREFIX/bin/$TEXARCH/context</userinput></screen>
404
405 <para>
406 You can now proceed to <xref linkend="asymptote"/>,
407 <xref linkend="biber"/>, <xref linkend="dvisvgm"/> and / or <xref
408 linkend="xindy"/> if you wish to install them.
409 </para>
410
411 </sect2>
412
413 <sect2 role="commands">
414 <title>Command Explanations</title>
415
416 <para>
417 <command>patch -Np1 -i ../texlive-&texlive-version;-source-security_fix-1.patch</command>:
418 this updates the luatex source to v1.17.0 to fix security issues.
419 </para>
420
421 <para>
422 <command>sed -e '/local template (...)' (...)mtxrun.lua</command>: this makes a
423 change in a texmf-dist script so that ConTeXt can now run with luatex-v1.17.0.
424 </para>
425
426 <para>
427 <command>-C</command>: create config.cache, this saves significant
428 time in a parallel build.
429 </para>
430
431 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
432 href="../../xincludes/tex-prefix.xml"/>
433
434 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
435 href="../../xincludes/tex-lib.xml"/>
436
437 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
438 href="../../xincludes/static-libraries.xml"/>
439
440 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
441 href="../../xincludes/tex-shared.xml"/>
442
443 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
444 href="../../xincludes/tex-system.xml"/>
445<!--
446 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
447 href="../../xincludes/tex-xpdf.xml"/>-->
448
449 <para>
450 <command>--disable-dvisvgm</command>: As noted above, the shipped version
451 of dvisvgm, which has modified configuration files, cannot be built with
452 shared system libraries.
453 </para>
454
455 <para>
456 <command>make texlinks</command> : this runs the texlinks.sh script
457 to create symbolic links from formats to engines. In
458 practice, several of the targets such as <command>xetex</command> are now
459 separate binaries and for these it will report "file already exists".
460 </para>
461
462 <para>
463 <command>tar -xf texlive-&texmf-version;-texmf.tar.xz -C $TEXLIVE_PREFIX --strip-components=1</command>:
464 the tarball contains the files for the texmf-dist directory, and because
465 of its size we do not want to waste time and space untarring it and then
466 copying the files.
467 </para>
468
469 <para>
470 <command>install -v -m644 ../texk/tests/TeXLive/*
471 $TEXLIVE_PREFIX/tlpkg/TeXLive/</command>: This puts the perl
472 modules <filename>TLConfig.pm</filename> and <filename>TLUtils.pm</filename>
473 into the directory where the binary installer puts them - it is at the
474 start of the perl @INC@ PATH within texlive when installed using the above
475 configure switches. Without these modules, texlive is unusable.
476 </para>
477
478 <para>
479 <command>mktexlsr</command>: Create an <filename>ls-R</filename> file
480 which lists what was installed - this is used by kpathsea to find files.
481 </para>
482
483 <para>
484 <command>fmtutil-sys --all</command>: This initializes the TeX formats,
485 Metafont bases and Metapost mems.
486 </para>
487
488 <para>
489 <command>mkdir -pv $TEXLIVE_PREFIX/texmf-var/luatex-cache/context/</command>:
490 the context script created after this will not run correctly if this
491 directory is not present.
492 </para>
493
494 <para>
495 <option>--without-x</option>: use this if you do not have Xorg installed.
496 </para>
497
498 <para>
499 There are many other '--disable' or '--without' options. Some of them such
500 as <option>--without-texinfo</option> are accepted but no longer do anything,
501 others will prevent a program being built - but the far greater amount of
502 space used for the related items in texmf means there is no obvious benefit
503 from disabling a few of the programs.
504 </para>
505
506 </sect2>
507
508 <sect2 role="content">
509 <title>Contents</title>
510
511 <segmentedlist>
512 <segtitle>Installed Programs</segtitle>
513 <segtitle>Installed Libraries</segtitle>
514 <segtitle>Installed Directories</segtitle>
515
516 <seglistitem>
517 <seg>Over 300 binaries and symlinks to scripts</seg>
518 <seg>libkpathsea.so,
519 libptexenc.so,
520 libsynctex.so,
521 libtexlua52.so,
522 libtexluajit.so
523 </seg>
524 <seg>$TEXLIVE_PREFIX/bin,
525 $TEXLIVE_PREFIX/include,
526 $TEXLIVE_PREFIX/lib,
527 $TEXLIVE_PREFIX/texmf-dist
528 </seg>
529 </seglistitem>
530 </segmentedlist>
531
532 <variablelist>
533 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
534 <?dbfo list-presentation="list"?>
535 <?dbhtml list-presentation="table"?>
536
537 <varlistentry id="texlive-programs">
538 <term><command>TeX&nbsp;programs</command></term>
539 <listitem>
540 <xi:include xmlns:xi="http://www.w3.org/2001/XInclude"
541 href="../../xincludes/texprogs.xml"/>
542 <indexterm zone="texlive texlive-programs">
543 <primary sortas="b-texlive-programs">TeX Live programs</primary>
544 </indexterm>
545 </listitem>
546 </varlistentry>
547
548 <varlistentry id="libkpathsea">
549 <term><filename class="libraryfile">libkpathsea.so</filename></term>
550 <listitem>
551 <para>
552 (kpathsearch) exists to look up a file in a list of directories
553 and is used by <command>kpsewhich</command>
554 </para>
555 <indexterm zone="texlive libkpathsea">
556 <primary sortas="c-libkpathsea">libkpathsea.so</primary>
557 </indexterm>
558 </listitem>
559 </varlistentry>
560
561 <varlistentry id="libptexenc">
562 <term><filename class="libraryfile">libptexenc.so</filename></term>
563 <listitem>
564 <para>
565 is a library for Japanese pTeX (publishing TeX)
566 </para>
567 <indexterm zone="texlive libptexenc">
568 <primary sortas="c-libptexenc">libptexenc.so</primary>
569 </indexterm>
570 </listitem>
571 </varlistentry>
572
573 <varlistentry id="libsynctex">
574 <term><filename class="libraryfile">libsynctex.so</filename></term>
575 <listitem>
576 <para>
577 is the SyncTeX (Synchronize TeXnology) parser library
578 </para>
579 <indexterm zone="texlive libsynctex">
580 <primary sortas="c-libsynctex">libsynctex.so</primary>
581 </indexterm>
582 </listitem>
583 </varlistentry>
584
585 <varlistentry id="libtexlua52">
586 <term><filename class="libraryfile">libtexlua52.so</filename></term>
587 <listitem>
588 <para>
589 provides Lua 5.2, modified for use with LuaTeX
590 </para>
591 <indexterm zone="texlive libtexlua52">
592 <primary sortas="c-libtexlua52">libtexlua52.so</primary>
593 </indexterm>
594 </listitem>
595 </varlistentry>
596
597 <varlistentry id="libtexluajit">
598 <term><filename class="libraryfile">libtexluajit.so</filename></term>
599 <listitem>
600 <para>
601 provides LuaJIT, modified for use with LuaJITTeX
602 </para>
603 <indexterm zone="texlive libtexluajit">
604 <primary sortas="c-libtexluajit">libtexluajit.so</primary>
605 </indexterm>
606 </listitem>
607 </varlistentry>
608 </variablelist>
609
610 </sect2>
611
612</sect1>
Note: See TracBrowser for help on using the repository browser.