coding_standard.xml 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 14978 -->
  3. <!-- Reviewed: no -->
  4. <appendix id="coding-standard">
  5. <title>Zend Framework Coding Standard für PHP</title>
  6. <sect1 id="coding-standard.overview">
  7. <title>Übersicht</title>
  8. <sect2 id="coding-standard.overview.scope">
  9. <title>Geltungsbereich</title>
  10. <para>
  11. Dieses Dokument bietet Richtlinien für die Formatierung von Code und Dokumentation
  12. für Individuen und Teams die im Zend Framework mitarbeiten. Viele Entwickler die
  13. den Zend Framework verwenden haben diese Code Standards als nützlich empfunden weil
  14. Ihr Code Stil mit jedem Zend Framework Code konsistent bleibt. Es ist auch
  15. anzumerken das es signifikant viel Arbeit erfordert einen kompletten Coding
  16. Standard zu definieren.
  17. Beachte: Manchmal entscheiden Entwickler das die Verfügbarkeit eines Standards
  18. wichtiger ist als was der Standard aktuell im höchsten Level des Designs empfiehlt.
  19. Diese Richtlinien im Zend Framework Coding Standard beschreiben die Praxis die im
  20. ZF Projekt sehr gut funktionieren. Diese Standard können geändert oder so wie sie
  21. sind verwendet werden solange Sie sich an unsere
  22. <ulink url="http://framework.zend.com/license">Lizenz</ulink> halten.
  23. </para>
  24. <para>
  25. Die Bereiche die im ZF Coding Standard abgedeckt werden enthalten:
  26. <itemizedlist>
  27. <listitem>
  28. <para>PHP Dateiformatierung</para>
  29. </listitem>
  30. <listitem>
  31. <para>Namens Konventionen</para>
  32. </listitem>
  33. <listitem>
  34. <para>Code Stil</para>
  35. </listitem>
  36. <listitem>
  37. <para>Inline Dokumentation</para>
  38. </listitem>
  39. </itemizedlist>
  40. </para>
  41. </sect2>
  42. <sect2 id="coding-standard.overview.goals">
  43. <title>Ziele</title>
  44. <para>
  45. Coding Standards sind in jedem Entwicklungs Projekt wichtig, aber sie sid speziell
  46. dann wichtig wenn viele Entwickler an dem gleichen Projekt arbeiten. Coding
  47. Standards helfen sicherzustellen das der Code von hoher Qualität ist, weniger
  48. Fehler hat, und einfach zu warten ist.
  49. </para>
  50. </sect2>
  51. </sect1>
  52. <sect1 id="coding-standard.php-file-formatting">
  53. <title>PHP Dateiformatierung</title>
  54. <sect2 id="coding-standard.php-file-formatting.general">
  55. <title>Allgemein</title>
  56. <para>
  57. Für Dateien, welche nur PHP Code beinhalten ist der schliessende Tag ("?>") nicht
  58. zugelassen. Er wird von PHP nicht benötigt, und das Weglassen verhindert das
  59. versehentlich Leerzeilen in die Antwort eingefügt werden.
  60. </para>
  61. <para>
  62. <emphasis>WICHTIG:</emphasis> Einbeziehen von beliebigen binärischen Daten durch
  63. <code>__HALT_COMPILER()</code> ist in den PHP Dateien im Zend Framework oder
  64. abgeleiteten Datei verboten. Das Benutzen ist nur für einige Installationsskirpte
  65. erlaubt.
  66. </para>
  67. </sect2>
  68. <sect2 id="coding-standard.php-file-formatting.indentation">
  69. <title>Einrücken</title>
  70. <para>
  71. Ein Einzug sollte aus 4 Leerzeichen bestehen. Tabulatoren sind nicht erlaubt.
  72. </para>
  73. </sect2>
  74. <sect2 id="coding-standard.php-file-formatting.max-line-length">
  75. <title>Maximale Zeilenlänge</title>
  76. <para>
  77. Die Zielzeilenlänge ist 80 Zeichen. Entwickler sollten jede Zeile Ihres Codes unter
  78. 80 Zeichen halten, soweit dies möglich und praktikabel ist. Trotzdem sind längere
  79. Zeilen in einigen Fällen erlaubt. Die maximale Länge einer Zeile beträgt 120
  80. Zeichen.
  81. </para>
  82. </sect2>
  83. <sect2 id="coding-standard.php-file-formatting.line-termination">
  84. <title>Zeilenbegrenzung</title>
  85. <para>
  86. Die Zeilenbegrenzung folgt der Unix Textdatei Konvention. Zeilen müssen mit
  87. einem einzelnen Zeilenvorschubzeichen (LF) enden. Zeilenvorschub Zeicen werden duch
  88. eine ordinale 10, oder durch 0x0A (hexadecimal) dargestellt.
  89. </para>
  90. <para>
  91. Beachte: Benutze nicht den Wagenrücklauf (CR) wie in den Konventionen von Apple's
  92. OS (0x0D) oder die Kombination aus Wagenrücklauf und Zeilenvorschub (CRLF) wie im
  93. Standard für das Windows OS (0x0D, 0x0A).
  94. </para>
  95. </sect2>
  96. </sect1>
  97. <sect1 id="coding-standard.naming-conventions">
  98. <title>Namens Konventionen</title>
  99. <sect2 id="coding-standard.naming-conventions.classes">
  100. <title>Klassen</title>
  101. <para>
  102. Zend Framework standartisiert eine Klassennamen Konvention wobei die Namen der
  103. Klassen direkt mit den Verzeichnissen übereinstimmen muß in welchen Sie gespeichert
  104. sind. Das Basisverzeichnis der ZF Standard Bibliothek ist das "Zend/" Verzeichnis,
  105. wobei das Basisverzeichnis der ZF Extras Bibliothek im "ZendX/" Verzeichnis ist.
  106. Alle Zend Framework Klassen werden hierarchisch unter dem gleichen Basisverzeichnis
  107. gespeichert.
  108. </para>
  109. <para>
  110. Klassennamen dürfen nur alphanumerische Zeichen enthalten. Nummern sind in
  111. Klassennamen gestattet es wird aber von Ihnen in den meisten Fällen abgeraten.
  112. Unterstriche sind nur gestattet im Platz des Pfadseparators -- der Dateiname
  113. "Zend/Db/Table.php" muß übereinstimmen mit dem Klassennamen "Zend_Db_Table".
  114. </para>
  115. <para>
  116. Wenn ein Klassenname aus mehr als einem Wort besteht, muß der erste Buchstabe von
  117. jedem neuen Wort großgeschrieben werden. Durchgehende Großbuchstaben sind nicht
  118. erlaubt, z.B. eine Klasse "Zend_PDF" ist nicht erlaubt, aber "Zend_Pdf" ist
  119. akzeptierbar.
  120. </para>
  121. <para>
  122. Diese Konventionen definieren einen Pseudo-Namespace Mechanismus für Zend
  123. Framework. Zend Framework wird das PHP Namespace Feature einbauen sobald es
  124. verfügbar ist und es für unsere Entwickler in deren Anwendungen ohne Bedenken
  125. verwendbar ist.
  126. </para>
  127. <para>
  128. Siehe die Klassennamen in der Standard und Extra Bibliothek für Beispiel dieser
  129. Klassennamen Konvention.
  130. <emphasis>WICHTIG:</emphasis> Code welcher mit dem Framework ausgeliefert werden
  131. muß, aber nicht Teil der Standard oder Extras Bibliothek ist (z.B. Anwendungscode
  132. oder Bibliotheken die nicht von Zend ausgeliefert werden), dürfen nie mit "Zend_"
  133. oder "ZendX_" beginnen.
  134. </para>
  135. </sect2>
  136. <sect2 id="coding-standard.naming-conventions.filenames">
  137. <title>Dateinamen</title>
  138. <para>
  139. Für alle anderen Dateien sind nur alphanummerische Zeichen, Unterstriche, und der
  140. Bindestrich ("-") gestattet. Leerzeichen sind völlig verboten.
  141. </para>
  142. <para>
  143. Jede Datei die irgendeinen PHP Code enthält sollte mit der Endung ".php" enden, mit
  144. Ausnahme der View Skripte. Die folgenden Beispiele zeigen akzeptierbare Dateinamen
  145. für Zend Framework Klassen:
  146. <programlisting role="php"><![CDATA[
  147. Zend/Db.php
  148. Zend/Controller/Front.php
  149. Zend/View/Helper/FormRadio.php
  150. ]]>
  151. </programlisting>
  152. Dateinamen müssen den Klassennamen wie oben beschrieben entsprechen.
  153. </para>
  154. </sect2>
  155. <sect2 id="coding-standard.naming-conventions.functions-and-methods">
  156. <title>Funktionen und Methoden</title>
  157. <para>
  158. Funktionsnamen dürfen nur Alphanummerische Zeichen enthalten. Unterstriche sind
  159. nicht gestattet. Nummern sind in Funktionsnamen gestattet aber in den meisten
  160. Fällen nicht empfohlen.
  161. </para>
  162. <para>
  163. Funktionsnamen müssen immer mit einem Kleinbuchstaben anfangen. Wenn Funktionsnamen
  164. aus mehr als einem Wort bestehen, muß der erste Buchstabe jeden Wortes
  165. großgeschrieben werden. Das wird normalerweise "camelCase" Formatierung genannt.
  166. </para>
  167. <para>
  168. Wortreichtum wird generell befürwortet. Funktionsnamen sollten so wortreich wie
  169. möglich sein um deren Zweck und Verhalten zu erklären.
  170. </para>
  171. <para>
  172. Das sind Beispiele akzeptierbarer Namen für Funktionen:
  173. <programlisting role="php"><![CDATA[
  174. filterInput()
  175. getElementById()
  176. widgetFactory()
  177. ]]>
  178. </programlisting>
  179. </para>
  180. <para>
  181. Für objekt-orientiertes Programmieren, sollten Zugriffspunkte für Instanzen oder
  182. statische Variablen immer mit "get" oder "set" beginnen. Wenn Design-Pattern
  183. implementiert werden, wie Singleton oder das Factory Pattern, sollte der Name der
  184. Methode den Namen des Pattern enthalten wo es praktikabel ist, um das Verhalten
  185. besser zu beschreiben.
  186. </para>
  187. <para>
  188. Für Methoden in Objekten die mit dem "private" oder "protected" Modifikator
  189. deklariert sind, muß das erste Zeichen des Namens der Methode ein einzelner
  190. Unterstrich sein. Das ist die einzige akzeptable Anwendung von einem Unterstrich
  191. im Namen einer Methode. Methoden die als "public" deklariert sind sollten nie
  192. einem Unterstrich enthalten.
  193. </para>
  194. <para>
  195. Funktionen im globalen Bereich (auch "floating functions" genannt) sind gestattet
  196. aber es wird von Ihnen in den meisten Fällen abgeraten. Diese Funktionen sollten
  197. in einer statischen Klasse gewrappt werden.
  198. </para>
  199. </sect2>
  200. <sect2 id="coding-standard.naming-conventions.variables">
  201. <title>Variablen</title>
  202. <para>
  203. Variablennamen dürfen nur Alphanummerische Zeichen enthalten. Unterstriche sind
  204. nicht gestattet. Nummern sind in Variablen gestattet in den meisten Fällen aber
  205. nicht empfohlen.
  206. </para>
  207. <para>
  208. Für Instanzvariablen die mit dem "private" oder "protected" Modifikator deklariert werden,
  209. muß das erste Zeichen des Funktionsnamens ein einzelner Unterstrich sein. Das ist die
  210. einzige akzeptierte Anwendung eines Unterstriches in einem variablen Namen. Klassenvariablen
  211. welche als "public" deklariert werden sollten nie mit einem Unterstrich beginnen.
  212. </para>
  213. <para>
  214. Wie bei Funktionsnamen (siehe Abschnitt 3.3) müssen Variablennamen immer mit einem
  215. Kleinbuchstaben starten und der "camelCaps" Schreibweise folgen.
  216. </para>
  217. <para>
  218. Wortreichtum wird generell befürwortet. Variablen sollen immer so wortreich wie möglich sein
  219. um die Daten zu beschreiben die der Entwickler in Ihnen zu speichern gedenkt.
  220. Von gedrängte Variablennamen wie "$i" und "$n" wird abgeraten für alles außer die kleinsten
  221. Schleifen. Wenn eine Schleife mehr als 20 Codezeilen enthält sollten die Index-Variablen
  222. einen ausführlicheren Namen haben.
  223. </para>
  224. </sect2>
  225. <sect2 id="coding-standard.naming-conventions.constants">
  226. <title>Konstanten</title>
  227. <para>
  228. Konstanten können beides enthalten, sowohl Alphanummerische Zeichen als auch Unterstriche.
  229. Nummern sind in Konstantennamen gestattet.
  230. </para>
  231. <para>
  232. Alle Buchstaben die in Konstantenname verwendet werden müssen großgeschrieben haben, wärend
  233. Wörter in einem Konstantennamen durch Unterstriche getrennt werden müssen.
  234. </para>
  235. <para>
  236. Zum Beispiel ist <code>EMBED_SUPPRESS_EMBED_EXCEPTION</code> gestattet aber
  237. <code>EMBED_SUPPRESSEMBEDEXCEPTION</code> nicht.
  238. </para>
  239. <para>
  240. Konstanten müssen als Klassenkonstanten definiert werden mit dem "const" Modifikator.
  241. Die Definition von Konstanten im globalen Bereich mit der "define" Funktion ist gestattet
  242. aber es wird es wird stärkstens davon abgeraten.
  243. </para>
  244. </sect2>
  245. </sect1>
  246. <sect1 id="coding-standard.coding-style">
  247. <title>Code Stil</title>
  248. <sect2 id="coding-standard.coding-style.php-code-demarcation">
  249. <title>PHP Code Abgrenzung</title>
  250. <para>
  251. PHP Code muß immer mit der kompletten Form des Standard-PHP Tags abgegrenzt sein:
  252. <programlisting role="php"><![CDATA[
  253. <?php
  254. ?>
  255. ]]>
  256. </programlisting>
  257. </para>
  258. <para>
  259. Kurze Tags sind nie erlaubt. Für Dateien die nur PHP Code enthalten, darf
  260. das schließende Tag nie angegeben werden (Siehe
  261. <xref linkend="coding-standard.php-file-formatting.general"/>).
  262. </para>
  263. </sect2>
  264. <sect2 id="coding-standard.coding-style.strings">
  265. <title>Strings</title>
  266. <sect3 id="coding-standard.coding-style.strings.literals">
  267. <title>String Literale</title>
  268. <para>
  269. Wenn ein String ein Literal ist (er also keine Variablenvertreter enthält), sollte
  270. immer das Apostroph oder "einzelne Anführungszeichen" verwendet werden um den String
  271. abzugrenzen:
  272. <programlisting role="php"><![CDATA[
  273. $a = 'Beispiel String';
  274. ]]>
  275. </programlisting>
  276. </para>
  277. </sect3>
  278. <sect3 id="coding-standard.coding-style.strings.literals-containing-apostrophes">
  279. <title>String Literale die Apostrophe enthalten</title>
  280. <para>
  281. Wenn ein literaler String selbst Apostrophe enthält, ist es gestattet den String mit
  282. Anführungszeichen oder "doppeltes Anführungszeichen" abzugrenzen. Das ist speziell für
  283. SQL Anweisungen nützlich:
  284. <programlisting role="php"><![CDATA[
  285. $sql = "SELECT `id`, `name` from `people` "
  286. . "WHERE `name`='Fred' OR `name`='Susan'";
  287. ]]>
  288. </programlisting>
  289. Diese Syntax ist zu bevorzugen, im Gegensatz zum Ausbruch von Apostrophs, da Sie viel
  290. einfacher lesbar ist.
  291. </para>
  292. </sect3>
  293. <sect3 id="coding-standard.coding-style.strings.variable-substitution">
  294. <title>Variabler Austausch</title>
  295. <para>
  296. Variabler Austausch ist gestatten bei Verwendung einer der Formen:
  297. <programlisting role="php"><![CDATA[
  298. $greeting = "Halle $name, willkommen zurück!";
  299. $greeting = "Hallo {$name}, willkommen zurück!";
  300. ]]>
  301. </programlisting>
  302. </para>
  303. <para>
  304. Aus Gründen der Konstistenz ist folgende Form nicht gestattet:
  305. <programlisting role="php"><![CDATA[
  306. $greeting = "Hallo ${name}, willkommen zurück!";
  307. ]]>
  308. </programlisting>
  309. </para>
  310. </sect3>
  311. <sect3 id="coding-standard.coding-style.strings.string-concatenation">
  312. <title>Verbinden von Strings</title>
  313. <para>
  314. Strings müssen verbunden werden indem man den "." Operator verwendet. Ein Leerzeichen muß
  315. immer vor und nach dem "." Operator hinzugefügt werden um die Lesbarkeit zu erhöhen:
  316. <programlisting role="php"><![CDATA[
  317. $company = 'Zend' . ' ' . 'Technologies';
  318. ]]>
  319. </programlisting>
  320. </para>
  321. <para>
  322. Wenn Strings mit dem "." Operator verbunden werden, ist es empfohlen die Anweisung in
  323. mehrere Zeilen umzubrechen um die Lesbarkeit zu erhöhen. In diesen Fällen sollte jede
  324. folgende Zeile mit Leerraum aufgefüllt werden so das der "." Operator genau unterhalb
  325. des "=" Operators ist:
  326. <programlisting role="php"><![CDATA[
  327. $sql = "SELECT `id`, `name` FROM `people` "
  328. . "WHERE `name` = 'Susan' "
  329. . "ORDER BY `name` ASC ";
  330. ]]>
  331. </programlisting>
  332. </para>
  333. </sect3>
  334. </sect2>
  335. <sect2 id="coding-standard.coding-style.arrays">
  336. <title>Arrays</title>
  337. <sect3 id="coding-standard.coding-style.arrays.numerically-indexed">
  338. <title>Nummerisch indizierte Arrays</title>
  339. <para>Negative Nummern sind in Indezes nicht gestattet.</para>
  340. <para>
  341. Ein indiziertes Array kann mit mit irgendeiner nicht-negativen Nummer beginnen, trotzdem
  342. sind alle BasisIndex neben 0 nicht erlaubt.
  343. </para>
  344. <para>
  345. Wenn indizierte Arrays mit dem <code>array</code> Funktion deklariert werden, muß ein
  346. folgendes Leerzeichen nach jeder Kommabegrenzung hinzugefügt werden um die Lesbarkeit
  347. zu erhöhen:
  348. <programlisting role="php"><![CDATA[
  349. $sampleArray = array(1, 2, 3, 'Zend', 'Studio');
  350. ]]>
  351. </programlisting>
  352. </para>
  353. <para>
  354. Es ist gestattet mehrzeilige indizierte Arrays zu definieren bei Verwendung des
  355. "array" Konstrukts. In diesem Fall, muß jede folgende Zeile mit Leerzeichen aufgefüllt
  356. werden so das der Beginn jeder Zeile ausgerichtet ist:
  357. <programlisting role="php"><![CDATA[
  358. $sampleArray = array(1, 2, 3, 'Zend', 'Studio',
  359. $a, $b, $c,
  360. 56.44, $d, 500);
  361. ]]>
  362. </programlisting>
  363. </para>
  364. </sect3>
  365. <sect3 id="coding-standard.coding-style.arrays.associative">
  366. <title>Assoziative Arrays</title>
  367. <para>
  368. Wenn assoziative Arrays mit dem <code>array</code> Konstrukt deklariert werden, ist das
  369. Umbrechen der Anweisung in mehrere Zeilen gestattet. In diesem Fall muß jede folgende
  370. Linie mit Leerraum aufgefüllt werden so das beide, der Schlüssel und der Wert untereinander
  371. stehen:
  372. <programlisting role="php"><![CDATA[
  373. $sampleArray = array('firstKey' => 'firstValue',
  374. 'secondKey' => 'secondValue');
  375. ]]>
  376. </programlisting>
  377. </para>
  378. </sect3>
  379. </sect2>
  380. <sect2 id="coding-standard.coding-style.classes">
  381. <title>Klassen</title>
  382. <sect3 id="coding-standard.coding-style.classes.declaration">
  383. <title>Klassen Deklarationen</title>
  384. <para>
  385. Klassen müssen entsprechend der Zend Framework Namenskonvention benannt werden.
  386. </para><para>
  387. Die Klammer sollte immer in der Zeile unter dem Klassennamen geschrieben werden.
  388. </para><para>
  389. Jede Klasse muß einen Dokumentationsblock haben der dem PHPDocumentor Standard entspricht.
  390. </para><para>
  391. Jeder Code in der Klasse muß mit vier Leerzeichen eingerückt sein.
  392. </para><para>
  393. Nur eine Klasse ist in jeder PHP Datei gestattet.
  394. </para><para>
  395. Das Platzieren von zusätzlichem Code in Klassendateien ist gestattet aber es wird davon
  396. abgeraten. In solchen Dateien müssen zwei leere Zeilen die Klasse von jedem zusätzlichen PHP
  397. Code in der Datei seperieren.
  398. </para><para>
  399. Das folgende ist ein Beispiel einer akzeptierbaren Klassendeklaration:
  400. <programlisting role="php"><![CDATA[
  401. /**
  402. * Dokumentations Block hier
  403. */
  404. class SampleClass
  405. {
  406. // gesamter Inhalt der Klasse
  407. // muss mit vier Leerzeichen eingerückt sein
  408. }
  409. ]]>
  410. </programlisting>
  411. </para>
  412. </sect3>
  413. <sect3 id="coding-standard.coding-style.classes.member-variables">
  414. <title>Klassenvariablen</title>
  415. <para>
  416. Klassenvariablen müssen entsprechend den Variablen-Benennungs-Konventionen des
  417. Zend Frameworks benannt werden.
  418. </para>
  419. <para>
  420. Jede Variable die in der Klasse deklariert wird muß am Beginn der Klasse ausgelistet werden,
  421. vor der Deklaration von allen Methoden.
  422. </para>
  423. <para>
  424. Das <code>var</code> Konstrukt ist nicht gestattet. Klassenvariablen definieren Ihre
  425. Sichtbarkeit durch die Verwendung des <code>private</code>, <code>protected</code>,
  426. oder <code>public</code> Modifikatoren. Das gestatten von direktem Zugriff auf
  427. Klassenvariablen durch deren Deklaration als public ist gestattet aber es wird davon
  428. abgeraten da hierfür Zugriffsmethoden verwendet werden sollten (set/get).
  429. </para>
  430. </sect3>
  431. </sect2>
  432. <sect2 id="coding-standard.coding-style.functions-and-methods">
  433. <title>Funktionen und Methoden</title>
  434. <sect3 id="coding-standard.coding-style.functions-and-methods.declaration">
  435. <title>Deklaration von Funktionen und Methoden</title>
  436. <para>
  437. Funktionen müssen nach der Funktions-Namenskonvention des Zend Frameworks benannt werden.
  438. </para>
  439. <para>
  440. Methoden innerhalb von Klassen müssen immer Ihre Sichtbarkeit durch Verwendung einer der
  441. <code>private</code>, <code>protected</code>, oder <code>public</code> Modifikatoren
  442. definieren.
  443. </para>
  444. <para>
  445. Wie bei Klassen, sollte die Klammer immer in der Zeile unterhalb des Funktionsnamens
  446. geschrieben werden.
  447. Leerzeichen zwischen dem Funktionsnamen und der öffnenden Klammer für die Argumente
  448. sind nicht erlaubt.
  449. </para>
  450. <para>
  451. Von Funktionen im globalen Raum wird komplett abgeraten.
  452. </para>
  453. <para>
  454. Das folgende ist ein Beispiel einer akzeptierbaren Funktionsdeklaration in einer Klasse:
  455. <programlisting role="php"><![CDATA[
  456. /**
  457. * Dokumentations Block hier
  458. */
  459. class Foo
  460. {
  461. /**
  462. * Dokumentations Block hier
  463. */
  464. public function bar()
  465. {
  466. // gesamter Inhalt der Funktion
  467. // muss durch view Leerzeichen eingerückt sein
  468. }
  469. }
  470. ]]>
  471. </programlisting>
  472. </para>
  473. <para>
  474. <emphasis>NOTIZ:</emphasis> Die Übergabe per Referenz ist die einzige erlaubt Mechanismus
  475. für die Übergabe von Parametern in der Deklaration einer Funktion:
  476. <programlisting role="php"><![CDATA[
  477. /**
  478. * Dokumentations Block hier
  479. */
  480. class Foo
  481. {
  482. /**
  483. * Dokumentations Block hier
  484. */
  485. public function bar(&$baz)
  486. {}
  487. }
  488. ]]>
  489. </programlisting>
  490. </para>
  491. <para>
  492. Der Aufruf durch Referenz ist nicht gestattet.
  493. </para>
  494. <para>
  495. Der Rückgabewert darf nicht in Klammern stehen. Das kann die Lesbarkeit behindern und
  496. zusätzlich den Code unterbrechen wenn eine Methode später später auf Rückgabe durch
  497. Referenz geändert wird.
  498. <programlisting role="php"><![CDATA[
  499. /**
  500. * Dokumentations Block hier
  501. */
  502. class Foo
  503. {
  504. /**
  505. * FALSCH
  506. */
  507. public function bar()
  508. {
  509. return($this->bar);
  510. }
  511. /**
  512. * RICHTIG
  513. */
  514. public function bar()
  515. {
  516. return $this->bar;
  517. }
  518. }
  519. ]]>
  520. </programlisting>
  521. </para>
  522. </sect3>
  523. <sect3 id="coding-standard.coding-style.functions-and-methods.usage">
  524. <title>Verwendung von Funktionen und Methoden</title>
  525. <para>
  526. Funktionsargumente sollten durch ein einzelnes trennendes Leerzeichen nach dem Komma
  527. Trennzeichen getrennt werden. Das folgende ist ein Beispiel für einen akzeptierbaren
  528. Aufruf einer Funktion die drei Argumente benötigt:
  529. <programlisting role="php"><![CDATA[
  530. threeArguments(1, 2, 3);
  531. ]]>
  532. </programlisting>
  533. </para>
  534. <para>
  535. Übergabe von Referenzen zur Laufzeit ist strengstens verboten. Siehe die Sektion für
  536. Funktions Deklarationen für den richtigen Weg um Funktionsargumente per Referenz
  537. zu übergeben.
  538. </para>
  539. <para>
  540. Durch die Übergabe von Arrays als Argument für eine Funktion, kann der
  541. Funktionsaufruf den "array" Hinweis enthalten und kann in mehrere Zeilen geteilt werden
  542. um die Lesbarkeit zu erhöhen. In solchen Fällen sind die normalen Richtlinien für
  543. das Schreiben von Arrays trotzdem noch anzuwenden:
  544. <programlisting role="php"><![CDATA[
  545. threeArguments(array(1, 2, 3), 2, 3);
  546. threeArguments(array(1, 2, 3, 'Zend', 'Studio',
  547. $a, $b, $c,
  548. 56.44, $d, 500), 2, 3);
  549. ]]>
  550. </programlisting>
  551. </para>
  552. </sect3>
  553. </sect2>
  554. <sect2 id="coding-standard.coding-style.control-statements">
  555. <title>Kontrollanweisungen</title>
  556. <sect3 id="coding-standard.coding-style.control-statements.if-else-elseif">
  557. <title>If/Else/Elseif</title>
  558. <para>
  559. Kontrollanweisungen die auf den <code>if</code> und <code>elseif</code> Konstrukten
  560. beruhen müssen ein einzelnes Leerzeichen vor der öffnenden Klammer der bedingten Anweisung
  561. und ein einzelnes Leerzeichen nach der schließenden Klammer.
  562. </para>
  563. <para>
  564. Innerhalb der bedingten Anweisungen zwischen den Klammern, müssen die Operationen, für die
  565. Lesbarkeit, durch Leerzeichen getrennt werden. Innere Klammern sind zu befürworten um
  566. die logische Gruppierung für größeren bedingte Anweisungen zu erhöhen.
  567. </para>
  568. <para>
  569. Die öffnende Klammer wird in der selben Zeile geschrieben wie die Bedingungsanweisung.
  570. Die schließende Klammer wird immer in einer eigenen Zeile geschrieben. Jeder Inhalt innerhalb
  571. der Klammer muß durch Verwendung von vier Leerzeichen eingerückt werden.
  572. <programlisting role="php"><![CDATA[
  573. if ($a != 2) {
  574. $a = 2;
  575. }
  576. ]]>
  577. </programlisting>
  578. </para>
  579. <para>
  580. Für "if" Anweisungen die "elseif" oder "else" beinhalten, sind die Konventionen
  581. der Formatierung ähnlich dem "if" Konstrukt. Das folgende Beispiel zeigt gültige
  582. Formatierungen für "if" Anweisungen mit "else" und/oder "elseif" Konstrukten:
  583. <programlisting role="php"><![CDATA[
  584. if ($a != 2) {
  585. $a = 2;
  586. } else {
  587. $a = 7;
  588. }
  589. if ($a != 2) {
  590. $a = 2;
  591. } elseif ($a == 3) {
  592. $a = 4;
  593. } else {
  594. $a = 7;
  595. }
  596. ]]>
  597. </programlisting>
  598. PHP erlaubt das Anweisungen in einigen Fällen auch ohne Klammern zu schreiben.
  599. Dieser Coding Standard macht keine Unterscheidungen und es müssen alle "if", "elseif" oder "else"
  600. Anweisungen in Klammern geschrieben werden.
  601. </para>
  602. <para>
  603. Die Verwendung des "elseif" Konstruktes ist erlaubt es wird aber strengstens davon abgeraten
  604. und es ist die "else if" Kombination zu bevorzugen.
  605. </para>
  606. </sect3>
  607. <sect3 id="coding-standards.coding-style.control-statements.switch">
  608. <title>Switch</title>
  609. <para>
  610. Kontrollanweisungen die mit der "switch" Anweisung geschrieben werden müssen ein einzelnes
  611. Leerzeichen vor der öffnenden Klammer der Bedingten Anweisung besitzen, und auch
  612. nach der schließenden Klammer.
  613. </para>
  614. <para>
  615. Jeglicher Inhalt innerhalb der "switch" Anweisung muß durch Verwendung von vier Leerzeichen
  616. eingerückt sein. Der Inhalt unter jeder "case" Anweisung muß durch Verwendung von vier
  617. zusätzlichen Leerzeichen eingerückt werden.
  618. </para>
  619. <programlisting role="php"><![CDATA[
  620. switch ($numPeople) {
  621. case 1:
  622. break;
  623. case 2:
  624. break;
  625. default:
  626. break;
  627. }
  628. ]]>
  629. </programlisting>
  630. <para>
  631. Das <code>default</code> Konstrukt darf nie bei der <code>switch</code> Anweisung vergessen
  632. werden.
  633. </para>
  634. <para>
  635. <emphasis>NOTIZ:</emphasis> Es ist machmal nützlich eine <code>case</code> Anweisung zu
  636. schreiben, die durch das nächste case fällt indem innerhalb solcher Fälle kein
  637. <code>break</code> oder <code>return</code> angegeben wird. Um diese Fälle von Fehlern
  638. zu unterscheiden, sollte jede <code>case</code> Anweisung in der <code>break</code>
  639. oder <code>return</code> unterlassen werden einen Kommentar enthalten der anzeigt das
  640. das break gewünschtermaßen unterdrückt wurde.
  641. </para>
  642. </sect3>
  643. </sect2>
  644. <sect2 id="coding-standards.inline-documentation">
  645. <title>Inline Dokumentation</title>
  646. <sect3 id="coding-standards.inline-documentation.documentation-format">
  647. <title>Dokumentations Format</title>
  648. <para>
  649. Alle Dokumentations Blöcke ("DocBlock") müssel mit dem phpDocumentor Format kompatibel sein.
  650. Die Beschreibung des phpDocumentor Formats is jenseits der Reichweite dieses Dokuments.
  651. Für weiterführende Informationen siehe:
  652. <ulink url="http://phpdoc.org/">http://phpdoc.org"></ulink>
  653. </para>
  654. <para>
  655. Alle Klassen Dateien müssen einen "file-level" Docblock am Beginn jeder Datei und einen
  656. "class-level" Docblock direkt überhalb jeder Klasse enthalten. Beispiele solcher
  657. Docblocks können anbei gefunden werden.
  658. </para>
  659. </sect3>
  660. <sect3 id="coding-standards.inline-documentation.files">
  661. <title>Dateien</title>
  662. <para>
  663. Jede Datei die PHP Code enthält muß einen Docblock am Beginn der Datei besitzen welcher
  664. mindestens diese phpDocumentor Tags enthält:
  665. <programlisting role="php"><![CDATA[
  666. /**
  667. * Kurze Beschreibung der Datei
  668. *
  669. * Lange Beschreibung der Datei (wenn vorhanden)...
  670. *
  671. * LICENSE: Einige Lizenz Informationen
  672. *
  673. * @copyright 2008 Zend Technologies
  674. * @license http://framework.zend.com/license BSD License
  675. * @version $Id:$
  676. * @link http://framework.zend.com/package/PackageName
  677. * @since Datei vorhanden seit Release 1.2.0
  678. */
  679. ]]>
  680. </programlisting>
  681. </para>
  682. </sect3>
  683. <sect3 id="coding-standards.inline-documentation.classes">
  684. <title>Klassen</title>
  685. <para>
  686. Jede Klasse muß einen Docblock haben welche mindestens diese phpDocumentor Tags enthält:
  687. <programlisting role="php"><![CDATA[
  688. /**
  689. * Kurze Beschreibung für die Klasse
  690. *
  691. * Lange Beschreibung für die Klasse (wenn vorhanden)...
  692. *
  693. * @copyright 2008 Zend Technologies
  694. * @license http://framework.zend.com/license BSD License
  695. * @version Release: @package_version@
  696. * @link http://framework.zend.com/package/PackageName
  697. * @since Klasse vorhanden seit Release 1.5.0
  698. * @deprecated Klasse abgeraten ab Release 2.0.0
  699. */
  700. ]]>
  701. </programlisting>
  702. </para>
  703. </sect3>
  704. <sect3 id="coding-standards.inline-documentation.functions">
  705. <title>Funktionen</title>
  706. <para>
  707. Jede Funktion, auch Objekt Methoden, müssen einen Docblock haben welcher mindestens folgendes
  708. enthält:
  709. <itemizedlist>
  710. <listitem><para>Eine Beschreibung der Funktion</para></listitem>
  711. <listitem><para>Alle Argumente</para></listitem>
  712. <listitem><para>Alle möglichen Rückgabewerte</para></listitem>
  713. </itemizedlist>
  714. </para>
  715. <para>
  716. Es ist nicht notwendig das "@access" Tag zu verwenden, weil das Accesslevel bereits vom
  717. "public", "private" oder "protected" Modifikator bekannt ist wenn die Funktion deklariert wird.
  718. </para>
  719. <para>
  720. Wenn eine Funktion/Methode eine Ausnahme werfen könnte, muß @throws für alle bekannten
  721. Exception Klassen verwendet werden:
  722. <programlisting role="php"><![CDATA[
  723. @throws exceptionclass [Beschreibung]
  724. ]]>
  725. </programlisting>
  726. </para>
  727. </sect3>
  728. </sect2>
  729. </sect1>
  730. </appendix>
  731. <!--
  732. vim:se ts=4 sw=4 et:
  733. -->