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 04/2017: SPEZIAL-DISTRIBUTIONEN

Digitale Ausgabe: Preis € 5,95
(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

WLAN lässt sich nicht einrichten
Werner Hahn, 21.03.2017 14:16, 0 Antworten
Dell Latitude E6510, Ubuntu 16.4, Kabelbox von Telecolumbus. Nach Anklicken des Doppelpfeiles (o...
"Mit Gwenview importieren" funktioniert seit openSuse 42.2 nicht mehr
Wimpy *, 20.03.2017 13:34, 2 Antworten
Bisher konnte ich von Digitalkamera oder SD-Karte oder USB-Stick Fotos mit Gwenview importieren....
Ich habe eine awk Aufgabe und bekomme es nicht so Recht hin
Dennis Hamacher, 10.03.2017 18:27, 1 Antworten
Ich hoffe Ihr könnt mir dabei helfen oder mir zeigen wie der Befehl richtig geschrieben wird. Ich...
Unter Linux Open Suse Leap 42.1 einen Windows Boot/ ISO USB Stick erstellen...
Tim Koetsier, 07.03.2017 15:26, 1 Antworten
Hallo, weiß jemand wie ich oben genanntes Vorhaben in die Tat umsetzen kann ? Wäre echt dankba...
Druckertreiber installieren OpenSuse42.1
Tim Koetsier, 07.03.2017 15:22, 1 Antworten
hallo, kann mir BITTE jemand helfen ich verzweifel so langsam. Habe einen Super Toner von Canon...