Projekt

Allgemein

Profil

Herunterladen (10,1 KB) Statistiken
| Zweig: | Markierung: | Revision:
f8309cb7 Moritz Bunkus
<html><head>
06cb6b12 Moritz Bunkus
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>4.5. Stil-Richtlinien</title><link rel="stylesheet" type="text/css" href="style.css"><meta name="generator" content="DocBook XSL Stylesheets V1.76.1-RC2"><link rel="home" href="index.html" title="Lx-Office: Installation, Konfiguration, Entwicklung"><link rel="up" href="ch04.html" title="Kapitel 4. Entwicklerdokumentation"><link rel="prev" href="ch04s04.html" title="4.4. Translations and languages"><link rel="next" href="ch04s06.html" title="4.6. Dokumentation erstellen"></head><body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF"><div class="navheader"><table width="100%" summary="Navigation header"><tr><th colspan="3" align="center">4.5. Stil-Richtlinien</th></tr><tr><td width="20%" align="left"><a accesskey="p" href="ch04s04.html">Zurück</a>&nbsp;</td><th width="60%" align="center">Kapitel 4. Entwicklerdokumentation</th><td width="20%" align="right">&nbsp;<a accesskey="n" href="ch04s06.html">Weiter</a></td></tr></table><hr></div><div class="sect1" title="4.5. Stil-Richtlinien"><div class="titlepage"><div><div><h2 class="title" style="clear: both"><a name="devel.style-guide"></a>4.5. Stil-Richtlinien</h2></div></div></div><p>Die folgenden Regeln haben das Ziel, den Code möglichst gut les-
und wartbar zu machen. Dazu gehört zum Einen, dass der Code einheitlich
eingerückt ist, aber auch, dass Mehrdeutigkeit so weit es geht vermieden
3adb0cb7 Moritz Bunkus
wird (Stichworte "Klammern" oder "Hash-Keys").</p><p>Diese Regeln sind keine Schikane sondern erleichtern allen das
Leben!</p><p>Jeder, der einen Patch schickt, sollte seinen Code vorher
06cb6b12 Moritz Bunkus
überprüfen. Einige der Regeln lassen sich automatisch überprüfen, andere
3adb0cb7 Moritz Bunkus
nicht.</p><div class="orderedlist"><ol class="orderedlist" type="1"><li class="listitem"><p>Es werden keine echten Tabs sondern Leerzeichen
06cb6b12 Moritz Bunkus
verwendet.</p></li><li class="listitem"><p>Die Einrückung beträgt zwei Leerzeichen. Beispiel:</p><pre class="programlisting">foreach my $row (@data) {
f8309cb7 Moritz Bunkus
if ($flag) {
# do something with $row
}

if ($use_modules) {
$row-&gt;{modules} = MODULE-&gt;retrieve(
id =&gt; $row-&gt;{id},
date =&gt; $use_now ? localtime() : $row-&gt;{time},
);
}

$report-&gt;add($row);
06cb6b12 Moritz Bunkus
}</pre></li><li class="listitem"><p>Öffnende geschweifte Klammern befinden sich auf der gleichen
3adb0cb7 Moritz Bunkus
Zeile wie der letzte Befehl. Beispiele:</p><pre class="programlisting">sub debug {
f8309cb7 Moritz Bunkus
...
}</pre><p>oder</p><pre class="programlisting">if ($form-&gt;{item_rows} &gt; 0) {
...
06cb6b12 Moritz Bunkus
}</pre></li><li class="listitem"><p>Schließende geschweifte Klammern sind so weit eingerückt wie
der Befehl / die öffnende schließende Klammer, die den Block
3adb0cb7 Moritz Bunkus
gestartet hat, und nicht auf der Ebene des Inhalts. Die gleichen
06cb6b12 Moritz Bunkus
Beispiele wie bei 3. gelten.</p></li><li class="listitem"><p>Die Wörter "<code class="function">else</code>",
3adb0cb7 Moritz Bunkus
"<code class="function">elsif</code>", "<code class="function">while</code>" befinden
06cb6b12 Moritz Bunkus
sich auf der gleichen Zeile wie schließende geschweifte Klammern.
3adb0cb7 Moritz Bunkus
Beispiele:</p><pre class="programlisting">if ($form-&gt;{sum} &gt; 1000) {
f8309cb7 Moritz Bunkus
...
} elsif ($form-&gt;{sum} &gt; 0) {
...
} else {
...
}

