In vielen Code-Beispielen und Paketen sieht man das Kommentar-Zeichen % am Ende von Zeilen.

Wieso? Welchen Zweck erfüllen sie?

gefragt 10 Jun '13, 11:51

cgnieder's gravatar image

cgnieder
22.1k253463
Akzeptiert-Rate: 60%

bearbeitet 02 Dez '14, 13:57


Wenn TeX das Ende einer Zeile sieht, wandelt es das in ein Leerzeichen um, exakt äquivalent, als wenn man ein Leerzeichen eingegeben hätte:

Open in writeLaTeX
Text
Text

ist genau gleich wie

Open in writeLaTeX
Text Text

Genaugenommen wird das Zeichen eingefügt, das der Nummer des Registers \endlinechar entspricht (solange der Wert zwischen einschließlich 0 und 255 liegt). In der Voreinstellung ist das 13 und entspricht der Eingabe der Enter-Taste (carriage return, ^^M in TeX-Schreibweise mit Kategorie-Code 5=Enter-Taste). Folgt dem Ende einer Zeile ein weiteres Ende einer Zeile, wird stattdessen \par eingefügt.

In Makro-Definitionen gilt das genauso wie im laufenden Text. Die Definition

Open in writeLaTeX
\newcommand*\foo{
foo
bar
}

ist gleich der Definition

Open in writeLaTeX
\newcommand*\foo{ foo bar }

wie folgendes Beispiel demonstriert:

Open in writeLaTeX
\documentclass{article}
\newcommand*\foo{
  foo
  bar
}
\begin{document}
bla\foo{}bar
\end{document}

Ergebnis 1

Da Leerzeichen am Anfang einer Zeile verschluckt werden, nicht aber an anderen Stellen, sollte man Leerzeichen, die durch das Ende von Zeilen verursacht werden, verstecken, damit sie nicht unbeabsichtigt an Stellen auftauchen, an denen man sie nicht möchte:

Open in writeLaTeX
\newcommand*\foo{%
  foo
  bar%
}

Diese Definition ist jetzt gleichwertig zu

Open in writeLaTeX
\newcommand*\foo{foo bar}

wie dieses Beispiel demonstriert:

Open in writeLaTeX
\documentclass{article}
\newcommand*\foo{%
  foo
  bar%
}
\begin{document}
bla\foo{}bar
\end{document}

Ergebnis 2

Jetzt sollte man aber auch nicht den Schluss ziehen, dass man einfach immer an das Ende einer Zeile ein % setzen sollte. Aufpassen muss man zum Beispiel nach Zuweisungen oder Primitiven, die Zahlen nach sich erwarten, wie \ifnum oder \count\foo=.... Diese schauen nämlich so lange weiter nach Zahlen, bis sie entweder ein nichtexpandierbares Token finden, das keine Zahl ist, oder bis sie auf ein Leerzeichen finden, das sie dann entfernen. Mit folgender Definition

Open in writeLaTeX
\newcommand*\test[1]{%
  \ifnum1=#1%
    1%
  \else
    keine 1%
  \fi
}

liefert

Open in writeLaTeX
\test{1}

vielleicht unerwarteterweise »keine 1«! Das liegt daran, dass die Definition gleichbedeutend ist mit

Open in writeLaTeX
\newcommand*\test[1]{\ifnum1=#11\else keine 1\fi}

und tatsächlich 1 mit 11 verglichen wurde. Übrigens: nach Anweisung wie im Beispiel \else und \fi muss man kein Leerzeichen verstecken, da TeX Leerzeichen nach Anwendungen ignoriert. Eine bessere Definition des obigen wäre z.B.:

Open in writeLaTeX
\newcommand*\test[1]{%
  \ifnum1=#1 % Leerzeichen nach `#1'
    1%
  \else
    keine 1%
  \fi
}

Ähnlich vorsichtig sollte man nach Zuweisungen sein, die Skips (Längen, die dehn- und stauchbare Anteile enthalten können) zuweisen und nach plus und minus suchen.

Permanenter link

beantwortet 10 Jun '13, 12:21

cgnieder's gravatar image

cgnieder
22.1k253463
Akzeptiert-Rate: 60%

bearbeitet 04 Dez '14, 11:16

Eine sehr gute Übersicht darüber, wann Zeilenenden oder Leerzeichen von LaTeX als Wortzwischenraum interpretiert werden und deshalb auch in der Ausgabe landen und wann nicht, findet man übrigens in dem Artikel »Ich habe zusätzliche Leerzeichen/Einzüge in meinem Text, die da nicht hingehören. Woher kommen die?«

Permanenter link

beantwortet 23 Jun '13, 18:14

saputello's gravatar image

saputello
11.1k174365
Akzeptiert-Rate: 51%

Deine Antwort
Vorschau umschalten

Folgen dieser Frage

Per E-Mail:

Wenn sie sich anmelden, kommen Sie für alle Updates hier in Frage

Per RSS:

Antworten

Antworten und Kommentare

Markdown-Grundlagen

  • *kursiv* oder _kursiv_
  • **Fett** oder __Fett__
  • Link:[Text](http://url.com/ "Titel")
  • Bild?![alt Text](/path/img.jpg "Titel")
  • nummerierte Liste: 1. Foo 2. Bar
  • zum Hinzufügen ein Zeilenumbruchs fügen Sie einfach zwei Leerzeichen an die Stelle an der die neue Linie sein soll.
  • grundlegende HTML-Tags werden ebenfalls unterstützt

Frage-Themen:

×52
×15
×7
×7

gestellte Frage: 10 Jun '13, 11:51

Frage wurde gesehen: 28,121 Mal

zuletzt geändert: 04 Dez '14, 11:16