File: coding_standard.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (1100 lines) | stat: -rw-r--r-- 45,785 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
1069
1070
1071
1072
1073
1074
1075
1076
1077
1078
1079
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<appendix id="coding-standard">
    <title>Convention de codage PHP de Zend Framework</title>

    <sect1 id="coding-standard.overview">
        <title>Vue d'ensemble</title>

        <sect2 id="coding-standard.overview.scope">
            <title>Portée</title>

            <para>
                Ce document fournit les lignes directrices pour le formatage de code et la
                documentation pour les contributeurs individuels et les équipes contributrices à
                Zend Framework. Un certain nombre de développeurs utilisant Zend Framework ont
                trouvé ces conventions de codage pratique car leurs styles de codage sont cohérents
                avec l'ensemble du code de Zend Framework. Il est également à noter qu'il exige un
                effort significatif pour spécifier entièrement des normes de codage. Parfois
                les développeurs considèrent l'établissement d'une norme plus important que ce que
                cette norme suggère réellement en tout cas au niveau de l'analyse détaillée de la
                conception. Les lignes directrices dans les conventions de codage de Zend Framework
                effectuent un cliché des pratiques qui ont bien fonctionnées dans le projet Zend
                Framework. Vous pouvez modifier ces règles ou les utiliser comme telles en accord
                avec les termes de votre <ulink
                url="http://framework.zend.com/license">licence.</ulink>
            </para>

            <para>
                Les sujets traités dans les conventions de codage de Zend Framework sont :
                <itemizedlist>
                    <listitem>
                        <para>Formatage des fichiers PHP</para>
                    </listitem>

                    <listitem>
                        <para>Conventions de nommage</para>
                    </listitem>

                    <listitem>
                        <para>Style de code</para>
                    </listitem>

                    <listitem>
                        <para>Documentation en ligne</para>
                    </listitem>
                </itemizedlist>
            </para>
        </sect2>

        <sect2 id="coding-standard.overview.goals">
            <title>Buts</title>

            <para>
                De bonnes conventions de codage sont importantes dans tout projet de
                développement, et plus particulièrement lorsque plusieurs développeurs travaillent
                en même temps sur le projet. Avoir ces conventions permet de s'assurer que le code
                est de haute qualité, peu buggé et facilement maintenu.
            </para>
        </sect2>
    </sect1>

    <sect1 id="coding-standard.php-file-formatting">
        <title>Formatage des fichiers PHP</title>

        <sect2 id="coding-standard.php-file-formatting.general">
            <title>Général</title>

            <para>
                Pour les fichiers contenant uniquement du code PHP, la balise de fermeture
                ("?&gt;") n'est jamais permise. Il n'est pas requis par PHP. Ne pas l'inclure permet
                de se prémunir les problèmes liés à l'injection accidentelle d'espaces blancs dans
                la sortie.
            </para>

            <para>
                <emphasis>IMPORTANT :</emphasis> L'inclusion de données binaires arbitraires
                comme il est permis par <code>__HALT_COMPILER()</code> est prohibé dans tout fichier
                PHP de Zend Framework, ainsi que dans tout fichier dérivé. L'utilisation de cette
                possibilité est uniquement permise pour des scripts spéciaux d'installation.
            </para>
        </sect2>

        <sect2 id="coding-standard.php-file-formatting.indentation">
            <title>Indentation</title>

            <para>Utilisez une indentation de 4 espaces, sans tabulations.</para>
        </sect2>

        <sect2 id="coding-standard.php-file-formatting.max-line-length">
            <title>Longueur maximum d'une ligne</title>

            <para>
                La longueur souhaitée d'une ligne est de 80 caractères, c'est-à-dire que les
                développeurs devraient avoir pour but de ne pas dépasser les 80 caractères pour des
                raisons pratiques. Cependant, des lignes plus longues sont acceptables. La longueur
                maximum de toute ligne de code PHP est de 120 caractères.
            </para>
        </sect2>

        <sect2 id="coding-standard.php-file-formatting.line-termination">
            <title>Terminaison de lignes</title>

            <para>
                La terminaison de ligne est la terminaison standard pour les fichier textes
                UNIX. Les lignes doit finir seulement avec un "linefeed" (LF). Les linefeeds sont
                représentés comme 10 en ordinal, ou 0x0A en hexadécimal.
            </para>

            <para>
                Note : N'utilisez pas de retour chariots (CR) comme le font les Macintosh
                (0x0D) ou de combinaison retour chariot/linefeed (CRLF) comme le font les
                ordinateurs sous Windows (0x0D, 0x0A).
            </para>
        </sect2>
    </sect1>

    <sect1 id="coding-standard.naming-conventions">
        <title>Conventions de nommage</title>

        <sect2 id="coding-standard.naming-conventions.classes">
            <title>Classes</title>

            <para>
                Zend Framework emploie une convention de nommage des classes où les noms des
                classes mènent directement dans les répertoires dans lesquels elles sont stockées.
                Le répertoire racine de Zend Framework est le répertoire "Zend/", tandis que le
                répertoire racine de la librairie extras de Zend Framework est "ZendX/". Toutes les
                classes sont stockées de façon hiérarchique sous ces dossiers racines.
            </para>

            <para>
                Les noms de classes ne peuvent contenir que des caractères alphanumériques.
                Les nombres sont autorisés, mais déconseillés. Les tirets bas ("_") ne sont
                autorisés que pour être utilisés comme séparateur de chemin ; le nom de fichier
                "Zend/Db/Table.php" doit mener à la classe appelée "Zend_Db_Table".
            </para>

            <para>
                Si un nom de classe comprend plus d'un mot, la première lettre de chaque
                nouveau mot doit être mis en majuscule. La mise en majuscule de lettres successives
                n'est pas autorisée, c'est-à-dire qu'une classe "Zend_PDF" est interdit alors que
                "Zend_Pdf" est autorisé.
            </para>

            <para>
                Ces conventions définissent un pseudo mécanisme d'espace de noms pour Zend
                Framework. Zend Framework adoptera la fonctionnalité des espaces de noms de PHP
                quand celle-ci sera disponible et qu'il sera possible pour les développeurs de
                l'utiliser dans leurs applications.
            </para>

            <para>
                Regardez les noms de classes dans les librairies standard et extras pour avoir
                des exemples de cette convention de nommage. <emphasis>IMPORTANT :</emphasis> le
                code qui opère avec le Framework mais qui n'en fait par partie, c'est-à-dire le code
                écrit par un utilisateur et pas Zend ou une des entreprises partenaires, ne doivent
                jamais commencer par "Zend_".
            </para>
        </sect2>

        <sect2 id="coding-standard.naming-conventions.abstracts">
            <title>Abstract Classes</title>

            <para>
                In general, abstract classes follow the same conventions as <link
                    linkend="coding-standard.naming-conventions.classes">classes</link>,
                with one additional rule: abstract class names must end in the term, "Abstract",
                and that term must not be preceded by an underscore. As an example,
                <classname>Zend_Controller_Plugin_Abstract</classname> is considered an
                invalid name, but <classname>Zend_Controller_PluginAbstract</classname> or
                <classname>Zend_Controller_Plugin_PluginAbstract</classname> would be valid
                names.
            </para>

            <note>
                <para>
                    This naming convention is new with version 1.9.0 of Zend Framework. Classes
                    that pre-date that version may not follow this rule, but will be renamed in
                    the future in order to comply.
                </para>

                <para>
                    The rationale for the change is due to namespace usage. As we look towards Zend
                    Framework 2.0 and usage of <acronym>PHP</acronym> 5.3, we will be using
                    namespaces. The easiest way to automate conversion to namespaces is to simply
                    convert underscores to the namespace separator -- but under the old naming
                    conventions, this leaves the classname as simply "Abstract" or "Interface" --
                    both of which are reserved keywords in <acronym>PHP</acronym>. If we prepend the
                    (sub)component name to the classname, we can avoid these issues.
                </para>

                <para>
                    To illustrate the situation, consider converting the class
                    <classname>Zend_Controller_Request_Abstract</classname> to use namespaces:
                </para>

                <programlisting language="php"><![CDATA[
namespace Zend\Controller\Request;

abstract class Abstract
{
    // ...
}
]]></programlisting>

                <para>
                    Clearly, this will not work. Under the new naming conventions, however, this
                    would become:
                </para>

                <programlisting language="php"><![CDATA[
namespace Zend\Controller\Request;

abstract class RequestAbstract
{
    // ...
}
]]></programlisting>

                <para>
                    We still retain the semantics and namespace separation, while omitting the
                    keyword issues; simultaneously, it better describes the abstract class.
                </para>
            </note>
        </sect2>

        <sect2 id="coding-standard.naming-conventions.interfaces">
            <title>Interfaces</title>

            <para>
                In general, interfaces follow the same conventions as <link
                    linkend="coding-standard.naming-conventions.classes">classes</link>,
                with one additional rule: interface names may optionally end in the term,
                "Interface", but that term must not be preceded by an underscore. As an example,
                <classname>Zend_Controller_Plugin_Interface</classname> is considered an
                invalid name, but <classname>Zend_Controller_PluginInterface</classname> or
                <classname>Zend_Controller_Plugin_PluginInterface</classname> would be valid
                names.
            </para>

            <para>
                While this rule is not required, it is strongly recommended, as it provides a
                good visual cue to developers as to which files contain interfaces rather than
                classes.
            </para>

            <note>
                <para>
                    This naming convention is new with version 1.9.0 of Zend Framework. Classes
                    that pre-date that version may not follow this rule, but will be renamed in
                    the future in order to comply. See <link
                        linkend="coding-standard.naming-conventions.abstracts">the previous
                        section</link> for more information on the rationale for this change.
                </para>
            </note>
        </sect2>

        <sect2 id="coding-standard.naming-conventions.filenames">
            <title>Noms de fichiers</title>

            <para>
                Pour tous les autres fichiers, seuls des caractères alphanumériques, tirets
                bas et tirets demi-cadratin ("-") sont autorisés. Les espaces et les caractères
                spéciaux sont interdits.
            </para>

            <para>
                Tout fichier contenant du code PHP doit se terminer par l'extension ".php".
                Ces exemples montrent des noms de fichiers acceptables pour contenir les noms de
                classes issus des exemples ci-dessus : <programlisting language="php"><![CDATA[
Zend/Db.php

Zend/Controller/Front.php

Zend/View/Helper/FormRadio.php
]]></programlisting>
                Les noms de fichiers doivent correspondre aux noms des classes décris ci-dessus.
            </para>
        </sect2>

        <sect2 id="coding-standard.naming-conventions.functions-and-methods">
            <title>Fonctions et méthodes</title>

            <para>
                Les noms de fonctions ne peuvent contenir que des caractères alphanumériques.
                Les tirets bas ("_") ne sont pas permis. Les nombres sont autorisés mais
                déconseillés.
            </para>

            <para>
                Les noms de fonctions doivent toujours commencer avec une lettre en minuscule.
                Quand un nom de fonction est composé de plus d'un seul mot, la première lettre de
                chaque mot doit être mise en majuscule. C'est ce que l'on appelle communément la
                "notationCamel".
            </para>

            <para>
                La clarté est conseillée. Le nom des fonctions devrait être aussi explicite
                que possible, c'est un gage de compréhension du code.
            </para>

            <para>
                Voici des exemples de noms acceptables pour des fonctions : <programlisting
                role="php"><![CDATA[
filterInput()

getElementById()

widgetFactory()
]]></programlisting>
            </para>

            <para>
                Pour la programmation orientée objet, les accesseurs aux objets doivent
                toujours être préfixés par soit "get" soit "set". Lorsque vous utilisez des motifs
                de conception, comme le Singleton ou la Fabrique, le nom de la méthode doit contenir
                le nom du motif pour permettre une reconnaissance plus simple et plus rapide du
                motif.
            </para>

            <para>
                Pour des méthodes d'objet qui sont déclarées avec la construction "private" ou
                "protected", le premier caractère du nom variable doit être un tiret bas simple
                ("_"). C'est la seule utilisation autorisé d'un tiret bas dans un nom de méthode.
                Les méthodes déclarées "public" ne devraient jamais commencer par un tiret
                bas.
            </para>

            <para>
                Les fonctions à portée globale ("les fonctions flottantes") sont autorisées
                mais déconseillées. Il est recommandé de mettre ces fonctions dans des classes
                statiques.
            </para>
        </sect2>

        <sect2 id="coding-standard.naming-conventions.variables">
            <title>Variables</title>

            <para>
                Les noms de variables ne peuvent contenir que des caractères alphanumériques.
                Les tirets bas ne sont pas permis. Les nombres sont autorisés mais
                déconseillés.
            </para>

            <para>
                Pour les variables membres de classe qui sont déclarées comme "private" ou
                "protected", le premier caractère du nom de la variable doit être un tiret bas
                simple ("_"). C'est la seule utilisation autorisé d'un tiret bas dans un nom de
                variable. Les variables membres "public" ne devraient jamais commencer par un tiret
                bas.
            </para>

            <para>
                Tout comme les noms de fonction (cf la section 3.3 ci-dessus), les noms de
                variables doivent toujours commencer par un caractère en minuscule et suivre la
                convention de capitalisation de la "notationCamel".
            </para>

            <para>
                La clarté est conseillée. Les variables devraient toujours être aussi claires
                que pratiques. Des noms de variables comme "$i" et "$n" sont déconseillé pour tout
                autre usage que les petites boucles. Si une boucle contient plus de 20 lignes de
                code, les variables pour les indices doivent avoir des noms descriptifs.
            </para>
        </sect2>

        <sect2 id="coding-standard.naming-conventions.constants">
            <title>Constantes</title>

            <para>
                Les constantes peuvent contenir des caractères alphanumériques et des tirets
                bas. Les nombres sont autorisés.
            </para>

            <para>
                Les constantes doivent toujours être en majuscule, cependant les mots pouvant
                les composer doivent être séparés par des tiret-bats ("_").
            </para>

            <para>
                Par exemple, <code>EMBED_SUPPRESS_EMBED_EXCEPTION</code> est permis mais
                <code>EMBED_SUPPRESSEMBEDEXCEPTION</code> ne l'est pas.
            </para>

            <para>
                Les constantes doivent toujours être définies comme des membres d'une classe,
                en utilisant la construction "const". Définir des constantes globales avec "define"
                est permis mais déconseillé.
            </para>
        </sect2>
    </sect1>

    <sect1 id="coding-standard.coding-style">
        <title>Style de codage</title>

        <sect2 id="coding-standard.coding-style.php-code-demarcation">
            <title>Démarcation du code PHP</title>

            <para>
                Les codes PHP doivent toujours être délimités dans la forme complète, par les
                balises PHP standards : <programlisting language="php"><![CDATA[
<?php

?>
]]></programlisting>
            </para>

            <para>
                Les balises courtes d'ouvertures ("&lt;?")ne sont pas autorisées. Pour les
                fichiers ne contenant que du code PHP, la balise de fermeture doit toujours être
                omise (Voir <xref linkend="coding-standard.php-file-formatting.general" />).
            </para>
        </sect2>

        <sect2 id="coding-standard.coding-style.strings">
            <title>Chaînes de caractères</title>

            <sect3 id="coding-standard.coding-style.strings.literals">
                <title>Chaînes littérales</title>

                <para>
                    Lorsqu'une chaîne est littérale (c'est-à-dire qu'elle ne contient pas de
                    substitution de variables), l'apostrophe ou guillemet simple doit être utilisé
                    pour démarquer la chaîne : <programlisting language="php"><![CDATA[
$a = 'Exemple de chaîne de caractères';
]]></programlisting>
                </para>
            </sect3>

            <sect3 id="coding-standard.coding-style.strings.literals-containing-apostrophes">
                <title>Chaînes de caractères littérales avec apostrophes</title>

                <para>
                    Lorsque qu'une chaîne littérale contient des apostrophes, il est permis de
                    les démarquer en utilisant les guillemets doubles. Ceci est particulièrement
                    conseillé pour les requêtes SQL :
                    <programlisting language="php"><![CDATA[
$sql = "SELECT `id`, `name` from `people` "
     . "WHERE `name`='Eric' OR `name`='Caroline'";
]]></programlisting>
                    La syntaxe ci-dessus est préférée à l'échappement des apostrophes car elle
                    est plus facile à lire.
                </para>
            </sect3>

            <sect3 id="coding-standard.coding-style.strings.variable-substitution">
                <title>Substitution de variables</title>

                <para>
                    La substitution des variables est permise en utilisant une de ces deux
                    formes : <programlisting language="php"><![CDATA[
$greeting = "Bonjour $name, bienvenue !";

$greeting = "Bonjour {$name}, bienvenue !";
]]></programlisting>
                </para>

                <para>
                    Pour des raisons d'uniformité, cette forme n'est pas permise :
                    <programlisting language="php"><![CDATA[
$greeting = "Bonjour ${name}, bienvenue !";
]]></programlisting>
                </para>
            </sect3>

            <sect3 id="coding-standard.coding-style.strings.string-concatenation">
                <title>Concaténation de chaînes</title>

                <para>
                    Les chaînes peuvent êtres concaténées en utilisant l'opérateur ".". Un
                    espace doit toujours être ajouté avant, et après cet opérateur, cela permet
                    d'améliorer la lisibilité : <programlisting language="php"><![CDATA[
