AA_steps_johnnyberg_sxc_1354835.jpg

© Johnnyberg, sxc.hu

LaTeX-Dokumente automatisiert kompilieren

In kleinen Schritten

Wer gelegentlich mit LaTeX arbeitet, der profitiert von einem sauber geschriebenen Skript, das beim Übersetzen der Quelldateien hilft.

Langjährige LaTeX-Anwender kennen ihre Werkzeuge und verfügen über ein tieferes Verständnis für das Zusammenspiel der beteiligten Programme. Mit der Zeit geraten die einzelnen Handgriffe zur Routine. Einsteiger suchen dagegen häufig nach den richtigen Befehlen. Mit einem einfachen Skript gelingt das Übersetzen im Handumdrehen – inklusive geordnetem Aufräumen am Schluss.

Standardweg

Eine LaTeX-Datei im Rohformat macht noch keinen Sommer. Für das Übersetzen ins gewünschte Format existieren mehrere Wege. Einer davon führt mittels Zwischenschritt über das Device Independent Format (DVI). Zum Erzeugen von Postscript kommen die Kommandos latex und dvips zum Einsatz, für PDF hingegen latex und dvipdf. Der direkte Weg zum PDF führt über pdflatex (Abbildung 1).

Abbildung 1: Mit wenigen Befehlen übersetzen Sie TeX-Quelldateien in die Formate Postscript und PDF.

Der Ablauf entspricht in etwa jenem beim Kompilieren von Quellcode: Es entstehen Stück für Stück Inhalts-, Abbildungs- und Tabellenverzeichnisse sowie die Querverweise. Für einfache Dokumente genügt dabei ein Durchlauf, bei umfangreicheren Texten mit Verzeichnissen und Verweisen im Text fallen in der Regel drei Durchläufe an (Listing 1). Das gilt selbst beim Einsatz von Pdflatex (wobei in diesem Fall die Schritte 4 und 5 aus Listing 1 entfallen).

Listing 1

$ latex dokument.tex
$ latex dokument.tex
$ latex dokument.tex
$ dvipdf dokument.dvi
$ ps2pdf dokument.ps

Während des Übersetzen der Quellen entstehen eine Reihe von weiteren Dateien (siehe Tabelle "Hilfsdateien"). Darin merkt sich LaTeX alle dynamischen Objekte, die es während der Analyse des Dokuments findet und die es im nächsten Durchlauf in das finale Dokument übertragen muss – beispielsweise Querverweise mit der korrekten Seitenzahl. Mit Ausnahme der .log- und .aux-Datei werden diese Zwischendaten nur dann ausgegeben, wenn LaTeX das entsprechende Verzeichnis erzeugen soll.

Hilfsdateien

Suffix Beschreibung
.log Details zum letzten Übersetzen
.toc Inhaltsverzeichnis ("Table of Contents")
.lof Verzeichnis der Abbildungen ("List of Figures")
.lot Verzeichnis der Tabellen ("List of Tables")
.aux Informationen zwischen den Durchläufen
.idx Mit makeindex erzeugte Indexdateien

Ab ins Skript

Die Abfolge der Kommandos aus Listing 1 ergibt bereit ein einfaches Batch-Skript (Listing 2), das wir im Folgenden make-pdf.sh nennen. Der Einfachheit halber kommt im Beispiel Pdflatex zum Einsatz.

Nachdem Sie das Skript mittels chmod +x make-pdf.sh mit den entsprechenden Rechten ausgestattet haben, rufen Sie es mit ./make-pdf.sh auf. Es arbeitet die gespeicherten Kommandos ab und übersetzt dabei die Datei dokument.tex in ein PDF namens dokument.pdf.

Listing 2

#!/bin/bash
pdflatex dokument.tex
pdflatex dokument.tex
pdflatex dokument.tex

Damit Sie flexibel bleiben und sich beim Übersetzen nicht nur auf ein einziges Dokument festzulegen brauchen, ergänzen Sie das Skript um einen Parameter beim Aufruf – den Dateinamen der LaTeX-Datei. Diesen Dateinamen reicht das Skript in der Variable $1 an den Befehl pdflatex weiter (Listing 3). Die Variable $1 steht in Anführungszeichen, damit auch Dateinamen mit Leerzeichen nicht zum Stolperstein geraten.

