TeXLivePackaging
На этой странице описана организация дистрибутива TeXLive версии 2008.0
TeXLive package manager
Официальный дистрибутив распространяется вместе с собственной оболочкой для установки: tlmgr. Логически связанные файлы сгруппированы в пакеты, их описание формирует базу данных: texlive.tlpdb.
Пакеты TeXLive
Описание пакета состоит из
- названия (name)
- категории (category)
- базовая часть (TLCore)
- пакет (Package)
- коллекция (Collection)
- схема (Scheme)
- документация (Documentation)
- краткого описания (shortdesc)
- подробного описания (longdesc)
- списка файлов
- исполняемых (binfiles)
- используемых (runfiles)
- документации (docfiles)
- исходников (scrfiles)
- зависимостей (depend)
- исполняемых команд (execute)
- execute AddHyphen name=TEXLANG file=FILE [прочее] - подключить шаблоны переносов для языка TEXLANG из файла FILE; прочие параметры:
- lefthyphenmin - минимально допустимое количество букв до переноса
- righthyphenmin - минимально допустимое количество букв после переноса
- synonyms - список синонимов
- execute addMap font.map - подключить шрифт font.map в конфиге updmap.cfg
- execute addMixedMap font.map - подключить шрифт font.map в конфиге updmap.cfg в смешанном ("mixed") режиме
- execute BuildFormat FMTCFG - подключить в конфиге fmtutil.cnf все форматы из файла texmf/fmtutil/format.FMTCFG.cnf
- execute AddHyphen name=TEXLANG file=FILE [прочее] - подключить шаблоны переносов для языка TEXLANG из файла FILE; прочие параметры:
- прочего (revision, catalogue-*)
Пример описания пакета 12many:
name 12many category Package revision 7340 shortdesc 12many, generalizing mathematical index sets longdesc In the discrete branches of mathematics and the computer longdesc sciences, it will only take some seconds until you're faced longdesc with a set like {1,...,m}. Only some people write longdesc $1\ldotp\ldotp m$, or $\{j:1\leq j\leq m\}$, and that journal longdesc you're submitting to might want something else entirely. \otm{} longdesc provides an interface that makes changing from one to another a longdesc one-line change. docfiles size=98 texmf-dist/doc/latex/12many/12many.pdf texmf-dist/doc/latex/12many/README srcfiles size=6 texmf-dist/source/latex/12many/12many.dtx texmf-dist/source/latex/12many/12many.ins runfiles size=1 texmf-dist/tex/latex/12many/12many.sty catalogue-ctan /macros/latex/contrib/12many catalogue-date 2007-05-25 16:15:27 +0200 catalogue-license lppl catalogue-version 0.3
Пакетные зависимости TeXLive
Зависимости a la RPM Requires в TeXLive описываются одной или несколькими директивами depend. Пакеты зависят от других пакетов, коллекции - от пакетов, схемы - от коллекций и пакетов (коллекции и схемы не содержат файлов). Специального вида зависимость depend bin-package.ARCH подразумевает выбор конкретного пакета для используемой архитектуры, например, bin-package.i386-linux. Циклических зависимостей (pkg1 ⇒ pkg2 ⇒ pkg1) пока не обнаружено. Пакеты, коллекции, схемы и зависимости между ними можно наглядно изобразить в виде графа (cм. рис.)
Особенности сборки в Debian и ALT Linux
Идея разделить дистрибутив на 5 исходных пакетов родилась в Debian и позднее была позаимствована командой ALT Linux. Поэтому описание сборки в существенной мере будет повторять руководство Debian и Debian TeX sub-policy.
Исходные пакеты
В основанных на RPM дистрибутивах бинарные пакеты получаются пересборкой исходных (src.rpm). Дерево TeXLive поделено на 5 относительно независимых частей:
- texlive-base
- основной набор файлов
- texlive-bin
- исходники компилируемых архитектуро-зависимых программ
- texlive-lang
- поддержка национальных языков
- texlive-doc
- документация
- texlive-extra
- дополнительные файлы
Бинарные пакеты
Строго говоря, большинство файлов TeXLive является текстовыми, за исключением некоторых утилит из texlive-base-bin. Из исходных пакетов собираются следующие бинарные:
- texlive-base:
- texlive-latex-base
- основные файлы LaTeX, достаточные для простых документов
- texlive-latex-recommended
- рекомендуемый набор файлов LaTeX, достаточный в большинстве других случаев
- texlive-fonts-recommended
- рекомендуемый и обычно достаточный набор шрифтов
- texlive-bin:
- texlive-base-bin
- основной набор исполняемых и конфигурационных файлов
- texlive-doc:
- texlive-doc-*
- пакеты texlive-doc-en, texlive-doc-de и т.п., содержащие документацию на соответствующих языках
- texlive-lang:
- texlive-lang-*
- пакеты texlive-lang-dutch, texlive-lang-spanish и т.п. с поддержкой национальных особенностей, например, переносов
- texlive
- виртуальный пакет, зависящий от разумного набора реальных
- texlive-full
- виртуальный пакет, зависящий от всех пакетов TeXLive
Есть и другие пакеты с дополнительными возможностями и шрифтами. Смотрите их описание.
Манипуляции с исходным дистрибутивом
Дополнительно к базе texlive.tlpdb введён конфигурационный файл tpm2deb.cfg (в TeXLive версии 2007 формат пакетов был другой - tpm). Какой бинарный пакет собирается из какого исходного, определяется директивой name:
name;collection-basicbin;texlive-base-bin;texlive-bin
Здесь коллекция collection-basicbin соответствует бинарному пакету texlive-base-bin и собирается из исходного пакета texlive-bin.
Состав коллекции определяется директивами depend в описании пакетов: по ним производится рекурсивный обход, выявляющий полное подмножество пакетов. Если пакет оказывается нужен нескольким коллекциям, он попадает в «ближайшую»: до которой наименьшее число промежуточных узлов на графе (см. выше), а остальным в зависимости прописывается эта коллекция.
Иногда такой алгоритм себя не оправдывает. Требуется вручную переместить пакет в другую коллекцию, для чего используется директива move в файле tpm2deb.cfg:
move;bin-latex;collection-basicbin
Чтобы исключить из рассмотрения некоторые пакеты, например, уже имеющиеся в системе, или отдельные файлы, используется директива blacklist:
blacklist;tpm;bin-bzip2;* blacklist;tpm;iwona;texlive-lang-polish blacklist;file;texmf-dist/doc/latex/splitindex/splitindex-OpenBSD-i386 blacklist;file;bin/[^/]*/tlmgr
Пакет можно исключить изо всех коллекций (*) или из конкретной. Файлы можно задать регулярным выражением.
Отсутствующие символические ссылки создаются директивой mapping link:
mapping;%_bindir/vpe;link;texmf-dist/scripts/vpe/vpe.pl mapping;%_bindir/xmltools;link;texmf-dist/scripts/context/stubs/unix/xmltools
В ALT Linux необходимые ссылки вычисляются по списку LINKED_SCRIPTS из файла source/texk/texlive/Makefile.in:
sed -e 's/\\$//;/^#/d;/./{H;$!d}' \ -e 'x;/LINKED_SCRIPTS =/!d;' \ -e "s/.*LINKED_SCRIPTS = \\n//" \ source/texk/texlive/Makefile.in | \ while read file; do \ link=`basename "$file" | sed 's,\.[^/]*$,,' | tr '[A-Z]' '[a-z]'`; \ echo "mapping;/usr/bin/$link;link;$file"; \ done
Описанные действия выполняются скриптом tlptool.pl, который создаёт список исходных файлов из дистрибутива TeXLive и списки файлов для включения в пакеты RPM (в секции %files) по одному на каждый. Список исходных файлов используется скриптом git-filter-tree для создания коммита-потомка полного дистрибутива, таким образом дистрибутив разбивается на 5 независимых бранчей в git.
TODO: про git подробнее.
Скрипт tpltool.pl
Поскольку поддержка Perl разработчиками базы TeXLive наиболее полна, для манипуляций с пакетами выбран этот язык программирования. Его алгоритм упрощённо можно описать так:
- Загрузка конфига
- Загрузка пакетной базы
- Рекурсивный поиск зависимостей для каждой коллекции
- Удаление пакетов из чёрного списка
- Перемещение пакетов из одной коллекции в другую и проставление зависимостей между коллекциями
- Далее для каждой коллекции
- печатается список файлов для включения в RPM
- печатается шаблон spec-файла с описанием пакета и секциями %install и %files
- печатается список файлов для включения в архив с исходниками
Настройки
Системные и пользовательские настройки осуществляются перечисленными ниже переменными из файла /etc/tex-common/web2c/texmf.cnf, первые имеют больший приоритет.
- TEXMFCONFIG
- Пользовательские настройки. По умолчанию: $HOME/.texmf-config/
- TEXMFVAR
- Сгенерированные пользователем файлы. По умолчанию: $HOME/.texmf-var/
- TEXMFHOME
- Пользовательские неменяемые файлы, например, дополнительные пакеты LaTeX. По умолчанию: $HOME/texmf/
- TEXMFSYSCONFIG
- Общесистемные настройки. По умолчанию: /etc/texmf
- TEXMFSYSVAR
- Сгенерированные общесистемные файлы. По умолчанию: /var/lib/texmf/
- TEXMFLOCAL
- Общесистемные файлы. По умолчанию: /usr/local/share/texmf/
- TEXMFDIST
- Общесистемные файлы, установленные из основных пакетов RPM. По умолчанию: /usr/share/texmf-texlive
- TEXMFMAIN
- Общесистемные файлы, установленные из дополнительных пакетов RPM. По умолчанию: /usr/share/texmf/
Новые файлы обычно кладутся администратором в TEXMFLOCAL, а пользователями - в TEXMFHOME. При необходимости можно добавить новый путь к переменной TEXMF в файле /etc/texmf/web2c/texmf.cnf (первые записи имеют больший приоритет). TEXMFCONFIG и TEXMFVAR используются при запуске команд texconfig, updmap и fmtutil пользователем. Имейте в виду, что texconfig при первом запуске копирует файлы настроек из TEXMFMAIN или TEXMFSYSCONFIG и не отслеживает последующие системные изменения.
Конфигурационные файлы
- texmf.cnf — базовые настройки и пути используемых программ
- fmtutil.cnf — доступные форматы TeX
- updmap.cfg — конфигурация шрифтов
- language.dat, language.def — шаблоны переносов для разных языков
- Внимание! В отличие от Debian в ALT Linux пока что редактируется непосредственно /etc/texmf/web2c/texmf.cnf, а не шаблоны для него.
Менеджер tlmgr предполагает автоматическое создание и обновление конфигурационных файлов. В ALT Linux реализовано небольшое подмножество команд tlmgr, а именно
- generate language.dat - обновить language.dat
- generate language.def - обновить language.def
- generate language - обновить language.dat и language.def
- generate fmtutil - обновить fmtutil.cnf
- generate updmap - обновить updmap.cfg
Итоговые файлы получаются слиянием заготовок
- /var/cache/texmf/tex/generic/config/language.dat
- /etc/texmf/language.d/00-language.dat
- прочие /etc/texmf/language.d/*.dat
- /var/cache/texmf/tex/generic/config/language.def
- /etc/texmf/language.d/00-language.def
- прочие /etc/texmf/language.d/*.def
- /etc/texmf/language.d/99-language.def со строкой \uselanguage {USenglish} %%% This MUST be the last line of the file
- /var/cache/texmf/web2c/fmtutil.cnf
- /etc/texmf/fmt.d/00-fmtutil.cnf
- прочие /etc/texmf/fmt.d/*.cnf
- /var/cache/texmf/web2c/updmap.cfg
- /etc/texmf/updmap.d/00-updmap.cfg
- прочие /etc/texmf/updmap.d/*.cfg
Заготовки создаются во время сборки пакетов и иногда представляют собой символические ссылки на файлы из других директорий. Чтобы добавить свои собственные настройки, достаточно положить соответствующий конфиг в одну из директорий /etc/texmf/*.d/.
Кеширование шрифтов
TeX компилирует шрифты (пиксели, метрики и пр.) на лету. Эта информация может быть закеширована и использована позднее. На многопользовательских системах желательно указать переменной VARTEXFONTS на какой-нибудь каталог, например, /var/cache/fonts, и заменить переменную MT_FEATURES с texmfvar на varfonts в файле /etc/texmf/web2c/mktex.cnf
Тестирование
Ошибки и прочие соображения заносите на страницу Тестирование TeXLive2008.0