$company = 'Zend' . ' ' . 'Technologies';
]]></programlisting>
                </para>

                <para>
                    Lors de la concaténation de chaînes avec l'opérateur ".", il est permis de
                    couper le segment en plusieurs lignes pour améliorer la lisibilité. Dans ces
                    cas, chaque nouvelle ligne doit être remplie avec des espaces, de façon à
                    aligner le "." sous l'opérateur "=" : <programlisting language="php"><![CDATA[
$sql = "SELECT `id`, `name` FROM `people` "
     . "WHERE `name` = 'Caroline' "
     . "ORDER BY `name` ASC ";
]]></programlisting>
                </para>
            </sect3>
        </sect2>

        <sect2 id="coding-standard.coding-style.arrays">
            <title>Tableaux</title>

            <sect3 id="coding-standard.coding-style.arrays.numerically-indexed">
                <title>Tableaux indexés numériquement</title>

                <para>L'utilisation d'indices négatifs n'est pas permise.</para>

                <para>
                    Un tableau indexé peut commencer avec n'importe quel nombre positif,
                    cependant cette méthode est déconseillée. Il est conseillé de commencer
                    l'indexation à 0.
                </para>

                <para>
                    Lors de la déclaration de tableaux indexés avec la construction
                    <code>array</code>, un espace doit être ajouté après chaque virgule délimitante,
                    pour améliorer la lisibilité : <programlisting language="php"><![CDATA[
$sampleArray = array(1, 2, 3, 'Zend', 'Studio');
]]></programlisting>
                </para>

                <para>
                    Il est aussi permis de déclarer des tableaux indexés sur plusieurs lignes
                    en utilisant la construction <code>array</code>. Dans ce cas, chaque nouvelle
                    ligne doit être remplie par des espaces jusqu'à ce que cette ligne s'aligne,
                    comme il est montré dans l'exemple suivant :
                    <programlisting language="php"><![CDATA[
$sampleArray = array(1, 2, 3, 'Zend', 'Studio',
                     $a, $b, $c,
                     56.44, $d, 500);
]]></programlisting>
                </para>

                <para>
                    Alternately, the initial array item may begin on the following line. If so,
                    it should be padded at one indentation level greater than the line containing
                    the array declaration, and all successive lines should have the same
                    indentation; the closing paren should be on a line by itself at the same
                    indentation level as the line containing the array declaration:
                </para>

                <programlisting language="php"><![CDATA[
$sampleArray = array(
    1, 2, 3, 'Zend', 'Studio',
    $a, $b, $c,
    56.44, $d, 500,
);
]]></programlisting>

                <para>
                    When using this latter declaration, we encourage using a trailing comma for
                    the last item in the array; this minimizes the impact of adding new items on
                    successive lines, and helps to ensure no parse errors occur due to a missing
                    comma.
                </para>
            </sect3>

            <sect3 id="coding-standard.coding-style.arrays.associative">
                <title>Tableaux associatifs</title>

                <para>
                    Lorsque de la déclaration de tableaux associatifs avec la construction
                    <code>array</code>, il est conseillé de séparer la définition sur plusieurs
                    lignes. Dans ce cas, chaque ligne successive doit être remplie par des espaces
                    pour que les clés et les valeurs soient alignées : <programlisting
                    role="php"><![CDATA[
$sampleArray = array('firstKey'  => 'firstValue',
                     'secondKey' => 'secondValue');
]]></programlisting>
                </para>

                <para>
                    Alternately, the initial array item may begin on the following line. If so,
                    it should be padded at one indentation level greater than the line containing
                    the array declaration, and all successive lines should have the same
                    indentation; the closing paren should be on a line by itself at the same
                    indentation level as the line containing the array declaration. For
                    readability, the various "=>" assignment operators should be padded such that
                    they align.
                </para>

                <programlisting language="php"><![CDATA[
$sampleArray = array(
    'firstKey'  => 'firstValue',
    'secondKey' => 'secondValue',
);
]]></programlisting>

                <para>
                    When using this latter declaration, we encourage using a trailing comma for
                    the last item in the array; this minimizes the impact of adding new items on
                    successive lines, and helps to ensure no parse errors occur due to a missing
                    comma.
                </para>
            </sect3>
        </sect2>

        <sect2 id="coding-standard.coding-style.classes">
            <title>Classes</title>

            <sect3 id="coding-standard.coding-style.classes.declaration">
                <title>Déclaration de classes</title>

                <para>
                    Les classes doivent être nommées conformément aux conventions de nommage
                    de Zend Framework.
                </para>

                <para>
                    L'accolade est toujours écrite dans la ligne sous le nom de la
                    classe.
                </para>

                <para>
                    Toutes les classes doivent avoir un bloc de documentation conforme aux
                    standards PHPDocumentor.
                </para>

                <para>Tout code d'une classe doit être indenté avec 4 espaces.</para>

                <para>Une seule classe est permise par fichier PHP.</para>

                <para>
                    Le placement de code additionnel dans un fichier de classe est permis,
                    mais déconseillé. Dans ces fichiers, deux lignes vides doivent séparer la classe
                    du code PHP additionnel.
                </para>

                <para>
                    Voici un exemple d'une déclaration de classe autorisée : <programlisting
                    role="php"><![CDATA[
/**
 * Bloc de documentation
 */
class SampleClass
{
    // contenu de la classe
    // qui doit être indenté avec 4 espaces
}
]]></programlisting>
                </para>

                <para>
                    Classes that extend other classes or which implement interfaces should
                    declare their dependencies on the same line when possible.
                </para>

                <programlisting language="php"><![CDATA[
class SampleClass extends FooAbstract implements BarInterface
{
}
]]></programlisting>

                <para>
                    If as a result of such declarations, the line length exceeds the <link
                        linkend="coding-standard.php-file-formatting.max-line-length">maximum line
                        length</link>, break the line before the "extends" and/or "implements"
                    keywords, and pad those lines by one indentation level.
                </para>

                <programlisting language="php"><![CDATA[
class SampleClass
    extends FooAbstract
    implements BarInterface
{
}
]]></programlisting>

                <para>
                    If the class implements multiple interfaces and the declaration exceeds the
                    maximum line length, break after each comma separating the interfaces, and
                    indent the interface names such that they align.
                </para>

                <programlisting language="php"><![CDATA[
class SampleClass
    implements BarInterface,
               BazInterface
{
}
]]></programlisting>
            </sect3>

            <sect3 id="coding-standard.coding-style.classes.member-variables">
                <title>Variables membres de la classe</title>

                <para>
                    Les variables membres doivent être nommées en respectant les conventions
                    de nommage de Zend Framework.
                </para>

                <para>
                    Toute variable déclarée dans une classe doit être listée en haut de cette
                    classe, avant toute déclaration de méthode.
                </para>

                <para>
                    La construction <code>var</code> n'est pas permise. Les variables membres
                    déclarent toujours leur visibilité en utilisant la construction
                    <code>private</code>, <code>protected</code>, ou <code>public</code>. L'accès
                    direct à ces variables membres en les rendant publiques est permis mais
                    déconseillé. Il est préférable d'utiliser des accesseurs (set/get).
                </para>
            </sect3>
        </sect2>

        <sect2 id="coding-standard.coding-style.functions-and-methods">
            <title>Fonctions et méthodes</title>

            <sect3 id="coding-standard.coding-style.functions-and-methods.declaration">
                <title>Déclaration de fonctions et de méthodes</title>

                <para>
                    Les fonctions doivent être nommées en respectant les conventions de
                    nommage de Zend Framework.
                </para>

                <para>
                    Les fonctions internes aux classes doivent toujours déclarer leur
                    visibilité en utilisant la construction <code>private</code>,
                    <code>protected</code>, ou <code>public</code>.
                </para>

                <para>
                    Tout comme les classes, l'accolade ouvrante est toujours écrite sous le
                    nom de la fonction. Il n'y a pas d'espace entre le nom de la fonction et les
                    parenthèses des arguments. Il n'y a pas d'espace entre la parenthèse fermante et
                    l'accolade.
                </para>

                <para>Les fonctions globales sont fortement déconseillées.</para>

                <para>
                    Voici un exemple d'une déclaration permise d'une fonction de classe :
                    <programlisting language="php"><![CDATA[
/*
 * Bloc de documentation
 */
class Foo
{
    /**
     * Bloc de documentation
     */
    public function bar()
    {
        // contenu de la fonction
        // qui doit être indenté avec 4 espaces
    }
}
]]></programlisting>
                </para>

                <para>
                    In cases where the argument list exceeds the <link
                        linkend="coding-standard.php-file-formatting.max-line-length">maximum line
                        length</link>, you may introduce line breaks. Additional arguments to the
                    function or method must be indented one additional level beyond the function
                    or method declaration.  A line break should then occur before the closing
                    argument paren, which should then be placed on the same line as the opening
                    brace of the function or method with one space separating the two, and at the
                    same indentation level as the function or method declaration. The following is
                    an example of one such situation:

                    <programlisting language="php"><![CDATA[
/**
 * Documentation Block Here
 */
class Foo
{
    /**
     * Documentation Block Here
     */
    public function bar($arg1, $arg2, $arg3,
        $arg4, $arg5, $arg6
    ) {
        // all contents of function
        // must be indented four spaces
    }
}
]]></programlisting>
                </para>

                <para>
                    Le passage par référence est permis uniquement
                    dans la déclaration de la fonction : <programlisting language="php"><![CDATA[
/**
 * Bloc de documentation
 */
class Foo
{
    /**
     * Bloc de documentation
     */
    public function bar(&$baz)
    {}
}
]]></programlisting>
                </para>

                <para>L'appel par référence est interdit.</para>

                <para>
                    La valeur de retour ne doit pas être entourée de parenthèses. Ceci peut
                    gêner à la lecture et peut aussi casser le code si une méthode est modifiée plus
                    tard pour retourner par référence. <programlisting language="php"><![CDATA[
/**
 * Bloc de documentation
 */
class Foo
{
    /**
     * INCORRECT
     */
    public function bar()
    {
        return($this->bar);
    }

    /**
     * CORRECT
     */
    public function bar()
    {
        return $this->bar;
    }
}
]]></programlisting>
                </para>
            </sect3>

            <sect3 id="coding-standard.coding-style.functions-and-methods.usage">
                <title>Usage de fonctions et méthodes</title>

                <para>
                    Les arguments d'une fonction sont séparés par un espace après la virgule
                    de délimitation. Voici un exemple d'un appel de fonction qui prend trois
                    arguments : <programlisting language="php"><![CDATA[
threeArguments(1, 2, 3);
]]></programlisting>
                </para>

                <para>
                    L'appel par référence est interdit. Référez vous à la section sur la
                    déclaration de fonctions pour la méthode correcte de passage des argument par
                    référence.
                </para>

                <para>
                    Pour les fonctions dont les arguments peuvent être des tableaux, l'appel à
                    la fonction doit inclure la construction "array" et peut être divisé en
                    plusieurs ligne pour améliorer la lecture. Dans ces cas, les standards
                    d'écriture de tableaux s'appliquent aussi : <programlisting language="php"><![CDATA[
threeArguments(array(1, 2, 3), 2, 3);

threeArguments(array(1, 2, 3, 'Zend', 'Studio',
                     $a, $b, $c,
                     56.44, $d, 500), 2, 3);

threeArguments(array(
    1, 2, 3, 'Zend', 'Studio',
    $a, $b, $c,
    56.44, $d, 500
), 2, 3);
]]></programlisting>
                </para>
            </sect3>
        </sect2>

        <sect2 id="coding-standard.coding-style.control-statements">
            <title>Structure de contrôle</title>

            <sect3 id="coding-standard.coding-style.control-statements.if-else-elseif">
                <title>If / Else / Elseif</title>

                <para>
                    Les structure de contrôles basées sur les constructions <code>if</code> et
                    <code>elseif</code> doivent avoir un seul espace avant la parenthèse ouvrante de
                    la condition, et un seul espace après la parenthèse fermante.
                </para>

                <para>
                    Pour la condition entre les parenthèses, les opérateurs doivent être
                    séparés par des espaces pour une meilleure lisibilité. Les parenthèses internes
                    sont conseillées pour améliorer le regroupement logique de longues
                    conditions.
                </para>

                <para>
                    L'accolade ouvrante est écrite sur la même ligne que la condition.
                    L'accolade fermante est toujours écrite sur sa propre ligne. Tout contenu
                    présent à l'intérieur des accolades doit être indenté par 4 espaces.
                    <programlisting language="php"><![CDATA[
if ($a != 2) {
    $a = 2;
}
]]></programlisting>
                </para>

                <para>
                    If the conditional statement causes the line length to exceed the <link
                        linkend="coding-standard.php-file-formatting.max-line-length">maximum line
                        length</link> and has several clauses, you may break the conditional into
                    multiple lines. In such a case, break the line prior to a logic operator, and
                    pad the line such that it aligns under the first character of the conditional
                    clause. The closing paren in the conditional will then be placed on a line with
                    the opening brace, with one space separating the two, at an indentation level
                    equivalent to the opening control statement.
                </para>

                <programlisting language="php"><![CDATA[
if (($a == $b)
    && ($b == $c)
    || (Foo::CONST == $d)
) {
    $a = $d;
}
]]></programlisting>

                <para>
                    The intention of this latter declaration format is to prevent issues when
                    adding or removing clauses from the conditional during later revisions.
                </para>

                <para>
                    Pour les instruction "if" qui incluent "elseif" ou "else", les conventions
                    de formatage sont similaires à celles de la construction "if". Les exemples
                    suivants montrent le formatage approprié pour les structures "if" avec "else"
                    et/ou les constructions "elseif" : <programlisting language="php"><![CDATA[
if ($a != 2) {
    $a = 2;
} else {
    $a = 7;
}

if ($a != 2) {
    $a = 2;
} elseif ($a == 3) {
    $a = 4;
} else {
    $a = 7;
}

if (($a == $b)
    && ($b == $c)
    || (Foo::CONST == $d)
) {
    $a = $d;
} elseif (($a != $b)
          || ($b != $c)
) {
    $a = $c;
} else {
    $a = $b;
}
]]></programlisting>
                    PHP permet que ces instructions soient écrites sans accolades dans
                    certaines circonstances. La convention de codage ne fait pas de différentiation
                    et toutes les instructions "if", "elseif" et "else" doivent utiliser des
                    accolades.
                </para>
            </sect3>

            <sect3 id="coding-standards.coding-style.control-statements.switch">
                <title>Switch</title>

                <para>
                    Les instructions de contrôle avec "switch" ne doivent avoir qu'un seul
                    espace avant la parenthèse ouvrante de l'instruction conditionnelle, et aussi un
                    seul espace après la parenthèse fermante.
                </para>

                <para>
                    Tout le contenu à l'intérieur de l'instruction "switch" doit être indenté
                    avec 4 espaces. Le contenu sous chaque "case" doit être indenté avec encore 4
                    espaces supplémentaires.
                </para>

                <programlisting language="php"><![CDATA[
switch ($numPeople) {
    case 1:
        break;

    case 2:
        break;

    default:
        break;
}
]]></programlisting>

                <para>
                    La construction <code>default</code> ne doit jamais être oubliée dans une
                    instruction <code>switch</code>.
                </para>

                <para>
                    <emphasis>NOTE :</emphasis> Il est parfois pratique d'écrire une clause
                    <code>case</code> qui passe à travers le <code>case</code> suivant en omettant
                    l'inclusion de <code>break</code> ou <code>return</code>. Pour distinguer ce cas
                    d'un bug, toute clause <code>case</code> ne contenant pas <code>break</code> ou
                    <code>return</code> doit contenir le commentaire "// break intentionally
                    omitted".
                </para>
            </sect3>
        </sect2>

        <sect2 id="coding-standards.inline-documentation">
            <title>Documentation intégrée</title>

            <sect3 id="coding-standards.inline-documentation.documentation-format">
                <title>Format de la documentation</title>

                <para>
                    Tous les blocs de documentation ("docblocks") doivent être compatible avec
                    le format phpDocumentor. La description du format phpDocumentor n'est pas du
                    ressort de ce document. Pour plus d'information, visitez <ulink
                    url="http://phpdoc.org/">http://phpdoc.org/</ulink>
                </para>

                <para>
                    Tous les fichiers de code source écrits pour Zend Framework ou qui opèrent
                    avec ce framework doivent contenir un docblock du fichier, en haut de chaque
                    fichier, et un docblock de classe immédiatement au dessus de chaque classe.
                    Ci-dessous vous trouverez des exemples de tels docblocs.
                </para>
            </sect3>

            <sect3 id="coding-standards.inline-documentation.files">
                <title>Fichiers</title>

                <para>
                    Chaque fichier qui contient du code PHP doit avoir un bloc d'entête en
                    haut du fichier qui contient au minimum ces balises phpDocumentor :
                    <programlisting language="php"><![CDATA[
/**
 * Description courte du fichier
 *
 * Description longue du fichier s'il y en a une
 *
 * LICENSE: Informations sur la licence
 *
 * @copyright  Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license   BSD License
 * @version    $Id:$
 * @link       http://framework.zend.com/package/PackageName
 * @since      File available since Release 1.5.0
*/
]]></programlisting>
                </para>
            </sect3>

            <sect3 id="coding-standards.inline-documentation.classes">
                <title>Classes</title>

                <para>
                    Chaque classe doit avoir un docblock qui contient au minimum ces balises
                    phpDocumentor : <programlisting language="php"><![CDATA[
/**
 * Description courte de la classe
 *
 * Description longue de la classe, s'il y en a une
 *
 * @copyright  Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license   BSD License
 * @version    Release: @package_version@
 * @link       http://framework.zend.com/package/PackageName
 * @since      Class available since Release 1.5.0
 * @deprecated Class deprecated in Release 2.0.0
 */
]]></programlisting>
                </para>
            </sect3>

            <sect3 id="coding-standards.inline-documentation.functions">
                <title>Fonctions</title>

                <para>
                    Chaque fonction, méthode, doit avoir un docblock contenant au minimum :
                    <itemizedlist>
                        <listitem>
                            <para>Une description de la fonction</para>
                        </listitem>

                        <listitem>
                            <para>Tous les arguments</para>
                        </listitem>

                        <listitem>
                            <para>Toutes les valeurs de retour possibles</para>
                        </listitem>
                    </itemizedlist>
                </para>

                <para>
                    Il n'est pas nécessaire d'utiliser la balise "@access" parce que le niveau
                    d'accès est déjà connu avec les constructions "public", "private", "protected"
                    utilisée pour déclarer la fonction.
                </para>

                <para>
                    Si une fonction/méthode peut lancer une exception, utilisez "@throws" :
                    <programlisting language="php"><![CDATA[
@throws exceptionclass [description]
]]></programlisting>
                </para>
            </sect3>
        </sect2>
    </sect1>
</appendix>