Listing 3

#!/bin/bash
pdflatex "$1"
pdflatex "$1"
pdflatex "$1"
find . -regextype posix-extended -regex '.+\.(aux|lo[gft]|toc|idx)' -delete

Bleibt noch das Aufräumen am Schluss, also das Löschen der Zwischendaten. In Zeile 5 von Listing 3 entfernen Sie diese über Find in Kombination mit einem Suchmuster als regulären Ausdruck [1].

Das Suchmuster beinhaltet mindestens ein beliebiges Zeichen (.+), gefolgt von einem Punkt (\.) und entweder der Zeichenkette aux, toc, idx oder lo in Kombination mit g, f oder t. Das Pipe-Zeichen fungiert innerhalb der runden Klammern als Oder-Operator.

Eine explizite Kennzeichnung des Anfangs (^) beziehungsweise des Endes des Suchmusters ($) ist nicht erforderlich – Find fügt das eigenständig hinzu. Ausgehend vom aktuellen Verzeichnis, symbolisiert durch den Punkt, stöbert das Programm alle Dateien auf, die auf das angegebene Suchmuster passen. Mit dem Parameter -delete am Ende des Aufrufs löscht die Software jeden Treffer.

Sie übergeben Find das Suchmuster als erweiterten POSIX-Ausdruck, was die zusätzliche Option -regextype posix-extended im Aufruf notwendig macht. Nutzer von BSD oder Mac OS X nutzen stattdessen die Option -E.

Diesen Artikel als PDF kaufen

Express-Kauf als PDF

Umfang: 3 Heftseiten

Preis € 0,99
(inkl. 19% MwSt.)

LinuxCommunity kaufen

Einzelne Ausgabe
 
Abonnements
 
TABLET & SMARTPHONE APPS
Bald erhältlich
Get it on Google Play

Deutschland

Ähnliche Artikel

Kommentare

Infos zur Publikation

LU 10/2016: Kryptographie

Digitale Ausgabe: Preis € 0,00
(inkl. 19% MwSt.)

LinuxUser erscheint monatlich und kostet 5,95 Euro (mit DVD 8,50 Euro). Weitere Infos zum Heft finden Sie auf der Homepage.

Das Jahresabo kostet ab 86,70 Euro. Details dazu finden Sie im Computec-Shop. Im Probeabo erhalten Sie zudem drei Ausgaben zum reduzierten Preis.

Bei Google Play finden Sie digitale Ausgaben für Tablet & Smartphone.

HINWEIS ZU PAYPAL: Die Zahlung ist ohne eigenes Paypal-Konto ganz einfach per Kreditkarte oder Lastschrift möglich!

Aktuelle Fragen

Probleme mit MPC/MPD
Matthias Göhlen, 27.09.2016 13:39, 0 Antworten
Habe gerade mein erstes Raspi Projekt angefangen, typisches Einsteigerding: Vom Raspi 3B zum Radi...
Soundkarte wird erkannt, aber kein Ton
H A, 25.09.2016 01:37, 6 Antworten
Hallo, Ich weiß, dass es zu diesem Thema sehr oft Fragen gestellt wurden. Aber da ich ein Linu...
Scannen nur schwarz-weiß möglich
Werner Hahn, 20.09.2016 13:21, 2 Antworten
Canon Pixma MG5450S, Dell Latitude E6510, Betriebssyteme Ubuntu 16.04 und Windows 7. Der Canon-D...
Meteorit NB-7 startet nicht
Thomas Helbig, 13.09.2016 02:03, 4 Antworten
Verehrte Community Ich habe vor Kurzem einen Netbook-Oldie geschenkt bekommen. Beim Start ersch...
windows bootloader bei instalation gelöscht
markus Schneider, 12.09.2016 23:03, 1 Antworten
Hallo alle zusammen, ich habe neben meinem Windows 10 ein SL 7.2 Linux installiert und musste...