coding_standard.xml 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21161 -->
  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. </para>
  18. <note>
  19. <para>
  20. Manchmal entscheiden Entwickler das die Verfügbarkeit eines Standards wichtiger
  21. ist als was der Standard aktuell im höchsten Level des Designs empfiehlt. Diese
  22. Richtlinien im Zend Framework Coding Standard beschreiben die Praxis die im
  23. Zend Framework Projekt sehr gut funktionieren. Diese Standard können geändert
  24. oder so wie sie sind verwendet werden solange Sie sich an unsere
  25. <ulink url="http://framework.zend.com/license">Lizenz</ulink> halten.
  26. </para>
  27. </note>
  28. <para>
  29. Die Bereiche die im Zend Framework Coding Standard abgedeckt werden enthalten:
  30. </para>
  31. <itemizedlist>
  32. <listitem><para><acronym>PHP</acronym> Dateiformatierung</para></listitem>
  33. <listitem><para>Namens Konventionen</para></listitem>
  34. <listitem><para>Code Stil</para></listitem>
  35. <listitem><para>Inline Dokumentation</para></listitem>
  36. </itemizedlist>
  37. </sect2>
  38. <sect2 id="coding-standard.overview.goals">
  39. <title>Ziele</title>
  40. <para>
  41. Coding Standards sind in jedem Entwicklungs Projekt wichtig, aber sie sind speziell
  42. dann wichtig wenn viele Entwickler an dem gleichen Projekt arbeiten. Coding
  43. Standards helfen sicherzustellen das der Code von hoher Qualität ist, weniger
  44. Fehler hat, und einfach zu warten ist.
  45. </para>
  46. </sect2>
  47. </sect1>
  48. <sect1 id="coding-standard.php-file-formatting">
  49. <title>PHP Dateiformatierung</title>
  50. <sect2 id="coding-standard.php-file-formatting.general">
  51. <title>Allgemein</title>
  52. <para>
  53. Für Dateien, welche nur <acronym>PHP</acronym> Code beinhalten ist der schliessende
  54. Tag ("?>") nicht zugelassen. Er wird von <acronym>PHP</acronym> nicht benötigt, und
  55. das Weglassen verhindert das versehentlich Leerzeilen in die Antwort eingefügt
  56. werden.
  57. </para>
  58. <note>
  59. <para>
  60. <emphasis>Wichtig</emphasis>: Einbeziehen von beliebigen binärischen Daten
  61. durch <methodname>__HALT_COMPILER()</methodname> ist in den
  62. <acronym>PHP</acronym> Dateien im Zend Framework oder abgeleiteten Datei
  63. verboten. Das Benutzen ist nur für einige Installationsskirpte erlaubt.
  64. </para>
  65. </note>
  66. </sect2>
  67. <sect2 id="coding-standard.php-file-formatting.indentation">
  68. <title>Einrücken</title>
  69. <para>
  70. Ein Einzug sollte aus 4 Leerzeichen bestehen. Tabulatoren sind nicht erlaubt.
  71. </para>
  72. </sect2>
  73. <sect2 id="coding-standard.php-file-formatting.max-line-length">
  74. <title>Maximale Zeilenlänge</title>
  75. <para>
  76. Die Zielzeilenlänge ist 80 Zeichen. Entwickler sollten jede Zeile Ihres Codes unter
  77. 80 Zeichen halten, soweit dies möglich und praktikabel ist. Trotzdem sind längere
  78. Zeilen in einigen Fällen erlaubt. Die maximale Länge einer <acronym>PHP</acronym>
  79. Codezeile beträgt 120 Zeichen.
  80. </para>
  81. </sect2>
  82. <sect2 id="coding-standard.php-file-formatting.line-termination">
  83. <title>Zeilenbegrenzung</title>
  84. <para>
  85. Die Zeilenbegrenzung folgt der Unix Textdatei Konvention. Zeilen müssen mit
  86. einem einzelnen Zeilenvorschubzeichen (LF) enden. Zeilenvorschub Zeicen werden duch
  87. eine ordinale 10, oder durch 0x0A (hexadecimal) dargestellt.
  88. </para>
  89. <para>
  90. Beachte: Benutze nicht den Wagenrücklauf (CR) wie in den Konventionen von Apple's
  91. OS (0x0D) oder die Kombination aus Wagenrücklauf und Zeilenvorschub
  92. (<acronym>CRLF</acronym>) wie im Standard für das Windows OS (0x0D, 0x0A).
  93. </para>
  94. </sect2>
  95. </sect1>
  96. <sect1 id="coding-standard.naming-conventions">
  97. <title>Namens Konventionen</title>
  98. <sect2 id="coding-standard.naming-conventions.classes">
  99. <title>Klassen</title>
  100. <para>
  101. Zend Framework standartisiert eine Klassennamen Konvention wobei die Namen der
  102. Klassen direkt mit den Verzeichnissen übereinstimmen muß in welchen Sie gespeichert
  103. sind. Das Basisverzeichnis der Zend Framework Standard Bibliothek ist das "Zend/"
  104. Verzeichnis, wobei das Basisverzeichnis der Zend Framework Extras Bibliothek im
  105. "ZendX/" Verzeichnis ist. Alle Zend Framework Klassen werden hierarchisch unter dem
  106. gleichen Basisverzeichnis gespeichert.
  107. </para>
  108. <para>
  109. Klassennamen dürfen nur alphanumerische Zeichen enthalten. Nummern sind in
  110. Klassennamen gestattet es wird aber von Ihnen in den meisten Fällen abgeraten.
  111. Unterstriche sind nur gestattet im Platz des Pfadseparators -- der Dateiname
  112. "<filename>Zend/Db/Table.php</filename>" muß übereinstimmen mit dem Klassennamen
  113. "<classname>Zend_Db_Table</classname>".
  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
  119. "<classname>Zend_Pdf</classname>" ist akzeptierbar.
  120. </para>
  121. <para>
  122. Diese Konventionen definieren einen Pseudo-Namespace Mechanismus für Zend
  123. Framework. Zend Framework wird das <acronym>PHP</acronym> Namespace Feature
  124. einbauen sobald es verfügbar ist und es für unsere Entwickler in deren Anwendungen
  125. ohne Bedenken verwendbar ist.
  126. </para>
  127. <para>
  128. Siehe die Klassennamen in der Standard und Extra Bibliothek für Beispiel dieser
  129. Klassennamen Konvention.
  130. </para>
  131. <note>
  132. <para>
  133. <emphasis>Wichtig</emphasis>: Code welcher mit dem Framework ausgeliefert
  134. werden muß, aber nicht Teil der Standard oder Extras Bibliothek ist (z.B.
  135. Anwendungscode oder Bibliotheken die nicht von Zend ausgeliefert werden),
  136. dürfen nie mit "Zend_" oder "ZendX_" beginnen.
  137. </para>
  138. </note>
  139. </sect2>
  140. <sect2 id="coding-standard.naming-conventions.abstracts">
  141. <title>Abstrakte Klassen</title>
  142. <para>
  143. Generell folgen abstrakte Klassen der gleichen Konvention wie <link
  144. linkend="coding-standard.naming-conventions.classes">Klassen</link>, mit einer
  145. zusätzlichen Regel: Die Namen von abstrakten Klassen müssen mit derm Term
  146. "Abstract" enden, und dem Term darf kein Unterstrich vorangestellt sein. Als
  147. Beispiel wird <classname>Zend_Controller_Plugin_Abstract</classname> als ungültig
  148. angenommen, aber <classname>Zend_Controller_PluginAbstract</classname> oder
  149. <classname>Zend_Controller_Plugin_PluginAbstract</classname> wären gültige Namen.
  150. </para>
  151. <note>
  152. <para>
  153. Diese Namens Konvention ist neu mit Version 1.9.0 des Zend Frameworks. Bei
  154. Klassen vor dieser Version kann es sein das sie dieser Regel nicht folgen, aber
  155. Sie werden in Zukunft umbenannt um zu entsprechen.
  156. </para>
  157. <para>
  158. Der Hintergrund dieser Änderung ist die Verwendung von Namespaces. Da wir auf
  159. Zend Framework 2.0 und die Verwendung von PHP 5.3 zugehen, werden wir Namespaces
  160. verwenden. Der einfachste Weg die Konvertierung zu Namespaces zu automatisieren
  161. besteht darin die Unterstriche in Namespace Separatoren zu konvertieren -- aber
  162. in der alten Namenskonvention, lässt dies den Klassennamen einfach als
  163. "Abstract" oder "Interface" zurück" -- beide sind reservierte Schlüsselwörter
  164. in PHP. Wenn wir den Namen der (Unter)Komponente dem Klassennamen voranstellen
  165. können wir diese Probleme vermeiden.
  166. </para>
  167. <para>
  168. Um die Situation zu illustrieren, nehmen wir an dass die Klasse
  169. <classname>Zend_Controller_Request_Abstract</classname> konvertiert wird um
  170. Namespaces zu verwenden:
  171. </para>
  172. <programlisting language="php"><![CDATA[
  173. namespace Zend\Controller\Request;
  174. abstract class Abstract
  175. {
  176. // ...
  177. }
  178. ]]></programlisting>
  179. <para>
  180. Natürlich wird das nicht funktionieren. In der neuen Namenskonvention würde
  181. dies aber trotzdem zu folgendem werden:
  182. </para>
  183. <programlisting language="php"><![CDATA[
  184. namespace Zend\Controller\Request;
  185. abstract class RequestAbstract
  186. {
  187. // ...
  188. }
  189. ]]></programlisting>
  190. <para>
  191. Wir bleiben trotzdem bei der Semantik und der Trennung auf Namespaces, wärend
  192. wir die Probleme mit den Schlüsselworten vermeiden; simultan beschreibt dies
  193. abstrakte Klassen besser.
  194. </para>
  195. </note>
  196. </sect2>
  197. <sect2 id="coding-standard.naming-conventions.interfaces">
  198. <title>Interfaces</title>
  199. <para>
  200. Generell folgen Interfaces der gleichen Konvention wie <link
  201. linkend="coding-standard.naming-conventions.classes">Klassen</link>, mit einer
  202. zusätzlichen Regel: Die Namen von Interfaces können optional mit dem Term
  203. "Interface" enden, aber dem Term darf kein Unterstrich vorangestellt sein. Als
  204. Beispiel wird <classname>Zend_Controller_Plugin_Interface</classname> als ungültig
  205. angenommen, aber <classname>Zend_Controller_PluginInterface</classname> oder
  206. <classname>Zend_Controller_Plugin_PluginInterface</classname> wären gültige Namen.
  207. </para>
  208. <para>
  209. Wärend diese Regel nicht benötigt wird, wird Sie stark empfohlen, da Sie
  210. Entwicklern einen guten visuellen Hinweis gibt welche Dateien ein Interface
  211. enthalten und welche Klassen.
  212. </para>
  213. <note>
  214. <para>
  215. Diese Namens Konvention ist neu mit Version 1.9.0 des Zend Frameworks. Bei
  216. Klassen vor dieser Version kann es sein das sie dieser Regel nicht folgen, aber
  217. Sie werden in Zukunft umbenannt um zu entsprechen. Siehe <link
  218. linkend="coding-standard.naming-conventions.abstracts">den vorhergehenden
  219. Abschnitt</link> für weitere Informationen über die Hintergründe für diese
  220. Änderung.
  221. </para>
  222. </note>
  223. </sect2>
  224. <sect2 id="coding-standard.naming-conventions.filenames">
  225. <title>Dateinamen</title>
  226. <para>
  227. Für alle anderen Dateien sind nur alphanummerische Zeichen, Unterstriche, und der
  228. Bindestrich ("-") gestattet. Leerzeichen sind völlig verboten.
  229. </para>
  230. <para>
  231. Jede Datei die irgendeinen <acronym>PHP</acronym> Code enthält sollte mit der
  232. Endung "<filename>.php</filename>" enden, mit Ausnahme der View Skripte. Die
  233. folgenden Beispiele zeigen akzeptierbare Dateinamen für Zend Framework Klassen:
  234. </para>
  235. <programlisting language="php"><![CDATA[
  236. Zend/Db.php
  237. Zend/Controller/Front.php
  238. Zend/View/Helper/FormRadio.php
  239. ]]></programlisting>
  240. <para>
  241. Dateinamen müssen den Klassennamen wie oben beschrieben entsprechen.
  242. </para>
  243. </sect2>
  244. <sect2 id="coding-standard.naming-conventions.functions-and-methods">
  245. <title>Funktionen und Methoden</title>
  246. <para>
  247. Funktionsnamen dürfen nur Alphanummerische Zeichen enthalten. Unterstriche sind
  248. nicht gestattet. Nummern sind in Funktionsnamen gestattet aber in den meisten
  249. Fällen nicht empfohlen.
  250. </para>
  251. <para>
  252. Funktionsnamen müssen immer mit einem Kleinbuchstaben anfangen. Wenn Funktionsnamen
  253. aus mehr als einem Wort bestehen, muß der erste Buchstabe jeden Wortes
  254. großgeschrieben werden. Das wird normalerweise "camelCase" Formatierung genannt.
  255. </para>
  256. <para>
  257. Wortreichtum wird generell befürwortet. Funktionsnamen sollten so wortreich wie
  258. möglich sein um deren Zweck und Verhalten zu erklären.
  259. </para>
  260. <para>
  261. Das sind Beispiele akzeptierbarer Namen für Funktionen:
  262. </para>
  263. <programlisting language="php"><![CDATA[
  264. filterInput()
  265. getElementById()
  266. widgetFactory()
  267. ]]></programlisting>
  268. <para>
  269. Für objekt-orientiertes Programmieren, sollten Zugriffspunkte für Instanzen oder
  270. statische Variablen immer mit "get" oder "set" beginnen. Wenn Design-Pattern
  271. implementiert werden, wie Singleton oder das Factory Pattern, sollte der Name der
  272. Methode den Namen des Pattern enthalten wo es praktikabel ist, um das Verhalten
  273. besser zu beschreiben.
  274. </para>
  275. <para>
  276. Für Methoden in Objekten die mit dem "private" oder "protected" Modifikator
  277. deklariert sind, muß das erste Zeichen des Namens der Methode ein einzelner
  278. Unterstrich sein. Das ist die einzige akzeptable Anwendung von einem Unterstrich
  279. im Namen einer Methode. Methoden die als "public" deklariert sind sollten nie
  280. einem Unterstrich enthalten.
  281. </para>
  282. <para>
  283. Funktionen im globalen Bereich (auch "floating functions" genannt) sind gestattet
  284. aber es wird von Ihnen in den meisten Fällen abgeraten. Diese Funktionen sollten
  285. in einer statischen Klasse gewrappt werden.
  286. </para>
  287. </sect2>
  288. <sect2 id="coding-standard.naming-conventions.variables">
  289. <title>Variablen</title>
  290. <para>
  291. Variablennamen dürfen nur Alphanummerische Zeichen enthalten. Unterstriche sind
  292. nicht gestattet. Nummern sind in Variablen gestattet in den meisten Fällen aber
  293. nicht empfohlen.
  294. </para>
  295. <para>
  296. Für Instanzvariablen die mit dem "private" oder "protected" Modifikator deklariert
  297. werden, muß das erste Zeichen des Funktionsnamens ein einzelner Unterstrich sein.
  298. Das ist die einzige akzeptierte Anwendung eines Unterstriches in einem variablen
  299. Namen. Klassenvariablen welche als "public" deklariert werden sollten nie mit einem
  300. Unterstrich beginnen.
  301. </para>
  302. <para>
  303. Wie bei Funktionsnamen (siehe Abschnitt 3.3) müssen Variablennamen immer mit einem
  304. Kleinbuchstaben starten und der "camelCaps" Schreibweise folgen.
  305. </para>
  306. <para>
  307. Wortreichtum wird generell befürwortet. Variablen sollen immer so wortreich wie
  308. möglich sein um die Daten zu beschreiben die der Entwickler in Ihnen zu speichern
  309. gedenkt. Von gedrängte Variablennamen wie "<varname>$i</varname>" und
  310. "<varname>$n</varname>" wird abgeraten für alles außer die kleinsten Schleifen.
  311. Wenn eine Schleife mehr als 20 Codezeilen enthält sollten die Index-Variablen einen
  312. ausführlicheren Namen haben.
  313. </para>
  314. </sect2>
  315. <sect2 id="coding-standard.naming-conventions.constants">
  316. <title>Konstanten</title>
  317. <para>
  318. Konstanten können beides enthalten, sowohl Alphanummerische Zeichen als auch
  319. Unterstriche. Nummern sind in Konstantennamen gestattet.
  320. </para>
  321. <para>
  322. Alle Buchstaben die in Konstantenname verwendet werden müssen großgeschrieben haben,
  323. wärend Wörter in einem Konstantennamen durch Unterstriche getrennt werden müssen.
  324. </para>
  325. <para>
  326. Zum Beispiel ist <constant>EMBED_SUPPRESS_EMBED_EXCEPTION</constant> gestattet aber
  327. <constant>EMBED_SUPPRESSEMBEDEXCEPTION</constant> nicht.
  328. </para>
  329. <para>
  330. Konstanten müssen als Klassenkonstanten definiert werden mit dem "const"
  331. Modifikator. Die Definition von Konstanten im globalen Bereich mit der "define"
  332. Funktion ist gestattet aber es wird es wird stärkstens davon abgeraten.
  333. </para>
  334. </sect2>
  335. </sect1>
  336. <sect1 id="coding-standard.coding-style">
  337. <title>Code Stil</title>
  338. <sect2 id="coding-standard.coding-style.php-code-demarcation">
  339. <title>PHP Code Abgrenzung</title>
  340. <para>
  341. <acronym>PHP</acronym> Code muß immer mit der kompletten Form des
  342. Standard-<acronym>PHP</acronym> Tags abgegrenzt sein:
  343. </para>
  344. <programlisting language="php"><![CDATA[
  345. <?php
  346. ?>
  347. ]]></programlisting>
  348. <para>
  349. Kurze Tags sind nie erlaubt. Für Dateien die nur <acronym>PHP</acronym> Code
  350. enthalten, darf das schließende Tag nie angegeben werden (Siehe <link
  351. linkend="coding-standard.php-file-formatting.general">generelle
  352. Standards</link>).
  353. </para>
  354. </sect2>
  355. <sect2 id="coding-standard.coding-style.strings">
  356. <title>Strings</title>
  357. <sect3 id="coding-standard.coding-style.strings.literals">
  358. <title>String Literale</title>
  359. <para>
  360. Wenn ein String ein Literal ist (er also keine Variablenvertreter enthält),
  361. sollte immer das Apostroph oder "einzelne Anführungszeichen" verwendet werden um
  362. den String abzugrenzen:
  363. </para>
  364. <programlisting language="php"><![CDATA[
  365. $a = 'Beispiel String';
  366. ]]></programlisting>
  367. </sect3>
  368. <sect3 id="coding-standard.coding-style.strings.literals-containing-apostrophes">
  369. <title>String Literale die Apostrophe enthalten</title>
  370. <para>
  371. Wenn ein literaler String selbst Apostrophe enthält, ist es gestattet den String
  372. mit Anführungszeichen oder "doppeltes Anführungszeichen" abzugrenzen. Das ist
  373. speziell für <constant>SQL</constant> Anweisungen nützlich:
  374. </para>
  375. <programlisting language="php"><![CDATA[
  376. $sql = "SELECT `id`, `name` from `people` "
  377. . "WHERE `name`='Fred' OR `name`='Susan'";
  378. ]]></programlisting>
  379. <para>
  380. Diese Syntax ist zu bevorzugen, im Gegensatz zum Ausbruch von Apostrophs, da Sie
  381. viel einfacher lesbar ist.
  382. </para>
  383. </sect3>
  384. <sect3 id="coding-standard.coding-style.strings.variable-substitution">
  385. <title>Variabler Austausch</title>
  386. <para>
  387. Variabler Austausch ist gestatten bei Verwendung einer der Formen:
  388. </para>
  389. <programlisting language="php"><![CDATA[
  390. $greeting = "Halle $name, willkommen zurück!";
  391. $greeting = "Hallo {$name}, willkommen zurück!";
  392. ]]></programlisting>
  393. <para>
  394. Aus Gründen der Konstistenz ist folgende Form nicht gestattet:
  395. </para>
  396. <programlisting language="php"><![CDATA[
  397. $greeting = "Hallo ${name}, willkommen zurück!";
  398. ]]></programlisting>
  399. </sect3>
  400. <sect3 id="coding-standard.coding-style.strings.string-concatenation">
  401. <title>Verbinden von Strings</title>
  402. <para>
  403. Strings müssen verbunden werden indem man den "." Operator verwendet. Ein
  404. Leerzeichen muß immer vor und nach dem "." Operator hinzugefügt werden um die
  405. Lesbarkeit zu erhöhen:
  406. </para>
  407. <programlisting language="php"><![CDATA[
  408. $company = 'Zend' . ' ' . 'Technologies';
  409. ]]></programlisting>
  410. <para>
  411. Wenn Strings mit dem "." Operator verbunden werden, ist es empfohlen die
  412. Anweisung in mehrere Zeilen umzubrechen um die Lesbarkeit zu erhöhen. In diesen
  413. Fällen sollte jede folgende Zeile mit Leerraum aufgefüllt werden so das der "."
  414. Operator genau unterhalb des "=" Operators ist:
  415. </para>
  416. <programlisting language="php"><![CDATA[
  417. $sql = "SELECT `id`, `name` FROM `people` "
  418. . "WHERE `name` = 'Susan' "
  419. . "ORDER BY `name` ASC ";
  420. ]]></programlisting>
  421. </sect3>
  422. </sect2>
  423. <sect2 id="coding-standard.coding-style.arrays">
  424. <title>Arrays</title>
  425. <sect3 id="coding-standard.coding-style.arrays.numerically-indexed">
  426. <title>Nummerisch indizierte Arrays</title>
  427. <para>Negative Nummern sind in Indezes nicht gestattet.</para>
  428. <para>
  429. Ein indiziertes Array kann mit mit irgendeiner nicht-negativen Nummer beginnen,
  430. trotzdem sind alle BasisIndex neben 0 nicht erlaubt.
  431. </para>
  432. <para>
  433. Wenn indizierte Arrays mit dem <type>Array</type> Funktion deklariert werden,
  434. muß ein folgendes Leerzeichen nach jeder Kommabegrenzung hinzugefügt werden um
  435. die Lesbarkeit zu erhöhen:
  436. </para>
  437. <programlisting language="php"><![CDATA[
  438. $sampleArray = array(1, 2, 3, 'Zend', 'Studio');
  439. ]]></programlisting>
  440. <para>
  441. Es ist gestattet mehrzeilige indizierte Arrays zu definieren bei Verwendung des
  442. "array" Konstrukts. In diesem Fall, muß jede folgende Zeile mit Leerzeichen
  443. aufgefüllt werden so das der Beginn jeder Zeile ausgerichtet ist:
  444. </para>
  445. <programlisting language="php"><![CDATA[
  446. $sampleArray = array(1, 2, 3, 'Zend', 'Studio',
  447. $a, $b, $c,
  448. 56.44, $d, 500);
  449. ]]></programlisting>
  450. <para>
  451. Alternativ kann das beginnende Array Element in der folgenden Zeile beginnen.
  452. Wenn das so ist, sollte es um ein Einrückungslevel tiefer stehen als die
  453. Zeile welche die Array Deklaration enthält und alle folgenden Zeilen sollten
  454. die gleiche Einrückung haben; der schließende Teil sollte in einer eigenen
  455. Zeile stehen und das gleiche Einrückungslevel haben wie die Zeile welche die
  456. Array Deklaration enthält:
  457. </para>
  458. <programlisting language="php"><![CDATA[
  459. $sampleArray = array(
  460. 1, 2, 3, 'Zend', 'Studio',
  461. $a, $b, $c,
  462. 56.44, $d, 500,
  463. );
  464. ]]></programlisting>
  465. <para>
  466. Wenn die letztere Deklaration verwendet wird, empfehlen wir ein endendes Komma
  467. für das letzte Element im Array zu verwenden; das minimiert das Problem beim
  468. Hinzufügen von neuen Elements bei zusätzlichen Zeilen, und hilft
  469. sicherzustellen das durch ein fehlendes Komma keine Parsing Fehler auftreten.
  470. </para>
  471. </sect3>
  472. <sect3 id="coding-standard.coding-style.arrays.associative">
  473. <title>Assoziative Arrays</title>
  474. <para>
  475. Wenn assoziative Arrays mit dem <type>Array</type> Konstrukt deklariert werden,
  476. ist das Umbrechen der Anweisung in mehrere Zeilen gestattet. In diesem Fall muß
  477. jede folgende Linie mit Leerraum aufgefüllt werden so das beide, der Schlüssel
  478. und der Wert untereinander stehen:
  479. </para>
  480. <programlisting language="php"><![CDATA[
  481. $sampleArray = array('firstKey' => 'firstValue',
  482. 'secondKey' => 'secondValue');
  483. ]]></programlisting>
  484. <para>
  485. Alternativ kann das beginnende Array Element in der folgenden Zeile beginnen.
  486. Wenn das so ist, sollte es um ein Einrückungslevel tiefer stehen als die
  487. Zeile welche die Array Deklaration enthält und alle folgenden Zeilen sollten
  488. die gleiche Einrückung haben; der schließende Teil sollte in einer eigenen
  489. Zeile stehen und das gleiche Einrückungslevel haben wie die Zeile welche die
  490. Array Deklaration enthält. Wegen der Lesbarkeit sollten die verschiedenen
  491. "=>" Operatoren so eingerückt werden das Sie untereinander stehen.
  492. </para>
  493. <programlisting language="php"><![CDATA[
  494. $sampleArray = array(
  495. 'firstKey' => 'firstValue',
  496. 'secondKey' => 'secondValue',
  497. );
  498. ]]></programlisting>
  499. <para>
  500. Wenn die letztere Deklaration verwendet wird, empfehlen wir ein endendes Komma
  501. für das letzte Element im Array zu verwenden; das minimiert das Problem beim
  502. Hinzufügen von neuen Elements bei zusätzlichen Zeilen, und hilft
  503. sicherzustellen das durch ein fehlendes Komma keine Parsing Fehler auftreten.
  504. </para>
  505. </sect3>
  506. </sect2>
  507. <sect2 id="coding-standard.coding-style.classes">
  508. <title>Klassen</title>
  509. <sect3 id="coding-standard.coding-style.classes.declaration">
  510. <title>Klassen Deklarationen</title>
  511. <para>
  512. Klassen müssen entsprechend der Zend Framework Namenskonvention benannt werden.
  513. </para>
  514. <para>
  515. Die Klammer sollte immer in der Zeile unter dem Klassennamen geschrieben werden.
  516. </para>
  517. <para>
  518. Jede Klasse muß einen Dokumentationsblock haben der dem PHPDocumentor Standard
  519. entspricht.
  520. </para>
  521. <para>
  522. Jeder Code in der Klasse muß mit vier Leerzeichen eingerückt sein.
  523. </para>
  524. <para>
  525. Nur eine Klasse ist in jeder <acronym>PHP</acronym> Datei gestattet.
  526. </para>
  527. <para>
  528. Das Platzieren von zusätzlichem Code in Klassendateien ist gestattet aber es
  529. wird davon abgeraten. In solchen Dateien müssen zwei leere Zeilen die Klasse von
  530. jedem zusätzlichen <acronym>PHP</acronym> Code in der Datei seperieren.
  531. </para>
  532. <para>
  533. Das folgende ist ein Beispiel einer akzeptierbaren Klassendeklaration:
  534. </para>
  535. <programlisting language="php"><![CDATA[
  536. /**
  537. * Dokumentations Block hier
  538. */
  539. class SampleClass
  540. {
  541. // gesamter Inhalt der Klasse
  542. // muss mit vier Leerzeichen eingerückt sein
  543. }
  544. ]]></programlisting>
  545. <para>
  546. Klassen die andere Klassen erweitern oder welche Interfaces implementieren
  547. sollen Ihre Abhängigkeit auf der gleichen Zeile deklarieren wenn das möglich
  548. ist.
  549. </para>
  550. <programlisting language="php"><![CDATA[
  551. class SampleClass extends FooAbstract implements BarInterface
  552. {
  553. }
  554. ]]></programlisting>
  555. <para>
  556. Wenn als Ergebnis so einer Deklaration, die Länge der Zeile die <link
  557. linkend="coding-standard.php-file-formatting.max-line-length">Maximale
  558. Zeilenlänge</link> überschreitet, ist die Zeile vor dem "extends" und
  559. oder "implements" Schlüsselwort umzubrechen und diese Zeilen um ein
  560. Einrückungslevel einzurücken.
  561. </para>
  562. <programlisting language="php"><![CDATA[
  563. class SampleClass
  564. extends FooAbstract
  565. implements BarInterface
  566. {
  567. }
  568. ]]></programlisting>
  569. <para>
  570. Wenn die Klasse mehrere Interfaces implementiert und die Deklaration die
  571. maximale Zeilenlänge übersteigt, ist nach jedem Komma umzubrechen und die
  572. Interfaces zu separieren, und die Namen des Interfaces so einzurücken das Sie
  573. untereinander stehen.
  574. </para>
  575. <programlisting language="php"><![CDATA[
  576. class SampleClass
  577. implements BarInterface,
  578. BazInterface
  579. {
  580. }
  581. ]]></programlisting>
  582. </sect3>
  583. <sect3 id="coding-standard.coding-style.classes.member-variables">
  584. <title>Klassenvariablen</title>
  585. <para>
  586. Klassenvariablen müssen entsprechend den Variablen-Benennungs-Konventionen des
  587. Zend Frameworks benannt werden.
  588. </para>
  589. <para>
  590. Jede Variable die in der Klasse deklariert wird muß am Beginn der Klasse
  591. ausgelistet werden, vor der Deklaration von allen Methoden.
  592. </para>
  593. <para>
  594. Das <emphasis>var</emphasis> Konstrukt ist nicht gestattet. Klassenvariablen
  595. definieren Ihre Sichtbarkeit durch die Verwendung des
  596. <property>private</property>, <property>protected</property>, oder
  597. <property>public</property> Modifikatoren. Das gestatten von direktem Zugriff
  598. auf Klassenvariablen durch deren Deklaration als public ist gestattet aber es
  599. wird davon abgeraten da hierfür Zugriffsmethoden verwendet werden sollten (set
  600. &amp; get).
  601. </para>
  602. </sect3>
  603. </sect2>
  604. <sect2 id="coding-standard.coding-style.functions-and-methods">
  605. <title>Funktionen und Methoden</title>
  606. <sect3 id="coding-standard.coding-style.functions-and-methods.declaration">
  607. <title>Deklaration von Funktionen und Methoden</title>
  608. <para>
  609. Funktionen müssen nach der Funktions-Namenskonvention des Zend Frameworks
  610. benannt werden.
  611. </para>
  612. <para>
  613. Methoden innerhalb von Klassen müssen immer Ihre Sichtbarkeit durch Verwendung
  614. einer der <property>private</property>, <property>protected</property>, oder
  615. <property>public</property> Modifikatoren definieren.
  616. </para>
  617. <para>
  618. Wie bei Klassen, sollte die Klammer immer in der Zeile unterhalb des
  619. Funktionsnamens geschrieben werden. Leerzeichen zwischen dem Funktionsnamen und
  620. der öffnenden Klammer für die Argumente sind nicht erlaubt.
  621. </para>
  622. <para>
  623. Von Funktionen im globalen Raum wird komplett abgeraten.
  624. </para>
  625. <para>
  626. Das folgende ist ein Beispiel einer akzeptierbaren Funktionsdeklaration in einer
  627. Klasse:
  628. </para>
  629. <programlisting language="php"><![CDATA[
  630. /**
  631. * Dokumentations Block hier
  632. */
  633. class Foo
  634. {
  635. /**
  636. * Dokumentations Block hier
  637. */
  638. public function bar()
  639. {
  640. // gesamter Inhalt der Funktion
  641. // muss durch view Leerzeichen eingerückt sein
  642. }
  643. }
  644. ]]></programlisting>
  645. <para>
  646. In den Fällen wo die Liste der Argumente die <link
  647. linkend="coding-standard.php-file-formatting.max-line-length">maximale
  648. Zeilenlänge</link> überschreitet, sollten Zeilenumbrüche eingeführt werden.
  649. Zusätzliche Argumente der Funktion oder Methode müssen durch einen zusätzlichen
  650. Einrückungslevel nach der Funktion oder Methodendeklaration eingerückt werden.
  651. Ein Zeilenumbruch sollte dann vor dem schließenden Argument stattfinden,
  652. welcher in der gleichen Zeile platziert werden sollte wie die öffnende Klammer
  653. der Funktion oder Methode mit einem einzelnen Leerzeichen das die zwei trennt,
  654. und mit dem gleichen Einrückungslevel wie die Deklaration der Funktion oder
  655. Methode. Das folgende ist ein Beispiel so einer Situation:
  656. </para>
  657. <programlisting language="php"><![CDATA[
  658. /**
  659. * Dokumentations Block Hier
  660. */
  661. class Foo
  662. {
  663. /**
  664. * Dokumentations Block Hier
  665. */
  666. public function bar($arg1, $arg2, $arg3,
  667. $arg4, $arg5, $arg6
  668. ) {
  669. // gesamter Inhalt der Funktion
  670. // muss durch view Leerzeichen eingerückt sein
  671. }
  672. }
  673. ]]></programlisting>
  674. <note>
  675. <para>
  676. <emphasis>Notiz</emphasis>: Die Übergabe per Referenz ist die einzige
  677. erlaubt Mechanismus für die Übergabe von Parametern in der Deklaration
  678. einer Funktion:
  679. </para>
  680. </note>
  681. <programlisting language="php"><![CDATA[
  682. /**
  683. * Dokumentations Block hier
  684. */
  685. class Foo
  686. {
  687. /**
  688. * Dokumentations Block hier
  689. */
  690. public function bar(&$baz)
  691. {}
  692. }
  693. ]]></programlisting>
  694. <para>
  695. Der Aufruf durch Referenz ist nicht gestattet.
  696. </para>
  697. <para>
  698. Der Rückgabewert darf nicht in Klammern stehen. Das kann die Lesbarkeit
  699. behindern und zusätzlich den Code unterbrechen wenn eine Methode später auf
  700. Rückgabe durch Referenz geändert wird.
  701. </para>
  702. <programlisting language="php"><![CDATA[
  703. /**
  704. * Dokumentations Block hier
  705. */
  706. class Foo
  707. {
  708. /**
  709. * FALSCH
  710. */
  711. public function bar()
  712. {
  713. return($this->bar);
  714. }
  715. /**
  716. * RICHTIG
  717. */
  718. public function bar()
  719. {
  720. return $this->bar;
  721. }
  722. }
  723. ]]></programlisting>
  724. </sect3>
  725. <sect3 id="coding-standard.coding-style.functions-and-methods.usage">
  726. <title>Verwendung von Funktionen und Methoden</title>
  727. <para>
  728. Funktionsargumente sollten durch ein einzelnes trennendes Leerzeichen nach dem
  729. Komma Trennzeichen getrennt werden. Das folgende ist ein Beispiel für einen
  730. akzeptierbaren Aufruf einer Funktion die drei Argumente benötigt:
  731. </para>
  732. <programlisting language="php"><![CDATA[
  733. threeArguments(1, 2, 3);
  734. ]]></programlisting>
  735. <para>
  736. Übergabe von Referenzen zur Laufzeit ist strengstens verboten. Siehe die Sektion
  737. für Funktions Deklarationen für den richtigen Weg um Funktionsargumente per
  738. Referenz zu übergeben.
  739. </para>
  740. <para>
  741. Durch die Übergabe von Arrays als Argument für eine Funktion, kann der
  742. Funktionsaufruf den "array" Hinweis enthalten und kann in mehrere Zeilen geteilt
  743. werden um die Lesbarkeit zu erhöhen. In solchen Fällen sind die normalen
  744. Richtlinien für das Schreiben von Arrays trotzdem noch anzuwenden:
  745. </para>
  746. <programlisting language="php"><![CDATA[
  747. threeArguments(array(1, 2, 3), 2, 3);
  748. threeArguments(array(1, 2, 3, 'Zend', 'Studio',
  749. $a, $b, $c,
  750. 56.44, $d, 500), 2, 3);
  751. threeArguments(array(
  752. 1, 2, 3, 'Zend', 'Studio',
  753. $a, $b, $c,
  754. 56.44, $d, 500
  755. ), 2, 3);
  756. ]]></programlisting>
  757. </sect3>
  758. </sect2>
  759. <sect2 id="coding-standard.coding-style.control-statements">
  760. <title>Kontrollanweisungen</title>
  761. <sect3 id="coding-standard.coding-style.control-statements.if-else-elseif">
  762. <title>If/Else/Elseif</title>
  763. <para>
  764. Kontrollanweisungen die auf den <emphasis>if</emphasis> und
  765. <emphasis>elseif</emphasis> Konstrukten beruhen müssen ein einzelnes
  766. Leerzeichen vor der öffnenden Klammer der bedingten Anweisung und ein
  767. einzelnes Leerzeichen nach der schließenden Klammer.
  768. </para>
  769. <para>
  770. Innerhalb der bedingten Anweisungen zwischen den Klammern, müssen die
  771. Operationen, für die Lesbarkeit, durch Leerzeichen getrennt werden. Innere
  772. Klammern sind zu befürworten um die logische Gruppierung für größeren bedingte
  773. Anweisungen zu erhöhen.
  774. </para>
  775. <para>
  776. Die öffnende Klammer wird in der selben Zeile geschrieben wie die
  777. Bedingungsanweisung. Die schließende Klammer wird immer in einer eigenen Zeile
  778. geschrieben. Jeder Inhalt innerhalb der Klammer muß durch Verwendung von vier
  779. Leerzeichen eingerückt werden.
  780. </para>
  781. <programlisting language="php"><![CDATA[
  782. if ($a != 2) {
  783. $a = 2;
  784. }
  785. ]]></programlisting>
  786. <para>
  787. Wenn die Kontrollanweisung die Ursache für eine Überschreitung der <link
  788. linkend="coding-standard.php-file-formatting.max-line-length">maximalen
  789. Zeilenlänge</link> ist, und sie mehrere Anweisungen hat, kann die
  790. Kontrollanweisung in mehrere Zeilen gebrochen werden. In solchen Fällen, ist
  791. die Zeile vor dem logischen Operator zu brechen und die Zeile so einzurücken
  792. das Sie unter dem ersten Zeichen der Kontrollanweisung steht. Der schließende
  793. Teil der Kontrollanweisung ist mit der öffnenden Klammer in einer eigenen Zeile
  794. zu platzieren, wobei ein einzelnes Leerzeichen die zwei trennen muß, und der
  795. Einrückungslevel identisch mit der öffenden Kontrollanweisung sein ist.
  796. </para>
  797. <programlisting language="php"><![CDATA[
  798. if (($a == $b)
  799. && ($b == $c)
  800. || (Foo::CONST == $d)
  801. ) {
  802. $a = $d;
  803. }
  804. ]]></programlisting>
  805. <para>
  806. Die Einrückung des späteren Deklarationsformats dient der Vorbeugung von
  807. Problemen beim Hinzufügen oder entfernen von Klauseln von der Kontrollanweisung
  808. bei späteren Revisionen.
  809. </para>
  810. <para>
  811. Für "if" Anweisungen die "elseif" oder "else" beinhalten, sind die Konventionen
  812. der Formatierung ähnlich dem "if" Konstrukt. Das folgende Beispiel zeigt gültige
  813. Formatierungen für "if" Anweisungen mit "else" und/oder "elseif" Konstrukten:
  814. </para>
  815. <programlisting language="php"><![CDATA[
  816. if ($a != 2) {
  817. $a = 2;
  818. } else {
  819. $a = 7;
  820. }
  821. if ($a != 2) {
  822. $a = 2;
  823. } elseif ($a == 3) {
  824. $a = 4;
  825. } else {
  826. $a = 7;
  827. }
  828. if (($a == $b)
  829. && ($b == $c)
  830. || (Foo::CONST == $d)
  831. ) {
  832. $a = $d;
  833. } elseif (($a != $b)
  834. || ($b != $c)
  835. ) {
  836. $a = $c;
  837. } else {
  838. $a = $b;
  839. }
  840. ]]></programlisting>
  841. <para>
  842. <acronym>PHP</acronym> erlaubt das Anweisungen in einigen Fällen auch ohne
  843. Klammern zu schreiben. Dieser Coding Standard macht keine Unterscheidungen und
  844. es müssen alle "if", "elseif" oder "else" Anweisungen in Klammern geschrieben
  845. werden.
  846. </para>
  847. </sect3>
  848. <sect3 id="coding-standards.coding-style.control-statements.switch">
  849. <title>Switch</title>
  850. <para>
  851. Kontrollanweisungen die mit der "switch" Anweisung geschrieben werden müssen ein
  852. einzelnes Leerzeichen vor der öffnenden Klammer der Bedingten Anweisung
  853. besitzen, und auch nach der schließenden Klammer.
  854. </para>
  855. <para>
  856. Jeglicher Inhalt innerhalb der "switch" Anweisung muß durch Verwendung von vier
  857. Leerzeichen eingerückt sein. Der Inhalt unter jeder "case" Anweisung muß durch
  858. Verwendung von vier zusätzlichen Leerzeichen eingerückt werden.
  859. </para>
  860. <programlisting language="php"><![CDATA[
  861. switch ($numPeople) {
  862. case 1:
  863. break;
  864. case 2:
  865. break;
  866. default:
  867. break;
  868. }
  869. ]]></programlisting>
  870. <para>
  871. Das <property>default</property> Konstrukt darf nie bei der
  872. <property>switch</property> Anweisung vergessen werden.
  873. </para>
  874. <note>
  875. <para>
  876. <emphasis>Notiz</emphasis>: Es ist machmal nützlich eine
  877. <property>case</property> Anweisung zu schreiben, die durch das nächste case
  878. fällt indem innerhalb solcher Fälle kein <property>break</property> oder
  879. <property>return</property> angegeben wird. Um diese Fälle von Fehlern zu
  880. unterscheiden, sollte jede <property>case</property> Anweisung in der
  881. <property>break</property> oder <property>return</property> unterlassen
  882. werden einen Kommentar enthalten der anzeigt dass das break gewünschtermaßen
  883. unterdrückt wurde.
  884. </para>
  885. </note>
  886. </sect3>
  887. </sect2>
  888. <sect2 id="coding-standards.inline-documentation">
  889. <title>Inline Dokumentation</title>
  890. <sect3 id="coding-standards.inline-documentation.documentation-format">
  891. <title>Dokumentations Format</title>
  892. <para>
  893. Alle Dokumentations Blöcke ("DocBlock") müssel mit dem phpDocumentor Format
  894. kompatibel sein. Die Beschreibung des phpDocumentor Formats is jenseits der
  895. Reichweite dieses Dokuments. Für weiterführende Informationen siehe:
  896. <ulink url="http://phpdoc.org/">http://phpdoc.org"></ulink>
  897. </para>
  898. <para>
  899. Alle Klassen Dateien müssen einen "file-level" Docblock am Beginn jeder Datei
  900. und einen "class-level" Docblock direkt überhalb jeder Klasse enthalten.
  901. Beispiele solcher Docblocks können anbei gefunden werden.
  902. </para>
  903. </sect3>
  904. <sect3 id="coding-standards.inline-documentation.files">
  905. <title>Dateien</title>
  906. <para>
  907. Jede Datei die <acronym>PHP</acronym> Code enthält muß einen Docblock am Beginn
  908. der Datei besitzen welcher mindestens diese phpDocumentor Tags enthält:
  909. </para>
  910. <programlisting language="php"><![CDATA[
  911. /**
  912. * Kurze Beschreibung der Datei
  913. *
  914. * Lange Beschreibung der Datei (wenn vorhanden)...
  915. *
  916. * LICENSE: Einige Lizenz Informationen
  917. *
  918. * @category Zend
  919. * @package Zend_Magic
  920. * @subpackage Wand
  921. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  922. * @license http://framework.zend.com/license BSD License
  923. * @version $Id:$
  924. * @link http://framework.zend.com/package/PackageName
  925. * @since Datei vorhanden seit Release 1.2.0
  926. */
  927. ]]></programlisting>
  928. <para>
  929. Das <property>@category</property> Tag muß den Wert "Zend" haben.
  930. </para>
  931. <para>
  932. Das <property>@package</property> Tag muß hinzugefügt sein, und sollte mit
  933. dem Namen der Komponente identisch sein dessen Klasse in der Datei enthalten
  934. ist; typischerweise wird dieser zwei Segmente haben, den Präfix "Zend", und
  935. den Namen der Komponente.
  936. </para>
  937. <para>
  938. Das <property>@subpackage</property> Tag ist optional. Wenn es angegeben wird,
  939. sollte es der Name der Subkomponente sein, ohne den Präfix der Klasse. Im
  940. obigen Beispiel ist die Annahme das die Klasse in der Datei entweder
  941. "<classname>Zend_Magic_Wand</classname>" ist oder den Klassennamen als Teil
  942. seines Präfixes verwendet.
  943. </para>
  944. </sect3>
  945. <sect3 id="coding-standards.inline-documentation.classes">
  946. <title>Klassen</title>
  947. <para>
  948. Jede Klasse muß einen Docblock haben welche mindestens diese phpDocumentor Tags
  949. enthält:
  950. </para>
  951. <programlisting language="php"><![CDATA[
  952. /**
  953. * Kurze Beschreibung für die Klasse
  954. *
  955. * Lange Beschreibung für die Klasse (wenn vorhanden)...
  956. *
  957. * @category Zend
  958. * @package Zend_Magic
  959. * @subpackage Wand
  960. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  961. * @license http://framework.zend.com/license BSD License
  962. * @version Release: @package_version@
  963. * @link http://framework.zend.com/package/PackageName
  964. * @since Klasse vorhanden seit Release 1.5.0
  965. * @deprecated Klasse abgeraten ab Release 2.0.0
  966. */
  967. ]]></programlisting>
  968. <para>
  969. Das <property>@category</property> Tag muß den Wert "Zend" haben.
  970. </para>
  971. <para>
  972. Das <property>@package</property> Tag muß hinzugefügt sein, und sollte mit
  973. der Komponente identisch sein der die Klasse gehört; typischerweise wird
  974. dieser zwei Segmente haben, den Präfix "Zend", und den Namen der Komponente.
  975. </para>
  976. <para>
  977. Das <property>@subpackage</property> Tag ist optional. Wenn es angegeben wird,
  978. sollte es der Name der Subkomponente sein, ohne den Präfix der Klasse. Im
  979. obigen Beispiel ist die Annahme das die Klasse in der Datei entweder
  980. "<classname>Zend_Magic_Wand</classname>" ist oder den Klassennamen als Teil
  981. seines Präfixes verwendet.
  982. </para>
  983. </sect3>
  984. <sect3 id="coding-standards.inline-documentation.functions">
  985. <title>Funktionen</title>
  986. <para>
  987. Jede Funktion, auch Objekt Methoden, müssen einen Docblock haben welcher
  988. mindestens folgendes enthält:
  989. </para>
  990. <itemizedlist>
  991. <listitem><para>Eine Beschreibung der Funktion</para></listitem>
  992. <listitem><para>Alle Argumente</para></listitem>
  993. <listitem><para>Alle möglichen Rückgabewerte</para></listitem>
  994. </itemizedlist>
  995. <para>
  996. Es ist nicht notwendig das "@access" Tag zu verwenden, weil das Accesslevel
  997. bereits vom "public", "private" oder "protected" Modifikator bekannt ist wenn
  998. die Funktion deklariert wird.
  999. </para>
  1000. <para>
  1001. Wenn eine Funktion oder Methode eine Ausnahme werfen könnte, muß @throws für
  1002. alle bekannten Exception Klassen verwendet werden:
  1003. </para>
  1004. <programlisting language="php"><![CDATA[
  1005. @throws exceptionclass [Beschreibung]
  1006. ]]></programlisting>
  1007. </sect3>
  1008. </sect2>
  1009. </sect1>
  1010. </appendix>