forked from kivitendo/kivitendo-crm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprogrammierstilrichtlinien.txt
141 lines (98 loc) · 3.74 KB
/
programmierstilrichtlinien.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
CRM Style Guide
---------------
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 wird (Stichworte
"Klammern" oder "Hash-Keys").
Diese Regeln sind keine Schikane, sondern erleichtern allen das Leben!
--------------------------------------------------------------------------
0. Falls nicht anders definiert, gelten im Zweifel die Konvention für die
PEAR-Coding-Standards (s.a. http://pear.php.net/manual/de/standards.php)
1. Es werden keine "echten" TAB-Zeichen sondern Leerzeichen verwendet.
Perltidy: -nt
2. Die Einrückung beträgt vier Leerzeichen.
Beispiel:
function test {
echo "Hallo Welt";
}
3. Öffnende geschweifte Klammern befinden sich auf der gleichen Zeile wie
der letzte Befehl.
Beispiele:
function test {
...
}
oder
if ($rows > 0) {
...
}
4. Schließende geschweifte Klammern sind so weit eingerückt wie der Befehl/
die öffnende schließende Klammer, die den Block gestartet hat, und nicht
auf der Ebene des Inhalts. Die gleichen Beispiele wie bei 3. gelten.
5. Die Wörter "else" "else if", "while" befinden sich auf der gleichen
Zeile wie schließende geschweifte Klammern.
Beispiele:
if ($sum"> 1000) {
...
} else if ($sum > 0) {
...
} else {
...
}
do {
...
} while ($a > 0);
6. Parameter von Funktionsaufrufen müssen mit runden Klammern versehen
werden.
Beispiel:
debug("Konnte Datei nicht oeffnen.\n");
7. Verschiedene Klammern
7.1 Aufeinander folgende runde Klammern sollten nicht durch Leerzeichen
abgesetzt werden.
Beispiel:
if (($debug == 1) && (($sum - 100) < 0)) {
...
}
7.2 Nach und vor eckigen Klammern sollten keine Leerzeichen stehen.
Beispiel:
$array[$i + 1] = 4;
8. Mehrzeilige Befehle
8.1 Werden die Parameter eines Funktionsaufrufes auf mehrere Zeilen
aufgeteilt, so müssen diese bis zu der Spalte eingerückt werden,
in der die ersten Funktionsparameter in der ersten Zeile stehen.
Beispiel:
$sth = $dbh->prepare("SELECT * FROM some_table WHERE col = ?",
$some_col_value);
8.2 Wird ein Befehl auf einer neuen Zeile forgesetzt, so ist ab der
zweiten Zeile zusätzlich vier Leerzeichen einzurücken.
Beispiel:
my $rowcount =
$row_$i ? $i : $rowcount - $rowbase;
9. Kommentare
9.1 Kommentare, die alleine in einer Zeile stehen, sollten soweit wie der
Code eingerückt sein.
9.2 Seitliche hängende Kommentare sollten einheitlich formatiert werden.
9.3 Die Kommentare sollten phpdoc-konform sein (Siehe auch: http://www.phpdoc.org/)
9.4 Warum man das tun sollte:
http://manual.phpdoc.org/HTMLSmartyConverter/HandS/phpDocumentor/tutorial_phpDocumentor.pkg.html
10. Die Maximale Zeilenlänge ist nicht bescränkt. Zeilenlängen <= 80
helfen, weil sie dann im Textmodus / per SSH deutlich besser lesbar
sind. Oft genug ist es aber nicht möglich oder nur unter großen
Verrenkungen, diese Vorgabe einzuhalten.
Zeilen sollten nicht länger als 132 Zeichen sein.
11. Dateien sollten im UTF-8 Format gespeichert werden.
12. Zeilenumbrüche bitte UNIX - Style (\n)
--------------------------------------------------------------------------
A.1 Einstellung für vim
Folgende Einstellungen für vim-Benutzer
.vimrc:
set fileencodings=utf-8
set expandtab
set shiftwidth=4
set softtabstop=4
set tabstop=4
A.2 Einstellungen für automatische phpdoc-Vorlagen in vim
Z.B.: http://markus.fischer.name/vim/phpdoc/
A.3 Zum Überprüfen von Leerzeichen oder Tabstops folgende Ergänzungen
.vimrc
set list listchars=trail:.
highlight SpecialKey ctermfg=DarkGray