coding_standard.xml 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785
  1. <appendix id="coding-standard">
  2. <title>Padrões de Codificação do Framework Zend para PHP</title>
  3. <sect1 id="coding-standard.overview">
  4. <title>Visão Geral</title>
  5. <sect2 id="coding-standard.overview.scope">
  6. <title>Escopo</title>
  7. <para>
  8. Este documento provê as linhas principais e recursos para desenvolvedores
  9. e times de desenvolvimento no Framework da Zend. São cobertos os seguintes
  10. assuntos:
  11. <itemizedlist>
  12. <listitem>
  13. <para>Formato do Arquivo PHP</para>
  14. </listitem>
  15. <listitem>
  16. <para>Convenção de Nomes</para>
  17. </listitem>
  18. <listitem>
  19. <para>Estilo de Código</para>
  20. </listitem>
  21. <listitem>
  22. <para>Documentação Inline</para>
  23. </listitem>
  24. </itemizedlist>
  25. </para>
  26. </sect2>
  27. <sect2 id="coding-standard.overview.goals">
  28. <title>Objetivos</title>
  29. <para>
  30. Bons padrões de código são importantes em qualquer projeto de desenvolvimento,
  31. mas particularmente quando múltiplos desenvolvedores estão trabalhando no mesmo
  32. projeto. Ter padrões ajuda a assegurar que o código seja de alta qualidade,
  33. tenha poucos bugs e seja de fácil manutenção.
  34. </para>
  35. </sect2>
  36. </sect1>
  37. <sect1 id="coding-standard.php-file-formatting">
  38. <title>Formato do Arquivo PHP</title>
  39. <sect2 id="coding-standard.php-file-formatting.general">
  40. <title>Geral</title>
  41. <para>
  42. Para arquivos que contenham somente código PHP, a tag de fechamento ("?>") não é permitida.
  43. Ela não é requerida pelo PHP. Não incluir esta tag evita espaços em branco na saída,
  44. deixados acidentalmente.
  45. </para>
  46. <para>
  47. <emphasis>IMPORTANTE:</emphasis>A inclusão de dados binários arbitrários, como o permitido por
  48. <code>__HALT_COMPILER()</code> é proibido em qualquer framework Zend, arquivo PHP ou arquivos
  49. derivados deles. O uso desta funcionalidade só é permitida para scripts especiais de instalação.
  50. </para>
  51. </sect2>
  52. <sect2 id="coding-standard.php-file-formatting.indentation">
  53. <title>Indentação</title>
  54. <para>Use indentação de 4 espaços, sem tabs.</para>
  55. </sect2>
  56. <sect2 id="coding-standard.php-file-formatting.max-line-length">
  57. <title>Tamanho máximo de linha</title>
  58. <para>
  59. A intenção é utilizar linhas com 80 caracteres, por exemplo, desenvolvedores
  60. devem procurar manter seu código próximo a 80 colunas se isso for prático.
  61. De qualquer forma, linhas longas são aceitáveis.
  62. O tamanho máximo de uma linha de código PHP é de 120 caracteres.
  63. </para>
  64. </sect2>
  65. <sect2 id="coding-standard.php-file-formatting.line-termination">
  66. <title>Final de Linha</title>
  67. <para>
  68. O final de linha segue o padrão para arquivos texto no Unix. Linhas devem acabar somente com um
  69. linefeed (LF). Linefeeds são representados como ordinal 10, ou hexadecimal 0x0A.
  70. </para>
  71. <para>Não use retorno de carro (CR)como nos computadores Macintosh (0x0D).</para>
  72. <para>
  73. Não use a combinação de retorno de carro/linefeed (CRLF) como nos computadores Windows (0x0D, 0x0A).
  74. </para>
  75. </sect2>
  76. </sect1>
  77. <sect1 id="coding-standard.naming-conventions">
  78. <title>Convenções de Nomes</title>
  79. <sect2 id="coding-standard.naming-conventions.classes">
  80. <title>Classes</title>
  81. <para>
  82. O Framework Zend emprega uma convenção por meio dos nomes das
  83. classes, diretamente mapeados aos diretórios nos quais estão arquivados.
  84. O diretório raiz do Framework Zend é o diretório "Zend/", abaixo do qual
  85. todas as classes são arquivadas hierarquicamente.
  86. </para>
  87. <para>
  88. Nomes de classes podem conter somente caracteres alfanuméricos. Números em nomes de classes são permitidos,
  89. mas desencorajados. Sublinhados são permitidos somente no lugar do separador de caminho -- o nome do arquivo
  90. "Zend/Db/Table.php" deve ser mapeado para o nome de classe "Zend_Db_Table".
  91. </para>
  92. <para>
  93. Se o nome de uma classe é composto por mais de uma palavra, a primeira letra de cada nova
  94. palavra deve ser maiúscula. Letras maiúsculas sucessivas não são permitidas, por exemplo
  95. a classe "Zend_PDF" não é permitida enquanto "Zend_Pdf" é aceita.
  96. </para>
  97. <para>
  98. As classes do Framework Zend de autoria da Zend ou de uma das companhias parceiras
  99. participantes e distribuídas com o Framework devem sempre iniciar com "Zend_" e
  100. devem estar arquivadas sob a hierarquia do diretório "Zend/".
  101. </para>
  102. <para>
  103. São exemplos de nomes aceitáveis para classes:
  104. <programlisting role="php"><![CDATA[
  105. Zend_Db
  106. Zend_View
  107. Zend_View_Helper
  108. ]]></programlisting>
  109. <emphasis>IMPORTANTE:</emphasis> Código que opera com o framework mas que não é parte dele,
  110. por exemplo, código escrito por um usuário final e não pela Zend ou uma das companhias parceiras,
  111. não pode começar com "Zend_".
  112. </para>
  113. </sect2>
  114. <sect2 id="coding-standard.naming-conventions.interfaces">
  115. <title>Interfaces</title>
  116. <para>
  117. Classes de interface devem seguir as mesmas convenções como outras classes (veja acima),
  118. porém deve acabar com a palavra "Interface", como nestes exemplos:
  119. <programlisting role="php"><![CDATA[
  120. Zend_Log_Adapter_Interface
  121. Zend_Controller_Dispatcher_Interface]]></programlisting>
  122. </para>
  123. </sect2>
  124. <sect2 id="coding-standard.naming-conventions.filenames">
  125. <title>Nomes de Arquivos</title>
  126. <para>
  127. Para todos os outros arquivos, somente caracteres alfanuméricos, sublinhado, e traço "-"
  128. são permitidos. Espaços e ponto são proibidos.
  129. </para>
  130. <para>
  131. Qualquer arquivo que contenha qualquer código PHP deve acabar com a extensão ".php".
  132. Estes exemplos mostram nomes de arquivo aceitáveis para as classes que estes contenham,
  133. baseados nos exemplos da seção acima:
  134. <programlisting role="php"><![CDATA[
  135. Zend/Db.php
  136. Zend/Controller/Front.php
  137. Zend/View/Helper/FormRadio.php]]></programlisting>
  138. Nomes de arquivos devem seguir o mapeamento para nomes de classes descrito acima.
  139. </para>
  140. </sect2>
  141. <sect2 id="coding-standard.naming-conventions.functions-and-methods">
  142. <title>Funções e Métodos</title>
  143. <para>
  144. Nomes de funções devem conter somente caracteres alfanuméricos. Sublinhados não são permitidos.
  145. Números são permitidos nos nomes, mas são desencorajados.
  146. </para>
  147. <para>
  148. Nomes de funções devem sempre começar com letra minúscula. Quando um nome consistir em mais de
  149. uma palavra, a primeira letra de cada nova palavra deve ser maiúscula. Isto é comumente chamado o
  150. método "studlyCaps" ou "camelCaps".
  151. </para>
  152. <para>
  153. Verbalização é encorajada. Nomes de funções devem ser tão longos quanto práticos para melhorar
  154. o entendimento do código.
  155. </para>
  156. <para>
  157. Estes são exemplos de nomes aceitáveis para funções:
  158. <programlisting role="php"><![CDATA[
  159. filterInput()
  160. getElementById()
  161. widgetFactory()]]></programlisting>
  162. </para>
  163. <para>
  164. Para programação orientada ao objeto, acessores para objetos devem sempre ser prefixados com
  165. "get" ou "set". Quando usando padrões de projeto, como o Singleton ou Factory Patterns,
  166. o nome do método deve conter o nome do padrão, como prática para que o padrão seja reconhecido na
  167. leitura.
  168. </para>
  169. <para>
  170. Funções no escopo global ("funções soltas") são permitidas mas desencorajadas.
  171. É recomendável que estas funções sejam empacotadas numa classe estática.
  172. </para>
  173. </sect2>
  174. <sect2 id="coding-standard.naming-conventions.variables">
  175. <title>Variáveis</title>
  176. <para>
  177. Nomes de variáveis devem conter somente caracteres alfanuméricos. Sublinhados não são permitidos.
  178. Números são permitidos nos nomes, mas desencorajados.
  179. </para>
  180. <para>
  181. Para variáveis membros de classes que são declaradas com o construtor "private" ou "protected",
  182. o primeiro caractere do nome da variável deve ser um único sublinhado. Este é o único uso aceitável
  183. de sublinhado no nome. Variáveis membros declaradas "public" não podem começar com sublinhado.
  184. </para>
  185. <para>
  186. Como nos nomes de funções (veja a seção 3.3 acima) nomes de variáveis devem iniciar com uma letra
  187. minúscula e seguir a convenção "camelCaps".
  188. </para>
  189. <para>
  190. Verbalização é encorajada. Nomes de variáveis devem ser tão longos quanto práticos. Nomes como
  191. "$i" e "$n" são desencorajados para qualquer coisa que não esteja num contexto de loop pequeno.
  192. Se um loop contém mais de 20 linhas de código, as variáveis para os indices precisam ter um nome mais
  193. descritivo.
  194. </para>
  195. </sect2>
  196. <sect2 id="coding-standard.naming-conventions.constants">
  197. <title>Constantes</title>
  198. <para>
  199. Constantes podem conter caracteres alfanuméricos e sublinhado. Números são permitidos nos nomes.
  200. </para>
  201. <para>
  202. Constantes devem ter sempre todas suas letras em maiúsculo.
  203. </para>
  204. <para>
  205. Constantes devem ser definidas como membros de classe usando o construtor "const".
  206. Definir constantes no escopo global com "define" é permitido, mas desencorajado.
  207. </para>
  208. </sect2>
  209. </sect1>
  210. <sect1 id="coding-standard.coding-style">
  211. <title>Estilo de Código</title>
  212. <sect2 id="coding-standard.coding-style.php-code-demarcation">
  213. <title>Demarcação de Código PHP</title>
  214. <para>
  215. Código PHP deve sempre estar delimitado de forma completa, com tags padrão do PHP:
  216. <programlisting role="php"><![CDATA[
  217. <?php
  218. ?>]]></programlisting>
  219. </para>
  220. <para>
  221. Tags curtas não são permitidas.
  222. </para>
  223. </sect2>
  224. <sect2 id="coding-standard.coding-style.strings">
  225. <title>Strings</title>
  226. <sect3 id="coding-standard.coding-style.strings.literals">
  227. <title>String Literal</title>
  228. <para>
  229. Quando uma string é literal (não contém substituições de variável), deve ser usado apóstrofo
  230. ou aspas simples para demarcar o texto.
  231. <programlisting role="php"><![CDATA[
  232. $a = 'Exemplo de Texto';]]></programlisting>
  233. </para>
  234. </sect3>
  235. <sect3 id="coding-standard.coding-style.strings.literals-containing-apostrophes">
  236. <title>String Literal Contendo Apóstrofos</title>
  237. <para>
  238. Quando uma string literal contém apóstrofos dentro de si, é permitido demarcar
  239. o texto com aspas ou "aspas duplas". Isto é especialmente encorajado para declarações SQL:
  240. <programlisting role="php"><![CDATA[
  241. $sql = "SELECT `id`, `name` from `people` WHERE `name`='Fred' OR `name`='Susan'";]]></programlisting>
  242. A sintaxe acima é preferida ao invés de escapar os apóstrofos.
  243. </para>
  244. </sect3>
  245. <sect3 id="coding-standard.coding-style.strings.variable-substitution">
  246. <title>Substituição de Variáveis</title>
  247. <para>
  248. A substituição de variáveis é permitida usando qualquer uma das duas formas:
  249. <programlisting role="php"><![CDATA[
  250. $greeting = "Olá $nome, bem-vindo de volta!";
  251. $greeting = "Olá {$nome}, bem-vindo de volta!";]]></programlisting>
  252. </para>
  253. <para>
  254. Por consistência, a forma a seguir não é permitida:
  255. <programlisting role="php"><![CDATA[
  256. $greeting = "Olá ${nome}, bem-vindo de volta!";]]></programlisting>
  257. </para>
  258. </sect3>
  259. <sect3 id="coding-standard.coding-style.strings.string-concatenation">
  260. <title>Concatenação de String</title>
  261. <para>
  262. Strings devem ser concatenadas usando o operador ".". Um espaço deve sempre
  263. ser adicionado antes e depois do operador "." para melhorar a legibilidade:
  264. <programlisting role="php"><![CDATA[
  265. $company = 'Zend' . 'Technologies';]]></programlisting>
  266. </para>
  267. <para>
  268. Quando estiver concatenando strings com o operador ".", é permitido quebrar a declaração em
  269. várias linhas para melhorar a legibilidade. Nestes casos, cada linha sucessiva deverá ser colocada
  270. num bloco com espaço em branco de forma que o operador "." esteja alinhado abaixo do operador "=":
  271. <programlisting role="php"><![CDATA[
  272. $sql = "SELECT `id`, `name` FROM `people` "
  273. . "WHERE `name` = 'Susan' "
  274. . "ORDER BY `name` ASC ";]]></programlisting>
  275. </para>
  276. </sect3>
  277. </sect2>
  278. <sect2 id="coding-standard.coding-style.arrays">
  279. <title>Arrays</title>
  280. <sect3 id="coding-standard.coding-style.arrays.numerically-indexed">
  281. <title>Arrays Indexados Numericamente</title>
  282. <para>Números negativos não são permitidos como índices.</para>
  283. <para>
  284. Um array indexado pode começar com qualquer número não negativo, porém
  285. isto é desencorajado. É recomendado que todo array tenha um índice inicial 0.
  286. </para>
  287. <para>
  288. Quando declarar arrays indexados com o construtor <code>array</code>, um espaço deve ser
  289. adicionado depois de cada vírgula para melhorar a legibilidade:
  290. <programlisting role="php"><![CDATA[
  291. $sampleArray = array(1, 2, 3, 'Zend', 'Studio');]]></programlisting>
  292. </para>
  293. <para>
  294. Também é permitido declarar arrays indexados em várias linhas usando o construtor "array".
  295. Neste caso, cada linha sucessiva deve ser colocada num bloco com espaços de forma que
  296. o início de cada código alinhe-se conforme mostrado abaixo:
  297. <programlisting role="php"><![CDATA[
  298. $sampleArray = array(1, 2, 3, 'Zend', 'Studio',
  299. $a, $b, $c,
  300. 56.44, $d, 500);]]></programlisting>
  301. </para>
  302. </sect3>
  303. <sect3 id="coding-standard.coding-style.arrays.associative">
  304. <title>Arrays Associativos</title>
  305. <para>
  306. Quando declarar arrays associativos com o construtor <code>array</code>, é recomendado
  307. quebrar a declaração em múltiplas linhas. Neste caso, cada linha sucessiva deve estar num bloco
  308. com espaço em branco, de forma que as chaves e valores estejam alinhados:
  309. <programlisting role="php"><![CDATA[
  310. $sampleArray = array('firstKey' => 'firstValue',
  311. 'secondKey' => 'secondValue');]]></programlisting>
  312. </para>
  313. </sect3>
  314. </sect2>
  315. <sect2 id="coding-standard.coding-style.classes">
  316. <title>Classes</title>
  317. <sect3 id="coding-standard.coding-style.classes.declaration">
  318. <title>Declaração de Classes</title>
  319. <para>
  320. Classes devem ser nomeadas seguindo a convenção de nomes.
  321. </para><para>
  322. A chave de abertura é sempre escrita embaixo do nome da classe (forma de "uma única chave real").
  323. </para><para>
  324. Toda classe deve ter um bloco de documentação, dentro do padrão do PHPDocumentor.
  325. </para><para>
  326. Todo código dentro de uma classe deve estar indentado com quatro espaços.
  327. </para><para>
  328. Somente uma classe é permitida por arquivo PHP.
  329. </para><para>
  330. Colocar código adicional em um arquivo de classe é permitido mas desencorajado. Nestes arquivos,
  331. duas linhas em branco devem separar a classe do código PHP adicional no arquivo.
  332. </para><para>
  333. Este é um exemplo de declaração aceitável de classe :
  334. <programlisting role="php"><![CDATA[
  335. /**
  336. * Bloco de documentação aqui
  337. */
  338. class SampleClass
  339. {
  340. // conteúdo completo da classe
  341. // deve estar indentado com quatro espaços
  342. }]]></programlisting>
  343. </para>
  344. </sect3>
  345. <sect3 id="coding-standard.coding-style.classes.member-variables">
  346. <title>Variáveis Membros de Classe</title>
  347. <para>
  348. Variáveis membro devem ser nomeadas de acordo com a convenção de nomes de variáveis.
  349. </para><para>
  350. Quaisquer variáveis declaradas numa classe devem ser listadas no topo da classe, antes
  351. de declarar qualquer função.
  352. </para><para>
  353. O construtor <code>var</code> não é permitido. Variáveis membro sempre declaram sua
  354. visibilidade usando o construtor <code>private</code>, <code>protected</code>
  355. ou <code>public</code>. Acessar variáveis membro diretamente tornando-as públicas
  356. é permitido mas desencorajado em favor de variáveis de acesso (set/get).
  357. </para>
  358. </sect3>
  359. </sect2>
  360. <sect2 id="coding-standard.coding-style.functions-and-methods">
  361. <title>Funções e Métodos</title>
  362. <sect3 id="coding-standard.coding-style.functions-and-methods.declaration">
  363. <title>Declaração de Funções e Métodos</title>
  364. <para>
  365. Nomes de funções devem seguir a convenção de nomes.
  366. </para><para>
  367. Funções dentro de classes sempre declaram sua visibilidade usando o
  368. construtor <code>private</code>, <code>protected</code> ou <code>public</code>.
  369. </para><para>
  370. Como classes, a chave de abertura deve sempre ser escrita abaixo do nome da função
  371. (forma de "uma única chave real").
  372. Não há espaços entre o nome da função e os parênteses para os argumentos.
  373. </para><para>
  374. Funções no escopo global são fortemente desencorajadas.
  375. </para><para>
  376. Este é um exemplo de declaração aceitável de função:
  377. <programlisting role="php"><![CDATA[
  378. /**
  379. * Bloco de documentação aqui
  380. */
  381. class foo
  382. /**
  383. * Bloco de documentação aqui
  384. */
  385. public function bar()
  386. {
  387. // todo conteúdo da função
  388. // deve ser indentado com quatro espaços
  389. }
  390. }]]></programlisting>
  391. </para>
  392. <para>
  393. <emphasis>NOTA:</emphasis> Passar valores por referência na declaração da função é
  394. permitido somente neste caso:
  395. <programlisting role="php"><![CDATA[
  396. /**
  397. * Bloco de documentação aqui
  398. */
  399. class foo
  400. /**
  401. * Bloco de documentação aqui
  402. */
  403. public function bar(&$baz)
  404. {
  405. // todo conteúdo da função
  406. // deve ser indentado com quatro espaços
  407. }
  408. }]]></programlisting>
  409. </para>
  410. <para>
  411. Passar valores por referência ao chamar a função é proibido.
  412. </para>
  413. <para>
  414. O valor de retorno não deve estar entre parênteses. Isto pode impedir a boa legibilidade
  415. e pode ainda quebrar o código de um método que seja alterado posteriormente para retornar
  416. por referência.
  417. <programlisting role="php"><![CDATA[
  418. /**
  419. * Documentation Block Here
  420. */
  421. class Foo
  422. {
  423. /**
  424. * ERRADO
  425. */
  426. public function bar()
  427. {
  428. return($this->bar);
  429. }
  430. /**
  431. * CERTO
  432. */
  433. public function bar()
  434. {
  435. return $this->bar;
  436. }
  437. }]]></programlisting>
  438. </para>
  439. </sect3>
  440. <sect3 id="coding-standard.coding-style.functions-and-methods.usage">
  441. <title>Uso de Funções e Métodos</title>
  442. <para>
  443. Argumentos de funções são separados por um espaço simples depois
  444. da vírgula. Este é um exemplo de chamada de função que tenha três argumentos:
  445. <programlisting role="php"><![CDATA[
  446. threeArguments(1, 2, 3);]]></programlisting>
  447. </para>
  448. <para>
  449. Passar parâmetros por referência na chamada da função é proibido. Veja a seção de
  450. declaração de funções para o modo correto de passar argumentos por referência.
  451. </para><para>
  452. Para funções que permitem arrays nos argumentos, a chamada da função pode incluir o
  453. construtor "array" e pode ser dividido em várias linhas para melhorar a legibilidade.
  454. Nestes casos, o padrão para escrever arrays também se aplica:
  455. <programlisting role="php"><![CDATA[
  456. threeArguments(array(1, 2, 3), 2, 3);
  457. threeArguments(array(1, 2, 3, 'Zend', 'Studio',
  458. $a, $b, $c,
  459. 56.44, $d, 500), 2, 3);]]></programlisting>
  460. </para>
  461. </sect3>
  462. </sect2>
  463. <sect2 id="coding-standard.coding-style.control-statements">
  464. <title>Instruções de Controle</title>
  465. <sect3 id="coding-standard.coding-style.control-statements.if-else-elseif">
  466. <title>If / Else / Elseif</title>
  467. <para>
  468. Instruções de controle baseadas nos construtores <code>if</code> e <code>elseif</code>
  469. devem ter um espaço simples antes do parêntese de abertura da condição e um espaço
  470. simples depois do parêntese de fechamento.
  471. </para>
  472. <para>
  473. Dentro das declarações condicionais entre os parênteses, operadores devem ser separados
  474. por espaços para legibilidade. Parênteses internos são encorajados para melhorar o agrupamento
  475. lógico de condicionais extensas.
  476. </para>
  477. <para>
  478. A chave de abertura é sempre escrita na mesma linha da instrução condicional. A chave de
  479. fechamento é sempre escrita em sua própria linha. Qualquer conteúdo dentro das chaves deve
  480. ser indentado por quatro espaços.
  481. <programlisting role="php"><![CDATA[
  482. if ($a != 2) {
  483. $a = 2;
  484. }]]></programlisting>
  485. </para>
  486. <para>
  487. Para instruções "if" que incluem "elseif" ou "else", a formatação deve ser como
  488. nos exemplos:
  489. <programlisting role="php"><![CDATA[
  490. if ($a != 2) {
  491. $a = 2;
  492. } else {
  493. $a = 7;
  494. }
  495. if ($a != 2) {
  496. $a = 2;
  497. } elseif ($a == 3) {
  498. $a = 4;
  499. } else {
  500. $a = 7;
  501. }]]></programlisting>
  502. O PHP permite, em certas circunstâncias, que as instruções sejam escritas sem as chaves.
  503. O padrão de código não as diferencia, pois todas instruções "if", "elseif" ou "else"
  504. devem utilizar as chaves.
  505. </para>
  506. <para>
  507. O uso do construtor "elseif" é permitido mas altamente desencorajado em favor da
  508. combinação "else if".
  509. </para>
  510. </sect3>
  511. <sect3 id="coding-standards.coding-style.control-statements.switch">
  512. <title>Switch</title>
  513. <para>
  514. Instruções de controle escritas com o construtor "switch" devem ter um espaço simples antes
  515. do parêntese de abertura da instrução condicional e um espaço simples depois do parêntese
  516. de fechamento.
  517. </para>
  518. <para>
  519. Todo conteúdo da instrução "switch" deve ser indentado com quatro espaços. O conteúdo
  520. abaixo de cada instrução "case" deve ser indentado com quatro espaços adicionais.
  521. </para>
  522. <programlisting role="php"><![CDATA[
  523. switch ($numPeople) {
  524. case 1:
  525. break;
  526. case 2:
  527. break;
  528. default:
  529. break;
  530. }]]></programlisting>
  531. <para>
  532. O construtor <code>default</code> jamais pode ser omitido da instrução <code>switch</code>.
  533. </para>
  534. <para>
  535. <emphasis>NOTA:</emphasis> Algumas vezes é útil escrever uma instrução <code>case</code> que entra no próximo
  536. case sem incluir um <code>break</code> ou <code>return</code>. Para distinguir aqueles cases dos bugs,
  537. qualquer instrução <code>case</code> onde <code>break</code> ou <code>return</code> são omitidos deve
  538. conter o comentário "// break intentionally omitted".
  539. </para>
  540. </sect3>
  541. </sect2>
  542. <sect2 id="coding-standards.inline-documentation">
  543. <title>Documentação Inline </title>
  544. <sect3 id="coding-standards.inline-documentation.documentation-format">
  545. <title>Formato da Documentação</title>
  546. <para>
  547. Todos blocos de documentação ("dockblocks") devem ser compatíveis com o formato do phpDocumentor.
  548. A descrição do formato do phpDocumentor está além do escopo deste documento.
  549. Para maiores informações, visite: <ulink url="http://phpdoc.org/">http://phpdoc.org"></ulink>
  550. </para>
  551. <para>
  552. Todo código fonte escrito para o Framework Zend ou que trabalhe com o framework deve conter
  553. um bloco de documentação em nível de arquivo no topo de cada arquivo e um bloco de documentação
  554. em nível de classe imediatamente acima de cada classe. Abaixo seguem exemplos destes blocos de
  555. documentação:
  556. </para>
  557. </sect3>
  558. <sect3 id="coding-standards.inline-documentation.files">
  559. <title>Arquivos</title>
  560. <para>
  561. Cada arquivo que contenha código PHP deve ter um bloco de cabeçalho no topo do arquivo que
  562. contenha, no mínimo, estas tags do phpDocumentor:
  563. <programlisting role="php"><![CDATA[
  564. /**
  565. * Short description for file
  566. *
  567. * Long description for file (if any)...
  568. *
  569. * LICENSE: Some license information
  570. *
  571. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  572. * @license http://www.zend.com/license/3_0.txt PHP License 3.0
  573. * @version $Id:$
  574. * @link http://dev.zend.com/package/PackageName
  575. * @since File available since Release 1.2.0
  576. */]]></programlisting>
  577. </para>
  578. </sect3>
  579. <sect3 id="coding-standards.inline-documentation.classes">
  580. <title>Classes</title>
  581. <para>
  582. Toda classe deve ter um bloco de documentação que contenha, no mínimo, as seguintes
  583. tags do phpDocumentor:
  584. <programlisting role="php"><![CDATA[
  585. /**
  586. * Short description for class
  587. *
  588. * Long description for class (if any)...
  589. *
  590. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  591. * @license http://www.zend.com/license/3_0.txt PHP License 3.0
  592. * @version Release: @package_version@
  593. * @link http://dev.zend.com/package/PackageName
  594. * @since Class available since Release 1.2.0
  595. * @deprecated Class deprecated in Release 2.0.0
  596. */]]></programlisting>
  597. </para>
  598. </sect3>
  599. <sect3 id="coding-standards.inline-documentation.functions">
  600. <title>Funções</title>
  601. <para>
  602. Toda função, incluindo métodos de objetos, deve ter um bloco de documentação
  603. que contenha, no mínimo, as seguintes tags:
  604. <itemizedlist>
  605. <listitem><para>Descrição da função</para></listitem>
  606. <listitem><para>Todos argumentos</para></listitem>
  607. <listitem><para>Todos os possíveis valores de retorno</para></listitem>
  608. </itemizedlist>
  609. </para>
  610. <para>
  611. Não é necessário usar a tag "@access" pois o nível de acesso é conhecido através
  612. do construtor "public", "private", ou "protected" usado para declarar a função.
  613. </para>
  614. <para>
  615. Se uma função/método pode gerar uma excessão, use @throws:
  616. <programlisting role="php"><![CDATA[
  617. @throws exceptionclass [description]
  618. ]]></programlisting>
  619. </para>
  620. </sect3>
  621. </sect2>
  622. </sect1>
  623. </appendix>
  624. <!--
  625. vim:se ts=4 sw=4 et:
  626. -->