do {
...
06cb6b12 Moritz Bunkus
} until ($a &gt; 0);</pre></li><li class="listitem"><p>Parameter von Funktionsaufrufen müssen mit runden Klammern
3adb0cb7 Moritz Bunkus
versehen werden. Davon nicht betroffen sind interne Perl-Funktionen,
06cb6b12 Moritz Bunkus
und grep-ähnliche Operatoren. Beispiel:</p><pre class="programlisting">$main::lxdebug-&gt;message("Could not find file.");
%options = map { $_ =&gt; 1 } grep { !/^#/ } @config_file;</pre></li><li class="listitem"><p>Verschiedene Klammern, Ihre Ausdrücke und Leerzeichen:</p><p>Generell gilt: Hashkeys und Arrayindices sollten nicht durch
3adb0cb7 Moritz Bunkus
Leerzeichen abgesetzt werden. Logische Klammerungen ebensowenig,
06cb6b12 Moritz Bunkus
Blöcke schon. Beispiel:</p><pre class="programlisting">if (($form-&gt;{debug} == 1) &amp;&amp; ($form-&gt;{sum} - 100 &lt; 0)) {
f8309cb7 Moritz Bunkus
...
}

$array[$i + 1] = 4;
$form-&gt;{sum} += $form-&gt;{"row_$i"};
$form-&gt;{ $form-&gt;{index} } += 1;

3adb0cb7 Moritz Bunkus
map { $form-&gt;{sum} += $form-&gt;{"row_$_"} } 1..$rowcount;</pre></li><li class="listitem"><p>Mehrzeilige Befehle</p><div class="orderedlist"><ol class="orderedlist" type="a"><li class="listitem"><p>Werden die Parameter eines Funktionsaufrufes auf mehrere
06cb6b12 Moritz Bunkus
Zeilen aufgeteilt, so sollten diese bis zu der Spalte eingerückt
3adb0cb7 Moritz Bunkus
werden, in der die ersten Funktionsparameter in der ersten Zeile
stehen. Beispiel:</p><pre class="programlisting">$sth = $dbh-&gt;prepare("SELECT * FROM some_table WHERE col = ?",
06cb6b12 Moritz Bunkus
$form-&gt;{some_col_value});</pre></li><li class="listitem"><p>Ein Spezialfall ist der ternäre Oprator "?:", der am
besten in einer übersichtlichen Tabellenstruktur organisiert
3adb0cb7 Moritz Bunkus
wird. Beispiel:</p><pre class="programlisting">my $rowcount = $form-&gt;{"row_$i"} ? $i
f8309cb7 Moritz Bunkus
: $form-&gt;{oldcount} ? $form-&gt;{oldcount} + 1
3adb0cb7 Moritz Bunkus
: $form-&gt;{rowcount} - $form-&gt;{rowbase};</pre></li></ol></div></li><li class="listitem"><p>Kommentare</p><div class="orderedlist"><ol class="orderedlist" type="a"><li class="listitem"><p>Kommentare, die alleine in einer Zeile stehen, sollten
06cb6b12 Moritz Bunkus
soweit wie der Code eingerückt sein.</p></li><li class="listitem"><p>Seitliche hängende Kommentare sollten einheitlich
formatiert werden.</p></li><li class="listitem"><p>Sämtliche Kommentare und Sonstiges im Quellcode ist bitte
3adb0cb7 Moritz Bunkus
auf Englisch zu verfassen. So wie ich keine Lust habe,
06cb6b12 Moritz Bunkus
französischen Quelltext zu lesen, sollte auch der Lx-Office
Quelltext für nicht-Deutschsprachige lesbar sein.
3adb0cb7 Moritz Bunkus
Beispiel:</p><pre class="programlisting">my $found = 0;
f8309cb7 Moritz Bunkus
while (1) {
last if $found;

# complicated check
$found = 1 if //
}

$i = 0 # initialize $i
$n = $i; # save $i
$i *= $const; # do something crazy
06cb6b12 Moritz Bunkus
$i = $n; # recover $i</pre></li></ol></div></li><li class="listitem"><p>Hashkeys sollten nur in Anführungszeichen stehen, wenn die
Interpolation gewünscht ist. Beispiel:</p><pre class="programlisting">$form-&gt;{sum} = 0;
f8309cb7 Moritz Bunkus
$form-&gt;{"row_$i"} = $form-&gt;{"row_$i"} - 5;
06cb6b12 Moritz Bunkus
$some_hash{42} = 54;</pre></li><li class="listitem"><p>Die maximale Zeilenlänge ist nicht beschränkt. Zeilenlängen
3adb0cb7 Moritz Bunkus
unterhalb von 79 Zeichen helfen unter bestimmten Bedingungen, aber
wenn die Lesbarkeit unter kurzen Zeilen leidet (wie zum Biespiel in
grossen Tabellen), dann ist Lesbarkeit vorzuziehen.</p><p>Als Beispiel sei die Funktion
<code class="function">print_options</code> aus
06cb6b12 Moritz Bunkus
<code class="filename">bin/mozilla/io.pl</code> angeführt.</p></li><li class="listitem"><p>Trailing Whitespace, d.h. Leerzeichen am Ende von Zeilen sind
unerwünscht. Sie führen zu unnötigen Whitespaceänderungen, die diffs
verfälschen.</p><p>Emacs und vim haben beide recht einfache Methoden zur
3adb0cb7 Moritz Bunkus
Entfernung von trailing whitespace. Emacs kennt das Kommande
<span class="command"><strong>nuke-trailing-whitespace</strong></span>, vim macht das gleiche
06cb6b12 Moritz Bunkus
manuell über <code class="literal">:%s/\s\+$//e</code> Mit <code class="literal">:au
3adb0cb7 Moritz Bunkus
BufWritePre * :%s/\s\+$//e</code> wird das an Speichern
gebunden.</p></li><li class="listitem"><p>Es wird kein <span class="command"><strong>perltidy</strong></span> verwendet.</p><p>In der Vergangenheit wurde versucht,
<span class="command"><strong>perltidy</strong></span> zu verwenden, um einen einheitlichen
Stil zu erlangen. Es hat sich aber gezeigt, dass
<span class="command"><strong>perltidy</strong></span>s sehr eigenwilliges Verhalten, was
06cb6b12 Moritz Bunkus
Zeilenumbrüche angeht, oftmals gut formatierten Code zerstört. Für
3adb0cb7 Moritz Bunkus
den Interessierten sind hier die
<span class="command"><strong>perltidy</strong></span>-Optionen, die grob den beschriebenen
Richtlinien entsprechen:</p><pre class="programlisting">-syn -i=2 -nt -pt=2 -sbt=2 -ci=2 -ibc -hsc -noll -nsts -nsfs -asc -dsm
f8309cb7 Moritz Bunkus
-aws -bbc -bbs -bbb -mbl=1 -nsob -ce -nbl -nsbl -cti=0 -bbt=0 -bar -l=79
-lp -vt=1 -vtc=1</pre></li><li class="listitem"><p>
3adb0cb7 Moritz Bunkus
<code class="varname">STDERR</code> ist tabu. Unkonditionale
Debugmeldungen auch.</p><p>Lx-Office bietet mit dem Modul <code class="classname">LXDebug</code>
einen brauchbaren Trace-/Debug-Mechanismus. Es gibt also keinen
Grund, nach <code class="varname">STDERR</code> zu schreiben.</p><p>Die <code class="classname">LXDebug</code>-Methode
06cb6b12 Moritz Bunkus
"<code class="function">message</code>" nimmt als ersten Paramter außerdem
eine Flagmaske, für die die Meldung angezeigt wird, wobei "0" immer
3adb0cb7 Moritz Bunkus
angezeigt wird. Solche Meldungen sollten nicht eingecheckt werden
06cb6b12 Moritz Bunkus
und werden in den meisten Fällen auch vom Repository
zurückgewiesen.</p></li><li class="listitem"><p>Alle neuen Module müssen use strict verwenden.</p><p>
3adb0cb7 Moritz Bunkus
<code class="varname">$form</code>, <code class="varname">$auth</code>,
<code class="varname">$locale</code>, <code class="varname">$lxdebug</code> und
<code class="varname">%myconfig</code> werden derzeit aus dem main package
importiert (siehe <a class="xref" href="ch04.html#devel.globals" title="4.1. Globale Variablen">Globale Variablen</a>. Alle anderen
06cb6b12 Moritz Bunkus
Konstrukte sollten lexikalisch lokal gehalten werden.</p></li></ol></div></div><div class="navfooter"><hr><table width="100%" summary="Navigation footer"><tr><td width="40%" align="left"><a accesskey="p" href="ch04s04.html">Zurück</a>&nbsp;</td><td width="20%" align="center"><a accesskey="u" href="ch04.html">Nach oben</a></td><td width="40%" align="right">&nbsp;<a accesskey="n" href="ch04s06.html">Weiter</a></td></tr><tr><td width="40%" align="left" valign="top">4.4. Translations and languages&nbsp;</td><td width="20%" align="center"><a accesskey="h" href="index.html">Zum Anfang</a></td><td width="40%" align="right" valign="top">&nbsp;4.6. Dokumentation erstellen</td></tr></table></div></body></html>