<?xml version="1.0"?>
<!DOCTYPE texinfo PUBLIC "-//GNU//DTD TexinfoML V6.4dev//EN" "http://www.gnu.org/software/texinfo/dtd/6.4dev/texinfo.dtd">
<texinfo xml:lang="fr">
<filename file="latex2e-fr.xml"></filename>
<preamble>\input texinfo
</preamble><!-- c $Id: latex2e-fr.texi 1132 2022-08-29 15:31:29Z vincentb1 $ -->
<!-- comment % ** dÃ©but de tÃªte (c'est pour courir Texinfo sur une rÃ©gion.) -->
<setfilename file="latex2e-fr.info" spaces=" ">latex2e-fr.info</setfilename>
<documentlanguage xml:lang="fr" spaces=" ">fr</documentlanguage>
<documentencoding encoding="UTF-8" spaces=" ">UTF-8</documentencoding>
<set name="UPDATED" line=" UPDATED Août 2022">Août 2022</set>
<!-- c $Id: common.texi 1089 2022-08-12 20:30:20Z vincentb1 $ -->
<!-- c Public domain. -->
<set name="LTXREFMAN_HOME_PAGE" line=" LTXREFMAN_HOME_PAGE https://latexref.xyz">https://latexref.xyz</set>
<set name="LTXREFMAN_BUGS" line=" LTXREFMAN_BUGS latexrefman@@tug.org">latexrefman@@tug.org</set>
<clear name="HAS-MATH" line=" HAS-MATH "></clear>
<macro name="iftexthenelse" line=" iftexthenelse {then,else}"><formalarg>then</formalarg><formalarg>else</formalarg>\else\@c
</macro>
<macro name="package" line=" package {packagename}"><formalarg>packagename</formalarg>@code{\packagename\}
</macro>
<!-- c used to remove something form the spell checker -->
<macro name="identity" line=" identity {x}"><formalarg>x</formalarg>\x\
</macro>

<tex endspaces=" ">
</tex>
<settitle spaces=" ">Manuel de référence officieux de &latex;2e (Août 2022)</settitle>
<!-- comment % ** fin de tête (c'est pour courir Texinfo sur une région.) -->

<!-- c latex 2.09 commandes devraient tous être présents maintenant, -->
<!-- c xx À faire: -->
<!-- c    - -shell-escape & -file-line-no pris en charge par MiKTeX -->
<!-- c    - exemple pdflatex -interaction=nonstopmode -file-line-error '\documentclass{minimal}\begin{document}\errmessage{Foirage}Salut\end{document}' -->
<!-- c      => le jobname est minimal, créer un nœud sur jobname -->
<!-- c      => style de message d'erreur traditionnel, car on n'est pas dans un fichier -->
<!-- c      => ajouter un nœud sur \errmessage -->
<!-- c -->
<!-- c    - définir « mode mzth rn lignr» -->
<!-- c -->
<!-- c xx mais LaTeX2e substance est manquant. -->
<!-- c xx une liste aléatoire de quelques items manquant est à la fin de ce fichier -->
<!-- c xx Lire le fichier NEWS pour les choses à mettre à jour. -->
<!-- c -->
<!-- c xx ending a run with errors -->
<!-- c xx ctan, distributions, composant de TeX -->
<!-- c xx mention \nocorr, \textit et ic -->
<!-- c xx donner réelle smallskip / etc. par défaut -->
<!-- c -->
<!-- c xx fusionner http://ctan.org/pkg/latex-info (paquetage CTAN latex-info) -->
<!-- c xx voir aussi http://ctan.org/tex-archive/info/latexcheat -->
<!-- c xx fusionner permutée-index -->
<!-- c xx fusionner latex manuel de la savane -->
<!-- c xx fusionner style mathématique hors texte -->
<!-- c xx mode veritical, mode horizontal -->
<!-- c xx check recent ltnews for (lots of) changes -->
<!-- c xx \write of non-ASCII chars (vincent mail of 14 Mar 2020 21:39:41) -->
<!-- c xx \nonstopmode etc., if they are officially supported by LaTeX? -->
<!-- c xx JH explain nfss somewhere -->
<!-- c xx JH expand BiBTeX -->
<!-- c xx JH expand theorem, AMS math -->
<!-- c xx JH something on code listings -->
<!-- c xx JH ligatures -->
<!-- c xx JH \stretch -->
<!-- c xx JH \mathstrut -->
<!-- c xx JH \phantom https://tex.stackexchange.com/questions/4519/how-do-i-create-an-invisible-character -->
<!-- c xx JH \baselineskip https://texfaq.org/FAQ-baselinepar -->
<!-- c xx JH \contentsline, \@@dottedtocline? -->
<!-- c xx JH \numexpr, \dimexpr, \glueexpr, \muexpr -->
<!-- c -->
<!-- c xx The typeset source2e has an index with all kernel -->
<!-- c xx commands, though some are internal and shouldn't be included. -->
<!-- c xx classes.dtx et al. define additional commands. -->
<!-- c xx See also http://ctan.org/pkg/macros2e. -->
<!-- c -->
<!-- c xx All the special characters should be definitively described. -->
<!-- c -->
<!-- c xx Notes de P. Bideault -->
<!-- c -->
<!-- c xx Le sommaire précède immédiatement la table des matières. C'est curieux, -->
<!-- c xx C'est curieux, et perturbant. -->
<!-- c xx Cette table des matières ne serait-elle mieux située en fin de document ? -->
<!-- c -->
<!-- c -->
<!-- c -->
<!-- c xx Le source2e typographie a un index avec tous noyau -->
<!-- c commandes xx, même si certains sont internes et ne devraient pas être inclus. -->
<!-- c -->
<!-- c xx much more from ltoutenc, depends on font? -->
<!-- c xx packages - required, additional, useful; oberdiek ... -->
<!-- c xx fonts - latexsys -->
<!-- c -->
<!-- c xx classes.dtx et al. définir des commandes supplémentaires. -->
<!-- c xx Voir aussi http://ctan.org/pkg/macros2e. -->
<!-- c xx Tous les caractères spéciaux devraient une fois pour toute être dérits -->
<!-- c -->
<!-- c xx packages & classes - requis, plus, utiles; Oberdiek; polices -->
<!-- c xx TODO: bogue texinfo, \AtBeginDocument ne va pas dans le .aux -->

<!-- c ressources pour les termes typographiques en français: -->
<!-- c    http://david.carella.free.fr/fr/typographie/glossaire-typographique.html -->
<!-- c    http://tex.loria.fr/typographie/normes.pdf -->
<!-- c    http://cahiers.gutenberg.eu.org/cg-bin/article/CG_2007___49_19_0.pdf -->
<!-- c Ainsi que http://gdt.oqlf.gouv.qc.ca/ -->
<!-- c -->
<!-- c Autres ressources: -->
<!-- c http://mirror.ctan.org/info/lshort/french/lshort-fr.pdf -->
<!-- c http://www.babafou.eu.org/Apprends_LaTeX/ -->
<!-- c http://lozzone.free.fr/latex/guide-local.pdf (Tout ce que vous avez toujours voulu savoir sur LaTeX) -->
<!-- c http://mirror.ctan.org/info/impatient/fr/fbook.pdf (TeX pour l'impatient) -->
<!-- c http://mirrors.ctan.org/info/bibtex/tamethebeast/ttb_en.pdf -Tame The Beast) -->
<!-- c https://faq.gutenberg.eu.org -->

<set name="ITEM_BULLET1" line=" ITEM_BULLET1 --">--</set>
<set name="ITEM_BULLET2" line=" ITEM_BULLET2 --">--</set>
<copying endspaces=" ">
<para>Ce document est un manuel de référence officieux pour &latex;, un
système de préparation de documents, version « Août 2022 ».
</para>
<para>Ce manuel a été traduit du fichier <file>LATEX.HLP</file> v1.0a de la
bibliothèque d&textrsquo;aide VMS. La version prétraduction a été rédigée par
George D. Greenwade de l&textrsquo;université d&textrsquo;état Sam Houston, au Texas (USA). La version
&latex; 2.09 a été rédigée par Stephen Gilmore. La version &latex;2e a
été adaptée à partir de celle-ci par Torsten Martinsen. Karl Berry a
fait d&textrsquo;autres mises à jour et ajouts, et reconnaît avec gratitude avoir
utilisé comme matière de référence <cite>Hypertext Help with &latex;</cite>,
de Sheldon Green, et <cite>&latex; Command Summary</cite> (pour &latex;2.09)
de L. Botway et C. Biemesderfer (publié par le &tex;
Users Group en
tant que <cite>&tex;niques</cite> numéro 10). Nous savons également gré à
Martin Herbert Dietze d&textrsquo;avoir de plus utilisé de la matière apparaissant
dans son latex2e-reference. (À partir de ces références aucun
texte n&textrsquo;a été copié directement).
</para>
<para>Tous droits réservés &copyright; 2015-2022 Vincent Belaïche &textmdash; traduction.&linebreak;
Tous droits réservés &copyright; 2007-2022 Karl Berry. &linebreak;
Tous droits réservés &copyright; 1988, 1994, 2007 Stephen Gilmore. &linebreak;
Tous droits réservés &copyright; 1994, 1995, 1996 Torsten Martinsen.
</para>
<para>Ci-après se trouve la licence sous laquelle est distribuée ce manuel ;
une traduction en est donnée en annexe, voir <ref label="License-translation"><xrefnodename>License translation</xrefnodename></ref>.
</para>
<!-- comment start of License -->
<para>Permission is granted to make and distribute verbatim copies of
this manual provided the copyright notice and this permission notice
are preserved on all copies.
</para>
<ignore>
Permission is granted to process this file through TeX and print the
results, provided the printed document carries copying permission
notice identical to this one except for the removal of this paragraph
(this paragraph not being relevant to the printed manual).
</ignore>

<para>Permission is granted to copy and distribute modified versions of this
manual under the conditions for verbatim copying, provided that the entire
resulting derived work is distributed under the terms of a permission
notice identical to this one.
</para>
<para>Permission is granted to copy and distribute translations of this manual
into another language, under the above conditions for modified versions.
<!-- comment end of License -->
</para></copying>

<dircategory spaces=" ">TeX</dircategory>
<direntry endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">LaTeX2e-fr</menutitle><menunode separator=". ">(latex2e-fr)</menunode><menudescription><pre xml:space="preserve">Manuel de référence officieux de LaTeX.
</pre></menudescription></menuentry></direntry>

<tex endspaces=" ">
</tex>

<html endspaces=" ">
</html>

<titlepage endspaces=" ">
<title spaces=" ">&latex;2e: Un manuel de référence officieux</title>
<subtitle spaces=" ">Août 2022</subtitle>
<author spaces=" "><url><urefurl>https://latexref.xyz/fr</urefurl></url></author>
<page></page>
<vskip> 0pt plus 1filll</vskip>
<insertcopying></insertcopying>
</titlepage>

<shortcontents></shortcontents>
<contents></contents>

<!-- c Best Effort Symbol -->
<macro name="visiblespace" line=" visiblespace">␣
</macro>
<macro name="BES" line=" BES {utf8,math}"><formalarg>utf8</formalarg><formalarg>math</formalarg>\utf8\
</macro>
<macro name="BESU" line=" BESU {utf8,math}"><formalarg>utf8</formalarg><formalarg>math</formalarg>\utf8\
</macro>
<macro name="EnvIndex" line=" EnvIndex {env}"><formalarg>env</formalarg>@findex @r{environnement} @code{\env\}
@findex @code{\env\}, @r{environnement}

</macro>
<macro name="PkgIndex" line=" PkgIndex {pkg}"><formalarg>pkg</formalarg>@findex @r{paquetage} @code{\pkg\}
@findex @code{\pkg\}, @r{paquetage}

</macro>
<macro name="Num" line=" Num {x}"><formalarg>x</formalarg>№ \x\
</macro>
<set name="PlainTeX" line=" PlainTeX @TeX{} de base">@TeX{} de base</set>
<set name="TeXLive" line=" TeXLive  @TeX{} Live">@TeX{} Live</set>
<set name="MiKTeX" line=" MiKTeX MiK@TeX{}">MiK@TeX{}</set>
<set name="MSWindows" line=" MSWindows Windows">Windows</set>
<set name="AppleMacintosh" line=" AppleMacintosh Macintosh">Macintosh</set>
<set name="GNULinux" line=" GNULinux  GNU/Linux">GNU/Linux</set>
<set name="NotInPlainTeX" line=" NotInPlainTeX Ceci n'est pas disponible en @value{PlainTeX}.">Ceci n'est pas disponible en @value{PlainTeX}.</set>
<set name="NeedsAMSSymb" line=" NeedsAMSSymb @value{NotInPlainTeX} En @LaTeX{} vous devez charger le paquetage @file{amssymb}.">@value{NotInPlainTeX} En @LaTeX{} vous devez charger le paquetage @file{amssymb}.</set>
<set name="NeedsSTIX" line=" NeedsSTIX @value{NotInPlainTeX} En @LaTeX{} vous devez charger le paquetage @file{stix}.">@value{NotInPlainTeX} En @LaTeX{} vous devez charger le paquetage @file{stix}.</set>

<node name="Top" spaces=" "><nodename>Top</nodename><nodenext automatic="on">About this document</nodenext><nodeup automatic="on">(dir)</nodeup></node>
<top spaces=" "><sectiontitle>&latex;2e : un manuel de référence officieux</sectiontitle>

<para>Ce document est un manuel de référence officieux pour &latex;2e, un
système de préparation de document, dans sa version « Août 2022 ».
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">À propos de ce document</menutitle><menunode separator=". ">About this document</menunode><menudescription><pre xml:space="preserve">reporter les bogues, etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Aperçu</menutitle><menunode separator=". ">Overview</menunode><menudescription><pre xml:space="preserve">Qu&textrsquo;est-ce que &latex;?.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Classe de documents</menutitle><menunode separator=". ">Document classes</menunode><menudescription><pre xml:space="preserve">Certaines des différentes classes disponibles.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Polices</menutitle><menunode separator=". ">Fonts</menunode><menudescription><pre xml:space="preserve">italique, gras, tapuscrit, etc
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Mise en page</menutitle><menunode separator=". ">Layout</menunode><menudescription><pre xml:space="preserve">Contrôle de la mise en page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Rubricage</menutitle><menunode separator=". ">Sectioning</menunode><menudescription><pre xml:space="preserve">Comment bien faire des rubriques.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Les renvois</menutitle><menunode separator=". ">Cross references</menunode><menudescription><pre xml:space="preserve">Renvoi automatique.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Environnements</menutitle><menunode separator=". ">Environments</menunode><menudescription><pre xml:space="preserve">tels que <code>enumerate</code> et <code>itemize</code>.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Sauts de ligne</menutitle><menunode separator=". ">Line breaking</menunode><menudescription><pre xml:space="preserve">Influencer les sauts de ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Sauts de page</menutitle><menunode separator=". ">Page breaking</menunode><menudescription><pre xml:space="preserve">Influencer les sauts de page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Notes en bas de page</menutitle><menunode separator=". ">Footnotes</menunode><menudescription><pre xml:space="preserve">Comment produire des notes en bas de page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Définitions</menutitle><menunode separator=". ">Definitions</menunode><menudescription><pre xml:space="preserve">Définir vos propres commandes, etc
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Compteurs</menutitle><menunode separator=". ">Counters</menunode><menudescription><pre xml:space="preserve">Compteurs internes utilisés par &latex;.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Longueurs</menutitle><menunode separator=". ">Lengths</menunode><menudescription><pre xml:space="preserve">Les commandes pour manipuler des longueurs.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Faire des paragraphes</menutitle><menunode separator=". ">Making paragraphs</menunode><menudescription><pre xml:space="preserve">Commandes pour contrôler les paragraphes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Formules de maths</menutitle><menunode separator=". ">Math formulas</menunode><menudescription><pre xml:space="preserve">Comment créer des formules mathématiques.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Modes</menutitle><menunode separator=". ">Modes</menunode><menudescription><pre xml:space="preserve">Modes paragraphe, mathématiques ou LR.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Les styles de page</menutitle><menunode separator=". ">Page styles</menunode><menudescription><pre xml:space="preserve">Différents styles de mise en page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Les espaces</menutitle><menunode separator=". ">Spaces</menunode><menudescription><pre xml:space="preserve">Espace horizontal et vertical.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Boîtes</menutitle><menunode separator=". ">Boxes</menunode><menudescription><pre xml:space="preserve">Faire des boîtes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Couleur</menutitle><menunode separator=". ">Color</menunode><menudescription><pre xml:space="preserve">Définir et utiliser des couleurs.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Graphiques</menutitle><menunode separator=". ">Graphics</menunode><menudescription><pre xml:space="preserve">Importer des graphiques de l&textrsquo;extérieur de &latex;.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Insertions spéciales</menutitle><menunode separator=". ">Special insertions</menunode><menudescription><pre xml:space="preserve">Insertion de caractères réservés et spéciaux.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Diviser l&textrsquo;entrée</menutitle><menunode separator=". ">Splitting the input</menunode><menudescription><pre xml:space="preserve">Traiter de gros fichiers en les partitionnant.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Parties pré/postliminaires</menutitle><menunode separator=". ">Front/back matter</menunode><menudescription><pre xml:space="preserve">Table des matières, glossaires, index.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Lettres</menutitle><menunode separator=". ">Letters</menunode><menudescription><pre xml:space="preserve">La classe <code>letter</code>.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Entrée / sortie du terminal</menutitle><menunode separator=". ">Terminal input/output</menunode><menudescription><pre xml:space="preserve">Interaction avec l&textrsquo;utilisateur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">La ligne de commande</menutitle><menunode separator=". ">Command line interface</menunode><menudescription><pre xml:space="preserve">Comportement indépendant du système de la ligne de commande.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Patrons de document</menutitle><menunode separator=". ">Document templates</menunode><menudescription><pre xml:space="preserve">Patron pour commencer diverses classes de documents.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Traduction de la licence</menutitle><menunode separator=". ">License translation</menunode><menudescription><pre xml:space="preserve">Une traduction à titre informatif de la licence.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Index des Concepts</menutitle><menunode separator=". ">Concept Index</menunode><menudescription><pre xml:space="preserve">Index général.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Index des commandes</menutitle><menunode separator=". ">Command Index</menunode><menudescription><pre xml:space="preserve">Liste alphabétique des  commandes &latex;.
</pre></menudescription></menuentry></menu>


</top>
<node name="About-this-document" spaces=" "><nodename>About this document</nodename><nodenext automatic="on">Overview</nodenext><nodeprev automatic="on">Top</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>À propos de ce document</sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1"><url><urefurl>https://latexref.xyz</urefurl></url> <r>page d&textrsquo;accueil</r></indexterm></findex>
<para>Ceci est un manuel de référence officieux pour le système &latex;2e de
préparation de document. Ce système est mis en œuvre sous forme d&textrsquo;un
paquet de macros pour le programme de composition &tex;
(<pxref label="Overview"><xrefnodename>Overview</xrefnodename></pxref>). La page d&textrsquo;accueil de ce document est
<url><urefurl>https://latexref.xyz</urefurl></url>. Cette page contient des liens vers
différentes versions de ce document, dans différents
formats et langues, mais aussi vers ses sources, vers les archives des listes de diffusion qui lui sont consacrées ainsi que vers d&textrsquo;autres
infrastructures.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1">&latex; ou &latex;2e, que choisir ?</indexterm></cindex>
<para>Dans ce document, on utilise principalement juste le terme « &latex; »
plutôt que « &latex;2e », étant donné que la version précédente de
&latex; (2.09) est gelée depuis des dizaines d&textrsquo;années.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="2">officieuse, nature de ce document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="3">L&textrsquo;équipe de projet &latex;</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="2"><email><emailaddress>latexrefman&arobase;tug.org</emailaddress></email> <r>adresse mél.</r></indexterm></findex>
<para>&latex; est désormais maintenu par un groupe de bénévoles
(<url><urefurl>http://latex-project.org</urefurl></url>).  La documentation officielle écrite
par le projet &latex; est disponible à partir de leur site web.
Le présent document est complètement officieux et n&textrsquo;a pas été examiné
par les mainteneurs de &latex;.
<cindex index="cp" spaces=" "><indexterm index="cp" number="4">rapports d&textrsquo;anomalies</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="5">rapports de bogues</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="6">bogues, rapports</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="7">anomalies, rapports</indexterm></cindex>
Ne leur envoyez donc pas de rapports d&textrsquo;anomalie ou quoi que ce soit
d&textrsquo;autre.
</para>
<para>En revanche, n&textrsquo;hésitez pas à adresser vos commentaires à
<email><emailaddress>latexrefman&arobase;tug.org</emailaddress></email>.
</para>
<para>Ce document est un manuel de référence. Il y a d&textrsquo;autres sources d&textrsquo;information sur
&latex; : elles sont très nombreuses, et s&textrsquo;adressent à des utilisateurs de tous niveaux.
Voici quelques introductions :
</para>
<!-- c voir http://mirror.ctan.org/help/ctan/CTAN-upload-addendum.html#urls -->
<table commandarg="url" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="url">http://ctan.org/pkg/latex-doc-ptr</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="3">latex-doc-ptr <r>document</r></indexterm></findex>
<para>Deux pages de références recommandées à &latex; documentation.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="url">http://ctan.org/pkg/first-latex-doc</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="4">first-latex-doc <r>document</r></indexterm></findex>
<para>Rédaction de votre premier document, avec un peu de texte et de mathématiques.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="url">http://ctan.org/pkg/usrguide</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="5">usrguide <r>documentation officielle</r></indexterm></findex>
<para>Le guide pour les auteurs de documents maintenu par le projet
&latex;. Bien d&textrsquo;autres guides écrits par bien d&textrsquo;autres gens sont aussi
disponibles, indépendamment du projet &latex; ; l&textrsquo;article suivant en
est un.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="url">http://ctan.org/pkg/lshort</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="6">lshort <r>document</r></indexterm></findex>
<para>Une courte (?) introduction à &latex;, traduite en de nombreuses langues
(traduction française : <url><urefurl>http://ctan.org/pkg/lshort-french</urefurl></url>).
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="url">http://tug.org/begin.html</itemformat></item>
</tableterm><tableitem><para>Introduction au  système &tex;, y compris &latex;, et plus amples références.
</para></tableitem></tableentry></table>


</chapter>
<node name="Overview" spaces=" "><nodename>Overview</nodename><nodenext automatic="on">Document classes</nodenext><nodeprev automatic="on">About this document</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Vue d&textrsquo;ensemble de &latex;</sectiontitle>

<para>Qu&textrsquo;est-ce que &latex;?
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="8">aperçu de &latex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="9">bases de &latex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="10">Knuth, Donald E.</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="11">Lamport, Leslie</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="12">&latex; aperçu</indexterm></cindex>
<para>&latex; est un système de composition de documents. Il fut à l&textrsquo;origine
créé par Leslie Lamport ; il est désormais maintenu par un groupe de
volontaires (<url><urefurl>http://latex-project.org</urefurl></url>).  Il est largement utilisé,
en particulier pour les documents complexes et techniques, tels que ceux
impliquant des mathématiques.
</para>
<!-- c - Au début, ajout de « à l'aide d'un simple éditeur de texte ». -->
<!-- c - Emploi d'italiques pour les notions principales. -->
<!-- c - À la fin, ajout de « qui contient son texte mis en page ». -->
<cindex index="cp" spaces=" "><indexterm index="cp" number="13">paquet de macro, &latex; en tant que</indexterm></cindex>
<para>À l&textrsquo;aide d&textrsquo;un simple éditeur de texte,
un utilisateur &latex; écrit un fichier, dit <emph>fichier d&textrsquo;entrée</emph>,
qui contient son texte ; des <emph>commandes</emph> y sont intercalées :
ce sont des instructions servant à décrire la manière dont le texte
doit être formaté.  En effet, &latex; est mis en œuvre comme un
ensemble de commandes liées s&textrsquo;interfaçant avec le programme de
composition &tex; de Donald E. Knuth (le terme technique est que
&latex; est un <dfn>paquet de macros</dfn> pour le moteur &tex;).
En donnant le fichier d&textrsquo;entrée au moteur &tex;,
l&textrsquo;utilisateur produit le <emph>document de sortie</emph>
qui contient son texte mis en page.
</para>
<!-- c - Les fichiers @LaTeX{} sont des fichiers texte ordinaires qui -->
<!-- c - peuvent être écrits avec n'importe quel éditeur de texte aux -->
<!-- c - performances raisonnables. -->

<para>Le terme &latex; est aussi parfois utilisé pour signifier le langage à
balises dans lequel le code source du document est écrit, c&textrsquo;est-à-dire  pour
signifier l&textrsquo;ensemble des commandes à la disposition d&textrsquo;un utilisateur de
&latex;.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="14">Lamport &tex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="15">prononciation</indexterm></cindex>
<para>Le nom &latex; est l&textrsquo;abréviation de &textldquo;Lamport &tex;&textrdquo;.  On le prononce
LA-TÈQUE.  Au sein du document, on produit le logo avec
<code>\LaTeX</code>.  Là où l&textrsquo;utilisation du logo n&textrsquo;est pas raisonnable, comme
dans du texte brut, écrivez le <samp>LaTeX</samp>.
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Début et fin</menutitle><menunode separator=". ">Starting and ending</menunode><menudescription><pre xml:space="preserve">Le début et la fin standards d&textrsquo;un document.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Fichiers de sortie</menutitle><menunode separator=".         ">Output files</menunode><menudescription><pre xml:space="preserve">Fichiers produits.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Moteurs &tex;</menutitle><menunode separator=".          ">&tex; engines</menunode><menudescription><pre xml:space="preserve">Programmes qui peuvent compiler du code source &tex; et &latex;.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Syntaxe des commandes &latex;</menutitle><menunode separator=". ">&latex; command syntax</menunode><menudescription><pre xml:space="preserve">Syntaxe générale des commandes &latex;.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Environnement</menutitle><menunode separator=".        ">Environment</menunode><menudescription><pre xml:space="preserve">Zone du code source avec un comportement distinct.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                             ">CTAN</menunode><menudescription><pre xml:space="preserve">Notre dépôt.
</pre></menudescription></menuentry></menu>

<node name="Starting-and-ending" spaces=" "><nodename>Starting and ending</nodename><nodenext automatic="on">Output files</nodenext><nodeup automatic="on">Overview</nodeup></node>
<section spaces=" "><sectiontitle>Début et fin</sectiontitle>

<anchor name="Starting-_0026-ending">Starting &amp; ending</anchor><!-- c ancien nom du noeud -->
<cindex index="cp" spaces=" "><indexterm index="cp" number="16">début et fin</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="17">fin et début</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="18">Bonjour le monde</indexterm></cindex>

<para>Les fichiers &latex; ont une structure globale simple, avec un début et
une fin standards. Voici un petit exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\begin&lbrace;document&rbrace;
Bonjour le monde \LaTeX.
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>Tout document &latex; a une ligne <code>\begin&lbrace;document&rbrace;</code> et une
ligne <code>\end&lbrace;document&rbrace;</code>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="19">classe de document, définition</indexterm></cindex>
<noindent></noindent>
<para>Ici <samp>article</samp> est ce que l&textrsquo;on appelle la <dfn>classe de document</dfn>.
Elle est implémentée dans un fichier <file>article.cls</file>. N&textrsquo;importe
quelle classe de document de votre système peut être utilisée. Quelques
classes de document sont définies par &latex; lui-même, et un grand
nombre d&textrsquo;autres sont largement disponibles. <xref label="Document-classes"><xrefnodename>Document classes</xrefnodename></xref>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="20">préambule, définition</indexterm></cindex>
<para>Vous pouvez inclure d&textrsquo;autres commandes &latex; entre les commandes
<code>\documentclass</code> et <code>\begin&lbrace;document&rbrace;</code>. Cette zone est
appelée le <dfn>préambule</dfn>.
</para>
<para>La paire <code>\begin&lbrace;document&rbrace;</code>, <code>\end&lbrace;document&rbrace;</code> définit un
<cindex index="cp" spaces=" "><indexterm index="cp" number="21">environnement</indexterm></cindex>
<dfn>environnement</dfn> ; l&textrsquo;environnement <samp>document</samp> (et aucun autre)
est obligatoire dans tous les documents &latex; (<pxref label="document"><xrefnodename>document</xrefnodename></pxref>).
&latex; vous fournit beaucoup d&textrsquo;environnements documenté ici
(<pxref label="Environments"><xrefnodename>Environments</xrefnodename></pxref>). Vous pouvez en trouver bien plus encore à partir
de paquetages externes, notamment ceux disponibles sur le CTAN
(<pxref label="CTAN"><xrefnodename>CTAN</xrefnodename></pxref>).
</para>
<para>Les rubriques suivantes sont consacrées aux façons de produire,
à partir d&textrsquo;un fichier d&textrsquo;entrée &latex;, des documents PDF ou
d&textrsquo;autres formats de sortie.
</para>

</section>
<node name="Output-files" spaces=" "><nodename>Output files</nodename><nodenext automatic="on">&tex; engines</nodenext><nodeprev automatic="on">Starting and ending</nodeprev><nodeup automatic="on">Overview</nodeup></node>
<section spaces=" "><sectiontitle>Fichiers de sortie</sectiontitle>

<para>&latex; produit un fichier de sortie principal et au moins deux
fichiers auxiliaires.  Le nom du fichier de sortie principal se termine
soit en <file>.dvi</file> soit en <file>.pdf</file>.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">.dvi</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="7"><r>fichier</r> .dvi</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="8"><r>commande</r> latex</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="9"><r>commande</r> xdvi</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="10"><r>commande</r> dvips</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="11"><r>commande</r> dvipdfmx</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="12"><r>commande</r> dvitype</indexterm></findex>
<anchor name="output-files-dvi">output files dvi</anchor>
<para>S&textrsquo;il est invoqué avec la commande système <command>latex</command>, alors il
produit un fichier « DeVice Independent<footnote><para>Indépendant du
périphérique de sortie, ce n&textrsquo;est toutefois pas un format portable de
document</para></footnote> » (<file>.dvi</file>). Vous pouvez visualiser ce fichier avec une
commande comme <command>xdvi</command>, ou le convertir en fichier PostScript
<code>.ps</code> avec <command>dvips</command> ou en fichier « Portable Document
Format<footnote><para>Format portable de document</para></footnote> » <code>.pdf</code> avec
<command>dvipdfmx</command>. Un grand nombre d&textrsquo;autres programmes utilitaires
pour fichiers DVI sont disponibles (<url><urefurl>http://mirror.ctan.org/dviware</urefurl></url>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">.pdf</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="13">.pdf <r>fichier</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="22">pdf&tex;</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="14"><r>commande</r> pdflatex</indexterm></findex>
<anchor name="output-files-pdf">output files pdf</anchor>
<para>Si &latex; est invoqué avec la commande système <command>pdflatex</command>,
alors la sortie principale est un fichier &textldquo;Portable Document Format&textrdquo;
(<file>.pdf</file>). Typiquement, il s&textrsquo;agit d&textrsquo;un fichier autonome, avec toutes
les polices et images incorporées.
D&textrsquo;autres commandes (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>) produisent des fichiers PDF.
</para>
<!-- c - Cela peut être très utile, mais cela rend le fichier de sortie beaucoup -->
<!-- c - plus grand que le fichier @file{.dvi} produit à partir du même document. -->

<!-- c - @findex @r{commande} lualatex -->
<!-- c - @cindex Lua@TeX{} -->
<!-- c - Si il est invoqué comme @command{lualatex}, un fichier @file{.pdf} est -->
<!-- c - créé à l'aide du moteur Lua@TeX{} (@url{http://luatex.org}). -->
<!-- c - -->
<!-- c - @findex @r{commande} xelatex -->
<!-- c - @cindex Xe@TeX{} -->
<!-- c - Si elle est invoquée comme @command{xelatex}, un fichier @file{.pdf} est -->
<!-- c - créé à l'aide du moteur Xe@TeX{} (@url{http://tug.org/xetex}). -->
<!-- c - -->
</tableitem></tableentry></table>

<!-- c - Beaucoup d'autres variantes moins courantes de @LaTeX{} (et @TeX{}) existent, qui -->
<!-- c - peuvent produire du HTML, XML, et d'autres choses. -->

<para>&latex; produit toujours au moins deux fichier supplémentaires.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">.log</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="23">fichier de transcription</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="24">fichier journal</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="15"><r>fichier</r> .log</indexterm></findex>
<anchor name="output-files-log">output files log</anchor>
<para>Ce fichier de transcription, ou <dfn>fichier journal</dfn>, contient des
informations sommaires telles que la liste des paquetages chargés. Il
contient aussi des messages de diagnostic
<!-- c - pour toutes les erreurs découvertes dans le fichier d'entrée. -->
et, possiblement, des informations supplémentaires concernant toutes
erreurs.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">.aux</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="25">fichier auxiliaire</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="16">.aux <r>fichier</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="26">double renvoi, résolution</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="27">renvoi en aval, résolution</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="28">renvoi, résolution</indexterm></cindex>
<anchor name="output-files-aux">output files aux</anchor>
<para>De l&textrsquo;information auxiliaire est utilisée par &latex; pour des choses
telles que les doubles renvois.  Par exemple, la première fois que
&latex; trouve un renvoi en aval &textmdash; une double référence à
quelque chose qui n&textrsquo;est pas encore apparu dans le code source &textmdash; il
apparaîtra dans la sortie comme un double point d&textrsquo;interrogation
<code>??</code>.  Quand l&textrsquo;endroit auquel le renvoi fait référence finit par
apparaître dans le code source, alors &latex; écrit son information de
localisation dans ce fichier <code>.aux</code>.  À l&textrsquo;invocation suivante,
&latex; lit l&textrsquo;information de localisation à partir de ce fichier et
l&textrsquo;utilise pour résoudre le renvoi, en remplaçant le double point
d&textrsquo;interrogation avec la localisation mémorisée.
</para>
</tableitem></tableentry></table>

<!-- c - Une liste ouverte d'autres fichiers peut être créé. Nous n'allons pas essayer de -->
<!-- c - les énumérer tous. Composants Xxx? -->

<findex index="fn" spaces=" "><indexterm index="fn" number="17">.lof <r>fichier</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="29">liste des figures, fichier</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="18">.lot <r>fichier</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="30">liste des tableaux, fichier</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="19">.toc <r>fichier</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="31">table des matières, fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="32">matières, fichier</indexterm></cindex>
<para>&latex; peut produire encore d&textrsquo;autres fichiers, caractérisés par la
terminaison du nom de fichier. Ceux-ci incluent un fichier <code>.lof</code>
qui est utilisé pour fabriquer la liste des figures, un fichier
<code>.lot</code> utilisé pour fabriquer une liste des tableaux, et un fichier
<code>.toc</code> utilisé pour fabriquer une table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table
of contents etc.</xrefnodename></pxref>).  Une classe de document particulière peut en créer
d&textrsquo;autres ; cette liste n&textrsquo;a pas de fin définie.
</para>

</section>
<node name="TeX-engines" spaces=" "><nodename>&tex; engines</nodename><nodenext automatic="on">&latex; command syntax</nodenext><nodeprev automatic="on">Output files</nodeprev><nodeup automatic="on">Overview</nodeup></node>
<section spaces=" "><sectiontitle>Les moteurs &tex;</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="33">moteurs, &tex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="34">implémentations de &tex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="35">UTF-8</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="36">entrée Unicode, native</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="37">polices TrueType</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="38">polices OpenType</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="39">&tex;, format</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="40">format &tex;, fichier (<code>.fmt</code>)</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="41">format &latex;, fichier (<code>.fmt</code>)</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="42">&latex;, format, fichier (<code>.fmt</code>)</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="43">fichier format &tex;</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="20">.fmt, <r>fichier</r></indexterm></findex>
<para>&latex; est un vaste ensemble de commandes qui sont exécuté par un
programme &tex; (<pxref label="Overview"><xrefnodename>Overview</xrefnodename></pxref>). Un tel ensemble de commande est
appelé un <dfn>format</dfn>, et peut être matérialisé dans un fichier binaire
<code>.fmt</code>, ce qui permet qu&textrsquo;il soit lu bien plus rapidement que le
source &tex; correspondant.
</para>
<para>Cette rubrique donne une brève vue d&textrsquo;ensemble des programmes &tex;
les plus répandus (voir aussi <ref label="Command-line-interface"><xrefnodename>Command line interface</xrefnodename></ref>).
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="21">latex</indexterm>latex</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="22">pdflatex</indexterm>pdflatex</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="23">etex, <r>commande</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="44">pdf&tex;, moteur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="45">moteur pdf&tex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="46">e-&tex;</indexterm></cindex>
<anchor name="tex-engines-latex">tex engines latex</anchor>
<para>Dans &tex; Live (<url><urefurl>http://tug.org/texlive</urefurl></url>, si &latex; est invoqué
avec les commandes système <command>latex</command> ou <command>pdflatex</command>, alors
le moteur pdf&tex; est exécuté (<url><urefurl>http://ctan.org/pkg/pdftex</urefurl></url>).
Selon qu&textrsquo;on invoque <command>latex</command> ou <command>pdflatex</command>, la sortie
principale est respectivement un fichier <file>.dvi</file> ou un fichier
<file>.pdf</file>.
</para>
<para>pdf&tex; incorpore les extensions qu&textrsquo;e-&tex; apporte au programme
original de Knuth (<url><urefurl>http://ctan.org/pkg/etex</urefurl></url>), ce qui inclut des
caractéristiques supplémentaires de programmation et la composition
bidirectionnelle, et a lui-même de nombreuses extensions.  e-&tex; est
lui-même disponible par la commande système <command>etex</command>, mais le
langage du fichier d&textrsquo;entrée est du &tex; de base (et le fichier produit
est un <file>.dvi</file>).
</para>
<para>Dans d&textrsquo;autres distributions &tex;, <command>latex</command> peut invoquer
e-&tex; plutôt que pdf&tex;.  Dans tous les cas, on peut faire
l&textrsquo;hypothèse que les extensions e-&tex; sont disponibles en &latex;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="24">lualatex</indexterm>lualatex</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="25">lualatex <r>commande</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="47">Lua&tex;</indexterm></cindex>
<anchor name="tex-engines-lualatex">tex engines lualatex</anchor>
<para>Si &latex; est invoqué avec la commandes systèmes <command>lualatex</command>,
alors le moteur Lua&tex; est exécuté
(<url><urefurl>http://ctan.org/pkg/luatex</urefurl></url>).  Ce programme permet que du code
écrit dans le langage script Lua (<url><urefurl>http://luatex.org</urefurl></url>) interagisse
avec la composition faite par &tex;.  Lua&tex; traite nativement
l&textrsquo;entrée en codage Unicode UTF-8, peut traiter les polices OpenType et
TrueType, et produit un fichier <file>.pdf</file> par défaut.  Il y a aussi
<command>dvilualatex</command> pour produire un fichier <file>.dvi</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="26">xelatex</indexterm>xelatex</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="27">xelatex <r>commande</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="48">Xe&tex;</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="28">.xdv <r>fichier</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="29">xdvipdfmx</indexterm></findex>
<anchor name="tex-engines-xelatex">tex engines xelatex</anchor>
<para>Si &latex; est invoqué avec la commandes système <command>xelatex</command>, le
moteur Xe&tex; est exécuté (<url><urefurl>http://tug.org/xetex</urefurl></url>).  Comme
Lua&tex;, Xe&tex; prend en charge nativement le codage Unicode UTF-8 et les
polices TrueType et OpenType, bien que leur implémentation soit
complètement différente, en utilisant principalement des bibliothèques
externes plutôt que du code interne.  Xe&tex; produit un fichier <file>.pdf</file>
en sortie ; il ne prend pas en charge la sortie DVI.
</para>
<para>En interne, Xe&tex; crée un fichier <code>.xdv</code> file, une variante de
DVI, et traduit cela en PDF en utilisant le
programme (<code>x</code>)<code>dvipdfmx</code>, mais ce processus est automatique.
Le fichier <code>.xdv</code> n&textrsquo;est utile que pour le débogage.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="30">platex</indexterm>platex</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="31">uplatex</indexterm>uplatex</itemformat></itemx>
</tableterm><tableitem><para>Ces commandes fournissent une prise en charge significativement plus
riche du japonais et d&textrsquo;autres langues ; la variante en <file>u</file> prend en
charge l&textrsquo;Unicode.  Voir <url><urefurl>https://ctan.org/pkg/ptex</urefurl></url> et
<url><urefurl>https://ctan.org/pkg/uptex</urefurl></url>.
</para></tableitem></tableentry></ftable>

<para>Depuis 2019, il y a une commande compagne en <code>-dev</code> et un format
pour tous les moteurs cités plus hauts :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="32">dvilualatex-dev</indexterm>dvilualatex-dev</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="33">latex-dev</indexterm>latex-dev</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="34">lualatex-dev</indexterm>lualatex-dev</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="35">pdflatex-dev</indexterm>pdflatex-dev</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="36">platex-dev</indexterm>platex-dev</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="37">uplatex-dev</indexterm>uplatex-dev</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="38">xelatex-dev</indexterm>xelatex-dev</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="49">parution, candidats</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="50">avant parution, essais</indexterm></cindex>
<para>Ce sont les candidats pour une parution de &latex; à venir. L&textrsquo;usage
principal est de découvrir et traiter les problèmes de compatibilité
avant la parution officielle.
</para>
<para>Ces formats en <code>-dev</code> rendent facile pour quiconque d&textrsquo;aider à
l&textrsquo;essai des documents et du code : vous pouvez exécuter, disons,
<code>pdflatex-dev</code> au lieu de <code>pdflatex</code>, sans changer quoi que ce
soit d&textrsquo;autre dans votre environnement.  En réalité, le plus facile et
utile est de toujours d&textrsquo;exécuter les versions en <code>-dev</code> au lieu de
s&textrsquo;embêter à basculer entre les deux. Pendant les périodes calmes après une
parution, ces commandes seront équivalentes.
</para>
<para>Ce ne sont pas des échantillons quotidiens de code de développement non
testé. L&textrsquo;équipe &latex; fait subir à ces commandes les mêmes essais
étendus de non régression avant leur parution.
</para>
<para>Pour plus ample  information, voir <i>The &latex; release workflow and the
&latex; <code>dev</code> formats</i> par Frank Mittelbach, <cite>TUGboat</cite> 40:2,
<url><urefurl>https://tug.org/TUGboat/tb40-2/tb125mitt-dev.pdf</urefurl></url>.
</para>
</tableitem></tableentry></ftable>

</section>
<node name="LaTeX-command-syntax" spaces=" "><nodename>&latex; command syntax</nodename><nodenext automatic="on">Environment</nodenext><nodeprev automatic="on">&tex; engines</nodeprev><nodeup automatic="on">Overview</nodeup></node>
<section spaces=" "><sectiontitle>Syntaxe des commandes &latex;</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="51">commandes, syntaxe des</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="39">\ <r>caractère de début des commandes</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="40">[...] <r>(pour les arguments optionnels)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="41">&lbrace;...&rbrace; <r>(pour les arguments obligatoires)</r></indexterm></findex>
<para>Dans le fichier d&textrsquo;entrée &latex;, un nom de commande commence avec une
controblique, <code>\</code>.  Le nom lui-même consiste soit en (a) une
chaîne de lettres ou (b) un unique caractère, qui dans ce cas n&textrsquo;est pas une lettre.
</para>
<para>Les noms de commandes &latex; sont sensibles à la casse de sorte que
<code>\pagebreak</code> diffère de <code>\Pagebreak</code> (ce dernier n&textrsquo;est pas une
commande standarde). La plupart des noms de commandes sont en bas de
casse, mais quoi qu&textrsquo;il en soit vous devez saisir toute commande en
respectant la casse dans laquelle elle est définie.
</para>
<para>Une commande peut être suivie de zéro, un ou plus d&textrsquo;arguments. Ces
arguments peuvent être soit obligatoires, soit optionnels.  Les
arguments obligatoires sont entre accolades, <code>&lbrace;...&rbrace;</code>.  Les
arguments optionnels sont entre crochets, <code>[...]</code>.  En général,
mais ce n&textrsquo;est pas universel, si la commande prend un argument optionnel,
il vient en premier, avant tout argument obligatoire.
</para>
<para>Au sein d&textrsquo;un argument optionnel, pour utiliser le crochet
fermant (<code>]</code>) cachez le au sein d&textrsquo;accolades, comme
dans <code>\item[crochet fermant &lbrace;]&rbrace;]</code>.  De même, si un argument
optionnel vient en dernier, sans argument obligatoire à sa suite, alors
pour que le premier caractère dans le texte suivant soit un crochet
ouvrant, cachez le entre accolades.
</para>
<para>&latex; obéit à la convention selon laquelle certaines commandes ont une forme étoilée
(<code>*</code>) qui est en relation avec la forme sans le <code>*</code>, telles que
<code>\chapter</code> et <code>\chapter*</code>.  La différence exacte de
comportement dépend de la commande.
</para>
<para>Ce manuel décrit toutes les options acceptées et les formes en <code>*</code>
pour les commandes dont il traite (à l&textrsquo;exception des omissions
involontaires ou bogues de ce manuel).
</para>
</section>
<node name="Environment" spaces=" "><nodename>Environment</nodename><nodenext automatic="on">CTAN</nodenext><nodeprev automatic="on">&latex; command syntax</nodeprev><nodeup automatic="on">Overview</nodeup></node>
<section spaces=" "><sectiontitle>Les environnements</sectiontitle>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;<var>nom-environnement</var>&rbrace;
  ...
\end&lbrace;<var>nom-environnement</var>&rbrace;
</pre></example>

<para>Un <dfn>environnement</dfn> est une zone du code source &latex;, au sein de
laquelle il y a un comportement différent.  Par exemple, pour la poésie
en &latex; mettez les lignes entre <code>\begin&lbrace;verse&rbrace;</code> et
<code>\end&lbrace;verse&rbrace;</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;verse&rbrace;
    Plus ne suis ce que j'ai été \\
     ...
\end&lbrace;verse&rbrace;
</pre></example>

<para><xref label="Environments"><xrefnodename>Environments</xrefnodename></xref>, pour une liste d&textrsquo;environnements.  En
particulier, il est à noter que tout document &latex; doit avoir un
environnement <code>document</code> : une paire <code>\begin&lbrace;document&rbrace;
... \end&lbrace;document&rbrace;</code>.
</para>
<para>Le <var>nom-environnement</var> du début doit s&textrsquo;accorder exactement avec
celui de la fin. Cela vaut aussi dans le cas où <var>nom-environnement</var> se
termine par une étoile (<code>*</code>) ; l&textrsquo;argument à la fois de
<code>\begin</code> et <code>\end</code> doit comprendre l&textrsquo;étoile.
</para>
<para>Les environnements peuvent avoir des arguments, y compris des arguments
optionnels.  L&textrsquo;exemple ci-dessous produit un tableau. Le premier
argument est optionnel (il aligne verticalement le tableau
sur sa première ligne) alors que le second argument est
obligatoire (il spécifie le format des colonnes du tableau).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;[t]&lbrace;r|l&rbrace;
  ... lignes du tableau ...
\end&lbrace;tabular&rbrace;
</pre></example>

</section>
<node name="CTAN" spaces=" "><nodename>CTAN</nodename><nodeprev automatic="on">Environment</nodeprev><nodeup automatic="on">Overview</nodeup></node>
<section spaces=" "><sectiontitle>CTAN : The Comprehensive &tex; Archive Network</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="52">CTAN</indexterm></cindex>

<para>Le &laquo;Comprehensive &tex; Archive
Network&raquo;, ou CTAN, est le dépôt de matière libre de la
communauté &tex; et &latex;.  C&textrsquo;est un ensemble de sites Internet
répartis dans le monde qui offre de télécharger de la matière en relation
avec &latex;.  Visitez le CTAN sur la Toile à l&textrsquo;adresse
<url><urefurl>https://ctan.org</urefurl></url>.
</para>
<para>Cette matière est organisée en paquetages, des paquets discrets qui offrent
typiquement une fonctionnalité cohérente et sont maintenus par une
personne ou un petit nombre de personnes.  Par exemple, beaucoup
d&textrsquo;organismes d&textrsquo;édition on un paquetage qui permet aux auteurs de
formater leurs articles conformément aux spécification de cet organisme.
</para>
<para>En plus des ressources massives, le site <code>ctan.org</code> offre des fonctions telles que
la recherche par nom ou par fonctionnalité.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="53">DANTE e.V.</indexterm></cindex>
<para>CTAN n&textrsquo;est pas un site unique, mais au lieu de cela un ensemble de
sites. L&textrsquo;un des ces sites est le cœur. Ce site gère activement la
matière, par exemple en acceptant les téléversements de matière
nouvelle ou mise à jour. Il est hébergé par le groupe &tex; allemand
DANTE e.V.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="54">miroirs du CTAN</indexterm></cindex>
<para>D&textrsquo;autres sites autour du monde apportent leur aide en miroitant, c&textrsquo;est à
dire en synchronisant automatiquement leurs collections sur le site
maître et en rendant à leur tour leurs copies publiquement
disponibles. Ceci donne aux utilisateurs géographiquement proches un
meilleur accès et allège la charge sur le site maître. La liste des
miroirs se trouve à <url><urefurl>https://ctan.org/mirrors</urefurl></url>.
</para>
</section>
</chapter>
<node name="Document-classes" spaces=" "><nodename>Document classes</nodename><nodenext automatic="on">Fonts</nodenext><nodeprev automatic="on">Overview</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Classes de documents</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="55">classes de documents</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="42">\documentclass</indexterm></findex>

<para>La classe globale d&textrsquo;un document est définie avec cette commande, c&textrsquo;est
normalement la première commande dans une fichier source &latex;.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[<var>options</var>]&lbrace;<var>classe</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>La commande <code>\documentclass</code> doit être la première commande dans un
fichier source &latex;.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="43"><r>classe</r> article</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="44"><r>classe</r> report</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="45"><r>classe</r> book</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="46"><r>classe</r> letter</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="47"><r>classe</r> slides</indexterm></findex>
<para>Les noms de <var>classe</var> de document incorporés à &latex;.  (Beaucoup
de classes de document sont disponibles dans des paquetages séparés ;
<pxref label="Overview"><xrefnodename>Overview</xrefnodename></pxref>.)
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">article</itemformat></item>
</tableterm><tableitem><anchor name="document-classes-article">document classes article</anchor>
<para>Pour un article de journal, une présentation, et diverses utilisations
générales.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">book</itemformat></item>
</tableterm><tableitem><anchor name="document-classes-book">document classes book</anchor>

<para>Des livres complets, y compris des chapitres et possiblement incluant
des pièces préliminaires telles qu&textrsquo;une préface, et postliminaires telles
qu&textrsquo;un appendice (<pxref label="Front_002fback-matter"><xrefnodename>Front/back matter</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">letter</itemformat></item>
</tableterm><tableitem><anchor name="document-classes-letter">document classes letter</anchor>
<para>Courrier, incluant optionnellement des étiquettes pour enveloppes
(<pxref label="Letters"><xrefnodename>Letters</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">report</itemformat></item>
</tableterm><tableitem><anchor name="document-classes-report">document classes report</anchor>
<para>Pour des documents de longueur entre celle d&textrsquo;un <code>article</code> et celle
d&textrsquo;un <code>book</code>, tels que des rapports techniques ou des thèses, et qui
peuvent contenir plusieurs chapitres.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">slides</itemformat></item>
</tableterm><tableitem><anchor name="document-classes-slides">document classes slides</anchor>
<para>Pour des présentations de diapositive &textmdash; rarement utilisé de nos jours.
À sa place la classe <code>beamer</code> est sans doute celle dont l&textrsquo;usage est
le plus répandu (<url><urefurl>https://ctan.org/pkg/beamer</urefurl></url>). <xref label="beamer-template"><xrefnodename>beamer
template</xrefnodename></xref>, pour un petit patron de document <code>beamer</code>.
</para>
</tableitem></tableentry></table>

<para>Les <var>options</var> standardes sont décrites dans les rubriques suivantes.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Options de classe de document</menutitle><menunode separator=". ">Document class options</menunode><menudescription><pre xml:space="preserve">Options globales
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Ajout de paquetage</menutitle><menunode separator=". ">Additional packages</menunode><menudescription><pre xml:space="preserve">Ajouter des paquetages.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Construction d&textrsquo;extension (classe ou paquetage)</menutitle><menunode separator=".   ">Class and package construction</menunode><menudescription><pre xml:space="preserve">Créer des
 nouvelles extensions (classe ou paquetage).
</pre></menudescription></menuentry></menu>

<node name="Document-class-options" spaces=" "><nodename>Document class options</nodename><nodenext automatic="on">Additional packages</nodenext><nodeup automatic="on">Document classes</nodeup></node>
<section spaces=" "><sectiontitle>Options de classe de document</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="56">options de classe de document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="57">options, classe de document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="58">options de classe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="59">options globales</indexterm></cindex>

<para>Vous pouvez spécifier ce qu&textrsquo;on appelle des <dfn>options globales</dfn> ou des
<dfn>options de classe</dfn> en les passant entre crochet à la commande
<code>\documentclass</code>, comme d&textrsquo;habitude. Pour spécifier plus d&textrsquo;une
<var>option</var>, séparez les par une virgule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass [<var>option1</var>, <var>option2</var>, ...]&lbrace;<var>classe</var>&rbrace;
</pre></example>

<para>Voici la liste des options standardes de classe.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="48"><r>option</r> 10pt</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="49"><r>option</r> 11pt</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="50"><r>option</r> 12pt</indexterm></findex>
<para>Toutes les classes standardes, sauf <code>slides</code> acceptent les options
suivantes pour sélectionner la taille de police de caractères (l&textrsquo;option
par défaut est <code>10pt</code>):
</para>
<example endspaces=" ">
<pre xml:space="preserve">12pt 11pt 10pt
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="51"><r>option</r> a4paper</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="52"><r>option</r> a5paper</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="53"><r>option</r> b5paper</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="54"><r>option</r> executivepaper</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="55"><r>option</r> legalpaper</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="56"><r>option</r> letterpaper</indexterm></findex>
<para>Toutes les classes standardes acceptent ces options de sélection de la
taille du papier (ci-après hauteur sur largeur) :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">a4paper</itemformat></item>
</tableterm><tableitem><para>210 sur 297<dmn>mm</dmn> (environ 8,25 sur 11,75 pouces)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">a5paper</itemformat></item>
</tableterm><tableitem><para>148 sur 210<dmn>mm</dmn> (environ 5,8 sur 8,3 pouces)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">b5paper</itemformat></item>
</tableterm><tableitem><para>176 sur 250<dmn>mm</dmn> (environ 6,9 sur 9,8 pouces)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">executivepaper</itemformat></item>
</tableterm><tableitem><para>7,25 sur 10,5 pouces
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">legalpaper</itemformat></item>
</tableterm><tableitem><para>8,5 sur 14 pouces
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">letterpaper</itemformat></item>
</tableterm><tableitem><para>8,5 sur 11 pouces (l&textrsquo;option par défaut)
</para></tableitem></tableentry></table>

<findex index="fn" spaces=" "><indexterm index="fn" number="57">\pdfpagewidth</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="58">\pdfpageheight</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="59"><r>paquetage</r> <code>geometry</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="60"><code>geometry</code>, <r>paquetage</r></indexterm></findex>
 <para>Lorsque on utilise l&textrsquo;un des moteurs pdf&latex;,
Lua&latex;, ou Xe&latex; (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>), les options autres
que <code>letterpaper</code> règlent la zone d&textrsquo;impression mais vous devez
également régler la taille du papier physique. Un méthode pour faire
cela est de placer <code>\pdfpagewidth=\paperwidth</code> et
<code>\pdfpageheight=\paperheight</code> dans le préambule de votre document.
<findex index="fn" spaces=" "><indexterm index="fn" number="61"><r>paquetage</r> <code>geometry</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="62"><code>geometry</code>, <r>paquetage</r></indexterm></findex>
</para>
<para>Le paquetage <code>geometry</code> fournit des méthodes flexibles pour régler
la zone d&textrsquo;impression et la taille du papier physique.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="63"><r>option</r> draft</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="64"><r>option</r> final</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="65"><r>option</r> fleqn</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="66"><r>option</r> landscape</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="67"><r>option</r> leqno</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="68"><r>option</r> openbib</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="69"><r>option</r> titlepage</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="70"><r>option</r> notitlepage</indexterm></findex>
<para>Diverses autres options:
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">draft, final</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="60">boîtes noires, en omettant</indexterm></cindex>
<para>Pour marquer/ne marquer pas les boîtes trop pleines avec une grande
boîte noire ; l&textrsquo;option par défaut est <code>final</code>.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">fleqn</itemformat></item>
</tableterm><tableitem><para>Pour aligner à gauches les formules hors texte ; par défaut elles sont centrées.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">landscape</itemformat></item>
</tableterm><tableitem><para>Pour sélectionner le format de page à l&textrsquo;italienne ; l&textrsquo;option par défaut
est à la française.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">leqno</itemformat></item>
</tableterm><tableitem><para>Pour Mettre les numéros d&textrsquo;équation sur le côté gauche des
équations ; par défaut ils sont sur le côté droit.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">openbib</itemformat></item>
</tableterm><tableitem><para>Pour utiliser le  format bibliographie <code>openbib</code>.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">titlepage, notitlepage</itemformat></item>
</tableterm><tableitem><para>Indique si la page de titre est séparée ; l&textrsquo;option par défaut
dépend de la classe.
</para></tableitem></tableentry></table>

<para>Ces options ne sont pas disponibles avec la classe <code>slides</code> :
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="71"><r>option</r> onecolumn</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="72"><r>option</r> twocolumn</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="73"><r>option</r> oneside</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="74"><r>option</r> twoside</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="75"><r>option</r> openright</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="76"><r>option</r> openany</indexterm></findex>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">onecolumn</itemformat></item>
<itemx spaces=" "><itemformat command="code">twocolumn</itemformat></itemx>
</tableterm><tableitem><para>Composer en une ou deux colonnes ; le défaut est <code>onecolumn</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">oneside</itemformat></item>
<itemx spaces=" "><itemformat command="code">twoside</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="77">\evensidemargin</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="78">\oddsidemargin</indexterm></findex>
<para>Sélectionne la disposition en recto simple ou recto-verso ; le défaut
est <code>oneside</code> pour recto simple, sauf pour la classe <code>book</code>.
</para>
<para>Le paramètre <code>\evensidemargin</code> (<code>\oddsidemargin</code>) détermine la
distance sur les pages de numéro pair (impair) entre le côté gauche
de la page et la marge gauche du texte.  Voir <ref label="page-layout-parameters-oddsidemargin"><xrefnodename>page layout
parameters oddsidemargin</xrefnodename></ref>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">openright</itemformat></item>
<itemx spaces=" "><itemformat command="code">openany</itemformat></itemx>
</tableterm><tableitem><para>Détermine si un chapitre doit commencer sur une page de droite ; défaut
est <code>openright</code> pour la classe <code>book</code>.
</para></tableitem></tableentry></table>

<para>La classe <code>slide</code> offre l&textrsquo;option <code>clock</code> pour l&textrsquo;impression du
temps au bas de chaque note.
</para>

</section>
<node name="Additional-packages" spaces=" "><nodename>Additional packages</nodename><nodenext automatic="on">Class and package construction</nodenext><nodeprev automatic="on">Document class options</nodeprev><nodeup automatic="on">Document classes</nodeup></node>
<section spaces=" "><sectiontitle>Ajout de paquetages</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="61">paquetages, le chargement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="62">chargement des paquetages supplémentaires</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="79">\usepackage</indexterm></findex>
<para>Les paquetages ajoutés <var>paquo</var> sont chargés comme ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>options</var>]&lbrace;<var>paquo</var>&rbrace;
</pre></example>

<para>Pour spécifier plus d&textrsquo;un paquetage, vous pouvez les séparer par une
virgule comme dans <code>\usepackage&lbrace;<var>paquo1</var>,<var>paquo2</var>,...&rbrace;</code>,
ou utiliser plusieurs commandes <code>\usepackage</code>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="63">options globales</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="64">globales, options</indexterm></cindex>
<para>Toutes les options indiquées dans la commande <code>\documentclass</code> qui
sont inconnues de la classe de document sélectionnée sont transmises aux
paquetages chargés par <code>\usepackage</code>.
</para>

</section>
<node name="Class-and-package-construction" spaces=" "><nodename>Class and package construction</nodename><nodeprev automatic="on">Additional packages</nodeprev><nodeup automatic="on">Document classes</nodeup></node>
<section spaces=" "><sectiontitle>Construction des extensions (classes et paquetages)</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="65">commandes des classes de document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="66">classe de document, commandes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="67">nouvelles classes, commandes</indexterm></cindex>

<para>Vous pouvez créer de nouvelles classes de document, et de nouveaux
paquetages. Par exemple, si vos notes doivent répondre à des exigences
locales, telles qu&textrsquo;un en-tête standard pour chaque page, alors vous
pourriez créer une nouvelle classe <code>cmsnote.cls</code> et commencer vos
documents par <code>\documentclass&lbrace;cmsnote&rbrace;</code>.
</para>
<para>Ce qui distingue un paquetage d&textrsquo;une classe de document c&textrsquo;est que les
commandes d&textrsquo;une paquetage sont utilisables pour différentes classes
alors que celles dans une classes de document sont spécifiques à cette
classes. Ainsi, une commande qui permet de régler les en-têtes de pages
irait dans un paquetage alors qu&textrsquo;une commande intitulant en-têtes de
pages par <code>Note du service de mathématique de la CMS</code> irait dans
une classe.
<cindex index="cp" spaces=" "><indexterm index="cp" number="68">classe et paquetage, différence</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="69">différence entre classe et paquetage</indexterm></cindex>
</para>
<para>Au sein d&textrsquo;un fichier classe ou paquetage on peut utiliser l&textrsquo;arobe
<code>&arobase;</code> comme un caractère dans les noms de commande sans avoir à
entourer le code contenant la commande en question par
<code>\makeatletter</code> et <code>\makeatother</code>.  <xref label="_005cmakeatletter-_0026-_005cmakeatother"><xrefnodename>\makeatletter &amp;
\makeatother</xrefnodename></xref>. Ceci permet de créer des commandes que les utilisateurs
ne risquent pas de redéfinir accidentellement. Une autre technique est
de préfixer les commandes spécifiques à une classe ou paquetage avec une
chaîne particulière, de sorte à empêcher votre classe ou paquetage
d&textrsquo;interférer avec d&textrsquo;autres. Par exemple, la classe <code>notecms</code>
pourrait avoir des commandes <code>\cms&arobase;tolist</code>, <code>\cms&arobase;fromlist</code>,
etc.
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Structure d&textrsquo;une extension</menutitle><menunode separator=". ">Class and package structure</menunode><menudescription><pre xml:space="preserve">Disposition du fichier.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Commande pour extensions</menutitle><menunode separator=". ">Class and package commands</menunode><menudescription><pre xml:space="preserve">Liste des commandes.
</pre></menudescription></menuentry></menu>


<node name="Class-and-package-structure" spaces=" "><nodename>Class and package structure</nodename><nodenext automatic="on">Class and package commands</nodenext><nodeup automatic="on">Class and package construction</nodeup></node>
<subsection spaces="  "><sectiontitle>Structure d&textrsquo;une extension (classe ou paquetage)</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="70">classe et paquetage, structure</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="71">extension, structure</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="72">classe, disposition du fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="73">paquetage, disposition du fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="74">options pour classe de document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="75">options pour paquetage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="76">classe, options</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="77">paquetage, options</indexterm></cindex>

<para>Un fichier de classe pour paquetage comprend typiquement quatre parties.
</para><enumerate first="1" endspaces=" ">
<listitem>
<para>Dans la <dfn>partie d&textrsquo;identification</dfn> le fichier dit s&textrsquo;il s&textrsquo;agit d&textrsquo;un
paquetage ou d&textrsquo;une classe &latex; et s&textrsquo;auto-décrit, en utilisant les
commandes <code>\NeedsTeXFormat</code> et <code>\ProvidesClass</code> ou
<code>\ProvidesPackage</code>.
</para></listitem><listitem>
<para>La partie des <dfn>déclarations préliminaires</dfn> déclare des commandes et
peut aussi charger d&textrsquo;autres fichiers. D&textrsquo;ordinaire ces commandes sont
celles nécessaires au code utilisé dans la partie suivante. Par exemple,
une classe <code>notecms</code> pourrait être appelée avec une option pour lire
un fichier où est défini une liste de personnes désignées comme
destinataires de la note, comme
<code>\documentclass[destinataires-math]&lbrace;notecms&rbrace;</code>, et donc on a
besoin de définir une commande
<code>\newcommand&lbrace;\defdestinataires&rbrace;[1]&lbrace;\def\&arobase;liste&arobase;destinataires&lbrace;#1&rbrace;&rbrace;</code>
à utiliser dans ce fichier.
</para></listitem><listitem>
<para>Dans la partie de <dfn>gestion des options</dfn> la classes ou le
paquetage déclare et traite ses options.  Les options de classes
permette à l&textrsquo;utilisateur de commencer leur document comme dans
<code>\documentclass[<var>liste d'options</var>]&lbrace;<var>nom de la classe</var>&rbrace;</code>,
pour modifier le comportement de la classe. Un exemple est lorsque on
déclare <code>\documentclass[11pt]&lbrace;article&rbrace;</code> pour régler la taille par
défaut de la police du document.
</para></listitem><listitem>
<para>Finalement, dans la partie des <dfn>déclarations supplémentaires</dfn> la
classe ou le paquetage effectue la plus grosse partie de son travail :
déclarant de nouvelles variables, commandes ou polices, et chargeant
d&textrsquo;autres fichiers.
</para></listitem></enumerate>

<para>Voici le commencement d&textrsquo;un fichier de classe, ce qui doit être
sauvegardé comme <file>souche.cls</file> à un emplacement où &latex; peut le
trouver, par exemple dans le même répertoire que le fichier <file>.tex</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\NeedsTeXFormat&lbrace;LaTeX2e&rbrace;
\ProvidesClass&lbrace;souche&rbrace;[2017/07/06 souche à partir de laquelle contruire des classes]
\DeclareOption*&lbrace;\PassOptionsToClass&lbrace;\CurrentOption&rbrace;&lbrace;article&rbrace;&rbrace;
\ProcessOptions\relax
\LoadClass&lbrace;article&rbrace;
</pre></example>
<cindex index="cp" spaces=" "><indexterm index="cp" number="78">classe, fichier d&textrsquo;exemple</indexterm></cindex>

<para>Elle s&textrsquo;auto-identifie, traite les options de classe par défaut en les
passant toutes à la classe <code>article</code>, et puis charge la classe
<code>article</code> de sorte à fournir la base du code de cette classe.
</para>
<para>Pour plus d&textrsquo;information, voir le guide officiel pour les auteurs de
classes et de paquetage, le « Class Guide »,
<url><urefurl>http://www.latex-project.org/help/documentation/clsguide.pdf</urefurl></url> (la
plupart des descriptions faites ici s&textrsquo;inspirent de ce document), ou
l&textrsquo;article suivant <url><urefurl>https://www.tug.org/TUGboat/tb26-3/tb84heff.pdf</urefurl></url>
illustrant la construction d&textrsquo;une nouvelle classe.
</para>
</subsection>
<node name="Class-and-package-commands" spaces=" "><nodename>Class and package commands</nodename><nodeprev automatic="on">Class and package structure</nodeprev><nodeup automatic="on">Class and package construction</nodeup></node>
<subsection spaces=" "><sectiontitle>Commande pour extension (classe ou paquetage)</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="79">classe et paquetage, commandes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="80">commandes pour classe ou paquetage</indexterm></cindex>

<para>Voici les commandes conçues pour aider les auteurs d&textrsquo;extension (classes
ou paquetages).
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">\AtBeginDvi&lbrace;specials&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="80">\AtBeginDvi</indexterm></findex>
<para>Sauvegarde dans une registre de boîte des choses qui sont à écrire dans
le fichier <file>.dvi</file> au début de l&textrsquo;achèvement de la première page du
</para>
<para>document.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\AtEndOfClass&lbrace;<var>code</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\AtEndOfPackage&lbrace;<var>code</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="81">\AtEndOfClass</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="82">\AtEndOfPackage</indexterm></findex>
<para>Crochet pour insérer le <var>code</var> à exécuter lorsque &latex; termine le
traitement de la classe ou du paquetage courants.  On peut utiliser ces
crochet plusieurs fois ; le <code>code</code> sera exécuté dans l&textrsquo;ordre
d&textrsquo;appel.  Voir aussi <ref label="_005cAtBeginDocument"><xrefnodename>\AtBeginDocument</xrefnodename></ref>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\CheckCommand&lbrace;<var>cmd</var>&rbrace;[<var>num</var>][<var>défaut</var>]&lbrace;<var>définition</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\CheckCommand*&lbrace;<var>cmd</var>&rbrace;[<var>num</var>][<var>défaut</var>]&lbrace;<var>définition</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="83">\CheckCommand</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="84">\CheckCommand*</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="81">nouvelle commande, vérification</indexterm></cindex>
<para>Similaire à <code>\newcommand</code> (<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></pxref>)
mais ne définit pas <var>cmd</var> ; à la place vérifie que la définition
actuelle de <var>cmd</var> est exactement celle donnée par <var>définition</var>
et est ou n&textrsquo;est pas <dfn>longue</dfn> selon ce que l&textrsquo;on attend.
<cindex index="cp" spaces=" "><indexterm index="cp" number="82">commande longue</indexterm></cindex>
Une commande est dite longue lorsque elle accepte <code>\par</code> au sein
d&textrsquo;un argument. On attend que la commande <var>cmd</var> soit longue avec la
version non-étoilée de <code>\CheckCommand</code>. Lève une erreur en cas
d&textrsquo;échec de la vérification. Ceci vous permet de vérifier avant de
redéfinir vous-même <var>cmd</var> qu&textrsquo;aucun paquetage ne l&textrsquo;a pas déjà fait.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ClassError&lbrace;<var>nom de la classe</var>&rbrace;&lbrace;<var>texte de l'erreur</var>&rbrace;&lbrace;<var>texte d'aide</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PackageError&lbrace;<var>nom du paquetage</var>&rbrace;&lbrace;<var>texte de l'erreur</var>&rbrace;&lbrace;<var>texte d'aide</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ClassWarning&lbrace;<var>nom de la classe</var>&rbrace;&lbrace;<var>texte avertissement</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PackageWarning&lbrace;<var>nom du paquetage</var>&rbrace;&lbrace;<var>texte avertissement</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ClassWarningNoLine&lbrace;<var>nom de la classe</var>&rbrace;&lbrace;<var>texte avertissement</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PackageWarningNoLine&lbrace;<var>nom du paquetage</var>&rbrace;&lbrace;<var>texte avertissement</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ClassInfo&lbrace;<var>nom de la classe</var>&rbrace;&lbrace;<var>texte info</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PackageInfo&lbrace;<var>nom du paquetage</var>&rbrace;&lbrace;<var>texte info</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ClassInfoNoLine&lbrace;<var>nom de la classe</var>&rbrace;&lbrace;<var>texte info</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PackageInfoNoLine&lbrace;<var>nom du paquetage</var>&rbrace;&lbrace;<var>texte info</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="85">\ClassError</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="86">\PackageError</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="87">\ClassWarning</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="88">\PackageWarning</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="89">\ClassWarningNoLine</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="90">\PackageWarningNoLine</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="91">\ClassInfo</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="92">\PackageInfo</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="93">\ClassInfoNoLine</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="94">\PackageInfoNoLine</indexterm></findex>
<para>Produit un message d&textrsquo;erreur, ou des messages d&textrsquo;avertissement ou
d&textrsquo;information.
</para>
<para>Pour <code>\ClassError</code> et <code>\PackageError</code> le message est
<var>texte de l&textrsquo;erreur</var>, suivi de l&textrsquo;invite d&textrsquo;erreur <code>?</code> de
&tex;. Si l&textrsquo;utilisateur demande de l&textrsquo;aide en tapant
<code>h</code>, il voit le <var>texte d&textrsquo;aide</var>.
</para>
<para>Les quatre commandes d&textrsquo;avertissement (warning) sont
similaires à ceci près qu&textrsquo;elles écrivent <var>texte avertissement</var> à
l&textrsquo;écran sans invite d&textrsquo;erreur. Les quatre commandes d&textrsquo;information écrivent
<var>texte info</var> seulement dans le fichier journal.  Les versions en
<code>NoLine</code> n&textrsquo;affichent pas le numéro de la ligne générant le message,
alors que les autres versions le font.
</para>
<para>Pour formater les messages, y compris le <var>texte d&textrsquo;aide</var> : utilisez
<code>\protect</code> pour empêcher une commande de se développer, obtenez un
saut de ligne avec <code>\MessageBreak</code>, et obtenez une espace avec
<code>\space</code> lorsque l&textrsquo;utilisation d&textrsquo;un caractère espace ne le permet
pas, comme après une commande.  Notez que &latex; ajoute un point final
à chaque message.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\CurrentOption</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="95">\CurrentOption</indexterm></findex>
<para>Se développe au contenu de l&textrsquo;option en cours de traitement. Peut
uniquement être utilisé au sein de l&textrsquo;argument <var>code</var> soit de
<code>\DeclareOption</code>, soit de <code>\DeclareOption*</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\DeclareOption&lbrace;<var>option</var>&rbrace;&lbrace;<var>code</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\DeclareOption*&lbrace;<var>option</var>&rbrace;&lbrace;<var>code</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="96">\DeclareOption</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="97">\DeclareOption*</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="83">classe, options</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="84">paquetage, options</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="85">options de classe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="86">options de paquetage</indexterm></cindex>
<para>Rend un option <var>option</var> disponible pour l&textrsquo;utilisateur, de sorte à ce
qu&textrsquo;il puisse la passer à leur commande <code>\documentclass</code>.  Par
exemple, la classe <code>notecms</code> pourrait avoir une option <code>logo</code>
pour mettre le logo de leur organisation sur la première page avec
<code>\documentclass[logo]&lbrace;notcms&rbrace;</code>.  Le fichier de classe doit
contenir <code>\DeclareOption&lbrace;logo&rbrace;&lbrace;<var>code</var>&rbrace;</code> (et plus loin,
<code>\ProcessOptions</code>).
</para>
<para>Si vous invoquez une option qui n&textrsquo;a pas été déclarée, par défaut cela
produit une avertissement semblable à <code>Unused global option(s):
[badoption].</code>  Vous pouvez changer ce comportement avec la version
étoilée <code>\DeclareOption*&lbrace;<var>code</var>&rbrace;</code>.  Par exemple, beaucoup de
classes étendent une classe existante en utilisant une commande du
genre <code>\LoadClass&lbrace;article&rbrace;</code>, et pour passer les options
supplémentaires à la classe sous-jacente utilisent un code tel que
celui-ci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareOption*&lbrace;%
\PassOptionsToClass&lbrace;\CurrentOption&rbrace;&lbrace;article&rbrace;%
&rbrace;
</pre></example>

<para>Un autre exemple est que la classes <code>notecms</code> permette aux
utilisateur de tenir des listes de destinataire des notes dans des
fichiers externes. Par exemple l&textrsquo;utilisateur invoque
<code>\documentclass[math]&lbrace;notecms&rbrace;</code> et la classe lit le fichier
<code>math.memo</code>.  Ce code gère le fichier s&textrsquo;il existe et sinon passe
l&textrsquo;option à la classe <code>article</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareOption*&lbrace;\InputIfFileExists&lbrace;\CurrentOption.memo&rbrace;&lbrace;&rbrace;&lbrace;%
    \PassOptionsToClass&lbrace;\CurrentOption&rbrace;&lbrace;article&rbrace;&rbrace;&rbrace;
</pre></example>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\DeclareRobustCommand&lbrace;<var>cmd</var>&rbrace;[<var>num</var>][<var>défaut</var>]&lbrace;<var>définition</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\DeclareRobustCommand*&lbrace;<var>cmd</var>&rbrace;[<var>num</var>][<var>défaut</var>]&lbrace;<var>définition</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="98">\DeclareRobustCommand</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="99">\DeclareRobustCommand*</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="87">nouvelle commande, définition</indexterm></cindex>
<para>Similaire à <code>\newcommand</code> et <code>\newcommand*</code>
(<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></pxref>) mais déclare une commande robuste,
même si <var>définition</var> comprend du code fragile. (Pour une discussion
sur les commandes robustes et fragiles <pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>). Utilisez ces
commande pour définir de nouvelles commandes robustes, ou redéfinir des
commandes existantes en les rendant robustes. Contrairement à
<code>\newcommand</code> elle ne produisent pas d&textrsquo;erreur si la macro <var>cmd</var>
existe déjà ; au lieu de cela un message est écrit dans le fichier
journal pour indiquer la redéfinition de la commande.
</para>
<para>Les commandes définies de cette manière sont légèrement moins efficace
que celle définies avec <code>\newcommand</code>, c&textrsquo;est pourquoi, à moins que
le contenu de la commande soit fragile et que la commande soit utilisée
au sein d&textrsquo;un argument mouvant, utilisez <code>\newcommand</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="100"><r>paquetage</r> <code>etoolbox</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="101"><code>etoolbox</code>, <r>paquetage</r></indexterm></findex>
 <para>Le paquetage <code>etoolbox</code> offre les commandes
<code>\newrobustcmd</code>, <code>\newrobustcmd*</code>, <code>\renewrobustcmd</code>,
<code>\renewrobustcmd*</code>, <code>\providerobustcmd</code>, et
<code>\providrobustcmd*</code> qui sont similaire aux commandes standardes
<code>\newcommand</code>, <code>\newcommand*</code>, <code>\renewcommand</code>,
<code>\renewcommand*</code>, <code>\providecommand</code>, et
<code>\providecommand*</code>, mais définissent une commande <var>cmd</var> robuste
avec deux avantages par rapport à <code>\DeclareRobustCommand</code> :
</para><enumerate first="1" endspaces=" ">
<listitem>
<para>Elle utilisent un mécanisme de protection de bas niveau d&textrsquo;e-&tex; au
lieu du mécanisme de plus au niveau de &latex; utilisant
<code>\protect</code>, ainsi elles ne subissent pas la légère perte de
performance mentionnée plus haut, et
</para></listitem><listitem>
<para>Elles font la même distinction entre <code>\new&dots;</code>,
<code>\renew&dots;</code>, et <code>\provide&dots;</code> que les commandes
standardes, ainsi elle ne font pas qu&textrsquo;envoyer un message dans le journal
lorsque vous redéfinissez <var>cmd</var> déjà existantes, dans ce cas vous
devez utiliser soit <code>\renew&dots;</code> soit <code>\provide&dots;</code> ou il
y a une erreur.
</para></listitem></enumerate>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\IfFileExists&lbrace;<var>nom fichier</var>&rbrace;&lbrace;<var>si vrai</var>&rbrace;&lbrace;<var>si faux</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\InputIfFileExists&lbrace;<var>nom fichier</var>&rbrace;&lbrace;<var>si vrai</var>&rbrace;&lbrace;<var>si faux</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="102">\IfFileExists</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="103">\InputIfFileExists</indexterm></findex>
<para>Exécute <var>si vrai</var> si &latex; peut trouver le fichier <file><var>nom
fichier</var></file> et <var>si faux</var> sinon.  Dans le second cas, le fichier est lu
immédiatement après exécuter <var>si vrai</var>.  Ainsi
<code>\IfFileExists&lbrace;img.pdf&rbrace;&lbrace;\includegraphics&lbrace;img.pdf&rbrace;&rbrace;&lbrace;\typeout&lbrace;AVERTISSEMENT
: img.pdf introuvable&rbrace;&rbrace;</code> n&textrsquo;inclut le graphique <file>img.pdf</file> que s&textrsquo;il
est trouvé, mais autrement produit seulement un avertissement.
</para>
<para>Cette commande cherche le fichier dans tous les chemins de recherche que
that &latex; utilise, et non pas seulement dans le répertoire courant.
Pour chercher uniquement dans le répertoire courant faites quelque chose
du genre de <code>\IfFileExists&lbrace;./<var>nom fichier</var>&rbrace;&lbrace;<var>si
vrai</var>&rbrace;&lbrace;<var>si faux</var>&rbrace;</code>.  Si vous demandez un fichier dont le nom n&textrsquo;a
pas d&textrsquo;extension <code>.tex</code> alors &latex; commencera par chercher le
fichier en apposant <code>.tex</code> à son nom ; pour plus ample information
sur la façon dont &latex; gère les extensions de nom de fichier voir
<ref label="_005cinput"><xrefnodename>\input</xrefnodename></ref>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\LoadClass[<var>liste d'options</var>]&lbrace;<var>nom de la classe</var>&rbrace;[<var>date de parution</var>]</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\LoadClassWithOptions&lbrace;<var>nom de la classe</var>&rbrace;[<var>date de parution</var>]</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="104">\LoadClass</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="105">\LoadClassWithOptions</indexterm></findex>
<para>Charge une classe, comme avec <code>\documentclass[<var>options
list</var>]&lbrace;<var>nom de la classe</var>&rbrace;[<var>release info</var>]</code>.  Voici un exemple :
<code>\LoadClass[twoside]&lbrace;article&rbrace;</code>.
</para>
<para>La <var>liste d&textrsquo;options</var>, si présente, est une liste ponctuée par des
virgules.  La <var>date de parution</var> est optionnelle.  Si elle est
présente, elle doit avoir le format <var>AAAA/MM/JJ</var>.  Si vous demandez
une <var>date de parution</var> et que la date du paquetage installé sur
votre système est antérieure, alors vous obtiendrez un avertissement à
l&textrsquo;écran et dans le journal de compilation du genre de <code>You have
requested, on input line 4, version `2038/01/19' of document class
article, but only version `2014/09/29 v1.4h Standard LaTeX document
class' is available.</code>
</para>
<para>La variante de la commande <code>\LoadClassWithOptions</code> utilise la liste
des options de la classe courante.  Cela veut dire qu&textrsquo;elle ignore toute
options passée via <code>\PassOptionsToClass</code>.  Ceci est une commande de
commodité qui vous permet de construire une nouvelle classe en
l&textrsquo;héritant d&textrsquo;une classe existante, telle que la classe standarde
<code>article</code>, sans avoir à gérer les options qui furent passée.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ExecuteOptions&lbrace;<var>liste d'options</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="106">\ExecuteOptions</indexterm></findex>
<para>Pour chaque option <var>option</var> de la <var>liste d&textrsquo;options</var>, dans
l&textrsquo;ordre d&textrsquo;apparition, cette commande exécute la commande
<code>\ds&arobase;<var>option</var></code>.  Si cette commande n&textrsquo;est pas définie, alors
l&textrsquo;option <var>option</var> est ignorée.
</para>
<para>Ceci peut être utilisé pour fournir d&textrsquo;un liste d&textrsquo;option par défaut avant
le <code>\ProcessOptions</code>.  Par exemple, si dans un fichier de classe
vous désirez utiliser par défaut la taille de police 11pt alors vous
devriez spécifier <code>\ExecuteOptions&lbrace;11pt&rbrace;\ProcessOptions\relax</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\NeedsTeXFormat&lbrace;<var>format</var>&rbrace;[<var>date du format</var>]</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="107">\NeedsTeXFormat</indexterm></findex>
<para>Spécifie le format sous lequel cette classe doit être utilisée.  Cette
directive est souvent donnée à la première ligne du fichier de classe,
et le plus souvent elle est utilisée de cette façon :
<code>\NeedsTeXFormat&lbrace;LaTeX2e&rbrace;</code>.  Lorsque un document utilisant cette
classe est traité, le nom du format donné ici doit s&textrsquo;accorder avec le
format qui est en cours d&textrsquo;exécution (y compris le fait que la chaîne
<var>format</var> est sensible à la casse).  Si il ne s&textrsquo;y accorde pas alors
l&textrsquo;exécution est interrompue par une erreur du genre de <samp>This file
needs format `LaTeX2e' but this is `xxx'.</samp>
</para>
<para>Pour spécifier une version du format dont vous savez qu&textrsquo;elle prend en
charge certaines fonctions, incluez l&textrsquo;argument optionnel <var>date du
format</var> correspondant au format où ces fonction furent implémentés.  Si
cette argument est présent il doit être de la forme <code>AAAA/MM/JJ</code>.
Si la version de format installée sur votre système est antérieure à la
<var>date du format</var> alors vous obtiendrez un avertissement du genre de
<samp>You have requested release `2038/01/20' of LaTeX, but only release
`2016/02/01' is available.</samp>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\OptionNotUsed</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="108">\OptionNotUsed</indexterm></findex>
<para>Ajoute l&textrsquo;option courante à la liste des options non utilisées.  Ne peut
être utilisé qu&textrsquo;au sein de l&textrsquo;argument <var>code</var> de
<code>\DeclareOption</code> ou <code>\DeclareOption*</code>.
</para>
<!-- c I cannot reproduce this behavior as it is documented in clsguide. -->
<!-- c In the absence of a @code{\DeclareOption*} declaration, @LaTeX{} issues -->
<!-- c on the console a warning like @code{LaTeX Warning: Unused global -->
<!-- c option(s): [unusedoption].} with the list of not-used options when it -->
<!-- c reaches @code{\begin@{document@}}. -->

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PassOptionsToClass&lbrace;<var>liste d'options</var>&rbrace;&lbrace;<var>nom de la classe</var>&rbrace;</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\PassOptionsToPackage&lbrace;<var>liste d'options</var>&rbrace;&lbrace;<var>nom du paquetage</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="109">\PassOptionsToClass</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="110">\PassOptionsToPackage</indexterm></findex>
<para>Ajoute les options de la liste ponctuée par des virgules <var>option
list</var> aux options utilisée par toute commande ultérieure
<code>\RequirePackage</code> ou <code>\usepackage</code> pour le paquetage
<var>nom du paquetage</var> ou la classe <var>nom de la classe</var>.
</para>
<para>La raison d&textrsquo;être de ces commande est que vous pouvez charger un
paquetage autant de fois que vous le voulez sans options, mais que si
voulez passer des options alors vous ne pouvez les fournir qu&textrsquo;au premier
chargement. Charger un paquetage avec des options plus d&textrsquo;une fois
produit une erreur du genre de <code>Option clash for package toto.</code>
(&latex; lance l&textrsquo;erreur même s&textrsquo;il n&textrsquo;y a pas de conflit entre les
options.)
</para>
<para>Si votre propre code introduit un paquetage deux fois alors vous pouvez
réduire cela en une fois, par exemple en remplaçant les deux
<code>\RequirePackage[landscape]&lbrace;geometry&rbrace;\RequirePackage[margins=1in]&lbrace;geometry&rbrace;</code>
par un seul <code>\RequirePackage[landscape,margins=1in]&lbrace;geometry&rbrace;</code>.
Mais si vous chargez un paquetage qui à son tour en charge un autre
alors vous devez mettre en queue les options que vous désirez pour cet
autre paquetage.  Par exemple, supposons que le paquetage <code>toto</code>
charge le paquetage <code>geometry</code>.  Au lieu de
<code>\RequirePackage&lbrace;toto&rbrace;\RequirePackage[draft]&lbrace;graphics&rbrace;</code> vous
devez écrire <code>\PassOptionsToPackage&lbrace;draft&rbrace;&lbrace;graphics&rbrace;
\RequirePackage&lbrace;toto&rbrace;</code>.  (Si <code>toto.sty</code> charge une option en
conflit avec ce que vous désirez alors vous devrez considérer une
modification de son code source.)
</para>
<para>Ces commandes sont également utiles aux utilisateurs de base et pas
seulement aux auteurs de classes et paquetage.  Par exemple, supposons
qu&textrsquo;un utilisateur veuille charger le paquetage <code>graphicx</code> avec
l&textrsquo;option <code>draft</code> et veuille également utiliser une classe
<code>toto</code> qui charge le paquetage <code>graphicx</code>, mais sans cette
option. L&textrsquo;utilisateur peut commencer son fichier &latex; avec
<code>\PassOptionsToPackage&lbrace;draft&rbrace;&lbrace;graphicx&rbrace;\documentclass&lbrace;toto&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProcessOptions</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProcessOptions*<var>\&arobase;options</var></itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="111">\ProcessOptions</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="112">\ProcessOptions*</indexterm></findex>
<para>Exécute le code pour chaque option que l&textrsquo;utilisateur a invoquée.  À
inclure dans le fichier classe sous la forme
<code>\ProcessOptions\relax</code> (à cause de l’existence de la variante
étoilée de la commande).
</para>
<para>Les options tombent dans deux catégories.  Les <dfn>options locales</dfn>
sont spécifiées pour un paquetage particulier au sein de l&textrsquo;argument
<var>options</var> dans <code>\PassOptionsToPackage&lbrace;<var>options</var>&rbrace;</code>,
<code>\usepackage[<var>options</var>]</code>, ou
<code>\RequirePackage[<var>options</var>]</code>.  Les <dfn>options globales</dfn> sont
celles données par l&textrsquo;utilisateur de la classe dans
<code>\documentclass[<var>options</var>]</code>. (Si une option est spécifiée à la
fois localement et globalement, alors elle est locale).
</para>
<para>Lorsque <code>\ProcessOptions</code> est appelé pour un paquetage
<file>pkg.sty</file>, il se produit ce qui suit :
</para><enumerate first="1" endspaces=" ">
<listitem>
<para>Pour chaque option <var>option</var> déclarée jusqu&textrsquo;à ce point avec
<code>\DeclareOption</code>, &latex; examine si cette option est soit globale
soit locale pour <code>pkg</code>. Si c&textrsquo;est le cas, il exécute le code
déclaré. Ceci est fait dans l&textrsquo;ordre de passage de ces options à
<file>pkg.sty</file>.
</para></listitem><listitem>
<para>Pour chaque option locale restante, il exécute la commande
<code>\ds&arobase;<var>option</var></code> si elle a été définie quelque part (autrement
que par un <code>\DeclareOption</code>) ; sinon, il exécute le code de
traitement par défaut des options donné dans <code>\DeclareOption*</code>. Si
aucun code de traitement par défaut n&textrsquo;a été déclaré, il produit un
message d&textrsquo;erreur. Ceci est fait dans l&textrsquo;ordre dans lequel ces options ont
été spécifiées.
</para></listitem></enumerate>

<para>Lorsque <code>\ProcessOptions</code> est appelé pour une classe il fonctionne
de la même manière à ceci près que toutes les options sont locales, et
que le code par défaut pour <code>\DeclareOption*</code> et
<code>\OptionNotUsed</code> plutôt qu&textrsquo;une erreur.
</para>
<para>La version étoilée <code>\ProcessOptions*</code> exécute le traitement des
options dans l&textrsquo;ordre spécifié par les commandes appelante, plutôt que
dans l&textrsquo;ordre de déclaration de la classe ou du paquetage. Pour un
paquetage, ceci signifie que les options globales sont traitées en
premier.
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProvidesClass&lbrace;<var>nom de la classe</var>&rbrace;[<var>date de parution</var> <var>brève information supplémentaire</var>]</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProvidesClass&lbrace;<var>nom de la classe</var>&rbrace;[<var>date de parution</var>]</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProvidesPackage&lbrace;<var>nom du paquetage</var>&rbrace;[<var>date de parution</var> <var>brève information supplémentaire</var>]</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProvidesPackage&lbrace;<var>nom du paquetage</var>&rbrace;[<var>date de parution</var>]</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="113">\ProvidesClass</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="114">\ProvidesPackage</indexterm></findex>
<para>Identifie la classe ou le paquetage, en tapant un message sur la
console et dans le fichier journal.
</para>
<para>Lorsqu&textrsquo;un utilisateur écrit <code>\documentclass&lbrace;notecms&rbrace;</code> alors
&latex; charge le fichier <file>notecms.cls</file>.  De même, un utilisateur
écrivant <code>\usepackage&lbrace;essai&rbrace;</code> invite &latex; à charger le
fichier <file>essai.sty</file>.  Si le nom du fichier ne s&textrsquo;accorde pas à
l&textrsquo;argument <var>nom de la classe</var> ou <var>nom du paquetage</var> alors un
avertissement est produit. Ainsi, si vous invoquez
<code>\documentclass&lbrace;notecms&rbrace;</code>, et que le fichier the file
<file>notecms.cls</file> comprend la déclaration statement
<code>\ProvidesClass&lbrace;xxx&rbrace;</code> alors vous obtiendrez un avertissement du
genre de like <code>You have requested document class `notecms', but the
document class provides 'xxx'.</code>  Cet avertissement n&textrsquo;empêche pas
&latex; de traiter le reste du fichier de la classe normalement.
</para>
<para>Si vous incluez l&textrsquo;argument optionnel, alors vous devez inclure la date,
avant le premier espace s&textrsquo;il y en a, et elle doit avoir le format
<code>AAAA/MM/JJ</code>.  Le reste de l&textrsquo;argument est en format libre,
toutefois il identifie traditionnellement la classe, et est écrit
pendant la compilation à l&textrsquo;écran et dans le journal.  Ainsi, si votre
fichier <file>notecms.cls</file> contient la ligne
<code>\ProvidesClass&lbrace;smcmem&rbrace;[2008/06/01 v1.0 Classe note CMS]</code> la
première ligne de votre document est <code>\documentclass&lbrace;notecms&rbrace;</code>
alors vous pourrez voir <code>Document Class: notecms 2008/06/01 v1.0
Classe note CMS</code>.
</para>
<para>La date dans l&textrsquo;argument optionnel permet aux utilisateurs de classe et
de paquetage de demander à être avertis si la version de la classe ou du
paquetage installé sur leur système est antérieure à <var>date de
parution</var>, en utilisant les arguments optionnels comme dans
<code>\documentclass&lbrace;smcmem&rbrace;[2018/10/12]</code> ou
<code>\usepackage&lbrace;toto&rbrace;[[2017/07/07]]</code>.  (Notez que les utilisateurs
de paquetages incluent seulement rarement une date, et les utilisateurs
de classe presque jamais).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ProvidesFile&lbrace;<var>nom fichier</var>&rbrace;[<var>information supplémentaire</var>]</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="115">\ProvidesFile</indexterm></findex>
<para>Déclare un fichier autre que les fichiers principaux de classe ou de
paquetage, tel qu&textrsquo;un fichier de configuration ou un fichier de
définition de police. Mettez la commande dans ce fichier et vous
obtiendrez dans le journal une information du genre de <code>File:
essai.config 2017/10/12 fichier de configuration pour essai.cls</code> lorsque
<var>nom fichier</var> vaut <samp>essai.config</samp> et que <var>information
supplémentaire</var> vaut <samp>2017/10/12 fichier de configuration pour
essai.cls</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\RequirePackage[<var>liste d'options</var>]&lbrace;<var>nom du paquetage</var>&rbrace;[<var>date de parution</var>]</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\RequirePackageWithOptions&lbrace;<var>nom du paquetage</var>&rbrace;[<var>date de parution</var>]</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="116">\RequirePackage</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="117">\RequirePackageWithOptions</indexterm></findex>
<para>Charge un paquetage, comme la commande <code>\usepackage</code> pour les
auteurs de documents.  <xref label="Additional-packages"><xrefnodename>Additional packages</xrefnodename></xref>. Voici un exemple :
<code>\RequirePackage[landscape,margin=1in]&lbrace;geometry&rbrace;</code>.  Notez que
l&textrsquo;équipe de développement de &latex; recommande fortement l&textrsquo;utilisation
de ces commandes de préférence à l&textrsquo;<code>\input</code> de &tex; de base ;
voir le « Class Guide ».
</para>
<para>La <var>liste d&textrsquo;options</var>, si présente, est une liste ponctuée de
virgules.  La <var>date de parution</var>, si présente, doit avoir le format
<var>AAAA/MM/JJ</var>.  Si la date de parution du paquetage tel qu&textrsquo;il est
installé sur votre système est antérieure à <var>date de parution</var> alors
vous obtiendrez un avertissement du genre de <code>You have requested,
on input line 9, version `2017/07/03' of package jhtest, but only
version `2000/01/01' is available</code>.
</para>
<para>La variante <code>\RequirePackageWithOptions</code> utilise la liste d&textrsquo;options
de la classe courante. Ceci implique qu&textrsquo;elle ignore toute option passée
à la classe via <code>\PassOptionsToClass</code>.  C&textrsquo;est une commande de
commodité pour permettre facilement de construire des classes sur des
classes existantes sans avoir à gérer les options qui sont passées.
</para>
<para>La différence entre <code>\usepackage</code> et <code>\RequirePackage</code> est
mince. La commande <code>\usepackage</code> est à l&textrsquo;intention du fichier
document alors que <code>\RequirePackage</code> l&textrsquo;est à celle des fichiers
paquetage ou classe.  Ainsi, utiliser <code>\usepackage</code> avant la
commande <code>\documentclass</code> amène &latex; à produire une erreur du
genre de <code>\usepackage before \documentclass</code>, là où vous pouvez
utiliser <code>\RequirePackage</code>.
</para></tableitem></tableentry></table>


</subsection>
</section>
</chapter>
<node name="Fonts" spaces=" "><nodename>Fonts</nodename><nodenext automatic="on">Layout</nodenext><nodeprev automatic="on">Document classes</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Polices de caractères</sectiontitle>
<anchor name="Typefaces">Typefaces</anchor><!-- c old name -->

<cindex index="cp" spaces=" "><indexterm index="cp" number="88">polices de caractères</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="89">fontes</indexterm></cindex>

<para>&latex; gère les polices de caractères en vous offrant de puissantes
capacités. Notamment, son schéma <dfn>NFSS</dfn> vous permet de travailler
aisément avec les polices, ou <dfn>familles de fontes</dfn> dans votre
document (par exemple, voir <ref label="Font-styles"><xrefnodename>Font styles</xrefnodename></ref>).  De plus, les documents
&latex; peuvent utiliser la plupart des polices disponibles de nos
jours, y compris des versions de Times Roman, Helvetica, Courier, etc.
(Notez cependant que beaucoup de polices ne prennent pas en charge les
mathématiques).
</para>
<para>La première police dans le monde &tex; était Computer Modern,
développée par Donald Knuth.  Elle est la police par défaut pour les
documents &latex; et est encore la plus largement utilisée.  Mais
passer à une autre police n&textrsquo;implique la plupart du temps que peu de
commandes.  Par exemple, mettre ce qui suit dans votre préambule vous
donne une police simili-Palatino, ce qui est élégant et plus lisible sur
écran que bien d&textrsquo;autres polices, tout en continuant à vous permettre de
composer des mathématiques.  (Exemple fourni par Michael Sharpe,
<url><urefurl>https://math.ucsd.edu/~msharpe/RcntFnts.pdf</urefurl></url>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[osf]&lbrace;newpxtext&rbrace; % osf pour le texte, non les math
\usepackage&lbrace;cabin&rbrace; % sans serif
\usepackage[varqu,varl]&lbrace;inconsolata&rbrace; % sans serif tapuscrit
\usepackage[bigdelims,vvarbb]&lbrace;newpxmath&rbrace; % bb de STIX
\usepackage[cal=boondoxo]&lbrace;mathalfa&rbrace; % mathcal
</pre></example>

<noindent></noindent>
<para>De plus, les moteurs <command>xelatex</command> ou <command>lualatex</command> vous
permettent d&textrsquo;utiliser toute police sur votre système en format OpenType
ou TrueType (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).
</para>
<para>Le catalogue de polices de &latex;
(<url><urefurl>https://tug.org/FontCatalogue</urefurl></url>) donne des échantillons graphiques
de polices et du source à copier/coller pour utiliser un grand nombre de
polices, dont beaucoup prennent en charges les mathématiques.  Son but
est de couvrir toutes les polices libres pour l&textrsquo;alphabet latin
utilisables facilement avec &latex;.
</para>
<para>Plus ample information peut également être trouvée sur le &tex; Users
Group, à <url><urefurl>https://www.tug.org/fonts/</urefurl></url>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Paquetage fontenc</menutitle><menunode separator=". ">fontenc package</menunode><menudescription><pre xml:space="preserve">Codage des polices.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Styles de polices</menutitle><menunode separator=". ">Font styles</menunode><menudescription><pre xml:space="preserve">Sélectionnez romain, italique, etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Formats de polices</menutitle><menunode separator=". ">Font sizes</menunode><menudescription><pre xml:space="preserve">Choisir la taille du point.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Commandes police de bas niveau</menutitle><menunode separator=". ">Low-level font commands</menunode><menudescription><pre xml:space="preserve">Sélectionnez le codage, famille, série, allure.
</pre></menudescription></menuentry></menu>

<node name="fontenc-package" spaces=" "><nodename>fontenc package</nodename><nodenext automatic="on">Font styles</nodenext><nodeup automatic="on">Fonts</nodeup></node>
<section spaces=" "><sectiontitle>Le paquetage <code>fontenc</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="90">fonte, codage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="91">UTF-8, prise en charge des fontes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="92">T1</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="93">OT1</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="118">fontenc</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>codage_fonte</var>]&lbrace;fontenc&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>codage_fonte1</var>, <var>codage_fonte2</var>, ...]&lbrace;fontenc&rbrace;
</pre></example>

<para>Spécifie les codages de fonte.  Un codage de fonte est une application
des codes de caractères vers les glyphes de fonte utilisés pour composer
votre texte en sortie.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="119"><r>paquetage</r> <code>fontspec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="120"><code>fontspec</code>, <r>paquetage</r></indexterm></findex>

<para>Ce paquetage ne fonctionne que si vous utilisez le moteur
<code>pdflatex</code> (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).  Si vous utilisez les moteurs
<command>xelatex</command> ou <command>lualatex</command> alors utilisez à la place le
paquetage <code>fontspec</code>.
</para>
<para>La police originale de &tex;, Computer Modern, comprend un nombre
limité de caractères. Par exemple, pour faire des caractères accentués
ordinaires vous devez utiliser <code>\accent</code> (<pxref label="_005caccent"><xrefnodename>\accent</xrefnodename></pxref>) mais
cela désactive la césure.  Les utilisateurs de &tex; ont spécifié
plusieurs normes concernant l&textrsquo;accès aux ensembles élargis de caractères
fournis par les fontes modernes.  Si vous utilisez <command>pdflatex</command>
alors placez ceci dans le préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[T1]&lbrace;fontenc&rbrace;
</pre></example>

<noindent></noindent>
<para>cela active la prise en charge pour les langages européens les plus
répandus, notamment le français, l&textrsquo;italien, le polonais.  En
particulier, si vous avez des mots avec des lettres accentuées alors
&latex; gérera leur césure et le document en sortie peut faire l&textrsquo;objet
de copier/coller.  (La seconde ligne optionnelle vous permet de taper
directement les caractères accentués dans votre fichier source).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="121"><r>paquetage</r> <code>lmodern</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="122"><code>lmodern</code>, <r>paquetage</r></indexterm></findex>
 <findex index="fn" spaces=" "><indexterm index="fn" number="123"><r>paquetage</r> <code>cm-super</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="124"><code>cm-super</code>, <r>paquetage</r></indexterm></findex>

<para>Si vous utilisez un codage tel que <code>T1</code> et que les caractères ne
sont pas nets ou passent mal au zoom alors vos fontes sont probablement
définies par des cartes binaires (bitmap), on parle de fontes
matricielles ou Type&nbsp;3.  Si vous désirez des fontes vectorielles,
utilisez un paquetage tel que <code>lmodern</code> ou <code>cm-super</code>
pour obtenir des fontes vectorielles qui étendent celles utilisées par
défaut par &latex;.
</para>
<para>Pour chaque <var>codage_fonte</var> passé en option mais encore non déclaré,
ce paquetage charge les fichiers de définitions du codage, nommé
<file><var>codage_fonte</var>enc.def</file>.  Il règle aussi
<code>\encodingdefault</code> comme le dernier codage dans la liste d&textrsquo;option.
</para>
<para>Voici les valeurs usuelles pour <var>codage_fonte</var>.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">OT1</itemformat></item>
</tableterm><tableitem><para>Le codage original pour &tex;.  Limité quasiment aux lettres latines non accentués.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">OMS, OML</itemformat></item>
</tableterm><tableitem><para>Codage des symboles et des lettres mathématiques.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">T1</itemformat></item>
</tableterm><tableitem><para>Texte étendu de &tex;.  Appelé parfois le codage Cork du nom de la
conférence du groupe d&textrsquo;utilisateurs &tex; durant laquelle il fut
élaboré.  Donne accès à la plupart des caractères accentués
européens. C&textrsquo;est l&textrsquo;option la plus fréquente pour ce paquetage.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">TS1</itemformat></item>
</tableterm><tableitem><para>Codage Texte Companion.
</para></tableitem></tableentry></table>

<noindent></noindent>
<para>Par défaut &latex; charge <code>OML</code>, <code>T1</code>, <code>OT1</code>, et ensuite
<code>OMS</code>, et règle le codage par défaut à <code>OT1</code>.
</para>
<para>Même si vous n&textrsquo;utilisez pas de lettres accentuées, vous pourriez avoir
besoin d&textrsquo;un codage de font si la fonte que vous utilisez l&textrsquo;exige.
</para>
<para>Si vous utilisez des fontes codée en <code>T1</code> autre que celles de la
police par défaut Computer Modern, alors vous pourriez avoir besoin de
charger le paquetage qui sélectionne vos fontes avant de charger
<file>fontenc</file>, de sorte à empêcher le système de charger l&textrsquo;une des
fontes codées en <code>T1</code> de la police par défaut.
</para>
<para>L&textrsquo;équipe du projet &latex; a réservé les noms de codage commençant
par : <samp>T</samp> pour les codages standards de texte à 256 caractères,
<samp>TS</samp> pour les symboles qui étendent les codages T correspondants,
<samp>X</samp> pour les codages de test, <samp>M</samp> pour les codages standards
de math à 256 caractères, <samp>A</samp> pour les applications spéciales,
<samp>OT</samp> pour les codages standards de texte à 128 caractères, et
<samp>OM</samp> pour les codages standards de math à 128 caractères (<samp>O</samp>
est l&textrsquo;initiale d&textrsquo;<samp>obsolete</samp>).
</para>
<para>Ce paquetage fournit un certain nombre de commandes, détaillées
ci-dessous. Beaucoup d&textrsquo;entre elles sont spécifiques à un codage, aussi
si vous avez défini une commande qui fonctionne pour un codage mais que
le codage courant en est différent alors la commande n&textrsquo;est pas active.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::           ">\DeclareFontEncoding</menunode><menudescription><pre xml:space="preserve">Définit un codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">\DeclareTextAccent</menunode><menudescription><pre xml:space="preserve">Définit un accent dans le codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">\DeclareTextAccentDefault</menunode><menudescription><pre xml:space="preserve">Repli pour utiliser un accent dans le codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::  ">\DeclareTextCommand &amp; \ProvideTextCommand</menunode><menudescription><pre xml:space="preserve">Nouvelle commande spécifique à un codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::  ">\DeclareTextCommandDefault &amp; \ProvideTextCommandDefault</menunode><menudescription><pre xml:space="preserve">Repli pour commandes spécifiques à un codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">\DeclareTextComposite</menunode><menudescription><pre xml:space="preserve">Accès direct à un glyphe accentué, dans le codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">\DeclareTextCompositeCommand</menunode><menudescription><pre xml:space="preserve">Code à exécuter pour une numéro de glyphe, dans le codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::              ">\DeclareTextSymbol</menunode><menudescription><pre xml:space="preserve">Définit un symbole dans le codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::       ">\DeclareTextSymbolDefault</menunode><menudescription><pre xml:space="preserve">Repli d&textrsquo;un symbole dans le codage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::           ">\LastDeclaredEncoding</menunode><menudescription><pre xml:space="preserve">Sauvegarde le dernier codage déclaré.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\UseTextSymbol &amp; \UseTextAccent</menunode><menudescription><pre xml:space="preserve">Passe temporairement à un autre codage.
</pre></menudescription></menuentry></menu>


<node name="_005cDeclareFontEncoding" spaces=" "><nodename>\DeclareFontEncoding</nodename><nodenext automatic="on">\DeclareTextAccent</nodenext><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareFontEncoding</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="94">fonte, déclarer le codage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="95">codage de fonte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="96">accents, définir</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="125">\DeclareFontEncoding</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareFontEncoding&lbrace;<var>codage</var>&rbrace;&lbrace;<var>réglages-texte</var>&rbrace;&lbrace;<var>réglages-math</var>&rbrace;
</pre></example>

<para>Déclare le codage de fonte <var>codage</var>.  Sauvegarde également la valeur
de <var>codage</var> dans <code>\LastDeclaredEncoding</code>
(<pxref label="_005cLastDeclaredEncoding"><xrefnodename>\LastDeclaredEncoding</xrefnodename></pxref>).
</para>
<para>Le fichier <file>t1enc.def</file> contient cette ligne (suivie de bien
d&textrsquo;autres) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareFontEncoding&lbrace;T1&rbrace;&lbrace;&rbrace;&lbrace;&rbrace;
</pre></example>

<para>Les <var>réglages-texte</var> sont les commandes que &latex; exécutera
chaque fois qu&textrsquo;il commute d&textrsquo;un codage à une autre avec les commandes
<code>\selectfont</code> et <code>\fontencoding</code>.  Les <var>réglages-math</var>
sont les commandes que &latex; utilise lorsque la fonte est accédée en
tant qu&textrsquo;alphabet mathématique.
</para>
<para>&latex; ignore tout espace au sein de <var>réglages-texte</var> et
<var>réglages-math</var>, de sorte à prévenir toute insertion non voulue
d&textrsquo;espace en sortie.
</para>
<para>Si vous inventez un codage vous devriez choisir un nom de deux ou trois
lettres commençant par <samp>L</samp> pour <samp>local</samp>, ou <samp>E</samp> pour
<samp>experimental</samp>.
</para>
<para>Notez que les fichiers de définition de codage de sortie sont
potentiellement lus plusieurs fois par &latex;, ainsi utiliser, par
ex.&noeos; <code>\newcommand</code> peut causer une erreur.  De plus, il est
préférable que de tels fichiers contiennent une ligne
<code>\ProvidesFile</code> (<pxref label="Class-and-package-commands"><xrefnodename>Class and package commands</xrefnodename></pxref>).
</para>
<para>Notez aussi qu&textrsquo;il est préférable de n&textrsquo;utiliser les commandes en
<code>\...Default</code> que dans un paquetage, et non dans les fichiers de
définition de codage, puisque ces fichiers ne devraient contenir que des
déclarations spécifiques à ce codage-là.
</para>

</subsection>
<node name="_005cDeclareTextAccent" spaces=" "><nodename>\DeclareTextAccent</nodename><nodenext automatic="on">\DeclareTextAccentDefault</nodenext><nodeprev automatic="on">\DeclareFontEncoding</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextAccent</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="97">fonte, codage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="98">accents, définir</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="126">\DeclareTextAccent</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextAccent&lbrace;<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;&lbrace;<var>cassetin</var>&rbrace;
</pre></example>

<para>Définit un accent, à mettre au dessus d&textrsquo;autres glyphe, au sein du codage
<var>codage</var> à la position <var>cassetin</var>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="99">cassetin, fonte</indexterm></cindex>
<para>Un <dfn>cassetin</dfn> est le numéro identifiant un glyphe au sein d&textrsquo;une
fonte.
<ignore>
Au temps de la typographie à l'ancienne, une @dfn{casse} était d'un
caisse en bois contenant tous les caractères en plomb d'une même fonte,
c.-à-d.@: partageant la même taille, allure, graisse, etc. Cette caisse
était subdivisée en compartiments appelés @dfn{cassetins} dans lesquels
on rangeait les caractères correspondant au même glyphe. C'est pourquoi,
en ce qui concerne la typographie numérique, nous recyclons le terme
cassetin pour désigner le numéro d'un glyphe au sein d'une fonte.
</ignore>
</para>
<para>La ligne suivante de <file>t1enc.def</file> déclare que pour fabriquer un
accent circonflexe comme dans <code>\^A</code>, le système va mettre l&textrsquo;accent
dans du cassetin 2 sur le caractère <samp>A</samp>, qui est représenté en
ASCII comme 65.  (Ceci vaut à moins qu&textrsquo;il y ait une déclaration
<code>DeclareTextComposite</code> ou <code>\DeclareTextCompositeCommand</code>
pertinente ; <pxref label="_005cDeclareTextComposite"><xrefnodename>\DeclareTextComposite</xrefnodename></pxref>) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextAccent&lbrace;\^&rbrace;&lbrace;T1&rbrace;&lbrace;2&rbrace;
</pre></example>

<para>Si <var>cmd</var> a déjà été défini, alors <code>\DeclareTextAccent</code> ne
produit pas d&textrsquo;erreur mais il enregistre la redéfinition dans le fichier
de transcription.
</para>

</subsection>
<node name="_005cDeclareTextAccentDefault" spaces=" "><nodename>\DeclareTextAccentDefault</nodename><nodenext automatic="on">\DeclareTextCommand &amp; \ProvideTextCommand</nodenext><nodeprev automatic="on">\DeclareTextAccent</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextAccentDefault</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="100">accents, définir</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="127">\DeclareTextAccent</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="128">\DeclareTextAccentDefault</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextAccentDefault&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;
</pre></example>

<para>S&textrsquo;il y a une commande d&textrsquo;accent <code>\<var>cmd</var></code> spécifique à un codage
mais qu&textrsquo;il n&textrsquo;y a aucun <code>\DeclareTextAccent</code> associé pour ce codage,
alors cette commande va prendre le relais en disant de l&textrsquo;utiliser comme
décrit pour <var>codage</var>.
</para>
<para>Par exemple, pour faire que le codage <code>OT1</code> soit le codage par
défaut pour l&textrsquo;accent <code>\&quot;</code>, déclarez ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextAccentDefault&lbrace;\&quot;&rbrace;&lbrace;OT1&rbrace;
</pre></example>

<noindent></noindent>
<para>Si vous tapez un <code>\&quot;</code> alors que le codage courant n&textrsquo;a pas de
définition pour cet accent, alors &latex; utilisera la définition issue
de <code>OT1</code>.
</para>
<para>c.-à-d.&noeos; que cette commande est équivalente l&textrsquo;appel suivant
(<pxref label="_005cUseTextSymbol-_0026-_005cUseTextAccent"><xrefnodename>\UseTextSymbol &amp; \UseTextAccent</xrefnodename></pxref>) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCommandDefault[1]&lbrace;\<var>cmd</var>&rbrace;
   &lbrace;\UseTextAccent&lbrace;<var>codage</var>&rbrace;&lbrace;\<var>cmd</var>&rbrace;&lbrace;#1&rbrace;&rbrace;
</pre></example>

<para>Notez que <code>\DeclareTextAccentDefault</code> fonctionne pour l&textrsquo;une
quelconque des commandes <file>fontenc</file> à un argument, et pas seulement
les commandes d&textrsquo;accent.
</para>

</subsection>
<node name="_005cDeclareTextCommand-_0026-_005cProvideTextCommand" spaces=" "><nodename>\DeclareTextCommand &amp; \ProvideTextCommand</nodename><nodenext automatic="on">\DeclareTextCommandDefault &amp; \ProvideTextCommandDefault</nodenext><nodeprev automatic="on">\DeclareTextAccentDefault</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextCommand</code> &amp; <code>\ProvideTextCommand</code></sectiontitle>

<anchor name="_005cDeclareTextCommand">\DeclareTextCommand</anchor>
<anchor name="_005cProvideTextCommand">\ProvideTextCommand</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="129">\DeclareTextCommand</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="130">\ProvideTextCommand</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\DeclareTextCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;[<var>nargs</var>]&lbrace;<var>defn&rbrace;</var>
\DeclareTextCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;[<var>nargs</var>][<var>défautargopt</var>]&lbrace;<var>défn</var>&rbrace;
</pre></example>

<para>ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ProvideTextCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\ProvideTextCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\ProvideTextCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;[<var>nargs</var>][<var>défautargopt</var>]&lbrace;<var>défn</var>&rbrace;
</pre></example>

<para>Définit la commande <code>\<var>cmd</var></code>, laquelle sera spécifique à un
codage.  Le nom <var>cmd</var> de la commande doit être précédé d&textrsquo;une
controblique, <code>\</code>.  Ces commandes ne peuvent apparaître que dans
le préambule.  Redéfinir <code>\<var>cmd</var></code> ne cause pas d&textrsquo;erreur. La
commande définie sera robuste même si le code dans <var>défn</var> est
fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Par exemple, le fichier <file>t1enc.def</file> contient la ligne suivante :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCommand&lbrace;\textperthousand&rbrace;&lbrace;T1&rbrace;&lbrace;\%\char 24 &rbrace;
</pre></example>

<para>Avec cela, vous pouvez exprimer des pour-milles comme ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[T1]&lbrace;fontenc&rbrace;  % dans le préambule
  ...
La limite légale est de \( 0,8 \)\textperthousand.
</pre></example>

<noindent></noindent>
<para>Si vous changez le codage de fonte en <code>OT1</code> alors vous obtenez une
erreur du genre de <samp>LaTeX Error: Command \textperthousand
unavailable in encoding OT1</samp>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="131">\DeclareTextSymbol</indexterm></findex>
<para>La variante <code>\ProvideTextCommand</code> agit de même, à ceci près qu&textrsquo;elle
ne fait rien si <code>\<var>cmd</var></code> est déjà définie.  La commande
<code>\DeclareTextSymbol</code> est plus rapide pour une simple association
d&textrsquo;un cassetin à un glyphe (<pxref label="_005cDeclareTextSymbol"><xrefnodename>\DeclareTextSymbol</xrefnodename></pxref>)
</para>
<para>Les arguments optionnels <var>nargs</var> et <var>défautargopt</var> jouent le même
rôle que dans <code>\newcommand</code> (<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></pxref>).
En un mot, <var>nargs</var> est un entier de 0 à 9 spécifiant le nombre
d&textrsquo;arguments que la commande <code>\<var>cmd</var></code> qu&textrsquo;on définit prend.  Ce
nombre inclut tout argument optionnel.  Omettre cet argument revient
au même que spécifier 0 pour dire que <code>\<var>cmd</var></code> n&textrsquo;a aucun
argument.  Et, si <var>défautargopt</var> est présent, alors le premier
argument de <code>\<var>cmd</var></code> est optionnel, et sa valeur par défaut est
<var>défautargopt</var> (ce qui peut être la chaîne vide).  Si
<var>défautargopt</var> n&textrsquo;est pas présent alors <code>\<var>cmd</var></code> ne prend
pas d&textrsquo;argument optionnel.
</para>

</subsection>
<node name="_005cDeclareTextCommandDefault-_0026-_005cProvideTextCommandDefault" spaces=" "><nodename>\DeclareTextCommandDefault &amp; \ProvideTextCommandDefault</nodename><nodenext automatic="on">\DeclareTextComposite</nodenext><nodeprev automatic="on">\DeclareTextCommand &amp; \ProvideTextCommand</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextCommandDefault</code> &amp; <code>\ProvideTextCommandDefault </code></sectiontitle>

<anchor name="_005cDeclareTextCommandDefault">\DeclareTextCommandDefault</anchor>
<anchor name="_005cProvideTextCommandDefault">\ProvideTextCommandDefault</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="132">\DeclareTextCommandDefault</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="133">\ProvideTextCommandDefault</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCommandDefault&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
</pre></example>

<para>ou :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ProvideTextCommandDefault&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
</pre></example>

<para>Donne une définition par défaut à <code>\<var>cmd</var></code>, pour la situation
où cette commande n&textrsquo;est pas définie dans le codage actuellement en
vigueur. La valeur par défaut doit utiliser uniquement les codages
connus comme disponibles.
</para>
<para>La déclaration ci-dessous rend <code>\copyright</code> disponible.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCommandDefault&lbrace;\copyright&rbrace;&lbrace;\textcircled&lbrace;c&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Elle utilise uniquement un codage (OMS) qui est toujours disponible.
</para>
<para>La déclaration <code>\DeclareTextCommandDefault</code> n&textrsquo;est pas destinée à
survenir dans un fichier de définition de codage puisque ces fichiers ne
doivent déclarer que des commandes à utiliser quand vous sélectionnez ce
codage. Au lieu de cela, elle devrait être dans un paquetage.
</para>
<para>Comme pour les commandes correspondantes qui ne sont pas en
<code>...Default</code>, la déclaration <code>\ProvideTextCommandDefault</code> a
exactement le même comportement que <code>\DeclareTextCommandDefault</code> à
ceci près qu&textrsquo;elle ne fait rien si <code>\<var>cmd</var></code> est déjà définie
(<pxref label="_005cDeclareTextCommand-_0026-_005cProvideTextCommand"><xrefnodename>\DeclareTextCommand &amp; \ProvideTextCommand</xrefnodename></pxref>).  De sorte qu&textrsquo;un
paquetage peut l&textrsquo;utiliser pour fournir une définition de repli que
d&textrsquo;autres paquetages peuvent améliorer.
</para>

</subsection>
<node name="_005cDeclareTextComposite" spaces=" "><nodename>\DeclareTextComposite</nodename><nodenext automatic="on">\DeclareTextCompositeCommand</nodenext><nodeprev automatic="on">\DeclareTextCommandDefault &amp; \ProvideTextCommandDefault</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextComposite</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="101">accents, définir</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="134">\DeclareTextComposite</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextComposite&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;&lbrace;<var>objet_simple</var>&rbrace;&lbrace;<var>cassetin</var>&rbrace;
</pre></example>

<para>Accède à un glyphe accentué directement, c.-à-d.&noeos; sans avoir à placer
une accent au dessus d&textrsquo;un caractère séparé.
</para>
<para>La ligne suivante extraite de <file>t1enc.def</file> signifie que <code>\^o</code>
aura pour effet que &latex; compose le <samp>o</samp> bas-de-casse en prenant
le caractère directement du cassetin 224 de la fonte.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextComposite&lbrace;\^&rbrace;&lbrace;T1&rbrace;&lbrace;o&rbrace;&lbrace;244&rbrace;
</pre></example>

<para><xref label="fontenc-package"><xrefnodename>fontenc package</xrefnodename></xref>, pour une liste des codages
usuels. L&textrsquo;<var>objet_simple</var> devrait être un seul caractère ou une seule
commande.  L&textrsquo;argument <var>cassetin</var> est d&textrsquo;ordinaire un entier positif
représenté en décimal (bien que les notations octale ou hexadécimale
soient possibles).  Normalement \<var>cmd</var> a déjà été déclarée pour ce
codage, soit avec <code>\DeclareTextAccent</code> soit avec un
<code>\DeclareTextCommand</code> à un argument.  Dans <file>t1enc.def</file>, la
ligne ci-dessus suit la commande
<code>\DeclareTextAccent&lbrace;\^&rbrace;&lbrace;T1&rbrace;&lbrace;2&rbrace;</code>.
</para>

</subsection>
<node name="_005cDeclareTextCompositeCommand" spaces=" "><nodename>\DeclareTextCompositeCommand</nodename><nodenext automatic="on">\DeclareTextSymbol</nodenext><nodeprev automatic="on">\DeclareTextComposite</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextCompositeCommand</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="102">accents, définir</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="135">\DeclareTextCompositeCommand</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCompositeCommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;&lbrace;<var>arg</var>&rbrace;&lbrace;<var>code</var>&rbrace;
</pre></example>

<para>Une version plus générale de <code>\DeclareTextComposite</code> qui exécute un
code arbitraire avec <code>\<var>cmd</var></code>.
</para>
<para>Ceci permet que des accents sur <samp>i</samp> se comportent de la même façon
que des accents sur le i-sans-point, <code>\i</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCompositeCommand&lbrace;\'&rbrace;&lbrace;OT1&rbrace;&lbrace;i&rbrace;&lbrace;\'\i&rbrace;
</pre></example>

<para><xref label="fontenc-package"><xrefnodename>fontenc package</xrefnodename></xref>, pour une liste des codages usuels.  Normalement
<code>\<var>cmd</var></code> doit avoir été déjà déclarée avec
<code>\DeclareTextAccent</code> ou avec un <code>\DeclareTextCommand</code> à un
argument.
</para>

</subsection>
<node name="_005cDeclareTextSymbol" spaces=" "><nodename>\DeclareTextSymbol</nodename><nodenext automatic="on">\DeclareTextSymbolDefault</nodenext><nodeprev automatic="on">\DeclareTextCompositeCommand</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextSymbol</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="103">symbole, définition</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="136">\DeclareTextSymbol</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextSymbol&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;&lbrace;<var>cassetin</var>&rbrace;
</pre></example>

<para>Définit un symbole dans le codage <var>codage</var> à la position
<var>cassetin</var>.  Les symboles définis de cette manière sont destinés à
être utilisés dans du texte, et non dans des mathématiques.
</para>
<para>Par exemple, cette ligne extraite de <file>t1enc.def</file> déclare le numéro
du glyphe à utiliser pour «, le guillemet
gauche :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextSymbol&lbrace;\guillemotleft&rbrace;&lbrace;T1&rbrace;&lbrace;19&rbrace;
</pre></example>

<noindent></noindent>
<para>La commande <code>\DeclareTextCommand&lbrace;\guillemotleft&rbrace;&lbrace;T1&rbrace;&lbrace;\char
19&rbrace;</code> a le même effet mais est plus lente (<pxref label="_005cDeclareTextCommand-_0026-_005cProvideTextCommand"><xrefnodename>\DeclareTextCommand &amp;
\ProvideTextCommand</xrefnodename></pxref>).
</para>
<para><xref label="fontenc-package"><xrefnodename>fontenc package</xrefnodename></xref>, pour une liste des codages usuels.  Le
<var>cassetin</var> peut être spécifié en notation décimale, ou octale (comme
dans <code>'023</code>), ou hexadécimale (comme dans <code>&quot;13</code>), bien que la
notation décimale ait l&textrsquo;avantage d&textrsquo;être insensible à la redéfinition du
guillemet anglais simple ou double par un autre paquetage.
</para>
<para>Si <code>\<var>cmd</var></code> est déjà définie, alors <code>\DeclareTextSymbol</code>
ne produit pas une erreur, mais il inscrit que la redéfinition a eu lieu
dans le fichier
<!-- c xx TODO = .log ? -->
transcript.
</para>

</subsection>
<node name="_005cDeclareTextSymbolDefault" spaces=" "><nodename>\DeclareTextSymbolDefault</nodename><nodenext automatic="on">\LastDeclaredEncoding</nodenext><nodeprev automatic="on">\DeclareTextSymbol</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareTextSymbolDefault</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="104">accents, définir</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="137">\DeclareTextSymbol</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="138">\DeclareTextSymbolDefault</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextSymbolDefault&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>codage</var>&rbrace;
</pre></example>

<para>S&textrsquo;il y a une <code>\<var>cmd</var></code> de symbole spécifique à un codage mais
qu&textrsquo;il n&textrsquo;y a pas de <code>\DeclareTextSymbol</code> associé pour ce codage,
alors cette commande peut prendre le relais, en disant d&textrsquo;obtenir le
symbole selon la description faite pour <var>codage</var>.
</para>
<para>Par exemple, pour déclarer que si le codage courant ne donne pas de
signification à <code>\textdollar</code> alors on utilise celle issue
d&textrsquo;<code>OT1</code>, déclarer ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextSymbolDefault&lbrace;\textdollar&rbrace;&lbrace;OT1&rbrace;
</pre></example>

<para>c.-à-d.&noeos; que cette commande est équivalente à cet appel
(<pxref label="_005cUseTextSymbol-_0026-_005cUseTextAccent"><xrefnodename>\UseTextSymbol &amp; \UseTextAccent</xrefnodename></pxref>) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareTextCommandDefault&lbrace;\<var>cmd</var>&rbrace;
   &lbrace;\UseTextSymbol&lbrace;<var>codage</var>&rbrace;&lbrace;\<var>cmd</var>&rbrace;&rbrace;
</pre></example>

<!-- c xx TODO éclaircir ce qu'on entend par commande à zéro argument de -->
<!-- c @file{fontenc} -->
<para>Notez que <code>\DeclareTextSymbolDefault</code> peut être
utilisé pour définir une signification par défaut pour toute commande à
zéro argument de <file>fontenc</file>.
</para>

</subsection>
<node name="_005cLastDeclaredEncoding" spaces=" "><nodename>\LastDeclaredEncoding</nodename><nodenext automatic="on">\UseTextSymbol &amp; \UseTextAccent</nodenext><nodeprev automatic="on">\DeclareTextSymbolDefault</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\LastDeclaredEncoding</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="139">\LastDeclaredEncoding</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\LastDeclaredEncoding
</pre></example>

<para>Obtient le nom du dernier codage déclaré. La commande
<code>\DeclareFontEncoding</code> stocke le nom de sorte qu&textrsquo;on puisse le
retrouver avec cette commande (<pxref label="_005cDeclareFontEncoding"><xrefnodename>\DeclareFontEncoding</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple suivant, on compte sur <code>\LastDeclaredEncoding</code>
plutôt que de donner le nom du codage explicitement :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareFontEncoding&lbrace;JH1&rbrace;&lbrace;&rbrace;&lbrace;&rbrace;
\DeclareTextAccent&lbrace;\'&rbrace;&lbrace;\LastDeclaredEncoding&rbrace;&lbrace;0&rbrace;
</pre></example>


</subsection>
<node name="_005cUseTextSymbol-_0026-_005cUseTextAccent" spaces=" "><nodename>\UseTextSymbol &amp; \UseTextAccent</nodename><nodeprev automatic="on">\LastDeclaredEncoding</nodeprev><nodeup automatic="on">fontenc package</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\UseTextSymbol</code> &amp; <code>\UseTextAccent</code></sectiontitle>

<anchor name="_005cUseTextSymbol">\UseTextSymbol</anchor>
<anchor name="_005cUseTextAccent">\UseTextAccent</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="140">\UseTextSymbol</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="141">\UseTextAccent</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\UseTextSymbol&lbrace;<var>codage</var>&rbrace;&lbrace;\<var>cmd</var>&rbrace;
</pre></example>

<para>ou :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\UseTextAccent&lbrace;<var>codage</var>&rbrace;&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Utilise un symbole ou un accent qui n&textrsquo;est pas défini dans le codage
courant.
</para>
<para>En général, pour utiliser une commande <file>fontenc</file> dans un codage où
elle n&textrsquo;est pas définie, et si la commande n&textrsquo;a pas d&textrsquo;arguments, alors
vous pouvez utiliser quelque chose de ce genre :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\UseTextSymbol&lbrace;OT1&rbrace;&lbrace;\ss&rbrace;
</pre></example>

<noindent></noindent>
<para>ce qui est équivalent à ceci (notez que les accolades externes forment
un groupe, de sorte que &latex; revient au codage précédent après le
<code>\ss</code>) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\fontencoding&lbrace;OT1&rbrace;\selectfont\ss&rbrace;
</pre></example>

<para>De même, pour utiliser une commande <file>fontenc</file> dans un codage où
elle n&textrsquo;est pas définie, et si la commande a un argument, vous pouvez
l&textrsquo;utiliser ainsi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\UseTextAccent&lbrace;OT1&rbrace;&lbrace;\'&rbrace;&lbrace;a&rbrace;
</pre></example>

<noindent></noindent>
<para>ce qui est équivalent à cela (encore une fois, notez les accolades
externes formant un groupe) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;fontencoding&lbrace;OT1&rbrace;\selectfont
   \'&lbrace;\fontencoding&lbrace;<var>cdg_en_vigueur</var>&rbrace;\selectfont a&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Ci-dessus, <var>cdg_en_vigueur</var> est le codage en vigueur avant cette
séquence de commandes, de sorte que <samp>a</samp> est composé en utilisant le
codage courant, et seulement l&textrsquo;accent est pris de <code>OT1</code>.
</para>
</subsection>
</section>
<node name="Font-styles" spaces=" "><nodename>Font styles</nodename><nodenext automatic="on">Font sizes</nodenext><nodeprev automatic="on">fontenc package</nodeprev><nodeup automatic="on">Fonts</nodeup></node>
<section spaces=" "><sectiontitle>styles des polices</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="105">styles de police</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="106">styles typographiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="107">styles de texte</indexterm></cindex>

<para>Les commandes de styles suivantes sont prises en charge par &latex;.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="108">forme déclarative des commandes de style de police</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="109">déclarative, forme des commandes de style de police</indexterm></cindex>
<para>Dans le tableau ci-dessous listant des commandes, les commandes en
<code>\text…</code> sont utilisées avec un argument, comme dans
<code>\textit&lbrace;texte&rbrace;</code>. C&textrsquo;est la forme préférée. Mais affichée à sa
suite, entre parenthèses, est la <dfn>forme déclarative</dfn> correspondante,
qui est souvent utile. Cette forme ne prend pas arguments comme dans
<code>&lbrace;\itshape <var>texte</var>&rbrace;</code>. La portée la forme déclarative s&textrsquo;étend
jusqu&textrsquo;à la prochaine commande de type style ou jusqu&textrsquo;à la fin du groupe
actuel. De plus, chacune a une forme par environnement comme
<code>\begin&lbrace;itshape&rbrace;…\end&lbrace;itshape&rbrace;</code>, que l&textrsquo;on décrit plus
amplement à la fin de cette rubrique.
</para>
<para>Ces commandes, dans n&textrsquo;importe laquelle des trois formes, sont
cumulatives ; par exemple, vous pouvez dire aussi bien
<code>\sffamily\bfseries</code> que <code>\bfseries\sffamily</code> pour obtenir du
gras sans empattement.
</para>
<anchor name="_005cnocorrlist">\nocorrlist</anchor>
<anchor name="_005cnocorr">\nocorr</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="142">\nocorrlist</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="143">\nocorr</indexterm></findex>
<para>Un avantage de ces commandes est qu&textrsquo;elles fournissent automatiquement
une correction d&textrsquo;italique si nécessaire (<pxref label="_005c_002f"><xrefnodename>\/</xrefnodename></pxref>). Plus précisément,
elles insèrent la correction italique à moins que le caractère suivant
dans la liste <code>\nocorrlist</code>, cette liste consistant par défaut en
le point et la virgule.  Pour supprimer l&textrsquo;insertion automatique de la
correction italique, utilisez <code>\nocorr</code> au début ou à la fin de
l&textrsquo;argument de la commande, comme dans <code>\textit&lbrace;\nocorr text&rbrace;</code> ou
<code>\textsc&lbrace;text \nocorr&rbrace;</code>.
</para>

<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">\textrm (\rmfamily)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="144">\textrm</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="145">\rmfamily</indexterm></findex>
<para>Romain.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textit (\itshape)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="146">\textit</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="147">\itshape</indexterm></findex>
<para>Italique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textmd (\mdseries)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="148">\textmd</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="149">\mdseries</indexterm></findex>
<para>Poids moyen (par défaut).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textbf (\bfseries)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="150">\textbf</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="151">\bfseries</indexterm></findex>
<para>Gras.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textup (\upshape)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="152">\textup</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="153">\upshape</indexterm></findex>
<para>Droit (par défaut). Le contraire d&textrsquo;incliné.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textsl (\slshape)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="154">\textsl</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="155">\slshape</indexterm></findex>
<para>Inclinée.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textsf (\sffamily)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="156">\textsf</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="157">\sffamily</indexterm></findex>
<para>Sans empattement.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textsc (\scshape)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="158">\textsc</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="159">\scshape</indexterm></findex>
<para>Petites capitales.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\texttt (\ttfamily)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="160">\texttt</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="161">\ttfamily</indexterm></findex>
<para>Tapuscrit, encore appelé « machine à écrire ».
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\textnormal (\normalfont)</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="162">\textnormal</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="163">\normalfont</indexterm></findex>
<para>Police principale du document.
</para>
</tableitem></tableentry></table>

<cindex index="cp" spaces=" "><indexterm index="cp" number="110">emphasis</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="164">\emph</indexterm></findex>
<para>Bien qu&textrsquo;elle change également la fonte, la commande
<code>\emph&lbrace;<var>texte</var>&rbrace;</code> est sémantique, pour que <var>texte</var> soit
mis en valeur, et ne devrait pas être utilisé en remplacement de
<code>\textit</code>.  Par exemple, le résultat de <code>\emph&lbrace;<var>texte
début</var> \emph&lbrace;<var>texte milieu</var>&rbrace; <var>texte fin</var>&rbrace;</code> est que <var>texte
début</var> et <var>texte fin</var> sont en italique, mais <var>texte milieu</var> est
en romain.
</para>
<para>&latex; fournit également les commandes suivantes, qui font passer
inconditionnellement à un style donné, c.-à-d.&noeos; <emph>ne</emph> sont
<emph>pas</emph> cumulatives. Elles sont utilisées déclarativement :
<code>&lbrace;\<var>cmd</var> ... &rbrace;</code> au lieu de <code>\<var>cmd</var>&lbrace;...&rbrace;</code>.
</para>
<para>(Les commandes inconditionnelle ci-dessous sont une version plus ancienne
de la commutation de fonte. Les commandes qui précèdent sont une
amélioration dans les plupart des circonstances ; toutefois il arrive
qu&textrsquo;une commutation inconditionnelle soit ce dont on a besoin).
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="165">\bf</indexterm>\bf</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="111">gras</indexterm></cindex>
<para>Passage en <b>gras</b>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="166">\cal</indexterm>\cal</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="112">lettres de script pour les mathématiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="113">lettres calligraphiques pour les mathématiques</indexterm></cindex>
<para>Passage en lettres calligraphiques pour les mathématiques.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="167">\em</indexterm>\em</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="114">accent</indexterm></cindex>
<para>Accent (italique dans romain, romain dans italiques).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="168">\il</indexterm>\il</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="115">italique</indexterm></cindex>
<para>Italique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="169">\rm</indexterm>\rm</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="116">police romaine</indexterm></cindex>
<para>Romain.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="170">\sc</indexterm>\sc</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="117">police petites capitales</indexterm></cindex>
<para>Les petites capitales.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="171">\sf</indexterm>\sf</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="118">sans empattement</indexterm></cindex>
<para>Sans empattement.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="172">\sl</indexterm>\sl</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="119">police inclinée</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="120">police oblique</indexterm></cindex>
<para>Incliné (oblique).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="173">\tt</indexterm>\tt</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="121">police machine à écrire</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="122">police tapuscrit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="123">police de largeur fixe</indexterm></cindex>
<para>Tapuscrit, encore appelé « Machine à écrire » (largeur fixe).
</para>
</tableitem></tableentry></ftable>


<para>La commande <code>\em</code> est la version inconditionnelle de <code>\emph</code>.
</para>
<para>Les commandes suivantes sont à utiliser en mode math.  Elle ne sont pas
cumulatives, ainsi <code>\mathbf&lbrace;\mathit&lbrace;<var>symbole</var>&rbrace;&rbrace;</code> ne crée
pas un <var>symbole</var> en gras italiques ; au lieu de cela, il sera juste
en italique. C&textrsquo;est ainsi car typiquement les symboles mathématiques ont
besoin d&textrsquo;être toujours traités typographiquement de la même manière,
indépendamment de ce qui les entoure.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">\mathrm</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="174">\mathrm</indexterm></findex>
<para>Romain, pour une utilisation en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\mathbf</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="175">\mathbf</indexterm></findex>
<para>Gras, pour une utilisation en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\mathsf</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="176">\mathsf</indexterm></findex>
<para>Sans empattement, pour une utilisation en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\mathtt</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="177">\mathtt</indexterm></findex>
<para>Tapuscrit, pour une utilisation en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\mathit</itemformat></item>
<itemx spaces=" "><itemformat command="code">(\mit)</itemformat></itemx>
</tableterm><tableitem><para>Italique, pour une utilisation en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\mathnormal</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="178">\mathnormal</indexterm></findex>
<para>Pour une utilisation en mode mathématique, par exemple dans un autre déclaration de type style.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\mathcal</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="179">\mathcal</indexterm></findex>
<para>Lettres calligraphiques, pour une utilisation en mode mathématique.
</para>
</tableitem></tableentry></table>

<anchor name="_005cmathversion">\mathversion</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="180">\mathversion</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="124">mathématiques, gras</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="125">gras, mathématiques</indexterm></cindex>
<para>En outre, la commande <code>\mathversion&lbrace;bold&rbrace;</code> peut être utilisée
pour commuter en caractères gras les lettres et les symboles dans les
formules. <code>\mathversion&lbrace;normal&rbrace;</code> restaure la valeur par défaut.
</para>
<anchor name="_005coldstylenums">\oldstylenums</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="181">\oldstylenums</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="126">chiffres elzéviriens</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="127">elzéviriens, chiffres</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="128">chiffres minuscules</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="129">chiffres bas-de-casse</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="130">chiffres français</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="131">chiffres non alignés</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="132">chiffres suspendus</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="133">chiffres Didot</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="134">chiffres alignés</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="182"><r>paquetage</r> <code>textcomp</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="183"><code>textcomp</code>, <r>paquetage</r></indexterm></findex>

<para>Enfin, la commande <code>\oldstylenums&lbrace;<var>chiffres</var>&rbrace;</code> sert à
composer des chiffres dits <dfn>elzéviriens</dfn>, ou <dfn>non alignés</dfn>, qui
ont des hauteurs et profondeurs (et parfois largeurs) distincts de
l&textrsquo;alignement standard des chiffres dits <dfn>Didot</dfn>, ou <dfn>alignés</dfn>,
qui ont tous la même hauteur que les lettres capitales.  Les polices
&latex; par défaut prennent en charge cela, et respecteront
<code>\textbf</code> (mais pas les autres styles, il n&textrsquo;y a pas de elzévirien
italique pour les chiffres en Computer Modern). Beaucoup d&textrsquo;autres
polices ont des chiffres elzévirien aussi ; parfois des options de
paquetage sont mises à disposition pour en faire le style par défaut.
Article de FAQ : <url><urefurl>https://www.texfaq.org/FAQ-osf</urefurl></url>.
</para>
</section>
<node name="Font-sizes" spaces=" "><nodename>Font sizes</nodename><nodenext automatic="on">Low-level font commands</nodenext><nodeprev automatic="on">Font styles</nodeprev><nodeup automatic="on">Fonts</nodeup></node>
<section spaces=" "><sectiontitle>tailles des polices</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="135">tailles de police</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="136">tailles des polices de caractères</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="137">tailles de texte</indexterm></cindex>

<para>Les commandes de type de taille standardes suivantes sont pris en charge
par &latex;.  Le tableau indique le nom de la commande et taille
utilisée (en points) correspondant réellement pour la police avec les
options <samp>10pt</samp>, <samp>11pt</samp>, et <samp>12pt</samp> de classe de document,
respectivement (<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="184">\tiny</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="185">\scriptsize</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="186">\footnotesize</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="187">\small</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="188">\normalsize</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="189">\large</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="190">\Large</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="191">\LARGE</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="192">\huge</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="193">\Huge</indexterm></findex>


<multitable endspaces=" "><columnprototypes><columnprototype bracketed="on"><code>\normalsize</code> (par défaut)<spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">24.88<spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">24.88<spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">24.88</columnprototype></columnprototypes>
<thead><row><entry command="headitem" spaces=" "><para>commande </para></entry><entry command="tab" spaces=" "><para><code>10pt</code> </para></entry><entry command="tab" spaces=" "><para><code>11pt</code> </para></entry><entry command="tab" spaces=" "><para><code>12pt</code>
</para></entry></row></thead><tbody><row><entry command="item" spaces=" "><para><code>\tiny</code>
</para></entry><entry command="tab" spaces=" "><para>5 </para></entry><entry command="tab" spaces=" "><para>6 </para></entry><entry command="tab" spaces=" "><para>6
</para></entry></row><row><entry command="item" spaces=" "><para><code>\scriptsize</code>
</para></entry><entry command="tab" spaces=" "><para>7 </para></entry><entry command="tab" spaces=" "><para>8 </para></entry><entry command="tab" spaces=" "><para>8
</para></entry></row><row><entry command="item" spaces=" "><para><code>\footnotesize</code>
</para></entry><entry command="tab" spaces=" "><para>8 </para></entry><entry command="tab" spaces=" "><para>9 </para></entry><entry command="tab" spaces="  "><para>10
</para></entry></row><row><entry command="item" spaces=" "><para><code>\small</code>
</para></entry><entry command="tab" spaces=" "><para>9 </para></entry><entry command="tab" spaces=" "><para>10 </para></entry><entry command="tab" spaces=" "><para>10,95
</para></entry></row><row><entry command="item" spaces=" "><para><code>\normalsize</code> (par défaut)
</para></entry><entry command="tab" spaces=" "><para>10 </para></entry><entry command="tab" spaces=" "><para>10.95 </para></entry><entry command="tab" spaces=" "><para>12
</para></entry></row><row><entry command="item" spaces=" "><para><code>\large</code>
</para></entry><entry command="tab" spaces=" "><para>12 </para></entry><entry command="tab" spaces=" "><para>12 </para></entry><entry command="tab" spaces="  "><para>14,4
</para></entry></row><row><entry command="item" spaces=" "><para><code>\Large</code>
</para></entry><entry command="tab" spaces=" "><para>14.4 </para></entry><entry command="tab" spaces=" "><para>14.4 </para></entry><entry command="tab" spaces=" "><para>17,28
</para></entry></row><row><entry command="item" spaces=" "><para><code>\LARGE</code>
</para></entry><entry command="tab" spaces=" "><para>17.28 </para></entry><entry command="tab" spaces=" "><para>17.28 </para></entry><entry command="tab" spaces=" "><para>20,74
</para></entry></row><row><entry command="item" spaces=" "><para><code>\huge</code>
</para></entry><entry command="tab" spaces=" "><para>20,74 </para></entry><entry command="tab" spaces="  "><para>20,74 </para></entry><entry command="tab" spaces=" "><para>24,88
</para></entry></row><row><entry command="item" spaces=" "><para><code>\Huge</code>
</para></entry><entry command="tab" spaces=" "><para>24.88 </para></entry><entry command="tab" spaces=" "><para>24.88 </para></entry><entry command="tab" spaces=" "><para>24.88
</para></entry></row></tbody></multitable>

<cindex index="cp" spaces=" "><indexterm index="cp" number="138">déclarative, forme des commandes de contrôle de la taille de police</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="139">forme déclarative des commandes de contrôle de la taille de police</indexterm></cindex>
<para>Les commandes énumérées ici sont des formes déclaratives (non des formes
par environnement), vu que c&textrsquo;est ainsi qu&textrsquo;on les utilise
typiquement. Comme dans l&textrsquo;exemple qui suit :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;quotation&rbrace; \small
  Le Tao que l'on peut nommer n'est pas le Tao éternel.
\end&lbrace;quotation&rbrace;
</pre></example>

<noindent></noindent>
<para>Dans ce qui précède, la portée de <code>\small</code> s&textrsquo;étend jusqu&textrsquo;à la fin
de l&textrsquo;environnement <code>quotation</code>.  Elle s&textrsquo;arrêterait également à la
prochaine commande de style ou à la fin du groupe courant, de sorte
qu&textrsquo;on aurait pu la mettre entre accolades <code>&lbrace;\small Ce texte est en
petits caractères.&rbrace;</code>.
</para>
<para>Essayer d&textrsquo;utiliser ces commandes en math, comme dans <code>$\small
mv^2/2$</code>, donne l&textrsquo;avertissement <samp>LaTeX Font Warning: Command \small
invalid in math mode</samp>, et la taille de fonte n&textrsquo;est pas changée. Pour
travailler avec un formule trop grande, le plus souvent la meilleure
option est d&textrsquo;utiliser l&textrsquo;environnement <code>displaymath</code> (<pxref label="Math-formulas"><xrefnodename>Math
formulas</xrefnodename></pxref>), ou l&textrsquo;un des environnements fournis par le paquetage
<code>amsmath</code>.  Pour des mathématiques dans le texte, comme dans un
tableau de formules, une alternative est quelque chose du genre de
<code>&lbrace;\small $mv^2/2$&rbrace;</code>.  (Il arrive que <code>\scriptsize</code> et
<code>\scriptstyle</code> soient pris l&textrsquo;un pour l&textrsquo;autre. Les deux changent la
taille mais le dernier change nombre d&textrsquo;autres aspects conditionnant la
composition des mathématiques. <xref label="Math-styles"><xrefnodename>Math styles</xrefnodename></xref>).
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="140">forme par environnement des commandes de contrôle de la taille de police</indexterm></cindex>
<para>Une <dfn>forme par environnement</dfn> de chacune de ces commandes est également
définie ; par exemple, <code>\begin&lbrace;tiny&rbrace;...\end&lbrace;tiny&rbrace;</code>. Toutefois,
en pratique cette forme peut aisément mener à des espaces indésirables au
début et/ou à la fin de d&textrsquo;environnement si on n&textrsquo;y prête pas attention,
ainsi on risque en général moins de faire d&textrsquo;erreur si on s&textrsquo;en tient à la
forme déclarative.
</para>
<para>(Digression : techniquement, vu la façon dont &latex; définit
<code>\begin</code> et <code>\end</code>, presque toutes les commandes qui ne
prennent pas d&textrsquo;argument on une forme par environnement. Mais dans
presque tous les cas ce serait juste une source de confusion de
l&textrsquo;utiliser. La raison pour mentionner spécifiquement la forme par
environnement des déclarations de taille de police est que cet usage
particulier n&textrsquo;est pas rare).
</para>
</section>
<node name="Low_002dlevel-font-commands" spaces=" "><nodename>Low-level font commands</nodename><nodeprev automatic="on">Font sizes</nodeprev><nodeup automatic="on">Fonts</nodeup></node>
<section spaces=" "><sectiontitle>commandes de fontes de bas niveau</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="141">commandes de fontes de bas niveau</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="142">commandes de fontes, de bas niveau</indexterm></cindex>

<para>Ces commandes sont principalement destinés aux auteurs de macros et
paquetages. Les commandes indiquées ici sont seulement un sous-ensemble
de celles disponibles.
<!-- c xx but it should be complete -->
<!-- c xx something about ultimately reading ENCFAM.fd? -->
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="low-level-font-commands-fontencoding">low level font commands fontencoding</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">\fontencoding&lbrace;codage&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="194">\fontencoding</indexterm></findex>
<para>Sélectionne le codage de police, le codage de la police utilisée en
sortie. Il y a un grand nombre de codages valides. Les plus usuels sont
<code>OT1</code>, le codage original de D.&noeos; Knuth pour la police Computer
Modern (la police par défaut), et <code>T1</code>, également désigné par
codage Cork, qui prend en charge les caractères accentués utilisés par
les langues européennes les plus parlées (allemand, français, italien,
polonais et d&textrsquo;autres encore), ce qui permet à &tex; de faire la césure
des mots contenant des lettres accentuées. Pour plus d&textrsquo;information, voir
<url><urefurl>https://ctan.org/pkg/encguide</urefurl></url>.
</para>
<anchor name="low-level-font-commands-fontfamily">low level font commands fontfamily</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\fontfamily&lbrace;<var>famille</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="195">\fontfamily</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="143">famille de polices</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="144">polices, catalogue</indexterm></cindex>
<para>Sélectionne la famille de polices.  La page web
<url><urefurl>https://www.tug.dk/FontCatalogue/</urefurl></url> donne un moyen de naviguer
facilement à travers un grand nombre des polices utilisées avec
&latex;.  Voici des exemples de quelques-unes des familles les plus
usuelles :
</para>
<multitable spaces=" " endspaces=" "><columnprototypes><columnprototype bracketed="on">font</columnprototype> <columnprototype bracketed="on">Computer Modern Typewriter XXXX</columnprototype></columnprototypes>
<tbody><row><entry command="item" spaces=" "><para><code>pag</code>
</para></entry><entry command="tab" spaces=" "><para>Avant Garde
</para></entry></row><row><entry command="item" spaces=" "><para><code>fvs</code>
</para></entry><entry command="tab" spaces=" "><para>Bitstream Vera Sans
</para></entry></row><row><entry command="item" spaces=" "><para><code>pbk</code>
</para></entry><entry command="tab" spaces=" "><para>Bookman
</para></entry></row><row><entry command="item" spaces=" "><para><code>bch</code>
</para></entry><entry command="tab" spaces=" "><para>Charter
</para></entry></row><row><entry command="item" spaces=" "><para><code>ccr</code>
</para></entry><entry command="tab" spaces=" "><para>Computer Concrete
</para></entry></row><row><entry command="item" spaces=" "><para><code>cmr</code>
</para></entry><entry command="tab" spaces=" "><para>Computer Modern
</para></entry></row><row><entry command="item" spaces=" "><para><code>cmss</code>
</para></entry><entry command="tab" spaces=" "><para>Computer Modern Sans Serif
</para></entry></row><row><entry command="item" spaces=" "><para><code>cmtt</code>
</para></entry><entry command="tab" spaces=" "><para>Computer Modern Typewriter
</para></entry></row><row><entry command="item" spaces=" "><para><code>pcr</code>
</para></entry><entry command="tab" spaces=" "><para>Courier
</para></entry></row><row><entry command="item" spaces=" "><para><code>phv</code>
</para></entry><entry command="tab" spaces=" "><para>Helvetica
</para></entry></row><row><entry command="item" spaces=" "><para><code>fi4</code>
</para></entry><entry command="tab" spaces=" "><para>Inconsolata
</para></entry></row><row><entry command="item" spaces=" "><para><code>lmr</code>
</para></entry><entry command="tab" spaces=" "><para>Latin Modern
</para></entry></row><row><entry command="item" spaces=" "><para><code>lmss</code>
</para></entry><entry command="tab" spaces=" "><para>Latin Modern Sans
</para></entry></row><row><entry command="item" spaces=" "><para><code>lmtt</code>
</para></entry><entry command="tab" spaces=" "><para>Latin Modern Typewriter
</para></entry></row><row><entry command="item" spaces=" "><para><code>pnc</code>
</para></entry><entry command="tab" spaces=" "><para>New Century Schoolbook
</para></entry></row><row><entry command="item" spaces=" "><para><code>ppl</code>
</para></entry><entry command="tab" spaces=" "><para>Palatino
</para></entry></row><row><entry command="item" spaces=" "><para><code>ptm</code>
</para></entry><entry command="tab" spaces=" "><para>Times
</para></entry></row><row><entry command="item" spaces=" "><para><code>uncl</code>
</para></entry><entry command="tab" spaces=" "><para>Uncial
</para></entry></row><row><entry command="item" spaces=" "><para><code>put</code>
</para></entry><entry command="tab" spaces=" "><para>Utopia
</para></entry></row><row><entry command="item" spaces=" "><para><code>pzc</code>
</para></entry><entry command="tab" spaces=" "><para>Zapf Chancery
</para></entry></row></tbody></multitable>

<anchor name="low-level-font-commands-fontseries">low level font commands fontseries</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\fontseries&lbrace;<var>série</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="196">\fontseries</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="145">séries de polices</indexterm></cindex>
<para>Sélectionne une série de police. Une <dfn>série</dfn> combine une
<dfn>graisse</dfn> et une <dfn>largeur</dfn>. Typiquement, une police prend en
charge seulement quelques-unes des combinaisons possibles. Les
combinaisons de valeurs de séries comprennent notamment :
</para>
<multitable spaces=" " endspaces=" "><columnprototypes><columnprototype bracketed="on"><spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">Moyen (normal)<spacecmd type="spc"/><spacecmd type="spc"/></columnprototype></columnprototypes>
<tbody><row><entry command="item" spaces=" "><para><code>m</code>
</para></entry><entry command="tab" spaces=" "><para>Moyen (normal)
</para></entry></row><row><entry command="item" spaces=" "><para><code>b</code>
</para></entry><entry command="tab" spaces=" "><para>Gras
</para></entry></row><row><entry command="item" spaces=" "><para><code>c</code>
</para></entry><entry command="tab" spaces=" "><para>Condensé
</para></entry></row><row><entry command="item" spaces=" "><para><code>bc</code>
</para></entry><entry command="tab" spaces=" "><para>Condensé Gras
</para></entry></row><row><entry command="item" spaces=" "><para><code>bx</code>
</para></entry><entry command="tab" spaces=" "><para>Gras étendu
</para></entry></row></tbody></multitable>


<cindex index="cp" spaces=" "><indexterm index="cp" number="146">graisses de police</indexterm></cindex>
<para>Les valeurs possibles de graisses, considérées individuellement, sont :
</para>
<multitable spaces=" " endspaces=" "><columnprototypes><columnprototype bracketed="on"><spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">Demi-gras &textmdash; m pour medium en anglais</columnprototype></columnprototypes>
<tbody><row><entry command="item" spaces=" "><para><code>ul</code>
</para></entry><entry command="tab" spaces=" "><para>Ultra maigre
</para></entry></row><row><entry command="item" spaces=" "><para><code>el</code>
</para></entry><entry command="tab" spaces=" "><para>Extra maigre
</para></entry></row><row><entry command="item" spaces=" "><para><code>l</code>
</para></entry><entry command="tab" spaces=" "><para>Maigre &textmdash; <samp>l</samp> pour <i>light</i> en anglais
</para></entry></row><row><entry command="item" spaces=" "><para><code>sl</code>
</para></entry><entry command="tab" spaces=" "><para>Semi maigre
</para></entry></row><row><entry command="item" spaces=" "><para><code>m</code>
</para></entry><entry command="tab" spaces=" "><para>Demi-gras &textmdash; <samp>m</samp> pour <i>medium</i> en anglais
</para></entry></row><row><entry command="item" spaces=" "><para><code>sb</code>
</para></entry><entry command="tab" spaces=" "><para>Semi gras
</para></entry></row><row><entry command="item" spaces=" "><para><code>b</code>
</para></entry><entry command="tab" spaces=" "><para>Gras &textmdash; <samp>b</samp> pour <i>bold</i> en anglais
</para></entry></row><row><entry command="item" spaces=" "><para><code>eb</code>
</para></entry><entry command="tab" spaces=" "><para>Extra gras
</para></entry></row><row><entry command="item" spaces=" "><para><code>ub</code>
</para></entry><entry command="tab" spaces=" "><para>Ultra gras
</para></entry></row></tbody></multitable>


<cindex index="cp" spaces=" "><indexterm index="cp" number="147">Largeurs de police</indexterm></cindex>
<para>La valeurs possibles de largeur, considérées individuellement sont :
</para>
<multitable spaces=" " endspaces=" "><columnprototypes><columnprototype bracketed="on"><spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">Extra condensé&textndash;</columnprototype></columnprototypes>
<tbody><row><entry command="item" spaces=" "><para><code>uc</code>
</para></entry><entry command="tab" spaces=" "><para>Ultra condensé
</para></entry></row><row><entry command="item" spaces=" "><para><code>ec</code>
</para></entry><entry command="tab" spaces=" "><para>Extra condensé
</para></entry></row><row><entry command="item" spaces=" "><para><code>c</code>
</para></entry><entry command="tab" spaces=" "><para>Condensé
</para></entry></row><row><entry command="item" spaces=" "><para><code>sc</code>
</para></entry><entry command="tab" spaces=" "><para>Semi condensé
</para></entry></row><row><entry command="item" spaces=" "><para><code>m</code>
</para></entry><entry command="tab" spaces=" "><para>Moyen
</para></entry></row><row><entry command="item" spaces=" "><para><code>sx</code>
</para></entry><entry command="tab" spaces=" "><para>Semi étendu
</para></entry></row><row><entry command="item" spaces=" "><para><code>x</code>
</para></entry><entry command="tab" spaces=" "><para>étendu
</para></entry></row><row><entry command="item" spaces=" "><para><code>ex</code>
</para></entry><entry command="tab" spaces=" "><para>Extra étendu
</para></entry></row><row><entry command="item" spaces=" "><para><code>ux</code>
</para></entry><entry command="tab" spaces=" "><para>Ultra étendu
</para></entry></row></tbody></multitable>

<para>Lorsqu&textrsquo;on forme la chaîne de caractères <var>série</var> à partir de la
graisse et de la largeur, on laisse tomber le <code>m</code> qui signifie
médium concernant la graisse ou la largeur, auquel cas on en utilise
juste un (<samp><code>m</code></samp>).
</para>
<anchor name="low-level-font-commands-fontshape">low level font commands fontshape</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\fontshape&lbrace;<var>allure</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="197">\fontshape</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="148">allure de police</indexterm></cindex>
<para>Sélectionne l&textrsquo;allure de police. Les allures valides sont :
</para>
<multitable spaces=" " endspaces=" "><columnprototypes><columnprototype bracketed="on"><spacecmd type="spc"/><spacecmd type="spc"/></columnprototype> <columnprototype bracketed="on">Italique droit &textmdash; ui pour upright italic en anglais</columnprototype></columnprototypes>
<tbody><row><entry command="item" spaces=" "><para><code>n</code>
</para></entry><entry command="tab" spaces="  "><para>Droit (normal)
</para></entry></row><row><entry command="item" spaces=" "><para><code>it</code>
</para></entry><entry command="tab" spaces=" "><para>Italique
</para></entry></row><row><entry command="item" spaces=" "><para><code>sl</code>
</para></entry><entry command="tab" spaces=" "><para>Incliné (oblique) &textmdash; <samp>sl</samp> pour <i>slanted</i> en anglais.
</para></entry></row><row><entry command="item" spaces=" "><para><code>sc</code>
</para></entry><entry command="tab" spaces=" "><para>Petites capitales
</para></entry></row><row><entry command="item" spaces=" "><para><code>ui</code>
</para></entry><entry command="tab" spaces=" "><para>Italique droit &textmdash; <samp>ui</samp> pour <i>upright italic</i> en anglais
</para></entry></row><row><entry command="item" spaces=" "><para><code>ol</code>
<!-- c crédit : Jean-Côme Charpentier, cf. https://groups.google.com/g/fr.comp.text.tex/c/EV0nUu6DwoY -->
</para></entry><entry command="tab" spaces=" "><para>Détouré &textmdash; <samp>ol</samp> pour <i>outline</i> en anglais.
</para></entry></row></tbody></multitable>

<para>Les deux dernières allures ne sont pas disponibles pour la plupart des
familles de polices, et les petites capitales sont aussi souvent
absentes.
</para>

<anchor name="low-level-font-commands-fontsize">low level font commands fontsize</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\fontsize&lbrace;<var>taille</var>&rbrace;&lbrace;<var>interligne</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="198">\fontsize</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="199">\baselineskip</indexterm></findex>
<para>Réglage de la taille de police et de l&textrsquo;espacement d&textrsquo;interligne. L&textrsquo;unité
des deux paramètres est par défaut le point (<code>pt</code>). L&textrsquo;espacement
d&textrsquo;interligne est l&textrsquo;espace vertical nominal entre ligne, de ligne de base
à ligne de base. Il est stocké dans le paramètre
<code>\baselineskip</code>. La valeur par défaut de <code>\baselineskip</code> pour
la police Computer Modern est 1,2 fois le <code>\fontsize</code>.  Changer
directement <code>\baselineskip</code> est déconseillé dans la mesure où sa
valeur est réinitialisée à chaque fois qu&textrsquo;un changement de taille se
produit ; au lieu de cela utilisez <code>\baselinestretch</code>
(<pxref label="_005cbaselineskip-_0026-_005cbaselinestretch"><xrefnodename>\baselineskip &amp; \baselinestretch</xrefnodename></pxref>).
</para>
<anchor name="low-level-font-commands-linespread">low level font commands linespread</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\linespread&lbrace;<var>facteur</var>&rbrace;</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="200">\linespread</indexterm></findex>
<para>Équivalent à <code>\renewcommand&lbrace;\baselinestretch&rbrace;&lbrace;<var>facteur</var>&rbrace;</code>,
et donc doit être suivi de <code>\selectfont</code> pour prendre
effet. <xref label="_005cbaselineskip-_0026-_005cbaselinestretch"><xrefnodename>\baselineskip &amp; \baselinestretch</xrefnodename></xref>, pour plus ample
information.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\selectfont</itemformat></item>
</tableterm><tableitem><anchor name="low-level-font-commands-selectfont">low level font commands selectfont</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="201">\selectfont</indexterm></findex>
<para>Les modifications apportées en appelant les commandes de fonte
décrites ci-dessus n&textrsquo;entrent en vigueur qu&textrsquo;après que <code>\selectfont</code>
est appelé, comme dans
<code>\fontfamily&lbrace;<var>nomfamille</var>&rbrace;\selectfont</code>. La plupart du temps
il est plus pratique de mettre cela dans une macro :
<code>\newcommand*&lbrace;\mapolice&rbrace;&lbrace;\fontfamily&lbrace;<var>nomfamille</var>&rbrace;\selectfont&rbrace;</code>&linebreak;
(<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></pxref>).
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\usefont&lbrace;<var>codage</var>&rbrace;&lbrace;<var>famille</var>&rbrace;&lbrace;<var>série</var>&rbrace;&lbrace;<var>allure</var>&rbrace;</itemformat></item>
</tableterm><tableitem><anchor name="low-level-font-commands-usefont">low level font commands usefont</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="202">\usefont</indexterm></findex>
<para>Revient à la même chose que d&textrsquo;invoquer <code>\fontencoding</code>,
<code>\fontfamily</code>, <code>\fontseries</code> et <code>\fontshape</code> avec les
paramètres donnés, suivi par <code>\selectfont</code>. Par exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usefont&lbrace;ot1&rbrace;&lbrace;cmr&rbrace;&lbrace;m&rbrace;&lbrace;n&rbrace;
</pre></example>

</tableitem></tableentry></table>


</section>
</chapter>
<node name="Layout" spaces=" "><nodename>Layout</nodename><nodenext automatic="on">Sectioning</nodenext><nodeprev automatic="on">Fonts</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Mise en page</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="149">commandes de mise en page</indexterm></cindex>

<para>Commandes pour contrôler la disposition générale de la page.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\onecolumn </menunode><menudescription><pre xml:space="preserve">Utiliser la disposition à une colonne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\twocolumn </menunode><menudescription><pre xml:space="preserve">Utiliser la disposition à deux colonnes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\flushbottom </menunode><menudescription><pre xml:space="preserve">Faire toutes les pages de texte de la même hauteur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\raggedbottom </menunode><menudescription><pre xml:space="preserve">Autoriser les pages de texte à être de hauteurs différentes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Paramètres de mise en page</menutitle><menunode separator=". ">Page layout parameters</menunode><menudescription><pre xml:space="preserve"><code>\headheight</code> <code>\footskip</code>.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::           ">\baselineskip &amp; \baselinestretch</menunode><menudescription><pre xml:space="preserve">Interlignes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Flottants</menutitle><menunode separator=".                  ">Floats</menunode><menudescription><pre xml:space="preserve">Figures, tableaux, etc.
</pre></menudescription></menuentry></menu>


<node name="_005conecolumn" spaces=" "><nodename>\onecolumn</nodename><nodenext automatic="on">\twocolumn</nodenext><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle><code>\onecolumn</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="203">\onecolumn</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="150">sortie à une colonne</indexterm></cindex>

<para>La déclaration <code>\onecolumn</code> commence une nouvelle page et produit
une sortie à colonne unique. C&textrsquo;est la valeur par défaut.
</para>
</section>
<node name="_005ctwocolumn" spaces=" "><nodename>\twocolumn</nodename><nodenext automatic="on">\flushbottom</nodenext><nodeprev automatic="on">\onecolumn</nodeprev><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle><code>\twocolumn</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="204">\twocolumn</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="151">texte sur plusieurs colonnes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="152">sortie à deux colonnes</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\twocolumn [<var>texte1col préliminaire</var>]
</pre></example>

<para>Commence une nouvelle page et produit une sortie en deux colonnes. Si on
a passé l&textrsquo;option de classe <code>twocolumn</code> au document alors c&textrsquo;est le
comportement par défaut (<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></pxref>). Cette commande
est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Si l&textrsquo;argument optionnel <var>texte1col préliminaire</var> est présent, il est
composé dans le mode à une colonne avant que la composition à deux
colonnes ne commence.
</para>
<para>Les paramètres ci-après contrôlent la composition de la sortie en deux
colonnes :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="205">\columnsep</indexterm>\columnsep</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-columnsep">twocolumn columnsep</anchor>
<para>La distance entre les colonnes. Vaut 35pt par défaut. Changer la valeur
avec une commande telle que
<code>\setlength&lbrace;\columnsep&rbrace;&lbrace;40pt&rbrace;</code>. Vous devez faire le changement
avant que le mode en deux colonnes ne commence ; le préambule est
une bonne place pour le faire.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="206">\columnseprule</indexterm>\columnseprule</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-columnseprule">twocolumn columnseprule</anchor>
<para>La largeur du filet entre les colonnes. La valeur par défaut est 0pt, de
sorte qu&textrsquo;il n&textrsquo;y a pas de filet. Autrement, le filet apparaît à mi-chemin
entre les deux colonnes. Changez la valeur avec une commande telle que
<code>\setlength&lbrace;\columnseprule&rbrace;&lbrace;0.4pt&rbrace;</code>, avant que le mode en deux
colonnes ne commence.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="207">\columnwidth</indexterm>\columnwidth</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-columnwidth">twocolumn columnwidth</anchor>
<para>La largeur d&textrsquo;une colonne. En mode à une colonne ceci vaut
<code>\textwidth</code>. En mode à deux colonnes par défaut &latex; règle la
largeur de chacune des deux colonnes, <code>\columnwidth</code>, à la moitié
de <code>\textwidth</code> moins <code>\columnsep</code>.
</para>
</tableitem></tableentry></ftable>

<para>Dans un document en deux colonnes, les environnements étoilés
<code>table*</code> et <code>figure*</code> s&textrsquo;étendent en largeur sur deux colonnes,
alors que les environnements non étoilés <code>table</code> et <code>figure</code>
n&textrsquo;occupe qu&textrsquo;une colonne (<pxref label="figure"><xrefnodename>figure</xrefnodename></pxref> et <pxref label="table"><xrefnodename>table</xrefnodename></pxref>). &latex;
place les flottants étoilés au sommet d&textrsquo;une page.
Les paramètres ci-après contrôlent le comportement des flottants en cas
de sortie à deux colonnes :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="208">\dbltopfraction</indexterm>\dbltopfraction</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-dbltopfraction">twocolumn dbltopfraction</anchor>
<para>Fraction maximale au sommet d&textrsquo;une page sur deux colonnes qui peut être
occupée par des flottants s&textrsquo;étendant sur deux colonnes en largeur. Par
défaut vaut 0,7, ce qui signifie que la hauteur d&textrsquo;un environnement
<code>table*</code> ou <code>figure*</code> ne doit pas excéder
<code>0.7\textheight</code>. Si la hauteur de vos environnement flottant
excède cela alors vous pouvez prendre l&textrsquo;une des actions suivante pour
l&textrsquo;empêcher de flotter jusqu&textrsquo;à la fin du document :
</para>
<itemize spaces=" " endspaces=" "><itemprepend>&textndash;</itemprepend>
<listitem><prepend>&textndash;</prepend>
<para>Utiliser le spécificateur de localisation <code>[tp]</code> pour dire à
&latex; d&textrsquo;essayer de placer le flottant volumineux sur une page dédiée,
ou de même au sommet d&textrsquo;une page.
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Utiliser le spécificateur de localisation <code>[t!]</code> pour l&textrsquo;emporter
sur l&textrsquo;effet de <code>\dbltopfraction</code> pour ce flottant en particulier.
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Augmenter la valeur de <code>\dbltopfraction</code> à un nombre de grandeur
adéquate, pour éviter de faire flotter les pages si tôt.
</para></listitem></itemize>


<para>Vous pouvez le redéfinir, comme dans
<code>\renewcommand&lbrace;\dbltopfraction&rbrace;&lbrace;0.9&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="209">\dblfloatpagefraction</indexterm>\dblfloatpagefraction</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-dblfloatpagefraction">twocolumn dblfloatpagefraction</anchor>
<para>Pour une page de flottants s&textrsquo;étendant sur deux colonnes en largeur,
c&textrsquo;est la fraction minimum de la page qui doit être occupée par les
flottants. La valeur par défaut de &latex; est <samp>0.5</samp>. Se change
avec <code>\renewcommand</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="210">\dblfloatsep</indexterm>\dblfloatsep</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-dblfloatsep">twocolumn dblfloatsep</anchor>
<para>Sur une page de flottants s&textrsquo;étendant sur deux colonnes en largeur, cette
longueur est la distance entre les flottants à la fois en haut et en bas
de la page. Par défaut vaut <samp>12pt plus2pt minus2pt</samp> pour des
documents en <samp>10pt</samp> ou <samp>11pt</samp>, et <samp>14pt plus2pt minus4pt</samp>
pour <samp>12pt</samp>.
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="211">\dbltextfloatsep</indexterm>\dbltextfloatsep</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-dbltextfloatsep">twocolumn dbltextfloatsep</anchor>
<para>Cette longueur est la distance entre un flottant multi-colonnes en haut
ou en bas d&textrsquo;une page et le texte principal. Par défaut vaut <samp>20pt
plus2pt minus4pt</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="212">\dbltopnumber</indexterm>\dbltopnumber</itemformat></item>
</tableterm><tableitem><anchor name="twocolumn-dbltopnumber">twocolumn dbltopnumber</anchor>
<para>Sur une page de flottant avec des flottants large de deux colonnes, ce
compteur donne le nombre maximal de flottants autorisé au sommet de la
page.  La valeur par défaut de &latex; est <code>2</code>.
</para></tableitem></tableentry></ftable>

<!-- c From egreg at http://tex.stackexchange.com/a/142232/339 -->
<para>L&textrsquo;exemple suivant utilise l&textrsquo;argument optionnel de <code>\twocolumn</code> pour
crée un titre s&textrsquo;étendant sur les deux colonnes du document article :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[twocolumn]&lbrace;article&rbrace;
\newcommand&lbrace;\authormark&rbrace;[1]&lbrace;\textsuperscript&lbrace;#1&rbrace;&rbrace;
\begin&lbrace;document&rbrace;
\twocolumn[&lbrace;% au sein de cet argument optionnel, du texte en une colonne
  \centering
  \LARGE Le titre \\[1.5em]
  \large Auteur Un\authormark&lbrace;1&rbrace;,
         Auteur Deux\authormark&lbrace;2&rbrace;,
         Auteur Trois\authormark&lbrace;1&rbrace; \\[1em]
  \normalsize
  \begin&lbrace;tabular&rbrace;&lbrace;p&lbrace;.2\textwidth&rbrace;&arobase;&lbrace;\hspace&lbrace;2em&rbrace;&rbrace;p&lbrace;.2\textwidth&rbrace;&rbrace;
    \authormark&lbrace;1&rbrace;Departement Un  &amp;\authormark&lbrace;2&rbrace;Department Deux \\
     École Un                   &amp;École Deux
  \end&lbrace;tabular&rbrace;\\[3em] % espace sous la partie titre
  &rbrace;]

Le texte en deux colonnes est ici.
</pre></example>


</section>
<node name="_005cflushbottom" spaces=" "><nodename>\flushbottom</nodename><nodenext automatic="on">\raggedbottom</nodenext><nodeprev automatic="on">\twocolumn</nodeprev><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle><code>\flushbottom</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="213">\flushbottom</indexterm></findex>

<para>Rend toutes les pages du document qui suivent cette déclaration de la
même hauteur, en dilatant l&textrsquo;espace vertical là où c&textrsquo;est nécessaire pour
remplir le page. On fait cela le plus souvent pour des documents en
recto-verso car les différences entre pages vis-à-vis peuvent être
flagrantes.
</para>
<para>Si &tex; ne parvient pas à dilater de manière satisfaisante l&textrsquo;espace
vertical dans une page alors on obtient un message du genre de
<samp>Underfull \vbox (badness 10000) has occurred while \output is
active</samp>.  Lorsque on obtient cela, une option est de passer à
<code>\raggedbottom</code> (<pxref label="_005craggedbottom"><xrefnodename>\raggedbottom</xrefnodename></pxref>).  Alternativement, vous
pouvez ajuster la <code>textheight</code> pour rendre compatibles des pages,
ou vous pouvez ajouter de l&textrsquo;espace vertical élastique entre les lignes
ou entre les paragraphes, comme dans <code>\setlength&lbrace;\parskip&rbrace;&lbrace;0ex
plus0.1ex&rbrace;</code>.  L&textrsquo;option ultime est, dans une phase finale de rédaction,
d&textrsquo;ajuster les hauteurs de page individuellement
(<pxref label="_005cenlargethispage"><xrefnodename>\enlargethispage</xrefnodename></pxref>).
</para>
<para>L&textrsquo;état <code>\flushbottom</code> est la valeur par défaut seulement lorsque on
sélectionne l&textrsquo;option de classe <code>twocolumn</code> (<pxref label="Document-class-options"><xrefnodename>Document class
options</xrefnodename></pxref>), et pour les indexes fabriqués avec <code>makeidx</code>.
</para>
<!-- c  Cette commande est fragile (@pxref{\protect}) -->

</section>
<node name="_005craggedbottom" spaces=" "><nodename>\raggedbottom</nodename><nodenext automatic="on">Page layout parameters</nodenext><nodeprev automatic="on">\flushbottom</nodeprev><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle><code>\raggedbottom</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="214">\raggedbottom</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="153">étirement, omettre l&textrsquo;étirement vertical</indexterm></cindex>

<para>La déclaration <code>\raggedbottom</code> rend toutes les pages qui la suivent
de la hauteur naturelle de la matière sur cette page ; aucune des
longueurs élastiques n&textrsquo;est étirée. Ainsi, sur un document en recto-verso
les pages en vis-à-vis sont potentiellement de hauteurs
différentes. Cette commande peut être mise n&textrsquo;importe où dans le corps du
document. <xref label="_005cflushbottom"><xrefnodename>\flushbottom</xrefnodename></xref>.
</para>
<para>C&textrsquo;est le comportement par défaut à moins qu&textrsquo;on sélectionne l&textrsquo;option
<code>twocolumn</code> de classe de document (<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></pxref>).
</para>

</section>
<node name="Page-layout-parameters" spaces=" "><nodename>Page layout parameters</nodename><nodenext automatic="on">\baselineskip &amp; \baselinestretch</nodenext><nodeprev automatic="on">\raggedbottom</nodeprev><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle>Paramètres de mise en page</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="154">page, paramètres de mise en page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="155">paramètres, la mise en page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="156">mise en page, les paramètres de</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="157">en-tête, des paramètres pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="158">bas de page, des paramètres pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="159">en-tête et pied de page en cours</indexterm></cindex>

<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="215">\columnsep</indexterm>\columnsep</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="216">\columnseprule</indexterm>\columnseprule</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="217">\columnwidth</indexterm>\columnwidth</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="218">\columnsep</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="219">\columnseprule</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="220">\columnwidth</indexterm></findex>
<anchor name="page-layout-parameters-columnsep">page layout parameters columnsep</anchor>
<anchor name="page-layout-parameters-columnseprule">page layout parameters columnseprule</anchor>
<anchor name="page-layout-parameters-columnwidth">page layout parameters columnwidth</anchor>
<para>La distance entre les deux colonnes, la largeur d&textrsquo;un filet entre les
colonnes, et la largeur des colonnes, lorsque l&textrsquo;option de classe de
document <code>twocolumn</code> est en vigueur (<pxref label="Document-class-options"><xrefnodename>Document class
options</xrefnodename></pxref>).  <xref label="_005ctwocolumn"><xrefnodename>\twocolumn</xrefnodename></xref>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="221">\headheight</indexterm>\headheight</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="222">\headheight</indexterm></findex>
<anchor name="page-layout-parameters-headheight">page layout parameters headheight</anchor>
<para>Hauteur de la boîte qui contient l&textrsquo;en-tête de page en cours. La valeur
par défaut pour les classes <code>article</code>, <code>report</code>, et
<code>book</code> est <samp>12pt</samp> quelle que soit la taille de la police.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="223">\headsep</indexterm>\headsep</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="224">\headsep</indexterm></findex>
<anchor name="page-layout-parameters-headsep">page layout parameters headsep</anchor>
<para>La distance verticale entre le bas de la ligne d&textrsquo;en-tête et le haut du
texte principal. La valeur par défaut est <samp>25pt</samp>. Dans la classe
<code>book</code> la valeur par défaut est <samp>0.25in</samp> pour un document
réglé en 10pt, et <samp>0.275in</samp> pour un document en 11pt ou 12pt.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="225">\footskip</indexterm>\footskip</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="226">\footskip</indexterm></findex>
<anchor name="page-layout-parameters-footskip">page layout parameters footskip</anchor>
<para>Distance de la ligne de base de la dernière ligne de texte à la ligne de
base du pied de page. La valeur par défaut dans les classes
<code>article</code> et <code>report</code> est <samp>30pt</samp>. Dans la classe
<code>book</code> la valeur par défaut est <samp>0.35in</samp> pour les documents
réglés en 10pt, <samp>0.38in</samp> en 11pt, et <samp>30pt</samp> en 12pt.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="227">\linewidth</indexterm>\linewidth</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="228">\linewidth</indexterm></findex>
<anchor name="page-layout-parameters-linewidth">page layout parameters linewidth</anchor>
<para>Largeur de la ligne actuelle, diminuée pour chaque <code>list</code> imbriquée
(<pxref label="list"><xrefnodename>list</xrefnodename></pxref>). c.-à-d.&noeos; que la valeur nominale <code>\linewidth</code> vaut
<code>\textwidth</code> mais que pour chaque liste imbriquée la largeur
<code>\linewidth</code> est diminuée de la somme de <code>\leftmargin</code> et
<code>\rightmargin</code> pour cette liste (<pxref label="itemize"><xrefnodename>itemize</xrefnodename></pxref>).
<!-- c La valeur par défaut varie en fonction de la taille de la police, la -->
<!-- c largeur du papier, le mode à deux colonnes, etc. Pour un document de -->
<!-- c classe @code{article} en taille de police @samp{10pt}, elle vaut -->
<!-- c @samp{345pt} ; dans le mode à deux colonnes, elle passe à -->
<!-- c @samp{229.5pt}. -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="229">\marginparpush</indexterm>\marginparpush</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="230">\marginsep</indexterm>\marginsep</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="231">\marginparwidth</indexterm>\marginparwidth</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="232">\marginparpush</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="233">\marginsep</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="234">\marginparwidth</indexterm></findex>
<anchor name="page-layout-parameters-marginparpush">page layout parameters marginparpush</anchor>
<anchor name="page-layout-parameters-marginsep">page layout parameters marginsep</anchor>
<anchor name="page-layout-parameters-marginparwidth">page layout parameters marginparwidth</anchor>
<para>L&textrsquo;espace vertical minimal entre deux notes marginales, l&textrsquo;espace
horizontal entre le corps du texte et les notes marginales, et la
largeur horizontale des notes.
</para>
<para>Normalement les notes en marginales apparaissent à l&textrsquo;extérieur de la
page, mais la déclaration <code>\reversemarginpar</code> change cela (et
<code>\normalmarginpar</code> le rétablit).
</para>
<para>La valeur par défaut pour <code>\marginparpush</code> à la fois dans un
document de classe <code>book</code> ou <code>article</code> est : <samp>7pt</samp> si le
document est réglé à 12pt, et <samp>5pt</samp> s&textrsquo;il l&textrsquo;est à 11pt ou 10pt.
</para>
<para>Pour <code>\marginsep</code>, dans la classe <code>article</code> la valeur par
défaut est <samp>10pt</samp> sauf si le document est réglé à 10pt et en mode en
deux-colonnes où la valeur par défaut est <samp>11pt</samp>.
</para>
<para>Pour <code>\marginsep</code> dans la classe <code>book</code> la valeur par défaut
est <samp>10pt</samp> en mode deux-colonnes, et <samp>7pt</samp> en mode
mono-colonne.
</para>
<para>Pour <code>\marginparwidth</code> aussi bien dans les classes <code>book</code> que
<code>article</code>, en mode deux-colonnes la valeur par défaut est 60% ou
<code>\paperwidth &minus; \textwidth</code>, alors qu&textrsquo;en mode monocolonne
c&textrsquo;est 50% de cette distance.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="235">\oddsidemargin</indexterm>\oddsidemargin</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="236">\evensidemargin</indexterm>\evensidemargin</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="237">\oddsidemargin</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="238">\evensidemargin</indexterm></findex>
<anchor name="page-layout-parameters-oddsidemargin">page layout parameters oddsidemargin</anchor>
<anchor name="page-layout-parameters-evensidemargin">page layout parameters evensidemargin</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="160">marge gauche</indexterm></cindex>
<para>La <dfn>marge gauche</dfn> est la bande entre le bord gauche de la page et le
corps du texte.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="161">marge gauche nominale</indexterm></cindex>
<para>La <dfn>marge gauche nominale</dfn> est la marge gauche lorsque les
paramètres <code>\oddsidemargin</code> et <code>\eventsidemargin</code> sont à
<samp>0pt</samp>. Sa frontière est une ligne verticale imaginaire située
à une distance de <code>1in + \hoffset</code> du bord gauche de la page en
allant vers le côté droit. La longueur <code>\hoffset</code> vaut <code>0pt</code>,
ce paramètre est obsolète il servait dans les années 1980, quand le
système &tex; a été conçu, à rattraper les défauts des imprimantes de
l&textrsquo;époque dont le placement horizontal de la page par rapport à la
feuille de papier pouvait se dérégler.
</para>
<para>La longueur <code>\oddsidemargin</code> est la distance entre le bord gauche
du texte et la frontière de la marge gauche nominale pour les pages de
numéro impair dans les documents en recto-verso, et pour toutes les
pages sinon pour les documents en recto simple. La longueur
<code>\evensidemargin</code> est la distance entre le bord gauche du texte et
la frontière de la marge gauche nominale pour les pages de numéro pair
dans les documents en recto-verso.
</para>
<para>En d&textrsquo;autres termes <code>\oddsidemargin</code> ou <code>\evensidemargin</code>
donnent la différence entre la largeur de la marge gauche réel et la
marge gauche nominale. Ces distances <code>\oddsidemargin</code> et
<code>\evensidemargin</code> sont donc signées vers le coté droit, c&textrsquo;est à
dire qu&textrsquo;une valeur positive indique que la marge gauche réelle est plus
large que la marge gauche nominale, alors qu&textrsquo;une valeur négative indique
qu&textrsquo;au contraire elle est plus étroite.
</para>
<para>Dans un document en recto-verso le <dfn>côté intérieur</dfn> de la page est
le côté gauche pour les pages de numéro impair, et le côté droit pour
les pages de numéro pair. Le <dfn>côté extérieur</dfn> est le côté opposé au
côté intérieur : la longueur <code>\oddsidemargin</code> règle donc la
position de la marge intérieure des pages de numéro impair, alors que
<code>\evensidemargin</code> règle la position la marge extérieur des pages de
numéro pair.
</para>
<para>Pour une marge intérieure de 4cm dans un document en recto-verso, mettre
le code suivant dans le préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\evensidemargin\dimexpr\paperwidth-\textwidth-1in-4cm
\oddsidemargin\dimexpr4cm-1in
</pre></example>

<para>Vice-versa, pour une marge extérieure de 5cm dans un document en
recto-verso, mettre le code suivant dans le préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\evensidemargin\dimexpr5cm-1in
\oddsidemargin\dimexpr\paperwidth-\textwidth-1in-5cm
</pre></example>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="239">\paperheight</indexterm>\paperheight</itemformat></item>
</tableterm><tableitem><anchor name="page-layout-parameters-paperheight">page layout parameters paperheight</anchor>
<para>La hauteur du papier, à ne pas confondre avec la hauteur de la zone
d&textrsquo;impression.  Elle est normalement réglée avec une option de classe de
document, comme dans <code>\documentclass[a4paper]&lbrace;article&rbrace;</code>
(<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename><xrefinfoname>Options de classe de document</xrefinfoname></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="240">\paperwidth</indexterm>\paperwidth</itemformat></item>
</tableterm><tableitem><anchor name="page-layout-parameters-paperwidth">page layout parameters paperwidth</anchor>
<para>La largeur du papier, à ne pas confondre avec la largeur de la zone
d&textrsquo;impression.  Elle est normalement réglée avec une option de classe de
document, comme dans <code>\documentclass[a4paper]&lbrace;article&rbrace;</code>
(<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename><xrefinfoname>Options de classe de document</xrefinfoname></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="241">\textheight</indexterm>\textheight</itemformat></item>
</tableterm><tableitem><anchor name="page-layout-parameters-textheight">page layout parameters textheight</anchor>
<para>La hauteur verticale normale du corps de la page. Si le document réglé à
une taille de police nominale de 10pt, alors pour un document de classe
<code>article</code> ou <code>report</code>, elle vaut <samp>43\baselineskip</samp> ; pour
une classe <code>book</code>, elle vaut <samp>41\baselineskip</samp>.  Pour 11pt,
c&textrsquo;est <samp>38\baselineskip</samp> pour toutes les classes de document. Pour
<samp>12pt</samp> c&textrsquo;est <samp>36\baselineskip</samp> pour toutes les classes aussi.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="242">\textwidth</indexterm>\textwidth</itemformat></item>
</tableterm><tableitem><anchor name="page-layout-parameters-textwidth">page layout parameters textwidth</anchor>
<para>La largeur horizontale totale de l&textrsquo;ensemble du corps de la page. Pour un
document de classe <code>article</code> ou <code>report</code>, elle vaut
<samp>345pt</samp> à 10pt de taille de police, <samp>360pt</samp> à
11pt, et <samp>390pt</samp> à 12pt. Pour un document
<code>book</code>, elle veut <samp>4.5in</samp> à 10pt et <samp>5in</samp> à
11pt ou 12pt.
</para>
<para>En sortie multi-colonne, <code>\textwidth</code> reste de la largeur de tout
le corps de la page, tandis que <code>\columnwidth</code> est la largeur d&textrsquo;une
colonne (<pxref label="_005ctwocolumn"><xrefnodename>\twocolumn</xrefnodename></pxref>).
</para>
<para>Dans les listes (<pxref label="list"><xrefnodename>list</xrefnodename></pxref>), <code>\textwidth</code> demeure la largeur du
corps de la page entière (et <code>\columnwidth</code> est la largeur d&textrsquo;une
colonne entière), alors que <code>\linewidth</code> peut diminuer au sein de
listes imbriquées.
</para>
<para>À l&textrsquo;intérieur d&textrsquo;une minipage (<pxref label="minipage"><xrefnodename>minipage</xrefnodename></pxref> ) ou <code>\parbox</code>
(<pxref label="_005cparbox"><xrefnodename>\parbox</xrefnodename></pxref>), tous les paramètres liés à la largeur sont mis à la
largeur spécifiée, et de reviennent à leurs valeurs normales à la fin du
<code>minipage</code> ou <code>\parbox</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="243">\hsize</indexterm>\hsize</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="244">\hsize</indexterm></findex>
<anchor name="page-layout-parameters-hsize">page layout parameters hsize</anchor>
<para>Par souci d&textrsquo;exhaustivité : <code>\hsize</code> est le paramètre &tex;
primitif utilisé lorsque le texte est divisé en lignes. Il ne devrait
pas être utilisé dans des documents &latex; en conditions normales.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="245">\topmargin</indexterm>\topmargin</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="246">topmargin</indexterm></findex>
<anchor name="page-layout-parameters-topmargin">page layout parameters topmargin</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="162">marge supérieure</indexterm></cindex>
<para>La <dfn>marge supérieure</dfn> est la bande entre le bord supérieur de la page et le
bord supérieure de l&textrsquo;en-tête de page.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="163">marge supérieure nominale</indexterm></cindex>
<para>La <dfn>marge supérieure nominale</dfn> est la marge supérieur lorsque
<code>\topmargin</code> vaut <samp>0pt</samp>. Sa frontière est une ligne
horizontale imaginaire située à une distance de <code>1in + \voffset</code> du
bord supérieur de la page en allant vers le bas. La longueur
<code>\voffset</code> vaut <code>0pt</code>, ce paramètre est obsolète il servait
dans les années 1980, quand le système &tex; a été conçu, à rattraper
les défauts des imprimantes de l&textrsquo;époque dont le placement vertical de la
page par rapport à la feuille de papier pouvait se dérégler.
</para>
<para>La distance <code>\topmargin</code> sépare le haut de l&textrsquo;en-tête de page de la
frontière de la marge supérieure nominale. Elle est signée vers le bas,
c&textrsquo;est à dire que quand <code>\topmargin</code> est positif la marge supérieure
est plus large que la marge supérieure nominale, et que s&textrsquo;il est négatif
elle est au contraire plus étroite. En d&textrsquo;autres termes <code>\topmargin</code>
est la différence entre la largeur de la marge supérieure réelle et la
marge supérieure nominale.
</para>
<para>L&textrsquo;espace le haut de la page &tex; et le haut du corps de texte est
<code>1in + \voffset + \topmargin + \headheight + \headsep</code>. La marge
inférieure vaut donc <code>\paperheight -\textheight -\footskip - 1in -
\voffset - \topmargin - \headheight - \headsep</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="247">\topskip</indexterm>\topskip</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="248">\topskip</indexterm></findex>
<anchor name="page-layout-parameters-topskip">page layout parameters topskip</anchor>
<para>La distance minimale entre le sommet du corps de la page et la ligne de base de
la première ligne de texte. Pour les classes standard, la valeur par défaut est la
même que la taille de la police, par exemple, <samp>10pt</samp> à <samp>10pt</samp>.
</para>
</tableitem></tableentry></ftable>

</section>
<node name="_005cbaselineskip-_0026-_005cbaselinestretch" spaces=" "><nodename>\baselineskip &amp; \baselinestretch</nodename><nodenext automatic="on">Floats</nodenext><nodeprev automatic="on">Page layout parameters</nodeprev><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle><code>\baselineskip</code> &amp; <code>\baselinestretch</code></sectiontitle>

<anchor name="_005cbaselineskip">\baselineskip</anchor>
<anchor name="_005cbaselinestretch">\baselinestretch</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="249">\baselineskip</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="250">\baselinestretch</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="251">\linespread</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="164">espace entre les lignes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="165">interligne, espace</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="166">double espacement</indexterm></cindex>

<para>La variable <code>\baselineskip</code> est une longueur élastique
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).  Elle donne l&textrsquo;<dfn>interligne</dfn>, la distance normale
entre les lignes d&textrsquo;un paragraphe, de ligne de base à ligne de base.
</para>
<para>D&textrsquo;ordinaire un auteur de documents ne change pas directement
<code>\baselineskip</code> en écrivant. Au lieu de cela, l&textrsquo;interligne est
réglé par la commande de bas niveau de sélection de fonte
<code>\fontsize</code> (<pxref label="low-level-font-commands-fontsize"><xrefnodename>low level font commands fontsize</xrefnodename></pxref>).  La valeur
de <code>\baselineskip</code> est réinitialisée chaque fois qu&textrsquo;un changement
de fonte survient et ainsi tout changement direct de <code>\baselineskip</code>
serait anéanti dès la prochaine commutation de fonte. Pour la façon
d&textrsquo;influencer l&textrsquo;espacement des lignes, voir la discussion de
<code>\baselinestretch</code> ci-dessous.
</para>
<para>D&textrsquo;habitude, une taille de fonte et un interligne sont assignés par
l&textrsquo;auteur de la fonte. Ces nombres sont nominaux au sens où si, par
exemple, un fichier de style de fonte comprend la commande
<code>\fontsize&lbrace;10pt&rbrace;&lbrace;12pt&rbrace;</code> alors cela ne veut pas dire que les
caractères dans la fonte font 10<dmn>pt</dmn> de haut ; par exemple, les
parenthèses et les capitales accentuées pourraient être plus hautes. Non
plus cela ne signifie que si les lignes sont espacées de moins de
12<dmn>pt</dmn> alors elles risquent de se toucher. Ces nombres sont plutôt
des jugements typographiques.  (Souvent, le <code>\baselineskip</code> est
environ plus grand de 20<dmn>%</dmn> que la taille de fonte).
</para>
<!-- c adapted from FAQ -->
<para>Le <code>\baselineskip</code> n&textrsquo;est pas une propriété de chaque ligne, mais du
paragraphe entier. Il en résulte, que du texte de grande taille au milieu
d&textrsquo;un paragraphe, tel qu&textrsquo;un simple <code>&lbrace;\Huge Q&rbrace;</code>, est serré sur sa
ligne.  &tex; s&textrsquo;assure qu&textrsquo;il ne racle pas sur la ligne du dessus mais
il ne change par le <code>\baselineskip</code> pour que cette ligne-là soit
surplombée d&textrsquo;un espace supplémentaire. Pour résoudre ce problème,
utilisez un <code>\strut</code> (<pxref label="_005cstrut"><xrefnodename>\strut</xrefnodename></pxref>).
</para>
<para>La valeur de <code>\baselineskip</code> que &tex; utilise pour les paragraphes
est celle en vigueur à l&textrsquo;endroit de la commande ou ligne à blanc qui
termine l&textrsquo;unité de paragraphe. Ainsi, si un document contient le
paragraphe ci-dessous alors ses lignes seront recroquevillées ensemble,
comparées au lignes des paragraphes alentour.
</para>
<!-- c Adapted from B Beeton's "Lapses in TeX" TB 42:1 p 13. -->
<example endspaces=" ">
<pre xml:space="preserve">Beaucoup de gens considèrent les sauts de page entre du texte est une
équation affichée comme du mauvais style, alors qu'en fait l'affiche
fait partie du paragraphe.  Étant donné que l'affiche ci-dessous est en
taille de fonte footnotesize, l'entièreté du paragraphe a un espcement
d'interligne correspondant à cette taille. &lbrace;\footnotesize $$a+b = c$$&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="252">\lineskip</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="253">\lineskiplimit</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="254">\prevdepth</indexterm></findex>
<para>Le procédé de fabrication des paragraphes est que quand une nouvelle
ligne est ajoutée, si la somme de la profondeur de la ligne précédente
et de la hauteur de la nouvelle ligne est inférieure à
<code>\baselineskip</code> alors &tex; insère une glue verticale en quantité
suffisante pour faire la différence.  Il y a deux points délicats. Le
premier est que au cas où les lignes seraient trop proches l&textrsquo;une de
l&textrsquo;autre, plus proches que <code>\lineskiplimit</code>, alors &tex; au lieu de
cela utilise <code>\lineskip</code> comme la glue d&textrsquo;interligne.  Le second est
que &tex; n&textrsquo;utilise pas vraiment la profondeur de la ligne
précédente. Au lieu de cela il utilise <code>\prevdepth</code>, ce qui
d&textrsquo;ordinaire contient cette profondeur. Mais au début d&textrsquo;un paragraphe,
(ou de toute liste verticale) ou juste après un filet, <code>\prevdepth</code>
a la valeur de -1000<dmn>pt</dmn> et cette valeur spéciale dit à &tex; de ne
pas insérer de glue d&textrsquo;interligne au démarrage du paragraphe.
</para>
<para>Dans les classes standardes <code>\lineskiplimit</code> vaut 0<dmn>pt</dmn> et
<code>\lineskip</code> vaut 1<dmn>pt</dmn>. Selon le procédé exposé dans le
paragraphe précédent, la distance entre les lignes peut approcher zéro,
mais si elle devient zéro (ou moins que zéro) alors un écartement de
1<dmn>pt</dmn> est appliqué aux lignes.
</para>
<para>Il arrive qu&textrsquo;un auteur doive, à des fins d&textrsquo;édition, mettre le document
en double interligne, ou bien en interligne un-et-demi. La façon
correcte d&textrsquo;influencer la distance d&textrsquo;interligne est au travers de
<code>\baselinestretch</code> qui dilate <code>\baselineskip</code>, et a une valeur
par défaut de <samp>1.0</samp>.  C&textrsquo;est une commande, et non une longueur,
ainsi on change le facteur d&textrsquo;échelle comme dans
<code>\renewcommand&lbrace;\baselinestretch&rbrace;&lbrace;1.5&rbrace;\selectfont</code>.
</para>
<para>La façon la plus directe de changer l&textrsquo;interligne pour tout un document
est de placer <code>\linespread&lbrace;<var>facteur</var>&rbrace;</code> dans le préambule.
Pour un double espacement, prenez <var>facteur</var> à <samp>1.6</samp> et pour un
espacement un-et-demi utilisez <samp>1.3</samp>.  Ces nombres sont
approximatifs : par exemple puisque <code>\baselineskip</code> vaut environ
1,2 fois la taille de fonte, le multiplier par 1,6 donne un rapport
entre l&textrsquo;interligne et la taille de fonte d&textrsquo;environ 2.  (La commande
<code>\linespread</code> est définie comme
<code>\renewcommand&lbrace;\baselinestretch&rbrace;&lbrace;<var>facteur</var>&rbrace;</code> de sorte que
son effet n&textrsquo;entre en vigueur que lorsqu&textrsquo;un réglage de fonte
survient. Mais cela a toujours lieu au démarrage d&textrsquo;un document, de sorte
que là vous n&textrsquo;avez pas besoin de la faire suivre d&textrsquo;un
<code>\selectfont</code>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="255"><r>paquetage</r> <code>setspace</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="256"><code>setspace</code>, <r>paquetage</r></indexterm></findex>

<para>Une approche plus simple est fournie par le paquetage <code>setspace</code>.
Voici un exemple de base :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;setspace&rbrace;
\doublespacing  % ou \onehalfspacing pour 1,5
</pre></example>

<noindent></noindent>
<para>Placé dans le préambule ces déclarations démarreront le document dès le
début avec ces réglages de taille. Mais vous pouvez aussi les utiliser
dans le corps du document pour changer l&textrsquo;espacement à partir de ce
point, et par conséquent il y a <code>\singlespacing</code> pour revenir à
l&textrsquo;espacement normal. Dans le corps du document, une pratique meilleure
qu&textrsquo;utiliser ces déclarations est d&textrsquo;utiliser les environnements, tels que
<code>\begin&lbrace;doublespace&rbrace; ... \end&lbrace;doublespace&rbrace;</code>.  Ce paquetage
fournit aussi des commandes pour faire un espacement quelconque :
<code>\setstretch&lbrace;<var>factor</var>&rbrace;</code> et
<code>\begin&lbrace;spacing&rbrace;&lbrace;<var>factor</var>&rbrace; ... \end&lbrace;spacing&rbrace;</code>.
Ce paquetage conserve également un interligne simple là où c&textrsquo;est
typiquement désirable, comme dans les notes de bas de page et dans les
légendes de figure. Voir la documentation du paquetage.
</para>

</section>
<node name="Floats" spaces=" "><nodename>Floats</nodename><nodeprev automatic="on">\baselineskip &amp; \baselinestretch</nodeprev><nodeup automatic="on">Layout</nodeup></node>
<section spaces=" "><sectiontitle>Flottants</sectiontitle>

<para>Certains éléments typographiques, tels que les figures et les tableaux,
ne peuvent pas être à cheval sur plusieurs pages. Ils doivent être
composés en dehors du flux normal du texte, par exemple flottant au
sommet d&textrsquo;une page ultérieure
</para>
<para>&latex; sait gérer plusieurs classes de matière flottante. Il y a deux
classes définies par défaut, <code>figure</code> (<pxref label="figure"><xrefnodename>figure</xrefnodename></pxref>) et
<code>table</code> (<pxref label="table"><xrefnodename>table</xrefnodename></pxref>), mais vous pouvez créer une nouvelle
classes avec le paquetage <code>float</code>.
</para>
<para>Au sein d&textrsquo;une même classe flottante &latex; respecte l&textrsquo;ordre, de sorte
que la première figure dans le code source d&textrsquo;un document est toujours
composée avant la deuxième figure.  Cependant, &latex; peut mélanger
les classes, ainsi il peut se produire qu&textrsquo;alors que le premier tableau
apparaît dans le code source avant la première figure, il apparaisse
après elle dans le fichier de sortie.
</para>
<para>Le placement des flottants est l&textrsquo;objet de paramètres, donnés ci-dessous,
qui limitent le nombre de flottants pouvant apparaître au sommet d&textrsquo;une
page, et au bas de page, etc. Si à cause d&textrsquo;un nombre trop important de
flottants mis en queue ces limites les empêchent de tenir tous dans une
seule page, alors &latex; place ce qu&textrsquo;il peut et diffère le reste à la
page suivante. De la sorte, les flottants peuvent être composés loin de
leur place d&textrsquo;origine dans le code source.  En particulier, un flottant
qui prend beaucoup de place peut migrer jusqu&textrsquo;à la fin du document. Mais
alors, parce que tous les flottants dans une classe doivent apparaître
dans le même ordre séquentiel, tous les flottants suivant dans cette
classe apparaissent aussi à la fin.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="167">placement des flottants</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="168">spécificateur, placement de flottants</indexterm></cindex>
<para>En plus de changer les paramètres, pour chaque flottant vous pouvez
peaufiner l&textrsquo;endroit où l&textrsquo;algorithme de placement des flottants essaie de
le placer en utilisant sont argument <var>placement</var>.  Les valeurs
possibles sont une séquence des lettres ci-dessous. La valeur par
défaut pour à la fois <code>figure</code> et <code>table</code>, dans les deux
classes de document <code>article</code> et <code>book</code>, est <code>tbp</code>.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">t</itemformat></item>
</tableterm><tableitem><para>(pour Top) &textmdash; au sommet d&textrsquo;une page de texte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">b</itemformat></item>
</tableterm><tableitem><para>(pour Bottom) &textmdash; au bas d&textrsquo;une page de texte.  (Cependant, <code>b</code> n&textrsquo;est pas
autorisé avec des flottants en pleine-largeur (<code>figure*</code>) en cas de
sortie à double-colonne. Pour améliorer cela, on peut utiliser les
paquetages <file>stfloats</file> ou <file>dblfloatfix</file>, mais voyez la
discussion sur les avertissements dans la FAQ :
<url><urefurl>http://www.tex.ac.uk/cgi-bin/texfaq2html?label=2colfloat</urefurl></url>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">h</itemformat></item>
</tableterm><tableitem><para>(pour « Here », c.-à-d.&noeos;« Ici » en anglais) &textmdash; à la position du texte
où l&textrsquo;environnement <code>figure</code> apparaît. Cependant, <code>h</code> n&textrsquo;est pas
autorisé en soi-même ; <code>t</code> est ajouté automatiquement.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="169">ici, placer les flottants</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="257"><r>paquetage</r> <code>float</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="258"><code>float</code>, <r>paquetage</r></indexterm></findex>

<para>Pour forcer à tout prix un flottant à apparaître « ici », vous pouvez
charger le paquetage <code>float</code> et le spécificateur <code>H</code> qui y est
défini.  Pour plus ample discussion, voir l&textrsquo;entrée de FAQ à
<url><urefurl>http://www.tex.ac.uk/cgi-bin/texfaq2html?label=figurehere</urefurl></url>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">p</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="170">page de flottants</indexterm></cindex>
<para>(pour Page de flottants) &textmdash; sur une <dfn>page de flottants</dfn> séparée, qui est une
page ne contenant pas de texte, seulement des flottants.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">!</itemformat></item>
</tableterm><tableitem><para>Utilisé en plus de l&textrsquo;un des spécificateurs précédents ; pour ce flottant
seulement, &latex; ignore les restrictions à la fois sur le nombre de
flottants qui peuvent apparaître et les quantités relatives de texte
flottant et non-flottant sur la page.  Le spécificateur <code>!</code>
<emph>ne</emph> signifie <emph>pas</emph> « mets le flottant ici » ; voir
plus haut.
</para>
</tableitem></tableentry></table>

<para>Note : l&textrsquo;ordre dans lequel les lettres apparaissent au sein du paramètre
<var>placement</var> ne change pas l&textrsquo;ordre dans lequel &latex; essaie de
placer le flottant ; par exemple <code>btp</code> a le même effet que
<code>tbp</code>.  Tout ce que <var>placement</var> fait c&textrsquo;est que si une lettre
n&textrsquo;est pas présente alors l&textrsquo;algorithme n&textrsquo;essaie pas cet endroit.  Ainsi,
la valeur par défaut de &latex; étant <code>tbp</code> consiste à essayer
toutes les localisations sauf celle de placer le flottant là où il
apparaît dans le code source.
</para>
<para>Pour empêcher &latex; de rejeter tous les flottants à la fin du document
ou d&textrsquo;un chapitre, vous pouvez utiliser la commande <code>\clearpage</code>
pour commencer une nouvelle page et insérer tous les flottants pendants.
Si un saut de page est indésirable alors vous pouvez charger le
paquetage <file>afterpage</file> et commettre le code
<code>\afterpage&lbrace;\clearpage&rbrace;</code>.  Ceci aura l&textrsquo;effet d&textrsquo;attendre la fin de
la page courante et ensuite de faire passer tous les flottants encore
non placés.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="259"><r>paquetage</r> <code>flafter</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="260"><code>flafter</code>, <r>paquetage</r></indexterm></findex>

<para>&latex; peut composer un flottant avant l&textrsquo;endroit où il apparaît dans
le code source (quoique sur la même page de sortie) s&textrsquo;il y a un
spécificateur <code>t</code> au sein du paramètre <var>placement</var>.  Si ceci
n&textrsquo;est pas désiré, et que supprimer <code>t</code> n&textrsquo;est acceptable car ce
spécificateur empêche le flottant d&textrsquo;être placé au sommet de la page
suivante, alors vous pouvez empêcher  cela soit en utilisant le
paquetage <code>flafter</code> ou en utilisant ou en utilisant la
commande
<findex index="fn" spaces=" "><indexterm index="fn" number="261">\suppressfloats</indexterm></findex>
<code>\suppressfloats[t]</code>, ce qui entraîne le déplacement vers la page
suivante des flottants qui auraient du être placés au sommet de la page
courante.
</para>

<para>Voici les paramètres en relation aux fractions de pages occupées par du
texte flottant et non flottant (on peut les changer avec
<code>\renewcommand&lbrace;<var>paramètre</var>&rbrace;&lbrace;<var>nombre décimal entre 0 et
1</var>&rbrace;</code>) :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><findex index="fn" spaces=" "><indexterm index="fn" number="262">\bottomfraction</indexterm></findex>
<para>La fraction maximale de page autorisée à être occupées par des flottants
au bas de la page ; la valeur par défaut est <samp>.3</samp>.
</para>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="263">\floatpagefraction</indexterm>\floatpagefraction</itemformat></item>
</tableterm><tableitem><para>La fraction minimale d&textrsquo;une page de flottants qui doit être occupée par des
flottants ; la valeur par défaut <samp>.5</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="264">\textfraction</indexterm>\textfraction</itemformat></item>
</tableterm><tableitem><para>La fraction minimale d&textrsquo;une page qui doit être du texte ; si des
flottants prennent trop d&textrsquo;espace pour préserver une telle quantité de
texte, alors les flottants sont déplacés vers une autre page. La valeur
par défaut est <samp>.2</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="265">\topfraction</indexterm>\topfraction</itemformat></item>
</tableterm><tableitem><para>Fraction maximale au sommet d&textrsquo;une page page que peut être occupée avant
des flottants ; la valeur par défaut est <samp>.7</samp>.
</para>
</tableitem></tableentry></ftable>

<para>Les paramètres en relation à l&textrsquo;espace vertical autour des flottants (on
peut les changer avec
<code>\setlength&lbrace;<var>paramètre</var>&rbrace;&lbrace;<var>expression longueur</var>&rbrace;</code>) :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="266">\floatsep</indexterm>\floatsep</itemformat></item>
</tableterm><tableitem><para>Espace entre les flottants au sommet ou au bas d&textrsquo;une page ;  par défaut vaut
<samp>12pt plus2pt minus2pt</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="267">\intextsep</indexterm>\intextsep</itemformat></item>
</tableterm><tableitem><para>Espace au dessus et au dessous d&textrsquo;un flottant situé au milieu du texte
principal ; vaut par défaut <samp>12pt plus2pt minus2pt</samp> pour les styles
à <samp>10pt</samp> et à <samp>11pt</samp>, et <samp>14pt plus4pt minus4pt</samp> pour
<samp>12pt</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="268">\textfloatsep</indexterm>\textfloatsep</itemformat></item>
</tableterm><tableitem><para>Espace entre le dernier (premier) flottant au sommet (bas) d&textrsquo;une page ;
par défaut vaut <samp>20pt plus2pt minus4pt</samp>.
</para></tableitem></tableentry></ftable>

<para>Paramètres en relation avec le nombre de flottant sur une page (on peut
les changer avec <code>\setcounter&lbrace;<var>ctrname</var>&rbrace;&lbrace;<var>natural
number</var>&rbrace;</code>) :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="269">\bottomnumber</indexterm>\bottomnumber</itemformat></item>
</tableterm><tableitem><para>Nombre maximal de flottants pouvant apparaître au bas d&textrsquo;une page de
texte ; par défaut 1.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="270">\topnumber</indexterm>\topnumber</itemformat></item>
</tableterm><tableitem><para>Nombre maximal de flottants pouvant apparaître au sommet d&textrsquo;une page de
texte ; par défaut 2.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="271">\totalnumber</indexterm>\totalnumber</itemformat></item>
</tableterm><tableitem><para>Nombre maximal de flottants pouvant apparaître sur une page de
texte ; par défaut 3.
</para></tableitem></tableentry></ftable>

<para>L&textrsquo;article principal de FAQ &tex; en rapport avec les flottants
<url><urefurl>http://www.tex.ac.uk/cgi-bin/texfaq2html?label=floats</urefurl></url> contient des
suggestions pour relâcher les paramètres par défaut de &latex; de sorte
à réduire les problèmes de flottants rejetés à la fin. Une explication
complète de l&textrsquo;algorithme de placement des flottants se trouve dans
l&textrsquo;article de Frank Mittelbach « How to
influence the position of float environments like figure and table in
&latex;? »  (<url><urefurl>http://latex-project.org/papers/tb111mitt-float.pdf</urefurl></url>).
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::          ">\caption</menunode><menudescription><pre xml:space="preserve">Fabrique une légende pour un environnement flottant.
</pre></menudescription></menuentry></menu>


<node name="_005ccaption" spaces=" "><nodename>\caption</nodename><nodeup automatic="on">Floats</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\caption</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="272">\caption</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="171">captions</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\caption&lbrace;<var>texte-légende</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\caption[<var>texte-légende-bref</var>]&lbrace;<var>texte-légende</var>&rbrace;
</pre></example>

<para>Fabrique une légende pour un environnement flottant, tel que les
environnements <code>figure</code> ou <code>table</code> (<pxref label="figure"><xrefnodename>figure</xrefnodename></pxref>
ou <ref label="table"><xrefnodename>table</xrefnodename></ref>).
</para>
<para>Dans l&textrsquo;exemple suivant, &latex; place une légende sous l&textrsquo;espace blanc
vertical laissé par l&textrsquo;auteur pour l&textrsquo;inclusion ultérieur d&textrsquo;une image.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure&rbrace;
  \vspace*&lbrace;1cm&rbrace;
  \caption&lbrace;Alonzo Cushing, Battery A, 4th US Artillery.&rbrace;
  \label&lbrace;fig:CushingPic&rbrace;
\end&lbrace;figure&rbrace;
</pre></example>

<noindent></noindent>
<para>La commande <code>\caption</code> crée une étiquette pour la légende
<var>texte-légende</var> du genre de <samp>Figure 1 – </samp> pour un document
<code>article</code> ou <samp>Figure 1.1 – </samp> pour un document <code>book</code>.
Le texte est centré s&textrsquo;il est plus court que la largeur du texte, ou
composé comme un paragraphe sans retrait s&textrsquo;il prend plus d&textrsquo;une ligne.
</para>
<para>En plus de placer le <var>texte-légende</var> dans la sortie, la commande
<code>\caption</code> sauvegarde également cette information pour qu&textrsquo;elle soit
utilisée dans une liste de figures ou un liste de tableaux (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table
of contents etc.</xrefnodename></pxref>).
</para>
<para>Ci-dessous la commande <code>\caption</code> utilise l&textrsquo;argument optionnel
<var>texte-légende-bref</var>, de sorte que le texte plus bref apparaisse
dans la liste des tableaux plutôt que la version longue
<var>texte-légende</var>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;table&rbrace;
  \centering
  \begin&lbrace;tabular&rbrace;&lbrace;|*&lbrace;3&rbrace;&lbrace;c&rbrace;|&rbrace;
    \hline
    4  &amp;9  &amp;2 \\
    3  &amp;5  &amp;7 \\ 
    8  &amp;1  &amp;6 \\
    \hline
  \end&lbrace;tabular&rbrace;
  \caption[Carré de \textit&lbrace;Lo Shu&rbrace;]&lbrace;%
    Le carré de \textit&lbrace;Lo Shu&rbrace;, il est unique parmi les carrés
    d'ordre trois à la rotation ou réflexion près.&rbrace;
  \label&lbrace;tab:LoShu&rbrace;
\end&lbrace;table&rbrace;
</pre></example>

<noindent></noindent>
<para>&latex; crée une étiquette pour <var>texte-légende</var> du genre de
<samp>Table 1 – </samp> pour un document <code>article</code> ou <samp>Table 1.1 – </samp>
pour un document <code>book</code>.
</para>
<para>La légende peut apparaître au sommet d&textrsquo;une <code>figure</code> ou
<code>table</code>. Cela se produirait ainsi dans l&textrsquo;exemple précédent en
mettant la <code>\caption</code> entre le <code>\centering</code> et le
<code>\begin&lbrace;tabular&rbrace;</code>.
</para>
<para>Les différents environnements flottants sont numérotés séparément, par
défaut. Le compteur de l&textrsquo;environnement <code>figure</code> est nommé
<code>figure</code>, et de même le compteur de l&textrsquo;environnement <code>table</code>
est <code>table</code>.
</para>
<para>Le texte qui est mis dans la liste des figures ou des tableaux est un
argument mouvant.  Si vous obtenez l&textrsquo;erreur &latex; <samp>!  Argument
of \&arobase;caption has an extra &rbrace;</samp> alors vous devez précéder d&textrsquo;un
<code>\protect</code> toute commande fragile. <xref label="_005cprotect"><xrefnodename>\protect</xrefnodename></xref>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="273"><r>paquetage</r> <code>package</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="274"><code>package</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>caption</code> a beaucoup d&textrsquo;options pour ajuster
l&textrsquo;apparence de la légende, par ex.&noeos; changer la taille de la fonte,
faire que la légende soit un texte en retrait plutôt qu&textrsquo;un paragraphe,
ou faire que la légende soit toujours un paragraphe, plutôt qu&textrsquo;un texte
centré quand elle est courte.
</para>

</subsection>
</section>
</chapter>
<node name="Sectioning" spaces=" "><nodename>Sectioning</nodename><nodenext automatic="on">Cross references</nodenext><nodeprev automatic="on">Layout</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Rubricage</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="172">rubricage, commandes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="173">commandes de rubricage,</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="174"><code>part</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="175">partie</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="176"><code>chapter</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="177">chapitre</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="178">section</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="179"><code>subsection</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="180">sous-section</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="181"><code>subsubsection</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="182">sous-sous-section</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="183"><code>paragraph</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="184">paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="185"><code>subparagraph</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="186">sous-paragraphe</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="275">\part</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="276">\chapter</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="277">\section</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="278">\subsection</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="279">\subsubsection</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="280">\paragraph</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="281">\subparagraph</indexterm></findex>

<para>Structure votre texte en rubriques : parties, chapitres, sections,
etc. Toutes les commandes de rubricage ont la même forme, l&textrsquo;une parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><var>cmd-de-rubricage</var>&lbrace;<var>titre</var>&rbrace;
<var>cmd-de-rubricage</var>*&lbrace;<var>titre</var>&rbrace;
<var>cmd-de-rubricage</var>[<var>titre-tdm</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>Par exemple, déclarez le début d&textrsquo;une sous-section comme dans
<code>\subsection&lbrace;Motivation&rbrace;</code>.
</para>
<para>Le tableau suivant comprend chacune des commandes <var>cmd-de-rubricage</var>
de &latex;.  Toutes sont disponibles dans toutes les classes de
document standardes de &latex; <code>book</code>, <code>report</code>,
et <code>article</code>, à ceci près que <code>\chapter</code> n&textrsquo;est pas disponible
dans <code>article</code>.
</para>
<multitable spaces=" " endspaces=" "><columnfractions line=".25 .25 .40"><columnfraction value=".25"></columnfraction><columnfraction value=".25"></columnfraction><columnfraction value=".40"></columnfraction></columnfractions>
<thead><row><entry command="headitem" spaces=" "><para>Type de rubrique  </para></entry><entry command="tab" spaces=" "><para>Commande  </para></entry><entry command="tab" spaces=" "><para>Niveau
</para></entry></row></thead><tbody><row><entry command="item" spaces=" "><para>Part
</para></entry><entry command="tab" spaces=" "><para><code>\part</code>  </para></entry><entry command="tab" spaces=" "><para>-1 (<code>book</code>, <code>report</code>), 0 (<code>article</code>)
</para></entry></row><row><entry command="item" spaces=" "><para>Chapter
</para></entry><entry command="tab" spaces=" "><para><code>\chapter</code>   </para></entry><entry command="tab" spaces=" "><para>0
</para></entry></row><row><entry command="item" spaces=" "><para>Section
</para></entry><entry command="tab" spaces=" "><para><code>\section</code>   </para></entry><entry command="tab" spaces=" "><para>1
</para></entry></row><row><entry command="item" spaces=" "><para>Subsection
</para></entry><entry command="tab" spaces=" "><para><code>\subsection</code>   </para></entry><entry command="tab" spaces=" "><para>2
</para></entry></row><row><entry command="item" spaces=" "><para>Subsubsection
</para></entry><entry command="tab" spaces=" "><para><code>\subsubsection</code>   </para></entry><entry command="tab" spaces=" "><para>3
</para></entry></row><row><entry command="item" spaces=" "><para>Paragraph
</para></entry><entry command="tab" spaces=" "><para><code>\paragraph</code>   </para></entry><entry command="tab" spaces=" "><para>4
</para></entry></row><row><entry command="item" spaces=" "><para>Subparagraph
</para></entry><entry command="tab" spaces=" "><para><code>\subparagraph</code>   </para></entry><entry command="tab" spaces=" "><para>5
</para></entry></row></tbody></multitable>


<cindex index="cp" spaces=" "><indexterm index="cp" number="187"><code>*</code>, forme en <code>*</code> des commandes de rubricage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="188">étoilée, forme des commandes de rubricage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="189">forme étoilée des commandes de rubricage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="190">forme en * des commandes de rubricage</indexterm></cindex>
<para>Toutes ces commandes ont une forme en <code>*</code>, aussi appelée étoilée,
qui imprime <var>titre</var> comme d&textrsquo;habitude mais sans le numéroter et sans
fabriquer une entrée dans la table des matières.  Un exemple
d&textrsquo;utilisation est pour un appendice dans un <code>article</code>.  Entrer le
code <code>\appendix\section&lbrace;Appendice&rbrace;</code> donne en sortie <samp>A
Appendix</samp> (<pxref label="_005cappendix"><xrefnodename>\appendix</xrefnodename></pxref>).  Vous pouvez ôter le numéro <samp>A</samp> en
entrant à la place <code>\section*&lbrace;Appendice&rbrace;</code> (les articles omettent
couramment d&textrsquo;avoir une table des matières et ont des en-têtes de pages
simples alors les autres différences de la commande <code>\section</code>
peuvent être négligées).
</para>
<para>Le titre <var>titre</var> fournit la rubrique en tant que titre dans le texte
principal, mais il peut également apparaître dans la table des matières
et le haut et le bas de page (<pxref label="Page-styles"><xrefnodename>Page styles</xrefnodename></pxref>).  Vous pourriez
désirer un texte différent à ces endroits que dans le texte principal.
Toute ces commandes ont un argument optionnel <var>tdm-titre</var> destiné à
ces autres endroits.
</para>
<para>Le numéro dans la colonne &laquo;Niveau&raquo; de la
table ci-dessus détermine quelles rubriques sont numérotées, et
lesquelles apparaissent dans la table des matières.  Si le <var>niveau</var>
de la commande de rubricage est inférieur ou égal à la valeur du
compteur <code>secnumdepth</code> alors les rubriques correspondant à ces
commandes de rubricage sont numérotées (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref>).
Et, si <var>niveau</var> est inférieur ou égal à la valeur du compteur
<code>tocdepth</code> alors la table des matières comprend une entrée pour
cette rubrique (<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>).
</para>
<para>&latex; s&textrsquo;attend que avant d&textrsquo;avoir une <code>\subsection</code> vous ayez une
 <code>\section</code> et, dans un document de classe <code>book</code>, qu&textrsquo;avant
 une <code>\section</code> vous ayez un <code>\chapter</code>.  Autrement vous
 pourriez obtenir quelque chose comme une sous-section numérotée
 <samp>3.0.1</samp>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="282"><r>paquetage</r> <code>titlesec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="283"><code>titlesec</code>, <r>paquetage</r></indexterm></findex>

<para>&latex; vous permet de changer l&textrsquo;apparence des rubriques.  Un exemple
simple de ceci est que vous pouvez mettre le numéro de rubrique de type
section en lettres majuscules avec
<code>\renewcommand\thesection&lbrace;\Alph&lbrace;section&rbrace;&rbrace;</code> dans le préambule
(<pxref label="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol"><xrefnodename>\alph \Alph \arabic \roman \Roman \fnsymbol</xrefnodename></pxref>).  Le CTAN a
beaucoup de paquetages rendant ce genre d&textrsquo;ajustement plus facile,
notamment <code>titlesec</code>.
</para>
<para>Deux compteurs sont en relation avec l&textrsquo;apparence des rubriques fabriquées
par les commandes de rubricage.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="284">secnumdepth</indexterm>secnumdepth</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="285">secnumdepth <r>compteur</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="191">numéros de rubrique, composition</indexterm></cindex>
<anchor name="sectioning-secnumdepth">sectioning secnumdepth</anchor>
<anchor name="Sectioning_002fsecnumdepth">Sectioning/secnumdepth</anchor>
<para>Le compteur <code>secnumdepth</code> contrôle quels titres de rubriques sont
numérotés.  Régler le compteur avec
<code>\setcounter&lbrace;secnumdepth&rbrace;&lbrace;<var>niveau</var>&rbrace;</code> supprime la
numérotation des rubriques à toute profondeur supérieure à <var>niveau</var>
(<pxref label="_005csetcounter"><xrefnodename>\setcounter</xrefnodename></pxref>).  Voir la table plus haut pour la valeur des
niveaux. Par exemple, si le <code>secnumdepth</code> vaut 1 dans un
<code>article</code> alors la commande <code>\section&lbrace;Introduction&rbrace;</code> produit
en sortie quelque chose comme <samp>1 Introduction</samp> alors que
<code>\subsection&lbrace;Discussion&rbrace;</code> produit quelque chose comme
<samp>Discussion</samp>, sans numéro. La valeur par défaut de &latex; pour
<code>secnumdepth</code> vaut 3 dans la classe <file>article</file> et 2 dans les
classes <file>book</file> et <file>report</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="286">tocdepth</indexterm>tocdepth</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="287">tocdepth <r>counter</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="192">table des matières, impression des numéros de rubrique</indexterm></cindex>
<anchor name="sectioning-tocdepth">sectioning tocdepth</anchor>
<anchor name="Sectioning_002ftocdepth">Sectioning/tocdepth</anchor>
<para>Contrôle quelles rubriques sont listées dans la table des matières.
Régler <code>\setcounter&lbrace;tocdepth&rbrace;&lbrace;<var>niveau</var>&rbrace;</code> a pour effet que
les rubriques au niveau <var>niveau</var> sont celles de plus petit niveau à
être listées (<pxref label="_005csetcounter"><xrefnodename>\setcounter</xrefnodename></pxref>).  Voir la table ci-dessus pour les
numéros de niveau.  Par exemple, if <code>tocdepth</code> vaut 1 alors la table
des matières contiendra les rubriques issues de <code>\section</code>, mais pas
celles de <code>\subsection</code>.  La valeur par défaut de &latex; pour
<code>tocdepth</code> vaut 3 dans la classe <file>article</file> et 2 dans les
classes <file>book</file> et <file>report</file>.
</para></tableitem></tableentry></ftable>


<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::                                         ">\part</menunode><menudescription><pre xml:space="preserve">Commence une partie.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                                      ">\chapter</menunode><menudescription><pre xml:space="preserve">Commence un chapitre.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                                      ">\section</menunode><menudescription><pre xml:space="preserve">Commence une section.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                                   ">\subsection</menunode><menudescription><pre xml:space="preserve">Commence une sous-section.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">\subsubsection &amp; \paragraph &amp; \subparagraph</menunode><menudescription><pre xml:space="preserve">Subdivisions inférieures.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                                     ">\appendix</menunode><menudescription><pre xml:space="preserve">Commence un appendice.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">\frontmatter &amp; \mainmatter &amp; \backmatter</menunode><menudescription><pre xml:space="preserve">Les trois parties d&textrsquo;un livre.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                               ">\&arobase;startsection</menunode><menudescription><pre xml:space="preserve">Composer les rubriques.
</pre></menudescription></menuentry></menu>


<node name="_005cpart" spaces=" "><nodename>\part</nodename><nodenext automatic="on">\chapter</nodenext><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\part</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="288">\part</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="193">part</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="194">rubricage, part</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\part&lbrace;<var>titre</var>&rbrace;
\part*&lbrace;<var>titre</var>&rbrace;
\part[<var>tdm-titre</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<para>Début une partie de document.  Les classes standarde &latex;
<code>book</code>, <code>report</code>, et <code>article</code> offrent toutes cette
commande.
</para>
<para>L&textrsquo;exemple suivant produit une partie de document dans un livre :
</para>
<!-- c xxx à traduire -->
<example endspaces=" ">
<pre xml:space="preserve">\part&lbrace;VOLUME I \\
       PERSONAL MEMOIRS OF  U.\ S.\ GRANT&rbrace;
\chapter&lbrace;ANCESTRY--BIRTH--BOYHOOD.&rbrace;
My family is American, and has been for generations,
in all its branches, direct and collateral.
</pre></example>

<para>Dans chaque classe standarde la commande <code>\part</code> produit en sortie
un numéro de partie tel que <samp>Première partie</samp>, seul sur sa ligne,
en caractère gras, et en gros caractères.  Ensuite &latex; produit en
sortie <var>titre</var>, également seule sur sa ligne, en caractère gras et
en caractères encore plus gros.
Dans la classe <code>book</code>, le comportement par défaut de &latex; est
de mettre chaque titre de partie seule sur sa propre page. Si le livre
est en recto-verso alors &latex; saute une page si nécessaire pour que
la nouvelle partie commence sur une page à numéro impair. Dans un
<code>report</code> il est également seul sur une page, mais &latex; ne force
pas qu&textrsquo;elle soit de numéro impair.  Dans un <code>article</code> &latex; ne
le place pas sur une nouvelle page, mais au lieu de cela produit en
sortie le numéro de partie et le titre de partie sur la même page que le
document principal.
</para>
<para>La forme en <code>*</code> imprime <var>titre</var> mais n&textrsquo;imprime pas le numéro de
partie, et n&textrsquo;incrémente pas le compteur <code>part</code>, et ne produit
aucune entrée dans la table des matières.
</para>
<para>L&textrsquo;argument optionnel <var>tdm-titre</var> apparaît comme le titre de la
partie dans la table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents etc.</xrefnodename></pxref>) et
dans les hauts de pages (<pxref label="Page-styles"><xrefnodename>Page styles</xrefnodename></pxref>).  S&textrsquo;il n&textrsquo;est pas présent
alors <var>titre</var> est utilisé à sa place. Dans l&textrsquo;exemple suivante on met
un saut de ligne dans <var>titre</var> mais on l&textrsquo;enlève dans la table des
matières.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\part[Up from the bottom; my life]&lbrace;Up from the bottom\\ my life&rbrace;
</pre></example>

<para>Pour déterminer quelles rubrique sont numéroté et lesquelles
apparaissent dans la table des matières, le numéro de niveau d&textrsquo;une
partie vaut -1 (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref> et
<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="289"><r>paquetage</r> <code>indentfirst</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="290"><code>indentfirst</code>, <r>paquetage</r></indexterm></findex>


<para>Dans la classe <code>article</code>, si un paragraphe suit immédiatement le
titre de partie alors il n&textrsquo;est pas renfoncé.  Pour obtenir un
renfoncement vous pouvez utiliser le paquetage <code>indentfirst</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="291"><r>paquetage</r> <code>titlesec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="292"><code>titlesec</code>, <r>paquetage</r></indexterm></findex>

<para>Un paquetage pour changer le comportement de <code>\part</code> est
<code>titlesec</code>.  Voir sa documentation sur le CTAN.
</para>

</section>
<node name="_005cchapter" spaces=" "><nodename>\chapter</nodename><nodenext automatic="on">\section</nodenext><nodeprev automatic="on">\part</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\chapter</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="293">\chapter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="195">chapitre</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter&lbrace;<var>titre</var>&rbrace;
\chapter*&lbrace;<var>titre</var>&rbrace;
\chapter[<var>tdm-titre</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<para>Commence un chapitre.  Les classes standardes &latex;  <code>book</code> et
<code>report</code> ont cette commande, mais <code>article</code> non.
</para>
<para>L&textrsquo;exemple suivant produit un chapitre.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter&lbrace;Mirages&rbrace;
Appelez moi Ismaël.
Voici quelques années --- peu importe combien --- le porte-monnaie vide
ou presque, rien ne me retenant à terre, je songeai à naviguer un peu et
à voir l'étendue liquide du globe.
</pre></example>

<para>Le comportement par défaut de &latex; est de commence chaque chapitre
sur une page neuve, une page à numéro impair si le document est en
recto-verso.  Il produit un numéro de chapitre tel que <samp>Chapitre 1</samp>
en gros caractère gras (la taille est <code>\huge</code>). Ensuite il place le
<var>titre</var> sur une nouvelle ligne, en caractère gras encore plus gros
(taille <code>\Huge</code>).  Il incrémente également le compteur
<code>chapter</code>, ajoute une entrée à la table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table
of contents etc.</xrefnodename></pxref>), et règle l&textrsquo;information de haut de page (<pxref label="Page-styles"><xrefnodename>Page
styles</xrefnodename></pxref>).
</para>
<para>La forme étoilée, ou forme en <code>*</code>, affiche <var>titre</var> sur une
nouvelle ligne, en caractère gras. Mais elle n&textrsquo;affiche pas le numéro de
chapitre, ni n&textrsquo;incrémente le compteur <code>chapter</code>, et ne produit
aucune entrée dans la table des matières, et n&textrsquo;affecte pas le haut de
page.  (Si vous utilise le style de page <code>headings</code> dans un
document recto-verso alors le haut de page sera dérivé du chapitre
précédent). Voici un exemple illustrant cela :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter*&lbrace;Préambule&rbrace;
</pre></example>

<para>L&textrsquo;argument optionnel <var>tdm-titre</var> apparaît comme titre de chapitre
dans la table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents etc.</xrefnodename></pxref>) et dans les
hauts de page (<pxref label="Page-styles"><xrefnodename>Page styles</xrefnodename></pxref>).  Si il n&textrsquo;est pas présent alors
<var>titre</var> sera à la place.  L&textrsquo;exemple suivant montre le nom complet
dans le titre de chapitre,
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter[Weyl]&lbrace;Hermann Klaus Hugo (Peter) Weyl (1885--1955)&rbrace;
</pre></example>

<noindent></noindent>
<para>mais seulement <samp>Weyl</samp> sur la page de table des matières.  L&textrsquo;exemple
suivant place un saut de ligne dans le titre, mais ceci ne fonctionne
pas bien avec les hauts de page, alors il omet le saut dans la table des
matières
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter[J'ai tout donné ; mon histoire]&lbrace;J'ai tout donné\\ mon histoire&rbrace;
</pre></example>

<para>Pour déterminer quelles rubriques sont numérotées et lesquelles
apparaissent dans la table des matières, le numéro de niveau d&textrsquo;un
chapitre est 0 (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref> et
<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="294"><r>paquetage</r> <code>indentfirst</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="295"><code>indentfirst</code>, <r>paquetage</r></indexterm></findex>

<!-- c French version only -->
<findex index="fn" spaces=" "><indexterm index="fn" number="296"><r>paquetage</r> <code>mlp</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="297"><code>mlp</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="298"><r>paquetage</r> <code>babel</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="299"><code>babel</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="300"><r>paquetage</r> <code>polyglossia</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="301"><code>polyglossia</code>, <r>paquetage</r></indexterm></findex>

<para>Lorsque vous chargez un paquetage d&textrsquo;internationalisation tel que
<code>babel</code>, <code>mlp</code> ou <code>polyglossia</code>, et que la langue
sélectionnée est le français, alors le premier paragraphe après le titre
est normalement renfoncé, comme c&textrsquo;est la convention en typographie
française. Par contre, si vous restez en langue par défaut,
c.-à-d.&noeos; en anglo-américain,
<!-- c End French version  only -->
le paragraphe qui suit le titre de chapitre n&textrsquo;est pas renfoncé, étant donné que c&textrsquo;est
<!-- c French version only -->
pour l&textrsquo;anglo-américain
<!-- c End French version only -->
une pratique typographique standarde.  Pour obtenir un renfoncement
<!-- c French version only -->
dans ce cas
<!-- c End French version only -->
utilisez le paquetage <code>indentfirst</code>.
</para>
<para>Vous pouvez changer ce qui est affiché pour le numéro de chapitre.  Pour
le changer en quelque chose du genre de <samp>Cours 1</samp>, placez dans le
préambule soit <code>\renewcommand&lbrace;\chaptername&rbrace;&lbrace;Cours&rbrace;</code>, soit
cela (<pxref label="_005cmakeatletter-_0026-_005cmakeatother"><xrefnodename>\makeatletter &amp; \makeatother</xrefnodename></pxref>) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makeatletter
\renewcommand&lbrace;\&arobase;chapapp&rbrace;&lbrace;Cours&rbrace;
\makeatother
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="302"><r>paquetage</r> <code>babel</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="303"><code>babel</code>, <r>paquetage</r></indexterm></findex>

<noindent></noindent><para>Pour que cela soit fonction de la langue principale du document, voir le paquetage <code>babel</code>.
</para>
<para>Dans un document recto-verso &latex; commence les chapitres sur des
pages de numéro impair, en laissant si nécessaire une page de numéro
pair blanche à l&textrsquo;exception d&textrsquo;un éventuel haut de page.  Pour que cette
page soit complètement blanche, voir <ref label="_005cclearpage-_0026-_005ccleardoublepage"><xrefnodename>\clearpage &amp;
\cleardoublepage</xrefnodename></ref>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="304"><r>paquetage</r> <code>titlesec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="305"><code>titlesec</code>, <r>paquetage</r></indexterm></findex>

<para>Pour changer le comportement de la commande <code>\chapter</code>, vous pouvez
copier sa définition depuis le fichier de format &latex; et faire des
ajustements.  Mais il y a aussi beaucoup de paquetage sur le CTAN qui
traitent de cela.  L&textrsquo;un d&textrsquo;eux est <code>titlesec</code>.  Voir sa
documentation, mais l&textrsquo;exemple ci-dessous donne un aperçu de ce qu&textrsquo;il
peut faire.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;titlesec&rbrace;   % dans le préambule
\titleformat&lbrace;\chapter&rbrace;
  &lbrace;\Huge\bfseries&rbrace;  % format du titre
  &lbrace;&rbrace;                % étiquette, tel que 1.2 pour une sous-section
  &lbrace;0pt&rbrace;             % longueur de séparation entre l'étiquette et le titre
  &lbrace;&rbrace;                % code crochet exécuté avant
</pre></example>

<noindent></noindent>
<para>Ceci omet le numéro de chapitre <samp>Chapitre 1</samp> de la page, mais
contrairement à <code>\chapter*</code> cela conserve le chapitre dans la table
des matières et dans les hauts de page.
</para>

</section>
<node name="_005csection" spaces=" "><nodename>\section</nodename><nodenext automatic="on">\subsection</nodenext><nodeprev automatic="on">\chapter</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\section</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="306">\section</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="196">section</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\section&lbrace;<var>titre</var>&rbrace;
\section*&lbrace;<var>titre</var>&rbrace;
\section[<var>tdm-titre</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<para>Commence une section.  Les classes &latex; standardes <code>article</code>,
<code>book</code>, et <code>report</code> ont toutes cette commande.
</para>
<para>L&textrsquo;exemple suivant produit une section :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Dans cette partie nous nous intéressons plutôt à la fonction, au
comportement d'entrée-sortie, qu'aux détails de la réalisation de ce
comportement.

\section&lbrace;Machines de Turing&rbrace;
En dépit de ce désir de rester évasif sur l'implémentation, nous suivons
l'approche d'A.~Turing selon laquelle la première étape pour définir
l'ensemble des fonctions calculables est de réflechir au détails de ce
que des mécanismes peuvent faire.
</pre></example>

<para>Pour les classes standardes &latex; <code>book</code> et <code>report</code> la
sortie par défaut est du genre de <samp>1.2 <var>titre</var></samp> (pour
chapitre 1, section 2), seul sur sa ligne et fer à gauche, en caractères
gras et plus gros (la taille de police est <code>\Large</code>).  La même
chose vaut pour <code>article</code> à ceci près qu&textrsquo;il n&textrsquo;y a pas de chapitre
dans cette classe, et donc cela ressemble à <samp>2 <var>titre</var></samp>.
</para>
<para>La forme en <code>*</code> affiche <var>titre</var>. Mais elle n&textrsquo;affiche pas le
numéro de section, ni n&textrsquo;incrémente le compteur <code>section</code>, ne
produit aucune entrée dans la table des matières, et n&textrsquo;affecte pas le
haut de page.  (Si vous utilisez le style de page <code>headings</code> dans
un document recto-verso, alors le titre de haut de page sera celui de la
rubrique précédente).
</para>
<para>L&textrsquo;argument optionnel <var>tdm-titre</var> apparaît comme titre de section
dans la table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents etc.</xrefnodename></pxref>) et dans les
titres de haut de page (<pxref label="Page-styles"><xrefnodename>Page styles</xrefnodename></pxref>).  S&textrsquo;il n&textrsquo;est pas présent
alors <var>titre</var> est à la place.  L&textrsquo;exemple suivant montre le nom
complet dans le titre de la section,
</para>
<example endspaces=" ">
<pre xml:space="preserve">\section[Elisabeth~II]&lbrace;Elisabeth deux,
  Reine par la grâce de Dieu du Royaume Uni,
  du Canada et de ses autres Royaumes et Territoires,
  Chef du Commonwealth, Défenseur de la Foi.&rbrace;
</pre></example>

<noindent></noindent>
<para>mais seulement <samp>Elisabeth II</samp> dans la table de matière et sur les
hauts de page.  Dans l&textrsquo;exemple suivant il y a un saut de ligne dans
<var>titre</var> mais ça ne fonctionne pas pour la table des matières alors
il est omis de la table des matières et des titres de hauts de page.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\section[La vérité c'est que j'ai menti ; histoire de ma vie]&lbrace;La vérité
c'est que j'ai menti\\ histoire de ma vie&rbrace;
</pre></example>

<para>Pour déterminer quelles rubriques sont numérotées et lesquelles
apparaissent dans la table des matières, le numéro de niveau d&textrsquo;une
section est 1 (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref> et
<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="307"><r>paquetage</r> <code>indentfirst</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="308"><code>indentfirst</code>, <r>paquetage</r></indexterm></findex>

<!-- c French version only -->
<para>Lorsque vous chargez un paquetage d&textrsquo;internationalisation tel que
<code>babel</code>, <code>mlp</code> ou <code>polyglossia</code>, et que la langue
sélectionnée est le français, alors le premier paragraphe après le titre
est normalement renfoncé, comme c&textrsquo;est la convention en typographie
française. Par contre, si vous restez en langue par défaut,
c.-à-d.&noeos; en anglo-américain,
<!-- c End French version  only -->
le paragraphe qui suit le titre de section n&textrsquo;est pas renfoncé, étant donné que c&textrsquo;est
<!-- c French version only -->
pour l&textrsquo;anglo-américain
<!-- c End French version only -->
une pratique typographique standarde.  Pour obtenir un renfoncement
<!-- c French version only -->
dans ce cas
<!-- c End French version only -->
utilisez le paquetage <code>indentfirst</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="309"><r>paquetage</r> <code>titlesec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="310"><code>titlesec</code>, <r>paquetage</r></indexterm></findex>

<para>En général, pour changer le comportement de la commande <code>\section</code>,
il y a diverses options.  L&textrsquo;une d&textrsquo;elles et la commande
<code>\&arobase;startsection</code> (<pxref label="_005c_0040startsection"><xrefnodename>\&arobase;startsection</xrefnodename></pxref>).  Il y a aussi un grand
nombre de paquetages sur le CTAN traitant de cela, dont
<code>titlesec</code>.  Voir sa
documentation, mais l&textrsquo;exemple ci-dessous donne un aperçu de ce qu&textrsquo;il
peut faire.
</para>
<!-- c credit: egreg https://groups.google.com/forum/#!topic/comp.text.tex/tvc8oM5P4y4 -->
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;titlesec&rbrace;   % dans le préambule
\titleformat&lbrace;\section&rbrace;
  &lbrace;\normalfont\Large\bfseries&rbrace;  % format du titre
  &lbrace;\makebox[1pc][r]&lbrace;\thesection\hspace&lbrace;1pc&rbrace;&rbrace;&rbrace; % étiquette
  &lbrace;0pt&rbrace;                   % longueur de séparation entre l'étiquette et le titre
  &lbrace;&rbrace;                      % code crochet exécuté avant
\titlespacing*&lbrace;\section&rbrace;
  &lbrace;-1pc&rbrace;&lbrace;18pt&rbrace;&lbrace;10pt&rbrace;[10pc]
</pre></example>

<noindent></noindent>
<para>Cela met le numéro de section dans la marge.
</para>

</section>
<node name="_005csubsection" spaces=" "><nodename>\subsection</nodename><nodenext automatic="on">\subsubsection &amp; \paragraph &amp; \subparagraph</nodenext><nodeprev automatic="on">\section</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\subsection</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="311">\subsection</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="197">subsection</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\subsection&lbrace;<var>titre</var>&rbrace;
\subsection*&lbrace;<var>titre</var>&rbrace;
\subsection[<var>tdm-titre</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<para>Commence une sous-section.  Les classes &latex; standardes <code>article</code>,
<code>book</code>, et <code>report</code> ont toutes cette commande.
</para>
<para>L&textrsquo;exemple suivant produit une sous-section :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Nous allons montrer qu'il y a plus de fonction que de machines de Turing
et donc que certaines fonctions n'ont pas de machine associée.

\subsection&lbrace;Cardinal&rbrace; Nous allons commencer par deux paradoxes qui
mettent en scène le défi que pose à notre intuition la comparaison des
tailles d'ensembles infinis.
</pre></example>

<para>Pour les classes &latex; standardes <code>book</code> et <code>report</code> la
sortie par défaut est du genre de <samp>1.2.3 <var>titre</var></samp> (pour
chapitre 1, section 2, sous-section 3), seul sur sa ligne et fer à
gauche, en caractère gras et un peu plus gros (la taille de police est
<code>\large</code>).  La même chose vaut dans <code>article</code> à ceci près
qu&textrsquo;il n&textrsquo;y a pas de chapitre dans cette classe, alors cela ressemble à
<samp>2.3 <var>titre</var></samp>.
</para>
<para>La forme en <code>*</code> affiche <var>titre</var>.  Mais elle n&textrsquo;affiche pas le
numéro de sous-section, ni n&textrsquo;incrémente le compteur <code>subsection</code>,
et ne produit aucune entrée dans la table des matières.
</para>
<!-- c continuer la trad. -->
<para>L&textrsquo;argument optionnel <var>tdm-titre</var> apparaît comme le titre de
sous-section dans la table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents
etc.</xrefnodename></pxref>).  S&textrsquo;il n&textrsquo;est pas présent alors <var>titre</var> est à la place.
L&textrsquo;exemple suivant montre le texte complet dans le titre de sous-section,
</para>
<example endspaces=" ">
<pre xml:space="preserve">\subsection[$\alpha,\beta,\gamma$ paper]&lbrace;\textit&lbrace;The Origin of
  Chemical Elements&rbrace; by R.A.~Alpher, H.~Bethe, and G.~Gamow&rbrace;
</pre></example>

<noindent></noindent>
<para>mais seulement <samp>α,β,γ
paper</samp> dans la table des matières.
</para>
<para>Pour déterminer quelles rubriques sont numérotées et lesquelles
apparaissent dans la table des matières, le numéro de niveau d&textrsquo;une
sous-section est 2 (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref> et
<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="312"><r>paquetage</r> <code>indentfirst</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="313"><code>indentfirst</code>, <r>paquetage</r></indexterm></findex>

<!-- c French version only -->
<para>Lorsque vous chargez un paquetage d&textrsquo;internationalisation tel que
<code>babel</code>, <code>mlp</code> ou <code>polyglossia</code>, et que la langue
sélectionnée est le français, alors le premier paragraphe après le titre
est normalement renfoncé, comme c&textrsquo;est la convention en typographie
française. Par contre, si vous restez en langue par défaut,
c.-à-d.&noeos; en anglo-américain,
<!-- c End French version  only -->
le paragraphe qui suit le titre de sous-section n&textrsquo;est pas renfoncé, étant donné que c&textrsquo;est
<!-- c French version only -->
pour l&textrsquo;anglo-américain
<!-- c End French version only -->
une pratique typographique standarde.  Pour obtenir un renfoncement
<!-- c French version only -->
dans ce cas
<!-- c End French version only -->
utilisez le paquetage <code>indentfirst</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="314"><r>paquetage</r> <code>titlesec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="315"><code>titlesec</code>, <r>paquetage</r></indexterm></findex>

<!-- c -->
<para>Il y a diverses façon de changer le comportement de la commande
<code>\subsection</code>.  L&textrsquo;une d&textrsquo;elles et la commande <code>\&arobase;startsection</code>
(<pxref label="_005c_0040startsection"><xrefnodename>\&arobase;startsection</xrefnodename></pxref>).  Il y a aussi divers paquetages sur le CTAN
traitant de cela, dont <code>titlesec</code>.  Voir sa documentation, mais
l&textrsquo;exemple ci-dessous donne un aperçu de ce qu&textrsquo;il peut faire.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;titlesec&rbrace;   % dans le préambule
\titleformat&lbrace;\subsection&rbrace;[runin]
  &lbrace;\normalfont\normalsize\bfseries&rbrace;  % format du titre
  &lbrace;\thesubsection&rbrace;                   % étiquette
  &lbrace;0.6em&rbrace;                            % espacement entre l'étiquette et le titre
  &lbrace;&rbrace;                                 % code crochet exécuté avant
</pre></example>

<noindent></noindent>
<para>Cela place le numéro de sous-section et <var>titre</var> sur la première
ligne de texte.
</para>

</section>
<node name="_005csubsubsection-_0026-_005cparagraph-_0026-_005csubparagraph" spaces=" "><nodename>\subsubsection &amp; \paragraph &amp; \subparagraph</nodename><nodenext automatic="on">\appendix</nodenext><nodeprev automatic="on">\subsection</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\subsubsection</code>, <code>\paragraph</code>, <code>\subparagraph</code></sectiontitle>

<anchor name="_005csubsubsection">\subsubsection</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="316">\subsubsection</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="198">subsubsection</indexterm></cindex>
<!-- c -->
<anchor name="_005cparagraph">\paragraph</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="317">\paragraph</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="199">paragraph</indexterm></cindex>
<!-- c -->
<anchor name="_005csubparagraph">\subparagraph</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="318">\subparagraph</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="200">subparagraph</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi les suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\subsubsection&lbrace;<var>titre</var>&rbrace;
\subsubsection*&lbrace;<var>titre</var>&rbrace;
\subsubsection[<var>titre-tdm</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\paragraph&lbrace;<var>titre</var>&rbrace;
\paragraph*&lbrace;<var>titre</var>&rbrace;
\paragraph[<var>titre-tdm</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\subparagraph&lbrace;<var>titre</var>&rbrace;
\subparagraph*&lbrace;<var>titre</var>&rbrace;
\subparagraph[<var>titre-tdm</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<para>Débute une rubrique de type sous-sous-section, paragraphe, ou
sous-paragraphe.  Les classes &latex; standardes <code>article</code>,
<code>book</code>, et <code>report</code> disposent toutes de ces commandes, bien
que leur utilisation n&textrsquo;est pas courante.
</para>
<para>L&textrsquo;exemple suivant produit une sous-sous-section :
</para>
<!-- c xxx À traduire -->
<example endspaces=" ">
<pre xml:space="preserve">\subsubsection&lbrace;Piston ring compressors: structural performance&rbrace;
Provide exterior/interior wall cladding assemblies
capable of withstanding the effects of load and stresses from
consumer-grade gasoline engine piston rings.
</pre></example>

<para>La sortie produite par défaut de chacune de ces trois commande est la
même pour les classes &latex; standarde <code>article</code>, <code>book</code>, et
<code>report</code>.  Pour <code>\subsubsection</code> le <var>titre</var> est seul sur
sa ligne, en caractères gras avec la taille normale de police.  Pour
<code>\paragraph</code> le <var>titre</var> est sur la même ligne que le texte qui
suit, sans renfoncement, en caractères gras avec la taille normale de
police.  Pour <code>\subparagraph</code> le <var>titre</var> est sur la même ligne
que la texte qui suit, avec un renfoncement de paragraphe, en caractère
gras et avec la taille normale de police (comme les documents de classe
<code>article</code> n&textrsquo;ont pas de chapitre, leurs sous-sous-sections sont
numérotées et donc cela ressemble à <samp>1.2.3 <var>titre</var></samp>, pour
section 1, sous-section 2, et sous-sous-section 3.  Les deux autres
subdivisions ne sont pas numérotées).
</para>
<para>La forme en <code>*</code> affiche <var>titre</var>.  Mais elle n&textrsquo;incrémente pas le
compteur associé et ne produit pas d&textrsquo;entrée dans la table des matières
(et le titre produit pas <code>\subsubsection</code> n&textrsquo;a pas de numéro).
</para>
<para>L&textrsquo;argument optionnel <var>titre-tdm</var> apparaît comme le titre de la
rubrique dans la table des matières (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents etc.</xrefnodename></pxref>).
S&textrsquo;il est omis, alors <var>titre</var> est utilisé à la place.
</para>
<para>Pour déterminer quelles rubriques sont numérotées et lesquelles
apparaissent dans la table des matières, le numéro de niveau d&textrsquo;une
sous-sous-section est 3, celui d&textrsquo;un paragraphe est 4, et celui d&textrsquo;un
sous-paragraphe est 5 (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref> et
<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="319"><r>paquetage</r> <code>indentfirst</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="320"><code>indentfirst</code>, <r>paquetage</r></indexterm></findex>

<!-- c French version only -->
<para>Lorsque vous chargez un paquetage d&textrsquo;internationalisation tel que
<code>babel</code>, <code>mlp</code> ou <code>polyglossia</code>, et que la langue
sélectionnée est le français, alors le premier paragraphe après le titre
est normalement renfoncé, comme c&textrsquo;est la convention en typographie
française. Par contre, si vous restez en langue par défaut,
c.-à-d.&noeos; en anglo-américain,
<!-- c End French version  only -->
le paragraphe qui suit le titre de chapitre n&textrsquo;est pas renfoncé, étant donné que c&textrsquo;est
<!-- c French version only -->
pour l&textrsquo;anglo-américain
<!-- c End French version only -->
une pratique typographique standarde.  Une façon d&textrsquo;obtenir un renfoncement
<!-- c French version only -->
dans ce cas
<!-- c End French version only -->
est d&textrsquo;utiliser le paquetage <code>indentfirst</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="321"><r>paquetage</r> <code>titlesec</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="322"><code>titlesec</code>, <r>paquetage</r></indexterm></findex>

<para>Il y a de nombreuses manières de changer le comportement de ces
commandes. L&textrsquo;une est la commande <code>\&arobase;startsection</code>
(<pxref label="_005c_0040startsection"><xrefnodename>\&arobase;startsection</xrefnodename></pxref>).  Il y a aussi un grand nombre de paquetages
sur le CTAN traitant de cela, dont <code>titlesec</code>.  Voir sa
documentation sur le CTAN.
</para>
</section>
<node name="_005cappendix" spaces=" "><nodename>\appendix</nodename><nodenext automatic="on">\frontmatter &amp; \mainmatter &amp; \backmatter</nodenext><nodeprev automatic="on">\subsubsection &amp; \paragraph &amp; \subparagraph</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>

<section spaces=" "><sectiontitle><code>\appendix</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="323">\appendix</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="201">appendice</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="202">appendices</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\appendix
</pre></example>

<para>Ne produit pas directement quelque chose en sortie.  Mais dans un
document <code>book</code> ou <code>report</code> cela déclare que toute commande
<code>\chapter</code> qui suit commence une annexe.  Pour les documents
<code>article</code> cela fait la même chose mais avec les commandes
<code>\section</code>.  Remet également à zéro les compteurs <code>chapter</code> et
<code>section</code> dans un document <code>book</code> ou <code>report</code>, et dans un
<code>article</code> les compteurs <code>section</code> et <code>subsection</code>.
</para>
<para>Dans ce document de classe <code>book</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter&lbrace;Un&rbrace;  ...
\chapter&lbrace;Deux&rbrace;  ...
 ...
\appendix
\chapter&lbrace;Trois&rbrace;  ...
\chapter&lbrace;Quatre&rbrace;  ...
</pre></example>

<noindent></noindent>
<para>les deux premières commandes produisent en sortie <samp>Chapitre 1</samp> and
<samp>Chapitre 2</samp>.  Après la commande <code>\appendix</code> la numérotation devient
<samp>Annexe A</samp> et <samp>Annexe B</samp>.  <xref label="Larger-book-template"><xrefnodename>Larger book template</xrefnodename></xref>,
pour un autre exemple.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="324"><r>paquetage</r> <code>appendix</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="325"><code>appendix</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>appendix</code> ajoute la commande <code>\appendixpage</code>
pour créer une page de titre de partie intitulée <samp>Appendices</samp> dans
le corps du document avant la première annexe, ainsi que la
commande <code>\addappheadtotoc</code> pour créer l&textrsquo;entrée correspondante dans
la table des matières.  On peut régler le nom <samp>Appendices</samp> avec une
commande comme <code>\renewcommand&lbrace;\appendixname&rbrace;&lbrace;Annexes&rbrace;</code>, et il y
a plusieurs autres fonctions.  Voir la documentation sur le CTAN.
</para>
</section>
<node name="_005cfrontmatter-_0026-_005cmainmatter-_0026-_005cbackmatter" spaces=" "><nodename>\frontmatter &amp; \mainmatter &amp; \backmatter</nodename><nodenext automatic="on">\&arobase;startsection</nodenext><nodeprev automatic="on">\appendix</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\frontmatter</code>, <code>\mainmatter</code>, <code>\backmatter</code></sectiontitle>

<anchor name="_005cfrontmatter">\frontmatter</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="326">\frontmatter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="203"><code>book</code>, pièces préliminaires</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="204">livre, pièces préliminaires</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="205">pièces préliminaires d&textrsquo;un livre</indexterm></cindex>
<!-- c -->
<anchor name="_005cmainmatter">\mainmatter</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="327">\mainmatter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="206"><code>book</code>, pièces principales</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="207">livre, pièces principales</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="208">pièces principales d&textrsquo;un livre</indexterm></cindex>
<!-- c -->
<anchor name="_005cbackmatter">\backmatter</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="328">\backmatter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="209"><code>book</code>, pièces postliminaires</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="210"><code>book</code>, annexes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="211">livre, pièces postliminaires</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="212">livre, annexes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="213">pièces postliminaires d&textrsquo;un livre</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="214">annexes d&textrsquo;un livre</indexterm></cindex>

<para>Synopsis, l&textrsquo;un ou plus parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\frontmatter
…
\mainmatter
…
\backmatter
…
</pre></example>

<para>Formate un document de classe <code>book</code> différemment selon la partie
du document en cours de production. Les trois commandes sont toutes
optionnelles.
</para>
<para>Traditionnellement, les pièces préliminaires (<code>\frontmatter</code>) d&textrsquo;un
livre comprennent des choses telles que la page de titre, un abrégé, une
table des matières, une préface, une liste des notations, une liste des
figures et une liste des tableaux.  (Certaines des pages des pièces
préliminaires, telles que la page de titres, traditionnellement ne sont
pas numérotée). Les pièces postliminaires (<code>\backmatter</code>) peuvent
contenir des choses telles qu&textrsquo;un glossaire, une bibliographie, et un
index.
</para>
<para>La commande <code>\frontmatter</code> rend les numéros de page en chiffres
romains bas de casse, et rend les chapitres non numérotés, bien que les
titres de chaque chapitre apparaissent dans la table des matières ; si
vous utilisez là aussi d&textrsquo;autres commandes de rubricage, alors utilisez
la version en <code>*</code> (<pxref label="Sectioning"><xrefnodename>Sectioning</xrefnodename></pxref>).
</para>
<para>La commande <code>\mainmatter</code> permet de revenir au comportement
attendu, et réinitialise le numéro de page.
</para>
<para>La commande <code>\backmatter</code> n&textrsquo;affecte pas la numérotation des pages,
mais commute de nouveau les chapitres en mode sans numéros.
</para>
<para><xref label="Larger-book-template"><xrefnodename>Larger book template</xrefnodename></xref>, pour un exemple d&textrsquo;usage de ces trois
commandes.
</para>

</section>
<node name="_005c_0040startsection" spaces=" "><nodename>\&arobase;startsection</nodename><nodeprev automatic="on">\frontmatter &amp; \mainmatter &amp; \backmatter</nodeprev><nodeup automatic="on">Sectioning</nodeup></node>
<section spaces=" "><sectiontitle><code>\&arobase;startsection</code>, composer les rubriques.</sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="329">\&arobase;startsection</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="215">section, redéfinir</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\&arobase;startsection&lbrace;<var>nom</var>&rbrace;&lbrace;<var>niveau</var>&rbrace;&lbrace;<var>retrait</var>&rbrace;&lbrace;<var>avant</var>&rbrace;&lbrace;<var>après</var>&rbrace;&lbrace;<var>style</var>&rbrace;
</pre></example>

<para>Utilisé pour aider à redéfinir le comportement des commandes de
rubricage telles que <code>\section</code> ou <code>\subsection</code>.
</para>
<para>Notez que le paquetage <code>titlesec</code> rend la manipulation du rubricage
plus facile. De plus, bien que la plupart des exigences concernant les
commandes de rubricage peuvent être remplies avec
<code>\&arobase;startsection</code>, ce n&textrsquo;est pas le cas de certaines d&textrsquo;entre elles.  Par exemple,
dans les classes &latex; standardes <code>book</code> et <code>report</code>, les
commandes <code>\chapter</code> et <code>\report</code> ne sont pas construites de
cette manière. Pour fabriquer une telle commande, il est possible
d&textrsquo;utiliser la commande <code>\secdef</code>.
<!-- c xx define, and make a cross reference to, secdef. -->
</para>
<para>Techniquement, la commande <code>\&arobase;startsection</code> a la forme suivante :
</para><example endspaces=" ">
<pre xml:space="preserve">\&arobase;startsection&lbrace;<var>nom</var>&rbrace;
  &lbrace;<var>niveau</var>&rbrace;
  &lbrace;<var>retrait</var>&rbrace;
  &lbrace;<var>avant</var>&rbrace;
  &lbrace;<var>après</var>&rbrace;
  &lbrace;<var>style</var>&rbrace;*[<var>titretdm</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<noindent></noindent><para>de sorte que faire :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\section&rbrace;&lbrace;\&arobase;startsection&lbrace;<var>nom</var>&rbrace;
  &lbrace;<var>niveau</var>&rbrace;
  &lbrace;<var>retrait</var>&rbrace;
  &lbrace;<var>avant</var>&rbrace;
  &lbrace;<var>après</var>&rbrace;
  &lbrace;<var>style</var>&rbrace;&rbrace;
</pre></example>

<noindent></noindent><para>redéfinit <code>\section</code> en gardant sa forme standarde d&textrsquo;appel
<code>\section*[<var>titretdm</var>]&lbrace;<var>titre</var>&rbrace;</code> (dans laquelle on
rappelle que l&textrsquo;étoile <code>*</code> est optionnelle).
<xref label="Sectioning"><xrefnodename>Sectioning</xrefnodename></xref>. Ceci implique que quand vous écrivez une commande
comme <code>\renewcommand&lbrace;\section&rbrace;&lbrace;...&rbrace;</code>, le
<code>\&arobase;startsection&lbrace;...&rbrace;</code> doit venir en dernier dans la définition.
Voir les exemples ci-dessous.
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<beforefirstitem>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="var">nom</itemformat></item>
</tableterm><tableitem><anchor name="startsection-name">startsection name</anchor>
<anchor name="_005c_0040startsection_002fname">\&arobase;startsection/name</anchor>
<para>Nom du compteur utilisé pour numéroter les titres de rubrique.  Ce
compteur doit être défini séparément. Ceux qui sont utilisés le plus
communément sont <code>section</code>, <code>subsection</code>, ou
<code>paragraph</code>. Bien que dans ces cas-là le nom du compteur soit
identique à celui de la commande elle-même, utiliser le même nom n&textrsquo;est
pas obligatoire.
</para>
<para>Alors <code>\the</code><var>name</var> affiche le numéro de titre, et
<code>\</code><var>name</var><code>mark</code> sert aux en-têtes de page. Voir le
troisième exemple plus bas.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">niveau</itemformat></item>
</tableterm><tableitem><anchor name="startsection-level">startsection level</anchor>
<anchor name="_005c_0040startsection_002flevel">\&arobase;startsection/level</anchor>
<para>Entier donnant la profondeur de la commande de
rubricage. <xref label="Sectioning"><xrefnodename>Sectioning</xrefnodename></xref>, pour une liste des numéros standards de
niveaux.
</para>
<para>Si <var>niveau</var> est inférieur ou égal à la valeur du compteur
<code>secnumdepth</code>, alors les titres pour cette commande de rubricage
sont numérotés (<pxref label="Sectioning_002fsecnumdepth"><xrefnodename>Sectioning/secnumdepth</xrefnodename></pxref>). Par exemple : dans un
<code>article</code>, si <code>secnumdepth</code> vaut 1, alors une commande
<code>\section&lbrace;Introduction&rbrace;</code> produira en sortie une chaîne du type
« <code>1 Introduction</code> », alors que <code>\subsection&lbrace;Historique&rbrace;</code>
produira en sortie une chaîne sans numéro de préfixe :
« <code>Historique</code> ».
</para>
<para>Si <var>niveau</var> est inférieur ou égal à la valeur du compteur
<code>tocdepth</code>, alors la table des matières aura un article pour cette
rubrique.  Par exemple, dans un <code>article</code>, si <code>tocdepth</code> vaut
1, la table des matières listera les <code>section</code>s, mais pas les
<code>subsection</code>s.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">retrait</itemformat></item>
</tableterm><tableitem><anchor name="startsection-indent">startsection indent</anchor>
<anchor name="_005c_0040startsection_002findent">\&arobase;startsection/indent</anchor>

<para>Une longueur donnant le renfoncement de toutes les lignes du titre par
rapport à la marge de gauche. Pour un renfoncement nul, utilisez <code>0pt</code>.
<!-- c xx à insérer : -->
<!-- c vous pouvez utiliser la macro @code{\z@@} définie à @code{0pt} pour -->
<!-- c que le code soit plus efficace -->
Une valeur négative telle que <code>-1em</code> cause un débord du titre dans
la marge de gauche.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">avant</itemformat></item>
</tableterm><tableitem><anchor name="startsection-beforeskip">startsection beforeskip</anchor>
<anchor name="_005c_0040startsection_002fbeforeskip">\&arobase;startsection/beforeskip</anchor>
<para>Longueur dont la valeur absolue est la longueur de l&textrsquo;espace vertical
inséré avant le titre de la rubrique. Cet espacement est ignoré si la
rubrique commence au début d&textrsquo;une page.  Si ce nombre est négatif, alors
le premier paragraphe suivant le titre n&textrsquo;est pas renfoncé, s&textrsquo;il est
positif ou nul il l&textrsquo;est. (Notez que l&textrsquo;opposé de <code>1pt plus 2pt minus
3pt</code> est <code>-1pt plus -2pt minus -3pt</code>).
</para>
<para>Par exemple si <var>avant</var> vaut <code>-3.5ex plus -1ex minus -0.2ex</code>
alors pour commencer la nouvelle rubrique, &latex; ajoute environ 3,5
fois la hauteur d&textrsquo;une lettre x en espace vertical, et le premier
paragraphe de la rubrique n&textrsquo;est pas renfoncé.  Utiliser une longueur
élastique, c.-à-d.&noeos; comprenant <code>plus</code> et <code>minus</code>, est une
bonne pratique ici car cela donne à &latex; plus de latitude lors de la
fabrication de la page (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).
</para>
<para>La quantité totale d&textrsquo;espace vertical entre la ligne de base de la ligne
précédant cette rubrique et la ligne de base du titre de la rubrique est
la somme du <code>\parskip</code> dans la police du corps de texte, du
<code>\baselineskip</code> de la police du titre, et de la valeur absolue de
l&textrsquo;argument <var>avant</var>. Cet espace est typiquement élastique de sorte à
pouvoir se dilater ou se contracter.  (Si la rubrique commence en début
d&textrsquo;une page de sorte que cet espace soit ignoré, alors la ligne de base
du titre correspond à la ligne de base qu&textrsquo;aurait la première ligne de
texte sur cette page si celle-ci commençait par du texte).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">après</itemformat></item>
</tableterm><tableitem><anchor name="startsection-afterskip">startsection afterskip</anchor>
<anchor name="_005c_0040startsection_002fafterskip">\&arobase;startsection/afterskip</anchor>
<para>Longueur. Lorsque <var>après</var> est positif ou nul, il s&textrsquo;agit de l&textrsquo;espace
vertical à insérer après le titre de la rubrique. Lorsque elle est
négative, alors le titre fait corps avec le paragraphe le suivant
immédiatement. Dans ce cas la valeur absolue de la longueur donne
l&textrsquo;espace horizontal entre la fin du titre et le début du paragraphe
suivant.  (Notez que l&textrsquo;opposé de <code>1pt plus 2pt minus 3pt</code> est
<code>-1pt plus -2pt minus -3pt</code>).
</para>
<para>Comme c&textrsquo;est le cas avec <var>avant</var>, utiliser une longueur élastique
avec des composantes <code>plus</code> et <code>minus</code> est une bonne pratique
ici puisque elle donne à &latex; plus de latitude pour assembler la
page.
</para>
<para>Si <var>après</var> est positif ou nul, la quantité totale d&textrsquo;espace vertical
entre la ligne de base du titre de la rubrique et la ligne de base de la
première ligne du paragraphe suivant est la somme du <code>\parskip</code> de
la police du titre, de <code>\baselineskip</code> de la police du corps de
texte, et de la valeur de <var>après</var>. Cet espace est typiquement
élastique de sorte qu&textrsquo;il puisse se dilater ou se contracter. (Notez que,
du fait que le signe d&textrsquo;<var>après</var> contrôle que le titre soit
indépendant du texte qui le suit ou faisant corps avec lui, vous ne
pouvez pas utiliser un <var>après</var> négatif pour annuler une partie du
<code>\parskip</code>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">style</itemformat></item>
</tableterm><tableitem><anchor name="startsection-style">startsection style</anchor>
<anchor name="_005c_0040startsection_002fstyle">\&arobase;startsection/style</anchor>
<para>Contrôle le style du titre : voir les exemples plus bas. Les commandes
typiquement utilisées ici sont <code>\centering</code>, <code>\raggedright</code>,
<code>\normalfont</code>, <code>\hrule</code>, ou <code>\newpage</code>. La dernière
commande au sein de <var>style</var> peut être une commande prenant un
argument, telle que <code>\MakeUppercase</code> ou <code>\fbox</code>. Le titre de
la rubrique est passé en argument à cette commande. Par exemple régler
<var>style</var> à <code>\bfseries\MakeUppercase</code> a pour effet de produire
des titres gras et en capitales.
</para></tableitem></tableentry></table>

<para>Voici les réglages par défaut de &latex; pour les trois premiers
niveaux de rubricage qui sont définis par <code>\&arobase;startsection</code>, pour
les classes <file>article</file>, <file>book</file>, et <file>report</file>.
</para>
<itemize commandarg="bullet" endspaces=" "><itemprepend>&bullet;</itemprepend>
<listitem><prepend>&bullet;</prepend>
<para>Pour <code>section</code> : le <var>niveau</var> vaut 1, le <var>retrait</var> vaut 0<dmn>pt</dmn>,
le <var>avant</var> vaut <code>-3.5ex plus -1ex minus -0.2ex</code>, le <var>après</var>
vaut <code>2.3ex plus 0.2ex</code>, et le <var>style</var> vaut
<code>\normalfont\Large\bfseries</code>.
</para>
</listitem><listitem><prepend>&bullet;</prepend>
<para>Pour <code>subsection</code> : le <var>niveau</var>
vaut 2, le <var>retrait</var> vaut 0<dmn>pt</dmn>, le <var>avant</var> vaut
<code>-3.25ex plus -1ex minus -0.2ex</code>, le <var>après</var> vaut <code>1.5ex
plus 0.2ex</code>, et le <var>style</var> vaut <code>\normalfont\large\bfseries</code>.
</para>
</listitem><listitem><prepend>&bullet;</prepend>
<para>Pour <code>subsubsection</code> : le <var>niveau</var> vaut 3, le <var>retrait</var> vaut
0<dmn>pt</dmn>, le <var>avant</var> vaut <code>-3.25ex plus -1ex minus -0.2ex</code>, le
<var>après</var> vaut <code>1.5ex plus 0.2ex</code>, et le <var>style</var> vaut
<code>\normalfont\normalsize\bfseries</code>.
</para></listitem></itemize>


<para>Quelques exemples suivent. Ils vont soit au sein d&textrsquo;un fichier de
paquetage ou de classe, soit dans le préambule d&textrsquo;un document
&latex;. Si vous les mettez dans le préambule, elle doivent être entre
une commande <code>\makeatletter</code> et une commande <code>\makeatother</code>.
(Le message d&textrsquo;erreur <code>You can't use `\spacefactor' in vertical
mode.</code>  est le plus probable lorsque on oublie de faire
cela). <xref label="_005cmakeatletter-_0026-_005cmakeatother"><xrefnodename>\makeatletter &amp; \makeatother</xrefnodename></xref>.
</para>
<para>L&textrsquo;exemple ci-dessous centre les titres de section et les met en gros
caractères gras. Il le fait avec <code>\renewcommand</code> parce que les
classes standardes de &latex; ont déjà une commande <code>\section</code> de
définie. Pour la même raison il ne définit ni un compteur
<code>section</code>, ni les commandes <code>\thesection</code> et
<code>\l&arobase;section</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand\section&lbrace;%
  \&arobase;startsection&lbrace;section&rbrace;% <ref label="_005c_0040startsection_002fname"><xrefnodename>\&arobase;startsection/name</xrefnodename><xrefinfoname><var>nom</var></xrefinfoname><xrefprinteddesc><var>nom</var></xrefprinteddesc></ref>.
  &lbrace;1&rbrace;% <ref label="_005c_0040startsection_002flevel"><xrefnodename>\&arobase;startsection/level</xrefnodename><xrefinfoname><var>niveau</var></xrefinfoname><xrefprinteddesc><var>niveau</var></xrefprinteddesc></ref>.
  &lbrace;0pt&rbrace;% <ref label="_005c_0040startsection_002findent"><xrefnodename>\&arobase;startsection/indent</xrefnodename><xrefinfoname><var>retrait</var></xrefinfoname><xrefprinteddesc><var>retrait</var></xrefprinteddesc></ref>.
  &lbrace;-3.5ex plus -1ex minus -.2ex&rbrace;% <ref label="_005c_0040startsection_002fbeforeskip"><xrefnodename>\&arobase;startsection/beforeskip</xrefnodename><xrefinfoname><var>avant</var></xrefinfoname><xrefprinteddesc><var>avant</var></xrefprinteddesc></ref>.
  &lbrace;2.3ex plus.2ex&rbrace;% <ref label="_005c_0040startsection_002fafterskip"><xrefnodename>\&arobase;startsection/afterskip</xrefnodename><xrefinfoname><var>après</var></xrefinfoname><xrefprinteddesc><var>après</var></xrefprinteddesc></ref>.
  &lbrace;\centering\normalfont\Large\bfseries&rbrace;&rbrace;% <ref label="_005c_0040startsection_002fstyle"><xrefnodename>\&arobase;startsection/style</xrefnodename><xrefinfoname><var>style</var></xrefinfoname><xrefprinteddesc><var>style</var></xrefprinteddesc></ref>.
</pre></example>


<para>L&textrsquo;exemple ci-dessous met les titres de <code>subsection</code> en petites
capitales, et leur fait faire corps avec le paragraphe suivant.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand\subsection&lbrace;%
  \&arobase;startsection&lbrace;subsection&rbrace;%  <ref label="_005c_0040startsection_002fname"><xrefnodename>\&arobase;startsection/name</xrefnodename><xrefinfoname><var>nom</var></xrefinfoname><xrefprinteddesc><var>nom</var></xrefprinteddesc></ref>.
    &lbrace;2&rbrace;% <ref label="_005c_0040startsection_002flevel"><xrefnodename>\&arobase;startsection/level</xrefnodename><xrefinfoname><var>niveau</var></xrefinfoname><xrefprinteddesc><var>niveau</var></xrefprinteddesc></ref>.
    &lbrace;0em&rbrace;% <ref label="_005c_0040startsection_002findent"><xrefnodename>\&arobase;startsection/indent</xrefnodename><xrefinfoname><var>retrait</var></xrefinfoname><xrefprinteddesc><var>retrait</var></xrefprinteddesc></ref>.
    &lbrace;-1ex plus 0.1ex minus -0.05ex&rbrace;% <ref label="_005c_0040startsection_002fbeforeskip"><xrefnodename>\&arobase;startsection/beforeskip</xrefnodename><xrefinfoname><var>avant</var></xrefinfoname><xrefprinteddesc><var>avant</var></xrefprinteddesc></ref>.
    &lbrace;-1em plus 0.2em&rbrace;% <ref label="_005c_0040startsection_002fafterskip"><xrefnodename>\&arobase;startsection/afterskip</xrefnodename><xrefinfoname><var>après</var></xrefinfoname><xrefprinteddesc><var>après</var></xrefprinteddesc></ref>.
    &lbrace;\scshape&rbrace;% <ref label="_005c_0040startsection_002fstyle"><xrefnodename>\&arobase;startsection/style</xrefnodename><xrefinfoname><var>style</var></xrefinfoname><xrefprinteddesc><var>style</var></xrefprinteddesc></ref>.
  &rbrace;
</pre></example>


<para>Les exemples précédents redéfinissaient les commandes de titre de
rubriques existantes.  L&textrsquo;exemple suivant définit une nouvelle commande,
illustrant la nécessité d&textrsquo;un compteur et de macros pour son affichage.
</para>
<!-- c From https://groups.google.com/forum/#!searchin/comp.text.tex/startsection%7Csort:relevance/comp.text.tex/sB-nTS-oL08/ZZeKYdG0llMJ -->
<example endspaces=" ">
<pre xml:space="preserve">\setcounter&lbrace;secnumdepth&rbrace;&lbrace;6&rbrace;% affiche les compteurs justqu'à ce niveau
\newcounter&lbrace;subsubparagraph&rbrace;[subparagraph]% compteur pour la
                                          % numérotation
\renewcommand&lbrace;\thesubsubparagraph&rbrace;%
   &lbrace;\thesubparagraph.\&arobase;arabic\c&arobase;subsubparagraph&rbrace;% comment afficher
                                                % la numérotation
\newcommand&lbrace;\subsubparagraph&rbrace;&lbrace;\&arobase;startsection
                         &lbrace;subsubparagraph&rbrace;%
                         &lbrace;6&rbrace;%
                         &lbrace;0em&rbrace;%
                         &lbrace;\baselineskip&rbrace;%
                         &lbrace;0.5\baselineskip&rbrace;%
                         &lbrace;\normalfont\normalsize&rbrace;&rbrace;
\newcommand*\l&arobase;subsubparagraph%
  &lbrace;\&arobase;dottedtocline&lbrace;6&rbrace;&lbrace;10em&rbrace;&lbrace;5em&rbrace;&rbrace;% pour la table des matières
\newcommand&lbrace;\subsubparagraphmark&rbrace;[1]&lbrace;&rbrace;% pour les en-têtes de page
</pre></example>

</section>
</chapter>
<node name="Cross-references" spaces=" "><nodename>Cross references</nodename><nodenext automatic="on">Environments</nodenext><nodeprev automatic="on">Sectioning</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Des renvois</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="216">renvois</indexterm></cindex>

<para>Une des raisons pour numéroter des choses telles que les figures ou les
équations est d&textrsquo;indiquer au lecteur une référence vers elles, comme dans « Voir la
figure 3 pour plus de détails. »
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="217">étiquette</indexterm></cindex>
<para>Souvent on désire écrire quelque chose du genre de <samp>Voir
théorème~31</samp>. Mais Inclure manuellement le numéro est une mauvaise
pratique. Au lieu de cela, il vaut mieux écrire une <dfn>étiquette</dfn> du
genre <code>\label&lbrace;eq:ThmGreens&rbrace;</code> puis lui <dfn>faire référence</dfn> avec
<code>Voir l'équation~\ref&lbrace;eq:ThmGreens&rbrace;</code>. &latex; se charge de
déterminer automatiquement le numéro, de le produire en sortie, et de le
changer par la suite si besoin est.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Cela apparaîtra avec le théorème~\ref&lbrace;th:ThmGreens&rbrace;. % référence déclarée en aval
...
\begin&lbrace;theorem&rbrace; \label&lbrace;th:ThmGreens&rbrace;
  ...
\end&lbrace;theorem&rbrace;
...
Voir le théorème~\ref&lbrace;th:ThmGreens&rbrace; page~\pageref&lbrace;th:ThmGreens&rbrace;.
</pre></example>


<para>&latex; garde trace de l&textrsquo;information de renvoi dans un
fichier avec le même nom de base que le fichier contenant le
<code>\label&lbrace;...&rbrace;</code> mais avec une extension <file>.aux</file>. Ainsi si
<code>\label</code> est dans <file>calcul.tex</file> alors cette information est
dans <file>calcul.aux</file>. &latex; met cette information dans ce fichier à
chaque fois qu&textrsquo;il rencontre un <code>\label</code>.
</para>
<ignore>
(L'information a le format
@code{\newlabel@{@var{étiquette}@}@{@{@var{étiquette-courante}@}@{@var{numéro-de-page}@}@}}
où @var{étiquette-courante} est la valeur de la macro
@code{\@@currentlabel} qui est d'ordinaire mise à jour à chaque vous que
vous appelez @code{\refstepcounter@{@var{compteur}@}}.)
</ignore>

<cindex index="cp" spaces=" "><indexterm index="cp" number="218">référence déclarée en aval</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="219">aval, référence déclarée en</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="220">déclaration en aval de référence</indexterm></cindex>
<para>L&textrsquo;effet secondaire le plus courant du paragraphe précédent se produit
lorsque votre document a une <dfn>référence déclarée en aval</dfn>, c.-à-d.&noeos;
un <code>\ref</code> qui apparaît avant le <code>\label</code> associé. Si c&textrsquo;est la
première fois que vous compilez le document alors vous obtiendrez un
message <code>LaTeX Warning: Label(s) may have changed. Rerun to get
cross references right.</code> et dans la sortie la référence apparaîtra comme
deux points d&textrsquo;interrogation <samp>??</samp> en caractères gras. Ou, si vous
modifiez le document de telle façon que les références changent alors
vous obtiendrez le même avertissement et la sortie contiendra
l&textrsquo;information de référence de la fois précédente. La solution dans les
deux cas est juste de recompiler le document encore une fois.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="330"><r>paquetage</r> <code>cleveref</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="331"><code>cleveref</code>, <r>paquetage</r></indexterm></findex>


<para>Le paquetage <code>cleveref</code> élargit les possibilités de faire des
renvois de &latex;. Vous pouvez faire en sorte que si vous saisissez
<code>\begin&lbrace;thm&rbrace;\label&lbrace;th:Nerode&rbrace;...\end&lbrace;thm&rbrace;</code> alors
<code>\cref&lbrace;th:Nerode&rbrace;</code> produit en sortie <samp>théorème 3.21</samp>, sans
que vous ayez à saisir le mot « théorème ».
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\label </menunode><menudescription><pre xml:space="preserve">Attribuez un nom symbolique à un morceau de texte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\pageref</menunode><menudescription><pre xml:space="preserve">Faire un renvoi à un numéro de page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\ref</menunode><menudescription><pre xml:space="preserve">Faire un renvoi à une rubrique, figure ou chose similaire.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">xr&comma; paquetage</menutitle><menunode separator=". ">xr package</menunode><menudescription><pre xml:space="preserve">Renvois depuis un autre document.
</pre></menudescription></menuentry></menu>


<node name="_005clabel" spaces=" "><nodename>\label</nodename><nodenext automatic="on">\pageref</nodenext><nodeup automatic="on">Cross references</nodeup></node>
<section spaces=" "><sectiontitle><code>\label</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="332">\label</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\label&lbrace;<var>clef</var>&rbrace;
</pre></example>

<para>Attribut un numéro de référence à <var>clef</var>. Au sein de texte
ordinaire, <code>\label&lbrace;<var>clef</var>&rbrace;</code> attribut à <var>clef</var> le numéro
de la rubrique courante. Au sein d&textrsquo;un environnement numéroté, tel que
l&textrsquo;environnement <code>table</code> ou <code>theorem</code>,
<code>\label&lbrace;<var>clef</var>&rbrace;</code> attribue le numéro de cet environnement à
<var>clef</var>. On retire le numéro attribué avec la commande
<code>\ref&lbrace;<var>clef</var>&rbrace;</code> (<pxref label="_005cref"><xrefnodename>\ref</xrefnodename></pxref>).
</para>
<para>Le nom <var>clef</var> peut se composer de n&textrsquo;importe quelle séquence de
lettres, chiffres, ou caractères de ponctuation ordinaires. Il est
sensible à la casse &textmdash; lettres capitales ou bas-de-casse.
</para>
<para>Pour éviter de créer accidentellement deux étiquettes avec le même nom,
l&textrsquo;usage est d&textrsquo;utiliser des étiquettes composées d&textrsquo;un préfixe et d&textrsquo;un
suffixe séparés par un caractère <code>:</code> ou <code>.</code>. Certains préfixes
classiquement utilisés :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">ch</itemformat></item>
</tableterm><tableitem><para>pour les chapitres
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">sec</itemformat></item>
</tableterm><tableitem><para>les commandes de rubricage de niveau inférieur
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">fig</itemformat></item>
</tableterm><tableitem><para>pour les figures
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">tab</itemformat></item>
</tableterm><tableitem><para>pour les tableaux
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">eq</itemformat></item>
</tableterm><tableitem><para>pour les équations
</para></tableitem></tableentry></table>

<para>Ainsi, <code>\label&lbrace;fig:Euler&rbrace;</code> est une étiquette pour une figure avec
un portrait de ce grand homme.
</para>
<para>Dans l&textrsquo;exemple ci-dessous la clef <code>sec:test</code> se verra attribuée le
numéro de la section courante et la clef <code>fig:test</code> se verra
attribuée le numéro de la figure.  Soit dit en passant, mettez les
étiquettes (<code>\label</code>) après les légendes (<code>\caption</code>) au sein
des environnements <code>figure</code> ou <code>table</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\section&lbrace;Titre de la rubrique&rbrace;
\label&lbrace;sec:test&rbrace;
Dans cette rubrique~\ref&lbrace;sec:test&rbrace;.
\begin&lbrace;figure&rbrace;
  ...
  \caption&lbrace;Texte de la légende&rbrace;
  \label&lbrace;fig:test&rbrace;
\end&lbrace;figure&rbrace;
Voir Figure~\ref&lbrace;fig:test&rbrace;.
</pre></example>

</section>
<node name="_005cpageref" spaces=" "><nodename>\pageref</nodename><nodenext automatic="on">\ref</nodenext><nodeprev automatic="on">\label</nodeprev><nodeup automatic="on">Cross references</nodeup></node>
<section spaces=" "><sectiontitle><code>\pageref&lbrace;<var>clef</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="333">\pageref</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="221">renvoi avec numéro de page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="222">numéro de page, renvoi</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\pageref&lbrace;<var>clef</var>&rbrace;
</pre></example>

<para>Produit le numéro de page de l&textrsquo;endroit du texte où la commande
correspondante <code>\label</code>&lbrace;<var>clef</var>&rbrace; apparaît.
</para>
<para>Dans cet exemple le <code>\label&lbrace;eq:principale&rbrace;</code> est utilisé à la fois
pour le numéro de la formule et pour le numéro de page. (Notez que les
deux références sont des références déclarées en aval, ainsi ce document
a besoin d&textrsquo;être compilé deux fois pour les résoudre).
</para>
<example endspaces=" ">
<pre xml:space="preserve">Le résultat principal est la formule~\ref&lbrace;eq:principale&rbrace; de la
page~\pageref&lbrace;eq:principale&rbrace;.
  ...
\begin&lbrace;equation&rbrace; \label&lbrace;eq:principale&rbrace;
   \mathbf&lbrace;P&rbrace;=\mathbf&lbrace;NP&rbrace;
\end&lbrace;equation&rbrace;
</pre></example>

</section>
<node name="_005cref" spaces=" "><nodename>\ref</nodename><nodenext automatic="on">xr package</nodenext><nodeprev automatic="on">\pageref</nodeprev><nodeup automatic="on">Cross references</nodeup></node>
<section spaces=" "><sectiontitle><code>\ref&lbrace;<var>clef</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="334">\ref</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="223">renvoi, symbolique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="224">numéro de rubrique, renvoi</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="225">numéro d&textrsquo;équation, renvoi</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="226">numéro de figure, renvoi</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="227">numéro de note en bas de page, renvoi</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ref&lbrace;<var>clef</var>&rbrace;
</pre></example>

<para>Produit le numéro de la rubrique, équation, note en bas de page, figure,
&dots;, de la commande correspondante <code>\label</code> (<pxref label="_005clabel"><xrefnodename>\label</xrefnodename></pxref>).
Elle ne produit aucun texte, tel que le mot <samp>Section</samp> ou
<samp>Figure</samp>, juste le numéro lui-même sans plus.
</para>
<para>Dans cet exemple, le <code>\ref&lbrace;populaire&rbrace;</code> produit <samp>2</samp>.  Notez
que ceci est une référence déclarée en aval puisque elle est faite avant
<code>\label&lbrace;populaire&rbrace;</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Le format utilisé le plus largement est à l'article numéro~\ref&lbrace;populaire&rbrace;.
\begin&lbrace;enumerate&rbrace;
\item Plain \TeX
\item \label&lbrace;populaire&rbrace; \LaTeX
\item Con\TeX t
\end&lbrace;enumerate&rbrace;
</pre></example>


</section>
<node name="xr-package" spaces=" "><nodename>xr package</nodename><nodeprev automatic="on">\ref</nodeprev><nodeup automatic="on">Cross references</nodeup></node>
<section spaces=" "><sectiontitle>Le paquetage <code>xr</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="335"><r>paquetage</r> <code>xr</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="336"><code>xr</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="337"><r>paquetage</r> <code>xr-hyper</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="338"><code>xr-hyper</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="339">\externaldocument</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="228">renvois entre documents</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;xr&rbrace;
  \externaldocument&lbrace;<var>nom-de-base-document</var>&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;xr&rbrace;
  \externaldocument[<var>préfixe-renvoi</var>]&lbrace;<var>nom-de-base-document</var>&rbrace;
</pre></example>

<para>Fait des renvois vers le document externe
<file><var>nom-de-base-document</var>.tex</file>.
</para>
<para>Voici un exemple. Si <file>cours.tex</file> comprend ce qui suit dans le
préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;xr&rbrace;
  \externaldocument&lbrace;exercises&rbrace;
  \externaldocument[IND-]&lbrace;indications&rbrace;
  \externaldocument&lbrace;reponses&rbrace;
</pre></example>

<noindent></noindent>
<para>alors on peut utiliser des étiquettes de renvoi depuis les trois autres
documents. Supposons que <file>exercises.tex</file> a une liste énumérée qui
contient ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\item \label&lbrace;exer:ThmEuler&rbrace; Que se passe-t-il si chaque nœud a un
degré impair ?
</pre></example>

<noindent></noindent>
<para>et que <file>indications.tex</file> comprend une liste énumérée avec ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\item \label&lbrace;exer:ThmEuler&rbrace; Distinguez le cas à deux nœuds.
</pre></example>

<noindent></noindent>
<para>et que <file>reponses.tex</file> a une liste énumérée avec ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\item \label&lbrace;rep:ThmEuler&rbrace; Il n'y pas pas de chemin d'Euler, sauf
s'il y a exactement deux nœuds.
</pre></example>

<para>Après avoir compilé les documents <file>exercises</file>, <file>indications</file>,
et <file>reponses</file>, saisir ce qui suit dans le corps de <file>cours.tex</file>
aura pour effet qu&textrsquo;on a accès depuis <file>cours</file> aux numéros de renvoi
utilisés dans les autres documents.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Voir Exercice~\ref&lbrace;exer:ThmEuler&rbrace;, avec Indication~\ref&lbrace;IND-exer:ThmEuler&rbrace;.
La solution est Réponse~\ref&lbrace;rep:ThmEuler&rbrace;.
</pre></example>

<para>Le préfixe <code>IND-</code> pour les renvois depuis le fichier
<file>indications</file> est nécessaire parce que l&textrsquo;étiquette dans ce fichier
est la même que dans le fichier <file>exercices</file>. Sans ce préfixe, les
deux renvois auraient le numéro correspondant à ce dernier.
</para>
<para>Note : si le document utilise le paquetage <code>hyperref</code> alors au
lieu de <code>xr</code>, placez <code>\usepackage&lbrace;xr-hyper&rbrace;</code> avant le
<code>\usepackage&lbrace;hyperref&rbrace;</code>.  Aussi, si l&textrsquo;un quelconque parmi les
documents utilise <code>hyperref</code> alors tous doivent l&textrsquo;utiliser.
</para>

</section>
</chapter>
<node name="Environments" spaces=" "><nodename>Environments</nodename><nodenext automatic="on">Line breaking</nodenext><nodeprev automatic="on">Cross references</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Environnements</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="229">Environnements</indexterm></cindex>

<findex index="fn" spaces=" "><indexterm index="fn" number="340">\begin</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="341">\end</indexterm></findex>

<para>&latex; fournit beaucoup d&textrsquo;environnements pour baliser un certain texte.
Chaque environnement commence et se termine de la même manière :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;<var>nomenv</var>&rbrace;
...
\end&lbrace;<var>nomenv</var>&rbrace;
</pre></example>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::    ">abstract</menunode><menudescription><pre xml:space="preserve">Produit un abrégé.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::       ">array</menunode><menudescription><pre xml:space="preserve">Tableau pour les mathématiques.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">center</menunode><menudescription><pre xml:space="preserve">Lignes centrées.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">description</menunode><menudescription><pre xml:space="preserve">Lignes étiquetées.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">displaymath</menunode><menudescription><pre xml:space="preserve">Formule qui apparaissent sur leur propre ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">document</menunode><menudescription><pre xml:space="preserve">Entoure le document en entier.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">enumerate</menunode><menudescription><pre xml:space="preserve">Liste à numéros.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">eqnarray</menunode><menudescription><pre xml:space="preserve">Séquences d&textrsquo;équations alignées.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">equation</menunode><menudescription><pre xml:space="preserve">Équation en hors texte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">figure</menunode><menudescription><pre xml:space="preserve">Figures flottantes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">filecontents</menunode><menudescription><pre xml:space="preserve">Écrire des fichiers multiples à partir du fichier source.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">flushleft</menunode><menudescription><pre xml:space="preserve">Lignes jusitifiées à gauche.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::  ">flushright</menunode><menudescription><pre xml:space="preserve">Lignes jusitifiées à droite.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">itemize</menunode><menudescription><pre xml:space="preserve">Liste à puces.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">letter</menunode><menudescription><pre xml:space="preserve">Lettres.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::        ">list</menunode><menudescription><pre xml:space="preserve">Environnement pour listes génériques.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::        ">math</menunode><menudescription><pre xml:space="preserve">Math en ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">minipage</menunode><menudescription><pre xml:space="preserve">Page miniature.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">picture</menunode><menudescription><pre xml:space="preserve">Image avec du texte, des flèches, des lignes et des cercles.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">quotation et quote</menutitle><menunode separator=".    ">quotation &amp; quote</menunode><menudescription><pre xml:space="preserve">Citer du texte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">tabbing</menunode><menudescription><pre xml:space="preserve">Aligner du texte arbitrairement.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::       ">table</menunode><menudescription><pre xml:space="preserve">Tables flottantes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">tabular</menunode><menudescription><pre xml:space="preserve">Aligner du texte dans les colonnes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">thebibliography</menunode><menudescription><pre xml:space="preserve">Bibliographie ou liste de références.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">theorem</menunode><menudescription><pre xml:space="preserve">Théorèmes, lemmes, etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">titlepage</menunode><menudescription><pre xml:space="preserve">Pour des pages de titre sur mesure.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">verbatim</menunode><menudescription><pre xml:space="preserve">Simuler un entrée tapuscrite.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::       ">verse</menunode><menudescription><pre xml:space="preserve">Pour la poésie et d&textrsquo;autres choses.
</pre></menudescription></menuentry></menu>


<node name="abstract" spaces=" "><nodename>abstract</nodename><nodenext automatic="on">array</nodenext><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>abstract</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="342"><r>environnement</r> <code>abstract</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="343"><code>abstract</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="230">résumé</indexterm></cindex>

<para>Synopsis :
</para><example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;abstract&rbrace;
...
\end&lbrace;abstract&rbrace;
</pre></example>

<para>Produit un résumé, potentiellement contenant plusieurs paragraphes. Cet
environnement n&textrsquo;est défini que dans les classes de document
<code>article</code> et <code>report</code> (<pxref label="Document-classes"><xrefnodename>Document classes</xrefnodename></pxref>).
</para>
<para>Utiliser l&textrsquo;exemple ci-dessous au sein de la classe <code>article</code>
produit un paragraphe détaché. L&textrsquo;option <code>titlepage</code> de la classe de
document a pour effet que le résumé soit sur une page séparée
(<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></pxref>) ; ceci est le comportement par défaut
seulement dans la classe <code>report</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;abstract&rbrace;
  Nous comparons tous les récits de la proposition faits par Porter
  Alexander à Robert E Lee en lieu de l'Appomattox Court House que
  l'armée continue à combattre dans une guerre de guerilla, ce que Lee
  refusa.
\end&lbrace;abstract&rbrace;
</pre></example>

<para>L&textrsquo;exemple suivant produit un résumé en une-colonne au sein d&textrsquo;un document
en deux-colonnes (pour plus solution plus flexible, utilisez le paquetage
<file>abstract</file>).
</para>
<!-- c Adopted from http://www.tex.ac.uk/FAQ-onecolabs.html -->
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[twocolumn]&lbrace;article&rbrace;
  ...
\begin&lbrace;document&rbrace;
\title&lbrace;Babe Ruth comme ancêtre culturel : une approche atavique&rbrace;
\author&lbrace;Smith \\ Jones \\ Robinson\thanks&lbrace;Bourse des chemins de fer.&rbrace;&rbrace;
\twocolumn[
  \begin&lbrace;&arobase;twocolumnfalse&rbrace;
     \maketitle
     \begin&lbrace;abstract&rbrace;
       Ruth n'était pas seulement le Sultan du Swat, il était à lui tout
       seul l'équipe du swat.
     \end&lbrace;abstract&rbrace;
   \end&lbrace;&arobase;twocolumnfalse&rbrace;
   ]
&lbrace;   % by-hand insert a footnote at page bottom
 \renewcommand&lbrace;\thefootnote&rbrace;&lbrace;\fnsymbol&lbrace;footnote&rbrace;&rbrace;
 \footnotetext[1]&lbrace;Merci pour tout le poisson.&rbrace;
&rbrace;
</pre></example>


</section>
<node name="array" spaces=" "><nodename>array</nodename><nodenext automatic="on">center</nodenext><nodeprev automatic="on">abstract</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>array</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="344"><r>environnement</r> <code>array</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="345"><code>array</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="231">tableaux mathématiques</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;array&rbrace;&lbrace;<var>patron</var>&rbrace;
<var>entrée-col-1</var>&amp;<var>entrée-col-2</var> ... &amp;<var>entrée-col-n</var>&rbrace;\\
...
\end&lbrace;array&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;array&rbrace;[<var>pos</var>]&lbrace;<var>patron</var>&rbrace;
<var>entrée-col-1</var>&amp;<var>entrée-col-2</var> ... &amp;<var>entrée-col-n</var>&rbrace;\\
...
\end&lbrace;array&rbrace;
</pre></example>

<para>Les tableaux mathématiques sont produits avec l&textrsquo;environnement
<code>array</code>. Cet environnement ne peut être utilisé qu&textrsquo;en mode math
(<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>), normalement au sein d&textrsquo;un environnement mathématique
hors texte tel qu&textrsquo;<code>equation</code> (<pxref label="equation"><xrefnodename>equation</xrefnodename></pxref>).  Les entrées dans
chaque colonne sont séparées avec une esperluette (<code>&amp;</code>). Les lignes
sont terminées par une double controblique (<pxref label="_005c_005c"><xrefnodename>\\</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivant affiche un tableau trois par trois.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation*&rbrace;
  \chi(x) =
  \left|              % barre verticale en bordure
    \begin&lbrace;array&rbrace;&lbrace;ccc&rbrace;
      x-a  &amp;-b  &amp;-c  \\
      -d   &amp;x-e &amp;-f  \\
      -g   &amp;-h  &amp;x-i
    \end&lbrace;array&rbrace;
 \right|
\end&lbrace;equation*&rbrace;
</pre></example>

<para>L&textrsquo;argument obligatoire <var>patron</var> décrit le nombre de colonnes,
l&textrsquo;alignement en leur sein, et le formatage des régions
inter-colonne. Par exemple,
<code>\begin&lbrace;array&rbrace;&lbrace;rcl&rbrace;...\end&lbrace;array&rbrace;</code> produit trois colonnes :
la première fer à droite, la deuxième centrée, et la troisième fer à
gauche. Voir <ref label="tabular"><xrefnodename>tabular</xrefnodename></ref> pour une description complète de
<var>patron</var>, et des autres caractéristiques communes aux deux
environnements, y compris l&textrsquo;argument optionnel <code>pos</code>.
</para>
<para>L&textrsquo;environnement <code>array</code> diverge de <code>tabular</code> par deux
aspects. Le premier est que les entrées de <code>array</code> sont composées
en mode mathématique, en style texte (<pxref label="Math-styles"><xrefnodename>Math styles</xrefnodename></pxref>)
(sauf si le <var>patron</var> spécifie la colonne avec <code>p&lbrace;...&rbrace;</code>, ce
qui a pour effet que l&textrsquo;entrée est composée en mode texte). Le second est
que au lieu du paramètre <code>\tablcolsep</code> de <code>tabular</code>, l&textrsquo;espace
inter-colonne que &latex; met dans un <code>array</code> est contrôlé par
<findex index="fn" spaces=" "><indexterm index="fn" number="346">\arraycolsep</indexterm></findex>
<code>\arraycolsep</code>, qui spécifie la moitié de la largeur entre les
colonnes. La valeur par défaut est <samp>5pt</samp> de sorte qu&textrsquo;un espace de
10<dmn>pt</dmn> sépare deux colonnes.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="347"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="348"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Pour obtenir des tableaux entre accolades la méthode standarde est
d&textrsquo;utiliser le paquetage <code>amsmath</code>. Il comprend les environnements
<code>pmatrix</code> pour un tableau entre parenthèses <code>(...)</code>,
<code>bmatrix</code> pour un tableau entre crochets <code>[...]</code>,
<code>Bmatrix</code> pour un tableau entre accolades <code>&lbrace;...&rbrace;</code>,
<code>vmatrix</code> pour un tableau entre barres verticales <code>|...|</code>, et
<code>Vmatrix</code> pour un tableau entre doubles barres
verticales <code>||...||</code>, ainsi que diverses autres constructions de
tableaux.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="349"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="350"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>L&textrsquo;exemple suivant utilise le paquetage <code>amsmath</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;amsmath&rbrace;  % dans le préambule

\begin&lbrace;equation&rbrace;
  \begin&lbrace;vmatrix&rbrace;&lbrace;cc&rbrace;
    a  &amp;b \\
    c  &amp;d
  \end&lbrace;vmatrix&rbrace;=ad-bc
\end&lbrace;equation&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="351"><r>paquetage</r> <code>array</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="352"><code>array</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="353"><r>paquetage</r> <code>dcolumn</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="354"><code>dcolumn</code>, <r>paquetage</r></indexterm></findex>

<para>Il y a beaucoup de paquetages concernant les tableaux.  Le
paquetage <code>array</code> étend utilement leur possibilités de bien des
manières, et notamment en ajoutant des types de colonne.  Le
paquetage <code>dcolumn</code> ajoute un type de colonne pour centrer sur
le séparateur décimal. Pour les deux voir la documentation sur le CTAN.
</para>

</section>
<node name="center" spaces=" "><nodename>center</nodename><nodenext automatic="on">description</nodenext><nodeprev automatic="on">array</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>center</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="355"><r>environnement</r> <code>center</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="356"><code>center</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="232">centrer du texte, environnement pour</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
<var>ligne1</var> \\
<var>ligne2</var> \\
\end&lbrace;center&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>center</code> vous permet de créer un paragraphe
consistant de lignes qui sont centrées entre les marges de gauche et de
droite de la page courante. On utilise une double controblique,
<code>\\</code>, pour obtenir un saut de ligne (<pxref label="_005c_005c"><xrefnodename>\\</xrefnodename></pxref>).
<findex index="fn" spaces=" "><indexterm index="fn" number="357">\\ <r>(pour <code>center</code>)</r></indexterm></findex>
Si du texte est trop long pour entrer dans une ligne, alors &latex;
insère des sauts de ligne en évitant de faire des césures ou de dilater
ou contracter tout espace inter-mot.
</para>
<para>Cet environnement insère de l&textrsquo;espace au-dessus et au-dessous du corps du
texte. Voir <ref label="_005ccentering"><xrefnodename>\centering</xrefnodename></ref> pour ne pas avoir cet espace, par exemple
au sein d&textrsquo;un environnement <code>figure</code>.
</para>
<para>L&textrsquo;exemple suivant produit trois lignes centrées.  Il y a un espace
vertical supplémentaire entre les deux dernières lignes.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  Une thèse soumise en remplissant partiellement \\
  les exigences de \\[0.5ex]
  l'École pour l'Ingénierie Environnementale
\end&lbrace;center&rbrace;
</pre></example>

<para>Dans l&textrsquo;exemple suivant, selon la largeur de la ligne de la page,
&latex; pourrait faire un saut de ligne pour la partie avant la double
controblique.  Si cela se produit, il en centre chaque ligne, et sinon
il en centre l&textrsquo;unique ligne.  Ensuite &latex; faut un saut de ligne à la
double controblique, et centre la partie finale.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  Mon père considérait comme intolérable quiconque fréquentait l'église mais ne buvait pas d'alcool.\\
  J'ai grandi dans cette croyance.  --- Richard Burton
\end&lbrace;center&rbrace;
</pre></example>

<para>Ajouter une double controblique à la fin de la ligne finale est
optionnel.  Lorsque elle est présente, cela n&textrsquo;ajoute pas d&textrsquo;espace
vertical.
</para>
<para>Dans un document en double-colonne le texte est centré dans une colonne,
et non sur la page entière.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\centering</menunode><menudescription><pre xml:space="preserve">Forme déclarative de l&textrsquo;environnement <code>center</code>.
</pre></menudescription></menuentry></menu>


<node name="_005ccentering" spaces=" "><nodename>\centering</nodename><nodeup automatic="on">center</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\centering</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="358">\centering</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="233">centrer du texte, déclaration pour</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\centering ... &rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;group&rbrace;
  \centering ...
\end&lbrace;group&rbrace;
</pre></example>

<para>Centre la matière dans sa portée.  Utilisée le plus souvent l&textrsquo;intérieur d&textrsquo;un
environnement tel que <code>figure</code> ou dans une <code>parbox</code>.
</para>
<para>L&textrsquo;exemple suivant de déclaration <code>\centerin</code> a pour effet de
centrer le graphique horizontalement.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure&rbrace;
  \centering
  \includegraphics[width=0.6\textwidth]&lbrace;ctan_lion.png&rbrace;
  \caption&lbrace;CTAN Lion&rbrace;  \label&lbrace;fig:CTANLion&rbrace;
\end&lbrace;figure&rbrace;
</pre></example>

<noindent></noindent>
<para>La portée de ce <code>\centering</code> finit avec le <code>\end&lbrace;figure&rbrace;</code>.
</para>
<para>Contrairement à l&textrsquo;environnement <code>center</code>, la commande
<code>\centering</code> n&textrsquo;ajoute pas d&textrsquo;espacement vertical au-dessus et
au-dessous du texte. C&textrsquo;est son avantage dans l&textrsquo;exemple précédent ; il n&textrsquo;y
a pas d&textrsquo;espace en trop.
</para>
<para>Elle ne commence pas non plus un nouveau paragraphe ; elle change
simplement la façon dont &latex; formate les unités paragraphe. Si
<code>ww &lbrace;\centering xx \\ yy&rbrace; zz</code> est entouré de lignes à blanc,
alors &latex; crée un paragraphe dont la première ligne <code>ww xx</code>
est centrée, et dont la seconde ligne, non centrée, contient <code>yy
zz</code>. Généralement, ce qu&textrsquo;on désire c&textrsquo;est que la portée de la déclaration
contienne une ligne à blanc ou la commande <code>\end</code> d&textrsquo;un
environnement tel que <code>figure</code> ou <code>table</code> qui finisse l&textrsquo;unité
paragraphe.  Ainsi, si <code>&lbrace;\centering xx \\ yy\par&rbrace; zz</code> est entouré
de lignes à blanc alors cela fabrique un nouveau paragraphe avec deux
lignes centrées <samp>xx</samp> et <samp>yy</samp>, suivi d&textrsquo;un nouveau paragraphe
<samp>zz</samp> qui est formaté comme d&textrsquo;habitude.
</para>

</subsection>
</section>
<node name="description" spaces=" "><nodename>description</nodename><nodenext automatic="on">displaymath</nodenext><nodeprev automatic="on">center</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>description</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="359"><r>environnement</r> <code>description</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="360"><code>description</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="234">listes étiquetées, créer</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="235">listes de description, créer</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;description&rbrace;
\item [<var>étiquette du 1er article</var>] <var>texte du 1er article</var>
\item [<var>étiquette du 2e article</var>] <var>texte du 2e article</var>
...
\end&lbrace;description&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="361">\item</indexterm></findex>
<para>L&textrsquo;environnement <code>description</code> est utilisé pour fabriquer des listes
d&textrsquo;articles étiquetés. Chaque <var>étiquette</var> d&textrsquo;article est composée en
gras, alignée à gauche de sorte que les étiquettes longues continuent
sur la première ligne du texte de l&textrsquo;article.  Il doit y avoir au moins un
article ; sans cela on provoque l&textrsquo;erreur &latex; <samp>Something's
wrong--perhaps a missing \item</samp>.
</para>
<para>Cet exemple montre l&textrsquo;environnement utilisé pour une séquence de
définitions.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;definition&rbrace;
  \item[lama] Un prêtre.
  \item[lame] Une pièce coupante.
</pre></example>

<noindent></noindent>
<para>Les étiquettes <samp>lama</samp> et <samp>llama</samp> ressortent en gras avec leur
bords gauches alignés sur la marge de gauche.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="362">\item</indexterm></findex>
<para>Faites démarrer la liste d&textrsquo;articles avec la commande <code>\item</code>
(<pxref label="_005citem"><xrefnodename>\item</xrefnodename></pxref>). Utilisez l&textrsquo;étiquette optionnelle, comme dans
<code>\item[Point principal]</code>, en effet il n&textrsquo;y a pas de valeur par
défaut sensée. Après le <code>\item</code> se trouve du texte optionnel
pouvant contenir plusieurs paragraphes.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="236">gras machine à écrire, éviter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="237">gras tapuscrit, éviter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="238">étiquette machine à écrire dans les listes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="239">étiquette tapuscrite dans les listes</indexterm></cindex>
<para>Comme les étiquettes sont en gras, si le texte de l&textrsquo;étiquette appelle un
changement de police effectué dans la forme à argument (voir <ref label="Font-styles"><xrefnodename>Font
styles</xrefnodename><xrefinfoname>styles des polices</xrefinfoname></ref>) alors il ressortira en gras.  Par exemple,
si le texte de l&textrsquo;étiquette est en police machine à écrire comme dans
<code>\item[\texttt&lbrace;texte étiquette&rbrace;]</code> alors il apparaîtra en
tapuscrit gras, si cela est disponible. La méthode la plus simple pour
obtenir la police tapuscrit non grasse est d&textrsquo;utiliser la forme
déclarative : <code>\item[&lbrace;\tt texte étiquette&rbrace;]</code>.  De la même façon,
obtenez la police romaine standarde avec <code>\item[&lbrace;\rm texte
étiquette&rbrace;]</code>.
</para>
<para>En ce qui concerne les autres principaux environnements de liste à
étiquettes de &latex;, voir <ref label="itemize"><xrefnodename>itemize</xrefnodename></ref> et <ref label="enumerate"><xrefnodename>enumerate</xrefnodename></ref>.
Contrairement à ces environnements, imbriquer les environnements
<code>description</code> ne change pas l&textrsquo;étiquette par défaut ; elle est en
gras et alignée à gauche à tous les niveaux.
</para>
<para>Pour plus d&textrsquo;information sur les paramètres de disposition de liste, y
compris les valeurs par défaut, et sur la personnalisation de la
disposition de liste, voir <ref label="list"><xrefnodename>list</xrefnodename></ref>.  Le paquetage <code>enumitem</code> est
utile pour personnaliser les listes.
</para>
<para>Cet exemple met les étiquettes de description en petites capitales.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\descriptionlabel&rbrace;[1]&lbrace;%
  &lbrace;\hspace&lbrace;\labelsep&rbrace;\textsc&lbrace;#1&rbrace;&rbrace;&rbrace;
</pre></example>


</section>
<node name="displaymath" spaces=" "><nodename>displaymath</nodename><nodenext automatic="on">document</nodenext><nodeprev automatic="on">description</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>displaymath</code></sectiontitle>
<!-- c http://tex.stackexchange.com/questions/40492/what-are-the-differences-between-align-equation-and-displaymath -->

<findex index="fn" spaces=" "><indexterm index="fn" number="363"><r>environnement</r> <code>displaymath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="364"><code>displaymath</code>, <r>environnement</r></indexterm></findex>


<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
<var>des maths</var>
\end&lbrace;displaymath&rbrace;
</pre></example>


<para>L&textrsquo;environnement <code>displaymath</code> compose le texte <var>des maths</var> sur
sa propre ligne, centré par défaut.  L&textrsquo;option globale <code>fleqn</code>
justifie les équations à gauche ; voir <ref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></ref>.
</para>
<para>Aucun numéro d&textrsquo;équation n&textrsquo;est ajouté au texte de texte
<code>displaymath</code> ; pour obtenir un numéro d&textrsquo;équation, vous pouvez
utiliser l&textrsquo;environnement <code>equation</code> (<pxref label="equation"><xrefnodename>equation</xrefnodename></pxref>).
</para>
<para>&latex; ne fait pas de saut de ligne au sein de <var>des maths</var>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="365"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="366"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Notez que le paquetage <code>amsmath</code> comprend des possibilités beaucoup
plus vastes en matière d&textrsquo;affichage d&textrsquo;équations. Par exemple, il offre
plusieurs alternatives pour effectuer des sauts de lignes au sein de
texte en mode mathématique.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="367">\[...\] <r>displaymath</r></indexterm></findex>
<para>La construction <code>\[<var>des maths</var>\]</code> est un synonyme de
l&textrsquo;environnement <code>\begin&lbrace;displaymath&rbrace;<var>des
maths</var>\end&lbrace;displaymath&rbrace;</code>, mais ce dernier est plus pratique à
manipuler dans le fichier source ; par exemple la recherche d&textrsquo;un
caractère crochet <code>]</code> peut donner des faux positifs, alors qu&textrsquo;il
est plus probable que le mot <code>displaymath</code> soit unique.
</para>

<findex index="fn" spaces=" "><indexterm index="fn" number="368">$$...$$ <r>displaymath, forme approchée en &tex; de base</r></indexterm></findex>
<para>(Digression : la construction <code>$$<var>des maths</var>$$</code> tirée du
langage &tex; de base est souvent utilisée à tort comme un synonyme
de <code>displaymath</code>.  Elle n&textrsquo;en est pas un, et n&textrsquo;est pas du tout
officiellement prise en charge par &latex; ; <code>$$</code> ne prend pas en
charge <code>fleqn</code> (<pxref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></pxref>), gère l&textrsquo;espacement
vertical différemment, et n&textrsquo;effectue pas de vérification de
cohérence).
</para>
<para>Le texte composé par cet exemple est centré et seul sur sa ligne.
</para><example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
  \int_1^2 x^2\,dx=7/3
\end&lbrace;displaymath&rbrace;
</pre></example>
<para>De plus, le signe intégrale est plus grand que ce que la version en
ligne <code>\( \int_1^2 x^2\,dx=7/3 \)</code> produit.
</para>
</section>
<node name="document" spaces=" "><nodename>document</nodename><nodenext automatic="on">enumerate</nodenext><nodeprev automatic="on">displaymath</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>document</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="369"><r>environnement</r> <code>document</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="370"><code>document</code>, <r>environnement</r></indexterm></findex>


<para>L&textrsquo;environnement <code>document</code> entoure le corps entier d&textrsquo;un document.
Il est obligatoire dans tout document &latex;. <xref label="Starting-and-ending"><xrefnodename>Starting and
ending</xrefnodename></xref>.
</para><menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::          ">\AtBeginDocument</menunode><menudescription><pre xml:space="preserve">Crochet pour commandes à exécuter au début du document.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">\AtEndDocument</menunode><menudescription><pre xml:space="preserve">Crochet pour commandes à exécuter à la fin du document.
</pre></menudescription></menuentry></menu>


<node name="_005cAtBeginDocument" spaces=" "><nodename>\AtBeginDocument</nodename><nodenext automatic="on">\AtEndDocument</nodenext><nodeup automatic="on">document</nodeup></node>

<findex index="fn" spaces=" "><indexterm index="fn" number="371">\AtBeginDocument</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="240">début de document, crochet</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\AtBeginDocument&lbrace;<var>code</var>&rbrace;
</pre></example>

<para>Sauvegarde <var>code</var> et exécute le quand <code>\begin&lbrace;document&rbrace;</code> est
exécuté, à la toute fin du préambule.  Le code est exécuté après que les
tables de sélection de police ont été réglées, ainsi la police normale
du document est la police courante. Toutefois, le code est exécuté en
tant que faisant partie du préambule, c&textrsquo;est pourquoi on ne peut pas
composer du texte avec.
</para>
<para>On peut utiliser cette commande plus d&textrsquo;une fois ; les lignes de code
successives sont exécutée dans l&textrsquo;ordre de passage à la commande.
</para>

<node name="_005cAtEndDocument" spaces=" "><nodename>\AtEndDocument</nodename><nodeprev automatic="on">\AtBeginDocument</nodeprev><nodeup automatic="on">document</nodeup></node>

<findex index="fn" spaces=" "><indexterm index="fn" number="372">\AtEndDocument</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="241">fin document, crochet</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\AtEndDocument&lbrace;<var>code</var>&rbrace;
</pre></example>

<para>Sauvegarde <var>code</var> et l&textrsquo;exécute vers la fin du document.  Plus
précisément, il est exécuté lorsque <code>\end&lbrace;document&rbrace;</code> est exécuté,
avant que la dernière page ne soit terminée et avant que tous
environnements flottant restants soient traités. Si on désire d&textrsquo;une
partie du code soit exécuté après ces deux traitements, alors il suffit
d&textrsquo;inclure un <code>\clearpage</code> à l&textrsquo;endroit approprié du <var>code</var>.
</para>
<para>On peut utiliser cette commande plus d&textrsquo;une fois ; les lignes de code
successives sont exécutée dans l&textrsquo;ordre de passage à la commande.
</para>
</section>
<node name="enumerate" spaces=" "><nodename>enumerate</nodename><nodenext automatic="on">eqnarray</nodenext><nodeprev automatic="on">document</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>enumerate</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="373"><r>environnement</r> <code>enumerate</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="374"><code>enumerate</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="242">listes d&textrsquo;articles numérotés</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="243">numérotés, listes d&textrsquo;articles</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;enumerate&rbrace;
\item <var>article1</var>
\item <var>article2</var>
...
\end&lbrace;enumerate&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>enumerate</code> produit une liste numérotée d&textrsquo;articles.
Le format du numéro en étiquette dépend de si cet environnement est
imbriqué dans un autre ; voir plus bas.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="375">\item</indexterm></findex>
<para>La liste consiste en au moins un article. L&textrsquo;absence d&textrsquo;article cause
l&textrsquo;erreur &latex; <samp>Something's wrong--perhaps a missing \item</samp>.
Chaque article est produit avec la commande <code>\item</code>.
</para>
<para>Cet exemple fait la liste des deux premiers coureurs à l&textrsquo;arrivée du
marathon olympique de 1908 :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;enumerate&rbrace;
 \item Johnny Hayes (USA)
 \item Charles Hefferon (RSA)
\end&lbrace;enumerate&rbrace;
</pre></example>

<para>Les énumérations peuvent être imbriquées les unes dans les autres,
jusqu&textrsquo;à une profondeur de quatre niveaux. Elles peuvent aussi être
imbriquées au sein d&textrsquo;autres environnements fabriquant des paragraphes,
tels que <code>itemize</code> (<pxref label="itemize"><xrefnodename>itemize</xrefnodename></pxref>) et <code>description</code>
(<pxref label="description"><xrefnodename>description</xrefnodename></pxref>).
Le format de l&textrsquo;étiquette produite dépend du niveau d&textrsquo;imbrication de la
liste. Voici les valeurs par défaut de &latex; pour le format à chaque
niveau d&textrsquo;imbrication (où 1 est le niveau le plus externe) :
</para>
<enumerate first="1" endspaces=" ">
<listitem spaces=" "><para>numéro arabe suivi d&textrsquo;un point : <samp>1.</samp>, <samp>2.</samp>, &dots;
</para></listitem><listitem spaces=" "><para>lettre en bas de casse et entre parenthèse : <samp>(a)</samp>, <samp>(b)</samp> &dots;
</para></listitem><listitem spaces=" "><para>numéro romain en bas de casse suivi d&textrsquo;un point : <samp>i.</samp>, <samp>ii.</samp>, &dots;
</para></listitem><listitem spaces=" "><para>lettre capitale suivie d&textrsquo;un point : <samp>A.</samp>, <samp>B.</samp>, &dots;
</para></listitem></enumerate>


<findex index="fn" spaces=" "><indexterm index="fn" number="376">\enumi</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="377">\enumii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="378">\enumiii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="379">\enumiv</indexterm></findex>
<para>L&textrsquo;environnement <code>enumerate</code> utilise les compteurs <code>\enumi</code>,
&dots;, <code>\enumiv</code> (<pxref label="Counters"><xrefnodename>Counters</xrefnodename></pxref>).  Si vous utilisez l&textrsquo;argument
optionnel d&textrsquo;<code>\item</code> alors le compteur n&textrsquo;est pas incrémenté pour cet
article (<pxref label="_005citem"><xrefnodename>\item</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="380">\labelenumi</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="381">\labelenumii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="382">\labelenumiii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="383">\labelenumiv</indexterm></findex>
<para>L&textrsquo;environnement <code>enumerate</code> utilise les commandes de
<code>\labelenumi</code> jusqu&textrsquo;à <code>\labelenumiv</code> pour produire l&textrsquo;étiquette
par défaut. Ainsi, vous pouvez utiliser <code>\renewcommand</code> pour
changer le format des étiquettes (<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp;
\renewcommand</xrefnodename></pxref>). Par exemple, cette liste de premier niveau va être
étiquetée avec des lettres capitales, en gras, non suivies point :
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="384">\Alph <r>exemple</r></indexterm></findex>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\labelenumi&rbrace;&lbrace;\textbf&lbrace;\Alph&lbrace;enumi&rbrace;&rbrace;&rbrace;
\begin&lbrace;enumerate&rbrace;
  \item eI
  \item bi:
  \item si:
\end&lbrace;enumerate&rbrace;
</pre></example>


<para>Pour une liste des commandes comme <code>\Alph</code> utilisables pour
formater le compteur d&textrsquo;étiquette voir <ref label="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol"><xrefnodename>\alph \Alph \arabic \roman
\Roman \fnsymbol</xrefnodename></ref>.
</para>
<para>Pour plus ample information sur la personnalisation de la forme
<!-- c layout -> forme ? -->
voir <ref label="list"><xrefnodename>list</xrefnodename></ref>.  De même, le paquetage <code>enumitem</code> est utile pour
cela.
</para>
</section>
<node name="eqnarray" spaces=" "><nodename>eqnarray</nodename><nodenext automatic="on">equation</nodenext><nodeprev automatic="on">enumerate</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>eqnarray</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="385"><r>environnement</r> <code>eqnarray</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="386"><code>eqnarray</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="244">équations, aligner</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="245">aligner des équations</indexterm></cindex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="246"><code>align</code> <r>environnement, d&textrsquo;<code>amsmath</code></r></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="247"><code>amsmath</code> <r>paquetage, remplaçant <code>eqnarray</code></r></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="248">Madsen, Lars</indexterm></cindex>
<para>L&textrsquo;environnement <code>eqnarray</code> est obsolète. Il a des maladresses parmi
lesquelles l&textrsquo;espacement qui est incohérent avec d&textrsquo;autres éléments
mathématiques. (Voir l&textrsquo;article « Évitez eqnarray ! »&noeos; de Lars Madsen
(<url><urefurl>http://tug.org/TUGboat/tb33-1/tb103madsen.pdf</urefurl></url>). Les nouveaux
documents devraient inclure le paquetage <code>amsmath</code> et utiliser les
environnements d&textrsquo;affichage mathématique que celui-ci fournit, tels que
<code>align</code>. On inclut une description uniquement pour être complet et
pour pouvoir travailler avec d&textrsquo;anciens documents.
</para>
<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;eqnarray&rbrace; <r>(ou <code>eqnarray*</code>)</r>
<var>formula1</var> \\
<var>formula2</var> \\
...
\end&lbrace;eqnarray&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="387">\\ (for <code>eqnarray</code>)</indexterm></findex>
<para>L&textrsquo;environnement <code>eqnarray</code> est utilisé pour afficher une séquence
d&textrsquo;équations ou d&textrsquo;inégalités. Il est similaire à un environnement
<code>array</code> à trois colonnes, avec des lignes consécutives séparées par
<code>\\</code> et des articles consécutifs au sein d&textrsquo;une ligne séparé par une
esperluette <code>&amp;</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="388">\\* (pour <code>eqnarray</code>)</indexterm></findex>
<para><code>\\*</code> peut aussi être utilisé pour séparer les équations, avec sa
signification normale de ne pas autoriser un saut de page à cette ligne.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="389">\nonumber</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="249">numéro d&textrsquo;équation, omettre</indexterm></cindex>
<para>Un numéro d&textrsquo;équation est placé sur chaque ligne à moins que cette ligne
ait une commande <code>\nonumber</code>. Alternativement, la forme étoilé (en
<code>*</code>) de l&textrsquo;environnement (<code>\begin&lbrace;eqnarray*&rbrace;
... \end&lbrace;eqnarray*&rbrace;</code>) omet la numérotation des équations entièrement,
tout en faisant par ailleurs la même chose qu&textrsquo;<code>eqnarray</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="390">\lefteqn</indexterm></findex>
<para>La commande <code>\lefteqn</code> est utilisée pour couper les longues
formules sur plusieurs lignes. Elle compose son argument en hors texte
et le justifie à gauche dans une boîte de largeur nulle.
</para>
</section>
<node name="equation" spaces=" "><nodename>equation</nodename><nodenext automatic="on">figure</nodenext><nodeprev automatic="on">eqnarray</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>equation</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="391"><r>environnement</r> <code>equation</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="392"><code>equation</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="250">équations, environnement pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="251">formules, environnement pour</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
<var>texte mathématique</var>
\end&lbrace;equation&rbrace;
</pre></example>

<para>Même chose que l&textrsquo;environnement <code>displaymath</code> (<pxref label="displaymath"><xrefnodename>displaymath</xrefnodename></pxref>)
à ceci près que &latex; place un numéro d&textrsquo;équation aligné sur la marge
de droite. Le numéro d&textrsquo;équation est généré en utilisant le compteur
<code>equation</code>.
</para>
<para>Il ne faut aucune ligne vide entre <code>\begin&lbrace;equation&rbrace;</code> et
<code>\begin&lbrace;equation&rbrace;</code>, sinon &latex; dit qu&textrsquo;il manque une signe
dollar.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="393"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="394"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>amsmath</code> comprend des moyens étendus pour l&textrsquo;affichage
d&textrsquo;équations.  Les nouveaux documents devraient inclure ce paquetage.
</para>
</section>
<node name="figure" spaces=" "><nodename>figure</nodename><nodenext automatic="on">filecontents</nodenext><nodeprev automatic="on">equation</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>figure</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="395"><r>environnement</r> <code>figure</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="396"><code>figure</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="252">insérer des figures</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="253">figures, insertion</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure&rbrace;[<var>placement</var>]
  <var>corpsfigure</var>
  \caption[<var>titreldf</var>]&lbrace;<var>texte</var>&rbrace;  % optionnel
  \label&lbrace;<var>étiquette&rbrace;</var>          % optionnel
\end&lbrace;figure&rbrace;
</pre></example>

<noindent></noindent>
<para>ou :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure*&rbrace;[<var>placement</var>]
  <var>corpsfigure</var>
  \caption[<var>titreldf</var>]&lbrace;<var>texte</var>&rbrace;  % optionnel
  \label&lbrace;<var>étiquette&rbrace;</var>          % optionnel
\end&lbrace;figure*&rbrace;
</pre></example>

<para>Les figures sont de la matière qui ne fait pas partie du texte normal.  Un
exemple est de la matière qu&textrsquo;on ne peut pas avoir segmenté entre deux
pages, comme un graphique.  À cause de cela, &latex; ne compose pas les
figures en séquence avec le texte normal, mais au lieu de cela les fait
« flotter » jusqu&textrsquo;à un endroit convenable, tel que le haut de la page
suivante (<pxref label="Floats"><xrefnodename>Floats</xrefnodename></pxref>).
</para>

<para>Le <var>corpsfigure</var> peut consister de graphiques importés
(<pxref label="Graphics"><xrefnodename>Graphics</xrefnodename></pxref>), de texte, de commandes &latex;, etc. Il est composé
une <code>parbox</code> de largeur <code>\textwidth</code>.
</para>

<para>Pour les valeurs possibles de <var>placement</var> sont <code>h</code> pour « ici »
(<samp>here</samp> en anglais), <code>t</code> pour « en haut » (<samp>top</samp>),
<code>b</code> pour « en bas », et <code>p</code> pour sur un page séparée de
flottants. Pour l&textrsquo;effet de ces options sur l&textrsquo;algorithme de placement des
flottants, voir <ref label="Floats"><xrefnodename>Floats</xrefnodename></ref>.
</para>
<para>La version étoilée <code>figure*</code> est utilisée quand un document est en
mode double-colonne (<pxref label="_005ctwocolumn"><xrefnodename>\twocolumn</xrefnodename></pxref>). elle produit une figure qui
s&textrsquo;étend sur les deux colonnes, au sommet de la page. Pour ajouter la
possibilité de la placer à un bas de page voir la discussion de
<var>placement</var> <code>b</code> dans <ref label="Floats"><xrefnodename>Floats</xrefnodename></ref>.
</para>
<para>L&textrsquo;étiquette est optionnelle ; elle est utilisée pour les renvois
(<pxref label="Cross-references"><xrefnodename>Cross references</xrefnodename></pxref>).
<findex index="fn" spaces=" "><indexterm index="fn" number="397">\caption</indexterm></findex>
La commande optionnelle <code>\caption</code> spécifie la légende <var>texte</var>
pour la figure (<pxref label="_005ccaption"><xrefnodename>\caption</xrefnodename></pxref>). La légende est numérotée par
défaut. Si <var>titreldf</var> est présent, il est utilisé dans la liste des
figures au lieu de <var>texte</var> (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents etc.</xrefnodename></pxref>).
</para>
<para>Cet exemple fabrique une figure à partir d&textrsquo;un graphique. Il nécessite
l&textrsquo;un des paquetages <file>graphics</file> ou <file>graphicx</file>. Le graphique,
avec sa légende, est placé au sommet d&textrsquo;une page ou, s&textrsquo;il est rejeté à la
fin du document, sur une page de flottants.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure&rbrace;[t]
  \centering
  \includegraphics[width=0.5\textwidth]&lbrace;CTANlion.png&rbrace;
  \caption&lbrace;The CTAN lion, by Duane Bibby&rbrace;
\end&lbrace;figure&rbrace;
</pre></example>


</section>
<node name="filecontents" spaces=" "><nodename>filecontents</nodename><nodenext automatic="on">flushleft</nodenext><nodeprev automatic="on">figure</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>filecontents</code>: Écrire un fichier externe</sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="398"><r>environnement</r> <code>filecontents</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="399"><code>filecontents</code>, <r>environnement</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="400"><r>environnement</r> <code>filecontents*</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="401"><code>filecontents*</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="254">fichier externe, écrire</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="255">écrire un fichier externe</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;filecontents&rbrace;[<var>option</var>]&lbrace;<var>nomfichier</var>&rbrace;
<var>texte</var>
\end&lbrace;filecontents&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;filecontents*&rbrace;[<var>option</var>]&lbrace;<var>nomfichier</var>&rbrace;
<var>texte</var>
\end&lbrace;filecontents*&rbrace;
</pre></example>

<para>Crée un fichier nommé <var>nomfichier</var> dans le répertoire courant (ou
dans le répertoire de sortie s&textrsquo;il a été spécifié ; <pxref label="output-directory"><xrefnodename>output
directory</xrefnodename></pxref>) et y écrit <var>texte</var>. Par défaut un fichier déjà existant
n&textrsquo;est pas écrasé.
</para>
<para>La version non étoilée de l&textrsquo;environnement <code>filecontent</code> préfixe le
contenu du ficher créé d&textrsquo;une en-tête de commentaires &tex; ; voir
l&textrsquo;exemple ci-dessous. La version étoilée <code>filecontent*</code> n&textrsquo;inclut
par l&textrsquo;en-tête.
</para>
<para>Les options possibles sont :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">force</itemformat></item>
<itemx spaces=" "><itemformat command="code">overwrite</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="256"><code>force</code>, option de <code>filecontents</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="257"><code>overwrite</code>, option de <code>filecontents</code></indexterm></cindex>
<para>Écrase le fichier s&textrsquo;il existe.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">noheader</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="258"><code>noheader</code>, option de <code>filecontents</code></indexterm></cindex>
<para>Omet l&textrsquo;en-tête. Équivalent à utiliser <code>filecontents*</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">nosearch</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="259"><code>nosearch</code>, option de <code>filecontents</code></indexterm></cindex>
<para>Vérifie uniquement si un fichier existe dans le répertoire courant (et
le répertoire de sortie, s&textrsquo;il a été spécifié), non dans le chemin
complet de recherche.
</para>

</tableitem></tableentry></table>

<para>Ces options ont été ajoutées à la parution 2019 de &latex;.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="260">sources autonomes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="261">fichiers source, rendre autonomes</indexterm></cindex>
<para>Cet environnement peut être utilisé n&textrsquo;importe où dans le préambule, bien
qu&textrsquo;il apparaisse souvent avant la commande <code>\documentclass</code>. Elle
est classiquement utilisée pour créer un fichier <code>.bib</code> ou d&textrsquo;autre
fichier de données similaire à partir du document source principale, de
sorte à rendre le fichier source autonome. De même, il peut être utilisé
pour créer un fichier personnalisé de style ou de classe, rendant ainsi
encore le source autonome.
</para>

<para>Par exemple, ce document :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\begin&lbrace;filecontents&rbrace;&lbrace;JH.sty&rbrace;
\newcommand&lbrace;\monnom&rbrace;&lbrace;Jim Hef&lbrace;&rbrace;feron&rbrace;
\end&lbrace;filecontents&rbrace;
\usepackage&lbrace;JH&rbrace;
\begin&lbrace;document&rbrace;
Un article de \monnom.
\end&lbrace;document&rbrace;
</pre></example>

<para>produit ce fichier <file>JH.sty</file> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">%% LaTeX2e file `JH.sty'
%% generated by the `filecontents' environment
%% from source `test' on 2015/10/12.
%%
\newcommand&lbrace;\monnom&rbrace;&lbrace;Jim Hef&lbrace;&rbrace;feron&rbrace;
</pre></example>


</section>
<node name="flushleft" spaces=" "><nodename>flushleft</nodename><nodenext automatic="on">flushright</nodenext><nodeprev automatic="on">filecontents</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>flushleft</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="402"><r>environnement</r> <code>flushleft</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="403"><code>flushleft</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="262">justifier à gauche du texte, environnement pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="263">texte fer à gauche, environnement pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="264">texte ferré à gauche, environnement pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="265">texte drapeau droit, environnement pour</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;flushleft&rbrace;
<var>ligne1</var> \\
<var>ligne2</var> \\
...
\end&lbrace;flushleft&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="404">\\ <r>&textrsquo;pour <code>flushleft</code>)</r></indexterm></findex>
<para>L&textrsquo;environnement <code>flushleft</code> vous permet de créer un paragraphe
ferré à gauche, c&textrsquo;est à dire consistant en lignes qui sont alignées sur
la marge de gauche et en dentelures à droite comme un drapeau dont la
hampe (fer du composeur) serait à gauche et les franges à droite. Si
vous avez des lignes qui sont trop longues alors &latex; insère des
sauts de ligne sans faire de césure ni dilater ou contracter les espaces
inter-mot. Pour forcer un saut de ligne on utilise une double
controblique, <code>\\</code>. Pour la forme déclarative,
voir <ref label="_005craggedright"><xrefnodename>\raggedright</xrefnodename></ref>.
</para>
<para>L&textrsquo;exemple suivant crée une boîte de texte qui fait au plus 7,5cm de
large, et dont le texte est fer à gauche et drapeau à droite.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\noindent\begin&lbrace;minipage&rbrace;&lbrace;7.5cm&rbrace;
\begin&lbrace;flushleft&rbrace;
  Une longue phrase que \LaTeX&lbrace;&rbrace; coupe à l'endroit approprié. \\
  Et, une nouvelle ligne forcée par la double controblique.
\end&lbrace;flushleft&rbrace;
\end&lbrace;minipage&rbrace;
</pre></example>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\raggedright</menunode><menudescription><pre xml:space="preserve">Forme déclarative de l&textrsquo;environnement <code>flushleft</code>.
</pre></menudescription></menuentry></menu>


<node name="_005craggedright" spaces=" "><nodename>\raggedright</nodename><nodeup automatic="on">flushleft</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\raggedright</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="405">\raggedright</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="266">texte drapeau droit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="267">texte ferré à gauche</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="268">texte fer à gauche</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="269">justifié à gauche du texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="270">justification, drapeau droit</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\raggedright  ... &rbrace;
</pre></example>

<noindent></noindent>
<para>ou :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;<var>environnement</var>&rbrace; \raggedright
  ...
\end&lbrace;<var>environnement</var>&rbrace;
</pre></example>

<para>Une déclaration qui a pour effet que les lignes sont ferrées sur la
marge de gauche et drapeau sur la droite, c.-à-d.&noeos; que les mots sont
alignés sur la gauche comme sur le fer du composeur, et en dentelure
comme les franges d&textrsquo;un drapeau à droite. Elle peut être utilisée au sein
d&textrsquo;un <var>environnement</var> tel que <code>quote</code> ou d&textrsquo;une
<code>parbox</code>. Pour la forme par environnement voir <ref label="flushleft"><xrefnodename>flushleft</xrefnodename></ref>.
</para>
<para>Contrairement à l&textrsquo;environnement <code>flushleft</code>, la commande
<code>\raggedright</code> ne démarre pas un nouveau paragraphe ; elle change
seulement la façon dont &latex; formate les unités de paragraphe. Pour
affecter le format d&textrsquo;une unité de paragraphe, la portée de la déclaration
doit contenir la ligne à blanc ou la commande <code>\end</code> qui termine
l&textrsquo;unité de paragraphe.
</para>

<para>Dans l&textrsquo;exemple ci-après <code>\raggedright</code> dans la deuxième colonne
empêche &latex; de faire une composition très maladroite pour faire
rentrer le texte dans une colonne étroite.  Notez que
<code>\raggedright</code> est au sein d&textrsquo;accolades <code>&lbrace;...&rbrace;</code> pour borner
son effet.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;rp&lbrace;5cm&rbrace;&rbrace;
  Équipe alpha  &amp;&lbrace;\raggedright Cette équipe fait le travail réel.&rbrace; \\
  Équipe bêta   &amp;&lbrace;\raggedright Cette équipe assure que le système de
                   refroidissement ne manque jamais d'eau.&rbrace; \\
\end&lbrace;tabular&rbrace;
</pre></example>

</subsection>
</section>
<node name="flushright" spaces=" "><nodename>flushright</nodename><nodenext automatic="on">itemize</nodenext><nodeprev automatic="on">flushleft</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>flushright</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="406"><r>environnement</r> <code>flushright</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="407"><code>flushright</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="271">texte drapeau gauche, environnement pour</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="272">justifier à droite, environnement pour</indexterm></cindex>

<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;flushright&rbrace;
  <var>ligne1</var> \\
  <var>ligne2</var> \\
...
\end&lbrace;flushright&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="408">\\ <r>(pour <code>flushright</code>)</r></indexterm></findex>
<para>L&textrsquo;environnement <code>flushright</code> vous permet de créer un paragraphe
ferré à droite et drapeau gauche, c.-à-d.&noeos; consistant de lignes qui
sont alignées sur la marge de droite (fer à droite) et en dentelures
(drapeau) sur la marge de gauche. Si vous avez des lignes qui sont trop
longues pour entrer entre les marges, alors &latex; insère des sauts de
ligne sans faire de césure ni dilater ou contracter les espaces
inter-mot. Pour forcer un saut de ligne on utilise une double
controblique, <code>\\</code>. Pour la forme déclarative,
voir <ref label="_005craggedleft"><xrefnodename>\raggedleft</xrefnodename></ref>.
</para>
<para>Pour un exemple en relation avec cet environnement,
voir <ref label="flushleft"><xrefnodename>flushleft</xrefnodename></ref>, où il suffit mutatis mutandis de changer
<code>flushright</code> en <code>flushleft</code>.
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\raggedleft</menunode><menudescription><pre xml:space="preserve">Forme déclarative de l&textrsquo;environnement <code>flushright</code>.
</pre></menudescription></menuentry></menu>


<node name="_005craggedleft" spaces=" "><nodename>\raggedleft</nodename><nodeup automatic="on">flushright</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\raggedleft</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="409">\raggedleft</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="273">texte drapeau gauche</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="274">justification, drapeau gauche</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="275">justifier le texte à droite</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\raggedleft  ... &rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;<var>environnement</var>&rbrace; \raggedleft
  ...
\end&lbrace;<var>environnement</var>&rbrace;
</pre></example>

<para>Une déclaration qui a pour effet que les lignes sont ferrées sur la
marge de droite et drapeau sur la gauche, c.-à-d.&noeos; que les mots sont
alignés sur la droite comme sur le fer du composeur, et en dentelure
comme les franges d&textrsquo;un drapeau à gauche. Elle peut être utilisée au sein
d&textrsquo;un <var>environnement</var> tel que <code>quote</code> ou d&textrsquo;une
<code>parbox</code>. Pour la forme par environnement voir <ref label="flushleft"><xrefnodename>flushleft</xrefnodename></ref>.
</para>
<para>Contrairement à l&textrsquo;environnement <code>flushright</code>, la commande
<code>\raggedleft</code> ne démarre pas un nouveau paragraphe ; elle change
seulement la façon dont &latex; formate les unités de paragraphe. Pour
affecter le format d&textrsquo;une unité de paragraphe, la portée de la déclaration
doit contenir une ligne à blanc ou la commande <code>\end</code> qui termine
l&textrsquo;unité de paragraphe.
</para>
<para>Pour un exemple en relation avec cet environnement,
voir <ref label="_005craggedright"><xrefnodename>\raggedright</xrefnodename></ref>, où il suffit mutatis mutandis de changer
<code>\raggedright</code> en <code>\raggedleft</code>.
</para>
</subsection>
</section>
<node name="itemize" spaces=" "><nodename>itemize</nodename><nodenext automatic="on">letter</nodenext><nodeprev automatic="on">flushright</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>itemize</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="410"><r>environnement</r> <code>itemize</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="411"><code>itemize</code>, <r>environnement</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="412">\item</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="276">listes d&textrsquo;articles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="277">listes non ordonnées</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="278">listes à puces</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;itemize&rbrace;
  \item[<var>étiquette optionnelle du 1er article</var>] <var>texte du 1er article</var>
  \item[<var>étiquette optionnelle du 2e article</var>] <var>texte du 2e article</var>
   ...
\end&lbrace;itemize&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>itemize</code> produit une <dfn>liste non ordonnée</dfn>, qu&textrsquo;on
appelle parfois liste à puces. Il doit y avoir au moins une commande
<code>\item</code> au sein de l&textrsquo;environnement ; sans quoi &latex; produit
l&textrsquo;erreur <samp>Something's wrong--perhaps a missing \item</samp>.
</para>
<para>L&textrsquo;exemple suivant donne une liste à deux articles.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;itemize&rbrace;
 \item Esquisse au crayon et aquarelle par Cassandra
 \item Portrait Rice
\end&lbrace;itemize&rbrace;
</pre></example>

<noindent></noindent>
<para>Par défaut &textmdash; sans charger par ex.&noeos; le paquetage <code>babel</code> avec une
autre langue que USenglish &textmdash; dans une liste au premier niveau
d&textrsquo;imbrication l&textrsquo;étiquette est rendue par une puce, &bullet;.  Le format
des étiquettes dépend du niveau d&textrsquo;imbrication ; voir plus bas.
</para>

<findex index="fn" spaces=" "><indexterm index="fn" number="413">\item</indexterm></findex>
<para>On démarre les articles de liste avec la commande <code>\item</code>
(<pxref label="_005citem"><xrefnodename>\item</xrefnodename></pxref>).  Si vous passez à <code>\item</code> un argument optionnel en
le faisant suivre de crochets, comme dans <code>\item[<var>étiquette
optionnelle</var>]</code>, alors par défaut <var>étiquette optionnelle</var> apparaît en
gras et aligné à droite, de sorte qu&textrsquo;elle peut s&textrsquo;étendre dans la marge
de gauche.  Pour des étiquettes alignées à gauche voir l&textrsquo;environnement
<ref label="description"><xrefnodename>description</xrefnodename></ref>. À la suite <code>\item</code> se trouve le texte que
l&textrsquo;article qui peut être vide ou contenir plusieurs paragraphes.
</para>
<para>Les listes non ordonnées peuvent être imbriquées l&textrsquo;une dans l&textrsquo;autre, sur
jusqu&textrsquo;à quatre niveaux de profondeur. Elles peuvent aussi être imbriquées
avec d&textrsquo;autre environnements fabriquant des paragraphes, comme
<code>enumerate</code> (<pxref label="enumerate"><xrefnodename>enumerate</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="414">\labelitemi</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="415">\labelitemii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="416">\labelitemiii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="417">\labelitemiv</indexterm></findex>
<anchor name="itemize-labelitemi">itemize labelitemi</anchor>
<anchor name="itemize-labelitemii">itemize labelitemii</anchor>
<anchor name="itemize-labelitemiii">itemize labelitemiii</anchor>
<anchor name="itemize-labelitemiv">itemize labelitemiv</anchor>
<para>L&textrsquo;environnement <code>itemize</code> utilise les commandes de
<code>\labelitemi</code> jusqu&textrsquo;à <code>\labelitemiv</code> pour produire les
étiquettes par défaut (notez la convention que le nombre romain en bas
de casse à la fin du nom de la commande indique le niveau
d&textrsquo;imbrication). Voici les marques de chaque niveau :
</para>
<enumerate first="1" endspaces=" ">
<listitem spaces=" "><para>&bullet; (puce, issue de <code>\textbullet</code>)
</para></listitem><listitem spaces=" "><para><b>-<w>-</w></b> (tiret demi-cadratin gras, issu du <code>\normalfont\bfseries\textendash</code>)
</para></listitem><listitem spaces=" "><para>* (astérisque, issu de <code>\textasteriskcentered</code>)
</para></listitem><listitem spaces=" "><para>. (point centré verticalement, rendu ici comme un point final, issu de <code>\textperiodcentered</code>)
</para></listitem></enumerate>

<!-- c vincentb1 cette information n'est pas dans l'original, vérifiez avec Karl : -->

<para>Si vous utilisez le paquetage <code>babel</code> avec la langue
<code>french</code>, alors il y a des tirets pour tous les niveaux comme c&textrsquo;est
l&textrsquo;habitude des Français.
</para>


<para>Utilisez <code>\renewcommand</code> pour changer les étiquettes. Par exemple,
pour que le premier niveau utilise des losanges :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\labelitemi&rbrace;&lbrace;$\diamond$&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="418">\leftmargin</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="419">\leftmargini</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="420">\leftmarginii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="421">\leftmarginiii</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="422">\leftmarginiv</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="423">\leftmarginv</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="424">\leftmarginvi</indexterm></findex>
<anchor name="itemize-leftmargin">itemize leftmargin</anchor>
<anchor name="itemize-leftmargini">itemize leftmargini</anchor>
<anchor name="itemize-leftmarginii">itemize leftmarginii</anchor>
<anchor name="itemize-leftmarginiii">itemize leftmarginiii</anchor>
<anchor name="itemize-leftmarginiv">itemize leftmarginiv</anchor>
<anchor name="itemize-leftmarginv">itemize leftmarginv</anchor>
<anchor name="itemize-leftmarginvi">itemize leftmarginvi</anchor>
<para>Les paramètres de <code>\leftmargini</code> jusqu&textrsquo;à <code>\leftmarginvi</code>
définissent la distance entre la marge de gauche de l&textrsquo;environnement
susjacent et la marge de gauche de la liste. (On utilise aussi la convention de
nommage de la commande avec un nombre romain en bas de casse à la fin
pour désigner le niveau d&textrsquo;imbrication). Les valeurs par défaut sont :
<code>2.5em</code> pour le niveau 1 (<code>2em</code> en mode deux-colonnes),
<code>2.2em</code> pour le niveau 2, <code>1.87em</code> pour le niveau 3 et
<code>1.7em</code> pour le niveau 4, avec des valeurs plus petites pour les
niveaux plus profondément imbriqués.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="425"><r>paquetage</r> <code>enumitem</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="426"><code>enumitem</code>, <r>paquetage</r></indexterm></findex>

<para>Pour les autres environnements majeurs de listes à étiquettes de
&latex;, voir <ref label="description"><xrefnodename>description</xrefnodename></ref> et <ref label="enumerate"><xrefnodename>enumerate</xrefnodename></ref>. Les environnements
<code>itemize</code>, <code>enumerate</code> et <code>description</code> utilisent les
mêmes paramètres de contrôle de la disposition des listes. Pour leur
description, y compris les valeurs par défaut, ainsi que la
personnalisation de la disposition, voir <ref label="list"><xrefnodename>list</xrefnodename></ref>. Le paquetage
<code>enumitem</code> est utile pour personnaliser les listes.
</para>
<para>Dans cet exemple on réduit grandement l&textrsquo;espace de marge pour la liste à
puces la plus externe :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\leftmargini&rbrace;&lbrace;1.25em&rbrace; % valeur par défaut 2.5em
</pre></example>

<!-- c xx TODO vérifier que tout cela se retouve bien dans node list. -->
<ignore>
Quelques paramètres qui affectent le formatage des listes :

@ftable @code
@item \itemindent
Renfoncement supplémentaire avant chaque articles dans une liste ; la
valeur par défaut est zéro.

@item \labelsep
Espace entre l'étiquette et le texte d'un article ; la valeur par défaut
est @samp{.5em}.

@item \labelwidth
Largeur de l'étiquette ; la valeur par défaut est @samp{2em}, ou
@samp{1.5em} en mode deux-colonnes.

@item \listparindent
Renfoncement supplémentaire ajoutée aux paragraphes suivants à commencer
par le second au sein d'un article de liste ; la valeur par défaut est
@samp{0pt}.

@item \rightmargin
Distance horizontale entre la marge de droite de la liste et
l'environnement susjacent ; la valeur par défaut est @samp{0pt}, sauf à
l'intérieur des environnements @code{quote}, @code{quotation}, et
@code{verse}, où elle est réglée pour être égale à @code{\leftmargin}.

@end ftable

Paramètres affectant l'espacement vertical entre les articles de liste
(plutôt relâché, par défaut).

@ftable @code
@item \itemsep
Espace vertical entre les articles. La valeur par défaut est @code{2pt
plus1pt minus1pt} pour les documents en @code{10pt}, @code{3pt plus2pt
minus1pt} pour ceux en @code{11pt}, et @code{4.5pt plus2pt minus1pt}
pour ceux en @code{12pt}.

@item \parsep
Espace vertical supplémentaire entre les paragraphes au sein d'un
article de liste. Par défaut vaut la même chose que @code{\itemsep}.

@item \topsep
Espace vertical entre le premier article et le paragraphe précédent.
Pour les listes au niveau le plus haut, la valeur par défaut est
@code{8pt plus2pt minus4pt} pour les documents en @code{10pt}, @code{9pt
plus3pt minus5pt} pour ceux en @code{11pt}, et @code{10pt plus4pt
minus6pt} pour ceux en @code{12pt}. Ces valeurs sont réduites pour les
listes avec au moins un niveau d'imbrication.

@item \partopsep
Espace supplémentaire ajouté à @code{\topsep} quand l'environnement de
liste démarre un paragraphe. La valeur par défaut est @code{2pt plus1pt
minus1pt} pour les documents en @code{10pt}, @code{3pt plus1pt minus1pt}
pour ceux en @code{11pt}, et @code{3pt plus2pt minus2pt} pour ceux en
@code{12pt}.

@end ftable
</ignore>


<findex index="fn" spaces=" "><indexterm index="fn" number="427">\parskip <r>exemple</r></indexterm></findex>
<para>En particulier pour les listes avec des articles courts, il peut être
désirable d&textrsquo;élider l&textrsquo;espace entre les articles. Voici un exemple
définissant un environnement <code>itemize*</code> sans espacement
supplémentaire entre les articles, ni entre les paragraphes au sein d&textrsquo;un
seul article (<code>\parskip</code> n&textrsquo;est pas spécifique aux listes,
<pxref label="_005cparindent-_0026-_005cparskip"><xrefnodename>\parindent &amp; \parskip</xrefnodename></pxref>):
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newenvironment&lbrace;itemize*&rbrace;%
  &lbrace;\begin&lbrace;itemize&rbrace;%
    \setlength&lbrace;\itemsep&rbrace;&lbrace;0pt&rbrace;%
    \setlength&lbrace;\parsep&rbrace;&lbrace;0pt&rbrace;&rbrace;%
    \setlength&lbrace;\parskip&rbrace;&lbrace;0pt&rbrace;&rbrace;%
  &lbrace;\end&lbrace;itemize&rbrace;&rbrace;
</pre></example>


</section>
<node name="letter" spaces=" "><nodename>letter</nodename><nodenext automatic="on">list</nodenext><nodeprev automatic="on">itemize</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle>environnement <code>letter</code>: écrire des lettres postales</sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="428"><r>environnement</r> <code>letter</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="429"><code>letter</code>, <r>environnement</r></indexterm></findex>


<para>Cet environnement est utilisé pour créer des lettres. <xref label="Letters"><xrefnodename>Letters</xrefnodename></xref>.
</para>

</section>
<node name="list" spaces=" "><nodename>list</nodename><nodenext automatic="on">math</nodenext><nodeprev automatic="on">letter</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>list</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="430"><r>environnement</r> <code>list</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="431"><code>list</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="279">listes d&textrsquo;articles, générique</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;list&rbrace;&lbrace;<var>étiquetage</var>&rbrace;&lbrace;<var>espacement</var>&rbrace;
\item[<var>étiquette optionnelle du premier article</var>] texte du premier
  article
\item[<var>étiquette optionnelle du deuxième article</var>] texte du deuxième
  aticle
...
\end&lbrace;list&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>list</code> est un environnement générique qui est
utilisé pour construire des listes plus spécialisées. On l&textrsquo;utilise la
plupart du temps pour créer des listes via les environnements
<code>description</code>, <code>enumerate</code>, et <code>itemize</code>
(<pxref label="description"><xrefnodename>description</xrefnodename></pxref>, <ref label="enumerate"><xrefnodename>enumerate</xrefnodename></ref>, et <ref label="itemize"><xrefnodename>itemize</xrefnodename></ref>).  Par ailleurs,
beaucoup d&textrsquo;environnements standards de &latex; qui visuellement ne sont
pas des listes sont construits en utilisant <code>list</code>, ceci comprend
<code>quotation</code>, <code>quote</code>, <code>center</code>, <code>verbatim</code>, et bien
d&textrsquo;autres (<pxref label="quotation-_0026-quote"><xrefnodename>quotation &amp; quote</xrefnodename></pxref>, <pxref label="center"><xrefnodename>center</xrefnodename></pxref>,
<pxref label="flushright"><xrefnodename>flushright</xrefnodename></pxref>).
</para>
<para>Ici, on décrit l&textrsquo;environnement <code>list</code> en définissant un
nouvel environnement personnalisé.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcounter&lbrace;compteurlistenommage&rbrace;  % numérotes les articles
\newenvironment&lbrace;nommage&rbrace;
  &lbrace;\begin&lbrace;list&rbrace;
     &lbrace;Article~\Roman&lbrace;compteurlistenommage&rbrace;.&rbrace; % argument d'étiquetage
     &lbrace;\usecounter&lbrace;compteurlistenommage&rbrace;   % argument d'espacement
      \setlength&lbrace;\leftmargin&rbrace;&lbrace;3.5em&rbrace;&rbrace; % ...suite argument d'espacement
  &rbrace;
  &lbrace;\end&lbrace;list&rbrace;&rbrace;

\begin&lbrace;nommage&rbrace;
  \item Apparaît comme « Article~I. »
  \item[Étiquette spéciale.] Apparaît comme « Étiquette spéciale. »
  \item Apparaît comme « Article~II. »
\end&lbrace;nommage&rbrace;
</pre></example>

<para>L&textrsquo;argument obligatoire <var>étiquetage</var>, qui est le premier argument de
l&textrsquo;environnement <code>list</code>, spécifie comment les articles doivent être
étiquetés par défaut. Il peut contenir du texte et des commandes
&latex;, comme dans l&textrsquo;exemple précédent où il contient à la fois
<samp>Article</samp> et <samp>\Roman&lbrace;&dots;&rbrace;</samp>. &latex; forme l&textrsquo;étiquette
en mettant l&textrsquo;argument <var>étiquetage</var> dans une boîte de largeur
<code>\labelwidth</code>. Si l&textrsquo;étiquette est plus large que cela, la matière
supplémentaire s&textrsquo;étend sur la droite. Lorsque vous fabriquez une
instance de <code>list</code> vous pouvez l&textrsquo;emporter sur l&textrsquo;étiquetage par
défaut en donnant à <code>\item</code> un argument optionnel avec des crochets
et le texte, comme dans l&textrsquo;exemple précédent <code>\item[Étiquette
spéciale.]</code> ; <pxref label="_005citem"><xrefnodename>\item</xrefnodename></pxref>.
</para>
<para>Le second argument obligatoire <var>espacement</var> prend une liste de
commandes. L&textrsquo;une de celle qu&textrsquo;on y retrouve est
<code>\usecounter&lbrace;<var>nomcompteur</var>&rbrace;</code> (<pxref label="_005cusecounter"><xrefnodename>\usecounter</xrefnodename></pxref>).  Utilisez
la pour dire à &latex; de numéroter les articles en utilisant le
compteur fourni.  Ce compteur est remis à zéro chaque fois que &latex;
entre dans l&textrsquo;environnement, et le compteur est incrémenté par un chaque
fois que &latex; rencontre une commande <code>\item</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="432">\makelabel</indexterm></findex>
<para>Une autre commande qu&textrsquo;on retrouve dans <var>espacement</var> est
<code>\makelabel</code>, pour construire la boîte de l&textrsquo;étiquette.  Par défaut
elle positionne le contenu fer à droite. Elle prend un argument,
l&textrsquo;étiquette. Elle compose son contenu en mode LR. Un exemple de
changement de sa définition consiste dans l&textrsquo;exemple précédent
<code>nommage</code> à ajouter avant la définition de l&textrsquo;environnement
<code>\newcommand&lbrace;\namedmakelabel&rbrace;[1]&lbrace;\textsc&lbrace;#1&rbrace;&rbrace;</code>, et entre la
commande <code>\setlength</code> et la parenthèse clôturant l&textrsquo;argument
<var>espacement</var> à ajouter aussi <code>\let\makelabel\namedmakelabel</code>.
Ceci composera les étiquettes en petites capitales.  De même, en
remplaçant cette seconde ligne de code par <code>\let\makelabel\fbox</code> on
met les étiquettes dans une boîte encadrée.  Ci-après voici un autre
exemple de la commande <code>\makelabel</code>, dans la définition de
l&textrsquo;environnement <code>etiquetterouge</code>.
</para>
<para>De même on trouve souvent au sein de <var>espacement</var> des commandes pour
redéfinir l&textrsquo;espacement de la liste. Ci dessous on listes les paramètres
d&textrsquo;espacement et leur valeurs par défaut. (Il se peut que les valeurs par
défaut pour les environnements dérivés tels que <code>itemize</code> soient
différentes des valeurs exposées ici). Voir aussi la figure qui suit la
liste. Chaque paramètre est une longueur (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).  Les espaces
verticaux sont d&textrsquo;ordinaire des longueurs élastiques, avec une composante
en <code>plus</code> ou en <code>minus</code>, pour donner à &tex; de la
flexibilité dans le réglage de la page.  On change chaque paramètre avec
une commande du genre de as <code>\setlength&lbrace;itemsep&rbrace;&lbrace;2pt plus1pt
minus1pt&rbrace;</code>.  Pour obtenir certains effets, ces longueurs doivent être
mise à zéro, ou à une valeur négative.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="433">\itemindent</indexterm>\itemindent</itemformat></item>
</tableterm><tableitem><anchor name="list-itemindent">list itemindent</anchor>
<para>Espace supplémentaire horizontal de renfoncement, ajouté à de
<code>leftmargin</code>, de la première ligne de chaque article. Sa valeur par
défaut est <code>0pt</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="434">\itemsep</indexterm>\itemsep</itemformat></item>
</tableterm><tableitem><anchor name="list-itemsep">list itemsep</anchor>
<para>Espace vertical entre les articles, ajouté à <code>\parsep</code>.  Les
valeurs par défaut pour les trois premiers niveaux dans les classes de
&latex; <samp>article</samp>, <samp>book</samp>, et <samp>report</samp> à la taille de 10
point sont : <code>4pt plus2pt minus1pt</code>, <code>\parsep</code> (c.-à-d.&noeos;
<code>2pt plus1pt minus1pt</code>), et <code>\topsep</code> (c.-à-d.&noeos; <code>2pt
plus1pt minus1pt</code>).  Les valeurs par défaut à 11 points sont :
<code>4.5pt plus2pt minus1pt</code>, <code>\parsep</code> (c.-à-d.&noeos; <code>2pt
plus1pt minus1pt</code>), et <code>\topsep</code> (c.-à-d.&noeos; <code>2pt plus1pt
minus1pt</code>).  Les valeurs par défaut à 12 points sont : <code>5pt
plus2.5pt minus1pt</code>, <code>\parsep</code> (c.-à-d.&noeos; <code>2.5pt plus1pt
minus1pt</code>), et <code>\topsep</code> (c.-à-d.&noeos; <code>2.5pt plus1pt minus1pt</code>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="435">\labelsep</indexterm>\labelsep</itemformat></item>
</tableterm><tableitem><anchor name="list-labelsep">list labelsep</anchor>
<para>Espace horizontal entre l&textrsquo;étiquette et le texte d&textrsquo;un article. La valeur
par défaut pour les classes &latex; <samp>article</samp>, <samp>book</samp>, et
<samp>report</samp> est de <code>0.5em</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="436">\labelwidth</indexterm>\labelwidth</itemformat></item>
</tableterm><tableitem><anchor name="list-labelwidth">list labelwidth</anchor>
<para>Largeur horizontale. La boîte contenant l&textrsquo;étiquette est nominalement de
cette largeur. Si <code>\makelabel</code> renvoie un texte qui est plus large
que cela, alors le renfoncement de la première ligne de l&textrsquo;article sera
augmenté pour créer l&textrsquo;espace nécessaire à cette matière supplémentaire.
Si <code>\makelabel</code> renvoie un texte de largeur inférieur ou égale à
<code>\labelwidth</code> alors le comportement par défaut de &latex; est que
l&textrsquo;étiquette est composé fer à droite dans une boîte de cette largeur.
</para>
<para>Le bord de gauche de la boîte de l&textrsquo;étiquette est à
<code>\leftmargin</code>+<code>\itemindent</code>-<code>\labelsep</code>-<code>\labelwidth</code>
de la marge de gauche de l&textrsquo;environnement enveloppant.
</para>
<para>La valeur par défaut pour les classes &latex; <samp>article</samp>,
<samp>book</samp>, et <samp>report</samp> pour les listes de premier niveau vaut
<code>\leftmargini</code>-<code>\labelsep</code>, (c.-à-d.&noeos; <code>2em</code> en mode à une
colonne et <code>1.5em</code> en mode deux-colonnes).  Au deuxième niveau,
c&textrsquo;est <code>\leftmarginii</code>-<code>\labelsep</code>, et au troisième niveau
<code>\leftmarginiii</code>-<code>\labelsep</code>.  Ces définitions ont pour effet
que le bord de gauche de l&textrsquo;étiquette coïncide avec la marge de gauche
de l&textrsquo;environnement enveloppant.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="437">\leftmargin</indexterm>\leftmargin</itemformat></item>
</tableterm><tableitem><anchor name="list-leftmargin">list leftmargin</anchor>
<para>Espace horizontal entre la marge de gauche de l&textrsquo;environnement susjacent
(ou la marge de gauche de la page pour une liste de premier niveau), et
la marge de gauche de cette liste. Doit être positif ou nul.
</para>
<para>Dans les classes de document &latex; standardes, ce paramètre est réglé
à la valeur <code>\leftmargini</code> pour une liste de premier niveau, alors
que pour une liste de deuxième niveau, c&textrsquo;est à dire imbriquée dans une
liste de premier niveau, il est réglé à <code>\leftmarginii</code>.  Pour les
listes aux niveaux d&textrsquo;imbrication suivants les valeurs de
<code>\leftmarginiii</code> à <code>\leftmarginvi</code> sont utilisées.  (Imbriquer
des listes au delà de cinq niveaux produit le message d&textrsquo;erreur <samp>Too
deeply nested</samp>).
</para>
<para>Les valeurs par défaut des trois premiers niveaux dans les classes
&latex; <samp>article</samp>, <samp>book</samp>, et <samp>report</samp> sont les
suivantes : <code>\leftmargini</code> vaut <code>2.5em</code> (ou <code>2em</code> en mode
deux-colonnes), <code>\leftmarginii</code> vaut <code>2.2em</code>, et
<code>\leftmarginiii</code> vaut <code>1.87em</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="438">\listparindent</indexterm>\listparindent</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="280">débord</indexterm></cindex>
<para>Espace horizontal de renfoncement supplémentaire, au delà de
<code>\leftmargin</code>, pour le deuxième paragraphe et les suivants au sein
d&textrsquo;un article de liste.  Une valeur négative produit un <dfn>débord</dfn>,
c.-à-d.&noeos; un retrait sur la gauche. Sa valeur par défaut est <code>0pt</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="439">\parsep</indexterm>\parsep</itemformat></item>
</tableterm><tableitem><anchor name="list-parsep">list parsep</anchor> <para>Espace vertical entre les paragraphes d&textrsquo;un article.
Les valeurs par défaut pour les trois premiers niveaux dans les classes
&latex; <samp>article</samp>, <samp>book</samp> et <samp>report</samp> à la taille de 10
point sont : <code>4pt plus2pt minus1pt</code>, <code>2pt plus1pt minus1pt</code>,
and <code>0pt</code>.  La valeurs par défaut à la taille de 11 point sont :
<code>4.5pt plus2pt minus1pt</code>, <code>2pt plus1pt minus1pt</code>, et
<code>0pt</code>.  La valeurs par défaut à la taille de 12 point sont :
<code>5pt plus2.5pt minus1pt</code>, <code>2.5pt plus1pt minus1pt</code>, et
<code>0pt</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="440">\partopsep</indexterm>\partopsep</itemformat></item>
</tableterm><tableitem><anchor name="list-partopsep">list partopsep</anchor> <para>Espace vertical ajouté, en plus de
<code>\topsep</code>+<code>\parskip</code>, en haut et en bas de l&textrsquo;environnement
tout entier lorsque la liste considérée est précédée d&textrsquo;une ligne à
blanc. (Une ligne à blanc dans le source &latex; avant la liste change
l&textrsquo;espacement à la fois en haut et en bas de la liste ; que la ligne
suivant la liste soit à blanc est sans importance).
</para>
<para>Les valeurs par défaut pour les trois premiers niveaux dans les classes
&latex; <samp>article</samp>, <samp>book</samp>, et <samp>report</samp> à la taille de
point sont : <code>2pt plus1 minus1pt</code>, <code>2pt plus1pt minus1pt</code>, et
<code>1pt plus0pt minus1pt</code>.  Les valeurs par défaut à la taille de 11
point sont : <code>3pt plus1pt minus1pt</code>, <code>3pt plus1pt minus1pt</code>,
et <code>1pt plus0pt minus1pt</code>).  Les valeurs par défaut à la taille de
12 point sont : <code>3pt plus2pt minus3pt</code>, <code>3pt plus2pt
minus2pt</code>, et <code>1pt plus0pt minus1pt</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="441">\rightmargin</indexterm>\rightmargin</itemformat></item>
</tableterm><tableitem><anchor name="list-rightmargin">list rightmargin</anchor>

<para>Espace horizontal entre la marge de droite de la liste et la marge de
droite de l&textrsquo;environnement l&textrsquo;englobant. Vaut par défaut <code>0pt</code>. Doit
être positif ou nul.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="442">\topsep</indexterm>\topsep</itemformat></item>
</tableterm><tableitem><anchor name="list-topsep">list topsep</anchor> <para>Espace vertical ajouté aussi bien au haut qu&textrsquo;au bas
de la liste, en plus de <code>\parskip</code> (<pxref label="_005cparindent-_0026-_005cparskip"><xrefnodename>\parindent &amp; \parskip</xrefnodename></pxref>).
Les valeurs par défaut pour les trois premiers niveaux dans les classes
&latex; <samp>book</samp>, et <samp>report</samp> à la taille de 10 point sont :
<code>8pt plus2pt minus4pt</code>, <code>4pt plus2pt minus1pt</code>, and <code>2pt
plus1pt minus1pt</code>.  Les valeurs par défaut à la taille de 11 point
sont : <code>9pt plus3pt minus5pt</code>, <code>4.5pt plus2pt minus1pt</code>, and
<code>2pt plus1pt minus1pt</code>.  Les valeurs par défaut à la taille de 12
point sont : <code>10pt plus4pt minus6pt</code>, <code>5pt plus2.5pt
minus1pt</code>, et <code>2.5pt plus1pt minus1pt</code>.
</para>
</tableitem></tableentry></ftable>

<para>La figure suivante illustre les distances horizontales et verticales.
</para>
<float type="" endspaces=" ">
<image><imagefile>latex2e-figures/list</imagefile><imagewidth>3.21in</imagewidth><imageextension>.png</imageextension></image>
</float>

<para>Les longueurs illustrées sont listées ci-dessous.  La relation clef est
que le bord droit du crochet pour <var>h1</var> est à la même position
horizontale que le bord droit du crochet pour <var>h4</var>, de sorte que le
bord de gauche de la boîte de l&textrsquo;étiquette est à
<var>h3</var>+<var>h4</var>-(<var>h0</var>+<var>h1</var>).
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">v0</itemformat></item>
</tableterm><tableitem><para>vaut <math><code>&backslash;topsep</code> + <code>&backslash;parskip</code></math> si l&textrsquo;environnement
<code>list</code> ne commence pas un nouveau paragraphe, et
<code>\topsep</code>+<code>\parskip</code>+<code>\partopsep</code> sinon
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">v1</itemformat></item>
</tableterm><tableitem><para><code>\parsep</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">v2</itemformat></item>
</tableterm><tableitem><para><code>\itemsep</code>+<code>\parsep</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">v3</itemformat></item>
</tableterm><tableitem><para>Même valeur que <var>v0</var>.  (Cet espace est affecté selon qu&textrsquo;une ligne à
blanc apparaît dans le source au dessus de l&textrsquo;environnement ; la présence
d&textrsquo;une ligne à blanc au dessous de l&textrsquo;environnement est sans effet).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">h0</itemformat></item>
</tableterm><tableitem><para><code>\labelwidth</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">h1</itemformat></item>
</tableterm><tableitem><para><code>\labelsep</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">h2</itemformat></item>
</tableterm><tableitem><para><code>\listparindent</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">h3</itemformat></item>
</tableterm><tableitem><para><code>\leftmargin</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">h4</itemformat></item>
</tableterm><tableitem><para><code>\itemindent</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">h5</itemformat></item>
</tableterm><tableitem><para><code>\rightmargin</code>
</para>
</tableitem></tableentry></table>

<para>Les marges de gauche et de droite de la liste, affichées ci-dessus comme
<var>h3</var> et <var>h5</var>, sont exprimées relativement à celles fournies par
l&textrsquo;environnement englobant, ou par rapport aux marges de la page pour une
liste au niveau le plus externe.  La largeur de ligne utilisée pour la
composition des articles de la liste est <code>\linewidth</code> (<pxref label="Page-layout-parameters"><xrefnodename>Page
layout parameters</xrefnodename></pxref>).  Par exemple, réglez la marge de gauche de la liste
à un quart de la distance entre les marges de gauche et de droite de
l&textrsquo;environnement englobant avec
<code>\setlength&lbrace;\leftmargin&rbrace;&lbrace;0.25\linewidth&rbrace;</code>.
</para>
<para>Les sauts de page au sein d&textrsquo;une structure de liste sont contrôlés par
les paramètres ci-dessous. Pour chacun d&textrsquo;eux, la valeur par défaut de
&latex; est <code>-\&arobase;lowpenalty</code>, c.-à-d.&noeos; <code>-51</code>.  Comme c&textrsquo;est
négatif, cela encourage d&textrsquo;une certaine façon un saut de page à tout
endroit.  On peut changer cela avec un réglage de, par ex.,
<code>\&arobase;beginparpenalty=9999</code> ; une valeur de 10000 interdit une saut
de page.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="443">\&arobase;beginparpenalty</indexterm>\&arobase;beginparpenalty</itemformat></item>
</tableterm><tableitem><para>La pénalité de saut de page pour un saut avant la liste (par défaut
<code>-51</code>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="444">\&arobase;itempenalty</indexterm>\&arobase;itempenalty</itemformat></item>
</tableterm><tableitem><para>La pénalité pour un saut de page avant un article de liste (par défaut
<code>-51</code>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="445">\&arobase;endparpenalty</indexterm>\&arobase;endparpenalty</itemformat></item>
</tableterm><tableitem><para>La pénalité pour un saut de page après une liste (par défaut
<code>-51</code>).
</para>
</tableitem></tableentry></ftable>

<findex index="fn" spaces=" "><indexterm index="fn" number="446"><r>paquetage</r> <code>enumitem</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="447"><code>enumitem</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>enumitem</code> est utile pour personnaliser les
listes.
</para>
<para>Dans l&textrsquo;exemple suivant les étiquettes sont en rouge.  Elles sont
numérotées, et le bord gauche des étiquettes est aligné avec le bord
gauche du texte des articles.  <xref label="_005cusecounter"><xrefnodename>\usecounter</xrefnodename></xref>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;color&rbrace;
\newcounter&lbrace;cnt&rbrace;
\newcommand&lbrace;\makeredlabel&rbrace;[1]&lbrace;\textcolor&lbrace;red&rbrace;&lbrace;#1.&rbrace;&rbrace;
\newenvironment&lbrace;redlabel&rbrace;
  &lbrace;\begin&lbrace;list&rbrace;
    &lbrace;\arabic&lbrace;cnt&rbrace;&rbrace;
    &lbrace;\usecounter&lbrace;cnt&rbrace;
     \setlength&lbrace;\labelwidth&rbrace;&lbrace;0em&rbrace;
     \setlength&lbrace;\labelsep&rbrace;&lbrace;0.5em&rbrace;
     \setlength&lbrace;\leftmargin&rbrace;&lbrace;1.5em&rbrace;
     \setlength&lbrace;\itemindent&rbrace;&lbrace;0.5em&rbrace; % vaut \labelwidth+\labelsep
     \let\makelabel=\makeredlabel
    &rbrace;
  &rbrace;
&lbrace;\end&lbrace;list&rbrace;&rbrace;
</pre></example>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::         ">\item</menunode><menudescription><pre xml:space="preserve">Un article dans une liste.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">trivlist</menunode><menudescription><pre xml:space="preserve">Une forme restreinte de <code>list</code>.
</pre></menudescription></menuentry></menu>


<node name="_005citem" spaces=" "><nodename>\item</nodename><nodenext automatic="on">trivlist</nodenext><nodeup automatic="on">list</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\item</code>: Une entrée dans une liste</sectiontitle>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\item texte de l'article
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\item[<var>étiquette optionnelle</var>] texte de l'article
</pre></example>

<para>Un entrée dans une liste.  Les entrées sont préfixées par une étiquette,
dont la valeur par défaut dépend du type de liste.
</para>
<para>Parce que l&textrsquo;argument optionnel <var>étiquette optionnelle</var> est entouré
de crochets (<code>[</code> et <code>]</code>), pour utiliser des crochets au
sein de l&textrsquo;argument optionnel vous devez les cacher entre accolades, comme
dans <code>\item[Crochet fermant, &lbrace;]&rbrace;]</code>.  De même, pour utiliser un
crochet ouvrant comme premier caractère du texte d&textrsquo;un article, cachez le
aussi au sein d&textrsquo;accolade.  <xref label="LaTeX-command-syntax"><xrefnodename>&latex; command syntax</xrefnodename></xref>.
</para>
<para>Dans cet exemple la liste <code>enumerate</code> a deux articles qui utilise
l&textrsquo;étiquette par défaut et une qui utilise l&textrsquo;étiquette optionnelle.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;enumerate&rbrace;
  \item Moe
  \item[sometimes] Shemp
  \item Larry
\end&lbrace;enumerate&rbrace;
</pre></example>

<para>Le premier article est étiqueté <samp>1.</samp>, le deuxième article est
étiqueté <samp>sometimes</samp>, et le troisième article est étiqueté
<samp>2.</samp> (notez que, à cause de l&textrsquo;étiquette optionnelle dans le second
article, le troisième article ne reçoit pas l&textrsquo;étiquette <samp>3.</samp>).
</para>
</subsection>
<node name="trivlist" spaces=" "><nodename>trivlist</nodename><nodeprev automatic="on">\item</nodeprev><nodeup automatic="on">list</nodeup></node>
<subsection spaces=" "><sectiontitle><code>trivlist</code>: Une forme restreinte de <code>list</code></sectiontitle>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;trivlist&rbrace;
  ...
\end&lbrace;trivlist&rbrace;
</pre></example>

<para>Une version restreinte de l&textrsquo;environnement <code>list</code> dans laquelle les
marges sont sans renfoncement et <code>\item</code> sans l&textrsquo;argument optionnel
ne produit pas de texte.  Elle est utilisée le plus souvent au sein de
macros, de sorte à définir un environnement où la commande <code>\item</code>
fait partie de la définition de l&textrsquo;environnement.  Par exemple,
l&textrsquo;environnement <code>center</code> est défini pour l&textrsquo;essentiel comme ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newenvironment&lbrace;center&rbrace;
  &lbrace;\begin&lbrace;trivlist&rbrace;\centering\item\relax&rbrace;
  &lbrace;\end&lbrace;trivlist&rbrace;&rbrace;
</pre></example>

<para>Utiliser <code>trivlist</code> de la sorte permet à la macro d&textrsquo;hériter du code
mutualisé : combiner l&textrsquo;espace vertical provenant de deux environnements
adjacents ; détecter si le texte suivant l&textrsquo;environnement doit être
considéré comme un nouveau paragraphe ou la suite du paragraphe
précédent ; ajuster les marges de gauche et de droit pour d&textrsquo;éventuels
environnements de liste imbriqués.
</para>
<para>En particulier, <code>trivlist</code> utilise les valeurs courantes des
paramètres de liste (<pxref label="list"><xrefnodename>list</xrefnodename></pxref>), à ceci près que <code>\parsep</code> est
réglé à la valeur de <code>\parskip</code>, et que <code>\leftmargin</code>,
<code>\labelwidth</code>, et <code>\itemindent</code> sont réglés à zéro.
</para>
<para>Cet exemple produit les articles comme deux paragraphes, à ceci près que
(par défaut) ils n&textrsquo;ont pas de renfoncement de paragraphe et sont séparés
verticalement.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;trivlist&rbrace;
\item C'est un fameux trois-mâts, fin comme un oiseau
\item Hisse et ho, Santiano.
\end&lbrace;trivlist&rbrace;
</pre></example>

</subsection>
</section>
<node name="math" spaces=" "><nodename>math</nodename><nodenext automatic="on">minipage</nodenext><nodeprev automatic="on">list</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>math</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="448"><r>environnement</r> <code>math</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="449"><code>math</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="281">formules en ligne</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;math&rbrace;
<var>maths</var>
\end&lbrace;math&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="450">$ <r>en ligne, math</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="451">\(...\) <r>en ligne, math</r></indexterm></findex>
<para>L&textrsquo;environnement <code>math</code> insère les <var>maths</var> donnés au sein du
texte en cours. <code>\(...\))</code> et <code>$...$</code> sont des synonymes.
<xref label="Math-formulas"><xrefnodename>Math formulas</xrefnodename></xref>.
</para>
</section>
<node name="minipage" spaces=" "><nodename>minipage</nodename><nodenext automatic="on">picture</nodenext><nodeprev automatic="on">math</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>minipage</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="452"><r>environnement</r> <code>minipage</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="453"><code>minipage</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="282">minipage, créer une</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;minipage&rbrace;&lbrace;<var>largeur</var>&rbrace;
  <var>matière</var>
\end&lbrace;minipage&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;minipage&rbrace;[<var>position</var>][<var>hauteur</var>][<var>pos-interne</var>]&lbrace;<var>largeur</var>&rbrace;
<var>matière</var>
\end&lbrace;minipage&rbrace;
</pre></example>

<para>Place <var>matière</var> dans une boîte qui est <var>largeur</var> de large. C&textrsquo;est
comme une version réduite d&textrsquo;une page ; elle peut contenir ses propres
notes en bas de page, listes à puces, etc. (Il y a quelques
restrictions, notamment qu&textrsquo;elle ne peut pas avoir de flottants). Cette
boîte ne peut pas être coupée sur plusieurs pages. Ainsi <code>minipage</code>
est similaire à la commande <code>\parbox</code> (<pxref label="_005cparbox"><xrefnodename>\parbox</xrefnodename></pxref>), mais
contrairement à <code>\parbox</code>, d&textrsquo;autres environnements de production de
paragraphe peuvent être utilisés au sein d&textrsquo;une minipage.
</para>
<para>Cet exemple fait 7,5cm de large, et comprend deux paragraphes.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;minipage&rbrace;&lbrace;7.5cm&rbrace;
  Stephen Kleene fut un fondateur de la théorie de la récursivité.

  Il fut l'élève de Church, l'auteur de trois textes qui firent
  autorité, et le président de l'Association for Symbolic Logic, et il
  fut récompensé par la National Medal of Science.
 \end&lbrace;minipage&rbrace;
</pre></example>

<noindent></noindent>
<para>Voir plus bas pour une discussion sur le renfoncement de paragraphe au
sein d&textrsquo;une <code>minipage</code>.
</para>
<para>L&textrsquo;argument obligatoire <var>largeur</var> est une longueur rigide (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).
Il donne la largeur de la boîte dans laquelle <var>matière</var> est composée.
</para>
<para>Il y a trois arguments optionnels, <var>position</var>, <var>hauteur</var>, et
<var>pos-interne</var>.  Il n&textrsquo;est pas nécessaire de fournir les trois à la
fois. Par exemple, obtenez les valeurs par défaut pour <var>position</var> et
réglez <var>hauteur</var> avec
<code>\begin&lbrace;minipage&rbrace;[c][2.54cm]&lbrace;\columnwidth&rbrace; <var>matière</var>
\end&lbrace;minipage&rbrace;</code>.  (Obtenez la hauteur naturelle avec un argument vide,
<code>[]</code>).
</para>
<para>L&textrsquo;argument optionnel <var>position</var> gouverne la façon dont la
<code>minipage</code> s&textrsquo;aligne verticalement avec la matière l&textrsquo;entourant.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">c</itemformat></item>
</tableterm><tableitem><!-- c xx Clarify what it means when adjacent text lines do not have aligned -->
<!-- c vertical center with each other -->
<para>(Synonyme <code>m</code>) Valeur par défaut.  Positionne la <code>minipage</code> de
sorte que son centre vertical soit aligné avec le centre des lignes de
texte adjacentes.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">t</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="454">\vtop <r>&tex; de base</r></indexterm></findex>
<para>Aligne la ligne du haut de la <code>minipage</code> sur la ligne de base du
texte l&textrsquo;entourant (comme <code>\vtop</code> en &tex; de base).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">b</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="455">\vbox <r>&tex; de base</r></indexterm></findex>
<para>Aligne la ligne du bas de <code>minipage</code> avec la ligne de base du texte
l&textrsquo;entourant (comme <code>\vbox</code> en &tex; de base).
</para></tableitem></tableentry></table>

<para>Pour voir l&textrsquo;effet de ces options, comparez le résultat de la compilation de
</para>
<example endspaces=" ">
<pre xml:space="preserve">---\begin&lbrace;minipage&rbrace;[c]&lbrace;0.25in&rbrace;
  first\\ second\\ third
\end&lbrace;minipage&rbrace;
</pre></example>

<noindent></noindent>
<para>avec ce qui se passe en remplaçant <code>c</code> par <code>b</code> ou <code>t</code>.
</para>
<para>L&textrsquo;argument optionnel <var>hauteur</var> est une longueur rigide
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).  Il règle la hauteur de la <code>minipage</code>.  Vous
pouvez donner n&textrsquo;importe quelle valeur supérieure, égale ou inférieure à
la hauteur naturelle de la <code>minipage</code> sans que &latex; ne produise
une erreur ou un avertissement.  Vous pouvez aussi la régler à une
hauteur de valeur nulle ou négative.
</para>
<para>L&textrsquo;argument optionnel final <var>pos-interne</var> contrôle la disposition de
<var>matière</var> au sein de la boîte. Voici les valeurs possibles (la
valeur par défaut est la valeur de l&textrsquo;argument <var>position</var>).
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">t</itemformat></item>
</tableterm><tableitem><para>Place <var>matière</var> en haut de la boîte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">c</itemformat></item>
</tableterm><tableitem><para>Centre <var>matière</var> verticalement.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">b</itemformat></item>
</tableterm><tableitem><para>Place <var>matière</var> en bas de la boîte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">s</itemformat></item>
</tableterm><tableitem><para>Dilate <var>matière</var> verticalement ; elle doit contenir de l&textrsquo;espace
dilatable verticalement.
</para>
</tableitem></tableentry></table>

<para>L&textrsquo;argument <var>pos-interne</var> a un sens quand l&textrsquo;option <var>hauteur</var> est
réglée à une valeur supérieure à la hauteur naturelle de la
<code>minipage</code>.  Pour voir l&textrsquo;effet des options, exécutez l&textrsquo;exemple
suivant avec les différents choix possibles au lieu de <code>b</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Texte avant
\begin&lbrace;center&rbrace;
  ---\begin&lbrace;minipage&rbrace;[c][8cm][b]&lbrace;0.25\textwidth&rbrace;
       premier\\ deuxième\\ troisième
  \end&lbrace;minipage&rbrace;
\end&lbrace;center&rbrace;
Texte après
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="283">renfoncement des paragraphes, au sein d&textrsquo;une minipage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="284">paragraphes, renfoncement au sein d&textrsquo;une minipage</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="456">\parindent</indexterm></findex>
<para>Par défaut, les paragraphes ne sont pas renfoncés au sein d&textrsquo;un
environnement <code>minipage</code>. Vous pouvez restaurer le renfoncement
avec une commande telle que <code>\setlength&lbrace;\parindent&rbrace;&lbrace;1pc&rbrace;</code> placé
au début de <var>matière</var>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="285">notes en bas de page au sein des figures</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="286">figures, notes en bas de page au sein des</indexterm></cindex>
<para>Les notes en bas de page au sein d&textrsquo;un environnement <code>minipage</code> sont
gérées d&textrsquo;une façon qui est particulièrement utile pour mettre des notes
en bas de page dans des figures ou des tableaux. Une commande
<code>\footnote</code>  ou <code>\footnotetext</code> met la note en bas de page au bas
de la minipage au lieu de la mettre au bas de la page, et elle utilise
le compteur <code>\mpfootnote</code> au lieu du compteur ordinaire
<code>footnote</code> (<pxref label="Counters"><xrefnodename>Counters</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple ci-dessous place la note argument de <code>\footnote</code> en bas
de la table, et non en bas de la page.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;           % centre la minipage sur la ligne
\begin&lbrace;minipage&rbrace;&lbrace;6.5cm&rbrace;
  \begin&lbrace;center&rbrace;         % centre la table au sein de la minipage
    \begin&lbrace;tabular&rbrace;&lbrace;ll&rbrace;
      \textsc&lbrace;Monarque&rbrace;  &amp;\textsc&lbrace;Règne&rbrace;             \\ \hline
      Elizabeth II      &amp;63 ans\footnote&lbrace;à ce jour&rbrace; \\
      Victoria          &amp;63 ans                   \\
      George III        &amp;59 ans
    \end&lbrace;tabular&rbrace;
  \end&lbrace;center&rbrace;
\end&lbrace;minipage&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<para>Si vous imbriquez des minipages, alors il y a une bizarrerie dans
l&textrsquo;utilisation des notes <code>\footnote</code>. Les notes apparaissent au bas
du texte terminé par la prochaine <code>\end&lbrace;minipage&rbrace;</code> ce qui n&textrsquo;est
peut-être pas leur place logique.
</para>
<para>L&textrsquo;exemple suivant place un tableau de données côte à côte d&textrsquo;un
graphique. Ils sont verticalement centrés.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="457"><r>paquetage</r> <code>siunitx</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="458"><code>siunitx</code>, <r>paquetage</r></indexterm></findex>

<example endspaces=" ">
<pre xml:space="preserve">% siunitx permet d'avoir le type de colonne S dans les tableaux,
% pour l'alignement sur le séparateur décimal, réglé comme virgule.
\usepackage[output-decimal-marker=&lbrace;,&rbrace;]&lbrace;siunitx&rbrace;
\newcommand*&lbrace;\vcenteredhbox&rbrace;[1]&lbrace;\begin&lbrace;tabular&rbrace;&lbrace;&arobase;&lbrace;&rbrace;c&arobase;&lbrace;&rbrace;&rbrace;#1\end&lbrace;tabular&rbrace;&rbrace;
  ...
\begin&lbrace;center&rbrace;
  \vcenteredhbox&lbrace;\includegraphics[width=0.3\textwidth]&lbrace;nyc.png&rbrace;&rbrace;
  \hspace&lbrace;0.1\textwidth&rbrace;
  \begin&lbrace;minipage&rbrace;&lbrace;0.5\textwidth&rbrace;
    \begin&lbrace;tabular&rbrace;&lbrace;r|S&rbrace;
      % \multicolumn pour supprimer la barre verticale entre les titres
      % de colonnes
      \multicolumn&lbrace;1&rbrace;&lbrace;r&rbrace;&lbrace;Quartier&rbrace; &amp;
      % les accolades empêchent siunitx de voir le point comme un
      % séparateur décimal
      &lbrace;Pop. (million)&rbrace;  \\ \hline
      The Bronx      &amp;1.5  \\
      Brooklyn       &amp;2.6  \\
      Manhattan      &amp;1.6  \\
      Queens         &amp;2.3  \\
      Staten Island  &amp;0.5
    \end&lbrace;tabular&rbrace;
  \end&lbrace;minipage&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

</section>
<node name="picture" spaces=" "><nodename>picture</nodename><nodenext automatic="on">quotation &amp; quote</nodenext><nodeprev automatic="on">minipage</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>picture</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="459"><r>environnement</r> <code>picture</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="460"><code>picture</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="287">créer des images</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="288">images, créer</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;picture&rbrace;(<var>largeur</var>,<var>hauteur</var>)
   <var>commande picture</var>
\end&lbrace;picture&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;picture&rbrace;(<var>largeur</var>,<var>hauteur</var>)(<var>décalagex</var>,<var>décalagey</var>)
  <var>commande picture</var>
\end&lbrace;picture&rbrace;
</pre></example>

<noindent></noindent>
<para>où on a autant de <var>commande picture</var>(s) qu&textrsquo;on le désire.
</para>
<para>L&textrsquo;environnement <code>picture</code> vous permet de créer des dessins simples
contenant des lignes, des flèches, des boîtes, des cercles, et du texte.
Cet environnement n&textrsquo;est pas obsolète, mais les nouveaux documents
utilisent typiquement des systèmes de création de graphiques bien plus
puissants tels que TikZ, PStricks, MetaPost, ou Asymptote. Aucun de
ceux-ci n&textrsquo;est couvert dans ce document ; voir le CTAN.
</para>
<para>Pour commencer, voici un exemple illustrant la méthode du parallélogramme
pour additionner deux vecteurs.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="461">\unitlength</indexterm></findex>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\unitlength&rbrace;&lbrace;1cm&rbrace;
\begin&lbrace;picture&rbrace;(6,6)  % la boîte de l'image fera 6cm de large sur 6cm
                      % de haut
  \put(0,0)&lbrace;\vector(2,1)&lbrace;4&rbrace;&rbrace;  % la pente du vecteur est de 1/2
    \put(2,1)&lbrace;\makebox(0,0)[l]&lbrace;\ premier terme&rbrace;&rbrace;
  \put(4,2)&lbrace;\vector(1,2)&lbrace;2&rbrace;&rbrace;
    \put(5,4)&lbrace;\makebox(0,0)[l]&lbrace;\ second terme&rbrace;&rbrace;
  \put(0,0)&lbrace;\vector(1,1)&lbrace;6&rbrace;&rbrace;
    \put(3,3)&lbrace;\makebox(0,0)[r]&lbrace;somme\ &rbrace;&rbrace;
\end&lbrace;picture&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>picture</code> a un argument obligatoire qui est une
paire de nombres réels positifs (<var>largeur</var>,<var>hauteur</var>).
<!-- c { Dans la version française seulement -->
Le point est utilisé comme séparateur décimal quand ils ne sont pas
entiers.
<!-- c } -->
En les multipliant par <code>\unitlength</code> on obtient la taille nominale
de la sortie, c.-à-d.&noeos; l&textrsquo;espace que &latex; réserve sur la page en
sortie. Cette taille nominale n&textrsquo;est pas nécessairement la taille réelle
de l&textrsquo;image ; &latex; dessine aussi les parties de l&textrsquo;image en dehors de
la boîte de l&textrsquo;image.
</para>
<para>L&textrsquo;environnement <code>picture</code> a aussi un argument optionnel
(<var>décalagex</var>,<var>décalagey</var>). Il sert à décaler l&textrsquo;origine.
Contrairement aux arguments optionnels ordinaires, cet argument n&textrsquo;est
pas contenu entre crochets. Comme pour l&textrsquo;argument obligatoire, c&textrsquo;est une
paire de deux nombres. En les multipliant par <code>\unitlength</code> on
obtient les coordonnées du point situé dans le coin inférieur gauche de
l&textrsquo;image.
</para>
<para>Par exemple, si <code>\unitlength</code> a été réglée à <code>1mm</code>, la
commande
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;picture&rbrace;(100,200)(10,20)
</pre></example>

<noindent></noindent><para>produit un dessin de largeur 100 millimètres et hauteur 200
millimètres. Son origine est le point (10mm,20mm) et donc le coin
inférieur gauche est là, et le coin supérieur droit est à (110mm,220mm).
Lorsque vous tracez un dessin, typiquement vous omettez l&textrsquo;argument
optionnel, laissant l&textrsquo;origine au coin inférieur gauche. Si ensuite vous
voulez modifier le dessin en translatant tout, vous pouvez juste ajouter
l&textrsquo;argument optionnel approprié.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="289">position dans picture</indexterm></cindex>
<para>Chaque <var>commande picture</var> dit à &latex; où placer quelque chose en
donnant sa position. Une <dfn>position</dfn> est une paire telle que
<code>(2.4,-5)</code> donnant les coordonnées en x et en y. Une
<dfn>coordonnée</dfn> n&textrsquo;est pas une longueur, c&textrsquo;est un nombre réel (il
utilise le point <samp>.</samp> comme séparateur décimal et peut avoir un
signe moins). Elle spécifie une longueur en termes de la longueur unité
<code>\unitlength</code>, de sorte que si <code>\unitlength</code> a été réglée à
<code>1cm</code>, alors la coordonnées <samp>2.54</samp> spécifie une longueur de
2,54 centimètres.
</para>
<para>La valeur par défaut de &latex; pour <code>\unitlength</code> est
<code>1pt</code>. C&textrsquo;est une longueur rigide (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). Utilisez la
commande <code>\setlength</code> pour la modifier
(<pxref label="_005csetlength"><xrefnodename>\setlength</xrefnodename></pxref>). Effectuez ce changement uniquement en dehors de
l&textrsquo;environnement <code>picture</code>.
</para>
<para>L&textrsquo;environnement <code>picture</code> prend en charge les expressions
arithmétiques standardes en plus des nombres.
</para>
<para>Les coordonnées sont données relativement à une origine, qui est par
défaut au coin en bas à gauche de l&textrsquo;image. Notez que lorsque une
position apparaît en tant qu&textrsquo;argument, comme dans
<code>\put(1,2)&lbrace;...&rbrace;</code>, elle n&textrsquo;est pas entourées d&textrsquo;accolades puisque
les parenthèses servent à délimiter l&textrsquo;argument. De même, contrairement à
certains systèmes de dessin par ordinateur, l&textrsquo;axe des ordonnées y est
orienté vers le haut de la page, par ex.&noeos; <math>y = 1</math> est
<emph>au-dessus</emph> de <math>y = 0</math>.
</para>
<para>Il y a quatre manières de placer des choses dans une image : <code>\put</code>,
<code>\multiput</code>, <code>\qbezier</code>, et <code>\graphpaper</code>.  La plus
utilisée est <code>\put</code>. Le code suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">\put (11.3,-0.3)&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>met l&textrsquo;objet spécifié par <code>...</code> dans le dessin <code>picture</code>, avec
son point de référence aux coordonnées <math>(11.3,-0.3)</math>.  Les points de
référence des divers objets sont décrits plus bas.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="462">LR box</indexterm></findex>
<para>La commande <code>\put</code> crée une <dfn>LR box</dfn> (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).  Vous
pouvez mettre tout ce qui peut aller dans une <code>\mbox</code> (<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox
&amp; \makebox</xrefnodename></pxref>) dans l&textrsquo;argument texte de la commande <code>\put</code>.  Quand
vous faites cela, le point de référence devient le coin inférieur gauche
de la boîte. Dans cette image :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\unitlength&rbrace;&lbrace;1cm&rbrace;
...\begin&lbrace;picture&rbrace;(1,1)
  \put(0,0)&lbrace;\line(1,0)&lbrace;1&rbrace;&rbrace;
  \put(0,0)&lbrace;\line(1,1)&lbrace;1&rbrace;&rbrace;
\end&lbrace;picture&rbrace;
</pre></example>

<noindent></noindent>
<para>les trois points sont juste légèrement à la gauche du point où les deux
lignes forment un angle.  (À noter aussi que <code>\line(1,1)&lbrace;1&rbrace;</code> ne
demande pas une ligne de longueur un, mais une ligne dont l&textrsquo;étendue
selon la coordonnée x est de 1).
</para>
<para>Les commandes <code>\multiput</code>, <code>qbezier</code>, et <code>graphpaper</code> sont
décrites plus bas.
</para>
<para>Vous pouvez également utiliser cet environnement pour placer une matière
quelconque à un emplacement exact. Par exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;color,graphicx&rbrace;  % dans le préambule
  ...
\begin&lbrace;center&rbrace;
\setlength&lbrace;\unitlength&rbrace;&lbrace;\textwidth&rbrace;
\begin&lbrace;picture&rbrace;(1,1)   % réserve un espace large et haut de \textwidth
  \put(0,0)&lbrace;\includegraphics[width=\textwidth]&lbrace;desertedisland.jpg&rbrace;&rbrace;
  \put(0.25,0.35)&lbrace;\textcolor&lbrace;red&rbrace;&lbrace;X Trésor ici&rbrace;&rbrace;
\end&lbrace;picture&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<noindent></noindent>
<para>Le X rouge sera précisément à un quart de <code>\textwidth</code> à droite de
la marge de gauche, et <code>0.35\textwidth</code> au dessus du bas de
l&textrsquo;image.  Un autre exemple de cette utilisation est de placer un code
similaire dans l&textrsquo;en-tête de page pour obtenir une matière répétée sur
chaque page.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\put</menunode><menudescription><pre xml:space="preserve">Place un objet à un endroit spécifié.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\multiput</menunode><menudescription><pre xml:space="preserve">Dessine plusieurs instances d&textrsquo;un objet.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\qbezier</menunode><menudescription><pre xml:space="preserve">Dessine un courbe de Bézier quadratique.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\graphpaper</menunode><menudescription><pre xml:space="preserve">Dessine un quadrillage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\line</menunode><menudescription><pre xml:space="preserve">Dessine une ligne droite.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\linethickness</menunode><menudescription><pre xml:space="preserve">Règle l&textrsquo;épaisseur des lignes horizontales et verticales.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\thinlines</menunode><menudescription><pre xml:space="preserve">L&textrsquo;épaisseur de ligne par défaut.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\thicklines</menunode><menudescription><pre xml:space="preserve">Une plus grosse épaisseur de ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\circle</menunode><menudescription><pre xml:space="preserve">Dessine un cercle.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\oval</menunode><menudescription><pre xml:space="preserve">Dessine un ovale.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\shortstack</menunode><menudescription><pre xml:space="preserve">Empile plusieurs objets.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\vector</menunode><menudescription><pre xml:space="preserve">Dessine une ligne flèchée.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\makebox (picture)</menunode><menudescription><pre xml:space="preserve">Dessine une boîte de la taille spécifiée.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\framebox (picture)</menunode><menudescription><pre xml:space="preserve">Dessine une boîte avec un cadre autour.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\frame</menunode><menudescription><pre xml:space="preserve">Dessine un cadre autour d&textrsquo;un objet.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\dashbox</menunode><menudescription><pre xml:space="preserve">Dessine une boîte en tiretés.
</pre></menudescription></menuentry></menu>

<ignore>
@findex \unitlength
Vous dîtes à @LaTeX{} où mettre les choses dans le dessin en spécifiant
leur coordonnées. Une coordonnée est un nombre qui peut avoir une
séparateur décimal (point et non virgule) et un signe moins --- un
nombre comme @code{5}, @code{0.3} ou @code{-3.1416}.  Une coordonnées
spécifie une longueur en multiples de l'unité de longueur
@code{\unitlength}, ainsi si @code{\unitlength} a été réglée à
@code{1cm}, alors la coordonnée 2.54 spécifie une longueur de 2,54
centimètres.

Vous devriez changer la valeur de @code{\unitlength}, en utilisant la
commande @code{\setlength}, en dehors d'un environnement
@code{picture}. La valeur par défaut est @code{1pt}.

@PkgIndex{picture}
Le paquetage @package{picture} redéfinit l'environnement @code{picture} de
sorte qu'où que soit utilisé un nombre au sein de @var{commandes picture}
pour spécifier une coordonnée, on puisse alternativement utiliser une
longueur. Notez bien cependant que ceci empêche de dilater/contracter
ces longueurs en changeant @code{\unitlength}.

@cindex position, dans un dessin @code{picture}
Une @dfn{position} est une paire de coordonnées, telle que
@code{(2.4,-5)}, ce qui spécifie un point d'abscisse @code{2.4} et
d'ordonnée @code{-5}.  Les coordonnées sont spécifiées de la manière
habituelle relativement à une origine, qui est normalement dans le coin
inférieur gauche du dessin. Notez que lorsque une position apparaît en
argument, elle n'est pas entourée d'accolades ; on délimite l'argument
avec des parenthèses.

</ignore>

<node name="_005cput" spaces=" "><nodename>\put</nodename><nodenext automatic="on">\multiput</nodenext><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\put</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="463">\put</indexterm></findex>

<para><code>\put(<var>xcoord</var>,<var>ycoord</var>)&lbrace;<var>contenu</var>&rbrace;</code>
</para>
<para>La commande <code>\put</code> place <var>contenu</var> aux coordonnées
(<var>xcoord</var>,<var>ycoord</var>). Voir la discussion sur les coordonnées et
<code>\unitlength</code> dans <ref label="picture"><xrefnodename>picture</xrefnodename></ref>. Le <var>contenu</var> est traité en
mode LR (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>) de sorte qu&textrsquo;il ne peut pas contenir de sauts de
ligne.
</para>
<para>L&textrsquo;exemple ci-dessous inclut le texte dans le dessin <code>picture</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\put(4.5,2.5)&lbrace;Faire la manœuvre de \textit&lbrace;retrait&rbrace;&rbrace;
</pre></example>

<para>Le point de référence, la position (4.5,2.5), est le point en bas à
gauche de texte, au coin en bas à gauche du <samp>F</samp>.
</para>

</subsection>
<node name="_005cmultiput" spaces=" "><nodename>\multiput</nodename><nodenext automatic="on">\qbezier</nodenext><nodeprev automatic="on">\put</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\multiput</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="464">\multiput</indexterm></findex>

<para>Synopsis :
</para><example endspaces=" ">
<pre xml:space="preserve">\multiput(<var>x</var>,<var>y</var>)(<var>delta_x</var>,<var>delta_y</var>)&lbrace;<var>nbre-copies</var>&rbrace;&lbrace;<var>obj</var>&rbrace;
</pre></example>

<para>La commande <code>\multiput</code> copie l&textrsquo;objet <var>obj</var> en tout
<var>nbre-copies</var> fois, avec un incrément de <var>delta_x,delta_y</var>. Le
<var>obj</var> est placé en premier à la position <math>(x,y)</math>, puis à la
position <math>(x+\delta x,y+\delta y)</math>, et ainsi de suite.
</para>
<para>L&textrsquo;exemple ci-dessous dessine une grille simple avec une ligne sur cinq en
gras (voir aussi <ref label="_005cgraphpaper"><xrefnodename>\graphpaper</xrefnodename></ref>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;picture&rbrace;(10,10)
  \linethickness&lbrace;0.05mm&rbrace;
  \multiput(0,0)(1,0)&lbrace;10&rbrace;&lbrace;\line(0,1)&lbrace;10&rbrace;&rbrace; 
  \multiput(0,0)(0,1)&lbrace;10&rbrace;&lbrace;\line(1,0)&lbrace;10&rbrace;&rbrace;
  \linethickness&lbrace;0.5mm&rbrace;
  \multiput(0,0)(5,0)&lbrace;3&rbrace;&lbrace;\line(0,1)&lbrace;10&rbrace;&rbrace;
  \multiput(0,0)(0,5)&lbrace;3&rbrace;&lbrace;\line(1,0)&lbrace;10&rbrace;&rbrace;
\end&lbrace;picture&rbrace;
</pre></example>


</subsection>
<node name="_005cqbezier" spaces=" "><nodename>\qbezier</nodename><nodenext automatic="on">\graphpaper</nodenext><nodeprev automatic="on">\multiput</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\qbezier</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="465">\qbezier</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\qbezier(<var>x1</var>,<var>y1</var>)(<var>x2</var>,<var>y2</var>)(<var>x3</var>,<var>y3</var>)
\qbezier[<var>quant</var>](<var>x1</var>,<var>y1</var>)(<var>x2</var>,<var>y2</var>)(<var>x3</var>,<var>y3</var>)
</pre></example>

<para>Dessine une courbe de Bézier quadratique dont les points de contrôle
sont donnés par les trois arguments obligatoires
<code>(<var>x1</var>,<var>y1</var>)</code>, <code>(<var>x2</var>,<var>y2</var>)</code>, et
<code>(<var>x3</var>,<var>y3</var>)</code>.  c.-à-d.&noeos; que la courbe va de <var>(x1,y1)</var>
à <var>(x3,y3)</var>, est quadratique, et est telle que la tangente en
<var>(x1,y1)</var> passe par <var>(x2,y2)</var>, et de même pour la tangente en
<var>(x3,y3)</var>.
</para>
<para>L&textrsquo;exemple suivant dessine une courbe des coordonnées (1,1) à (1,0).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\qbezier(1,1)(1.25,0.75)(1,0)
</pre></example>

<noindent></noindent>
<para>La tangente de la courbe en (1,1) passe par (1.25,0.75), et la tangente
en (1,0) fait de même.
</para>
<para>L&textrsquo;argument optionnel <var>quant</var> donne le nombre de points
intermédiaires calculés.  Par défaut la commande dessine une courbe
lisse dont le nombre maximum de points est <code>\qbeziermax</code> (on change
cette valeur avec <code>\renewcommand</code>).
</para>
<para>L&textrsquo;exemple suivant dessine un rectangle avec un haut ondulé, en
utilisant <code>\qbezier</code> pour cette courbe.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;picture&rbrace;(8,4)
  \put(0,0)&lbrace;\vector(1,0)&lbrace;8&rbrace;&rbrace;  % axe des x
  \put(0,0)&lbrace;\vector(0,1)&lbrace;4&rbrace;&rbrace;  % axe des y
  \put(2,0)&lbrace;\line(0,1)&lbrace;3&rbrace;&rbrace;       % côté gauche
  \put(4,0)&lbrace;\line(0,1)&lbrace;3.5&rbrace;&rbrace;     % côté droit
  \qbezier(2,3)(2.5,2.9)(3,3.25)
    \qbezier(3,3.25)(3.5,3.6)(4,3.5)
  \thicklines  % ci-dessous, les lignes sont deux fois plus épaisses
  \put(2,3)&lbrace;\line(4,1)&lbrace;2&rbrace;&rbrace;
  \put(4.5,2.5)&lbrace;\framebox&lbrace;Méthode des trapèzes&rbrace;&rbrace;
\end&lbrace;picture&rbrace;
</pre></example>

</subsection>
<node name="_005cgraphpaper" spaces=" "><nodename>\graphpaper</nodename><nodenext automatic="on">\line</nodenext><nodeprev automatic="on">\qbezier</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\graphpaper</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="466">\graphpaper</indexterm></findex>
<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\graphpaper(<var>x_init</var>,<var>y_init</var>)(<var>x_dimen</var>,<var>y_dimen</var>)
\graphpaper[<var>espacement</var>](<var>x_init</var>,<var>y_init</var>)(<var>x_dimen</var>,<var>y_dimen</var>)
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="467"><r>paquetage</r> <code>graphpap</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="468"><code>graphpap</code>, <r>paquetage</r></indexterm></findex>

<para>Dessine un quadrillage.  Le paquetage <code>graphpap</code> est nécessaire.
L&textrsquo;origine du quadrillage est <code>(<var>x_init</var>,<var>y_init</var>)</code>.
Les lignes de la grille sont espacées de <var>espacement</var> unités (par défaut 10).
Le quadrillage s&textrsquo;étend sur <var>x_dimen</var> unités vers la droite et <var>y_dimen</var> vers le haut.
Tous les arguments doivent être des entiers positifs.
</para>
<para>L&textrsquo;exemple ci-dessous fait une grille avec sept lignes verticales et onze
horizontales.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;graphpap&rbrace;    % dans le préambule
  ...
\begin&lbrace;picture&rbrace;(6,20)    % dans le corps du document
  \graphpaper[2](0,0)(12,20)
\end&lbrace;picture&rbrace;
</pre></example>

<noindent></noindent>
<para>Les lignes sont numérotées toutes les dix unités.
</para>

</subsection>
<node name="_005cline" spaces=" "><nodename>\line</nodename><nodenext automatic="on">\linethickness</nodenext><nodeprev automatic="on">\graphpaper</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\line</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="469">\line</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\line(<var>x_avance</var>,<var>y_monte</var>)&lbrace;<var>excursion</var>&rbrace;
</pre></example>

<para>Dessine une ligne. Sa pente est telle que la ligne monte de <var>y_monte</var>
verticalement pour toute avancée horizontale de
<var>x_avance</var>. L&textrsquo;<var>excursion</var> est le déplacement horizontal total &textmdash;
ce n&textrsquo;est pas la longueur du vecteur, mais la variation en <math>x</math>. Dans
le cas spécial des lignes verticales, où (<var>x_avance</var>,<var>y_monte</var>)=(0,1),
l&textrsquo;<var>excursion</var> donne le déplacement en <math>y</math>.
</para>
<para>L&textrsquo;exemple suivant dessine une ligne commençant aux coordonnées (1,3).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\put(1,3)&lbrace;\line(2,5)&lbrace;4&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Pour toute avancée de 2 vers la droite, cette ligne monte de 5.  Parce
que <var>excursion</var> spécifie qu&textrsquo;elle avance de 4, elle monte en tout
de 10.  De sorte que son extrémité finale est
<math>(1,3)+(4,10)=(5,13)</math>.  En particulier, notez que
<math><var>excursion</var>=4</math> n&textrsquo;est pas la longueur de la ligne, mais c&textrsquo;est
son déplacement en <math>x</math>.
</para>
<para>Les arguments <var>x_avance</var> et <var>y_monte</var> sont des entiers qui
peuvent être positifs, négatifs, ou nuls (si les deux valent 0, alors
&latex; traite le second comme 1).  Avec
<code>\put(<var>x_init</var>,<var>y_init</var>)&lbrace;\line(<var>x_avance</var>,<var>y_monte</var>)&lbrace;<var>travel</var>&rbrace;&rbrace;</code>,
si <var>x_avance</var> est négatif alors l&textrsquo;extrémité finale de la ligne a sa
première coordonnée inférieure à <var>x_init</var>.  Si <var>y_monte</var> est
négatif alors l&textrsquo;extrémité finale a sa seconde coordonnées inférieure à
<var>y_init</var>.
</para>
<para>Si <var>excursion</var> est négatif alors vous obtenez <code>LaTeX Error: Bad \line or
\vector argument.</code>
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="290">graphiques, paquetages</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="470"><r>paquetage</r> <code>pict2e</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="471"><code>pict2e</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="472"><r>paquetage</r> <code>TikZ</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="473"><code>TikZ</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="474"><r>paquetage</r> <code>PSTricks</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="475"><code>PSTricks</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="476"><r>paquetage</r> <code>MetaPost</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="477"><code>MetaPost</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="478"><r>paquetage</r> <code>Asymptote</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="479"><code>Asymptote</code>, <r>paquetage</r></indexterm></findex>

<para>De base &latex; peut seulement dessiner des lignes avec une plage
limitée de pentes parce que ces lignes sont constituées par la
juxtaposition de petits segments de droite issus de polices
préfabriquées. Les deux nombres <var>x_avance</var> et <var>y_monte</var> prennent
des valeurs entières de &minus;6 jusqu&textrsquo;à 6. De plus ils doivent être
premiers entre eux, de sorte que (<var>x_avance</var>, <var>y_monte</var>)=(2,1) est
licite, mais pas (<var>x_avance</var>, <var>y_monte</var>)=(4,2) (is vous choisissez
cette dernière forme alors au lieu de lignes vous obtiendrez des
séquences de têtes de flèches ; la solution est de revenir à la première
forme).  Pour obtenir des lignes de pente arbitraire et plein d&textrsquo;autres
formes dans un système tel que <code>picture</code>, voir le paquetage
<code>pict2e</code> (<url><urefurl>https://ctan.org/pkg/pict2e</urefurl></url>).  Une autre solution
est d&textrsquo;utiliser un système graphique complet tel que TikZ, PSTricks,
MetaPost, ou Asymptote.
</para>

</subsection>
<node name="_005clinethickness" spaces=" "><nodename>\linethickness</nodename><nodenext automatic="on">\thinlines</nodenext><nodeprev automatic="on">\line</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\linethickness</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="480">\linethickness</indexterm></findex>

<para>La commande <code>\linethickness&lbrace;<var>dim</var>&rbrace;</code> déclare que l&textrsquo;épaisseur
des lignes horizontales et verticales dans un environnement
<code>picture</code> vaut <var>dim</var>, ce qui doit être une longueur positive
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).  Elle diffère de <code>\thinlines</code> et
<code>\thicklines</code> en ce qu&textrsquo;elle n&textrsquo;affecte pas l&textrsquo;épaisseur des lignes
obliques, cercles, ou ovales (<pxref label="_005coval"><xrefnodename>\oval</xrefnodename></pxref>).
</para>

</subsection>
<node name="_005cthinlines" spaces=" "><nodename>\thinlines</nodename><nodenext automatic="on">\thicklines</nodenext><nodeprev automatic="on">\linethickness</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\thinlines</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="481">\thinlines</indexterm></findex>

<para>La commande <code>\thinlines</code> déclare que l&textrsquo;épaisseur de trait des
lignes (<pxref label="_005cline"><xrefnodename>\line</xrefnodename></pxref>), cercles (<pxref label="_005ccircle"><xrefnodename>\circle</xrefnodename></pxref>) et ovales
(<pxref label="_005coval"><xrefnodename>\oval</xrefnodename></pxref>) qui suivent dans un environnement <code>picture</code> est
réglée à 0,4<dmn>pt</dmn>. C&textrsquo;est l&textrsquo;épaisseur par défaut, et donc cette
commande n&textrsquo;est nécessaire que si l&textrsquo;épaisseur a été changée par
soit <ref label="_005clinethickness"><xrefnodename>\linethickness</xrefnodename></ref>, soit <ref label="_005cthicklines"><xrefnodename>\thicklines</xrefnodename></ref>.
</para>

</subsection>
<node name="_005cthicklines" spaces=" "><nodename>\thicklines</nodename><nodenext automatic="on">\circle</nodenext><nodeprev automatic="on">\thinlines</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\thicklines</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="482">\thicklines</indexterm></findex>

<para>La commande <code>\thicklines</code> déclare que l&textrsquo;épaisseur de trait des
lignes (<pxref label="_005cline"><xrefnodename>\line</xrefnodename></pxref>), cercles (<pxref label="_005ccircle"><xrefnodename>\circle</xrefnodename></pxref>) et ovales
(<pxref label="_005coval"><xrefnodename>\oval</xrefnodename></pxref>) qui suivent dans un environnement <code>picture</code> est
réglée à 0,8<dmn>pt</dmn>. Voir aussi soit <ref label="_005clinethickness"><xrefnodename>\linethickness</xrefnodename></ref>,
soit <ref label="_005cthinlines"><xrefnodename>\thinlines</xrefnodename></ref>. Cette commande est illustrée dans l&textrsquo;exemple de la
méthode des trapèzes de <ref label="_005cqbezier"><xrefnodename>\qbezier</xrefnodename></ref>.
</para>

</subsection>
<node name="_005ccircle" spaces=" "><nodename>\circle</nodename><nodenext automatic="on">\oval</nodenext><nodeprev automatic="on">\thicklines</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\circle</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="483">\circle</indexterm></findex>

<para>Synopsis :
</para><example endspaces=" ">
<pre xml:space="preserve">\circle&lbrace;<var>diamètre</var>&rbrace;
\circle*&lbrace;<var>diamètre</var>&rbrace;
</pre></example>

<para>La commande <code>\circle</code> produit un cercle dont le diamètre est le
plus proche possible de celui spécifié. La forme étoilée (en <code>*</code>)
de la commande dessine un disque, c.-à-d.&noeos; un cercle plein.
</para>
<para>L&textrsquo;exemple suivant trace un cercle de rayon 6, centré en <code>(5,7)</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\put(5,7)&lbrace;\circle&lbrace;6&rbrace;&rbrace;
</pre></example>

<para>Les rayons disponibles pour <code>circle</code> sont, en points, les nombres
pair de 2 à 20 inclus. Pour <code>\circle*</code> ce sont tous les entiers de
1 à 15.
</para>

</subsection>
<node name="_005coval" spaces=" "><nodename>\oval</nodename><nodenext automatic="on">\shortstack</nodenext><nodeprev automatic="on">\circle</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\oval</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="484">\oval</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\oval(<var>largeur</var>,<var>hauteur</var>)[<var>portion</var>]
</pre></example>

<para>La commande <code>\oval</code> produit un rectangle aux coins arrondis,
ci-après désigné par <dfn>ovale</dfn>.  L&textrsquo;argument optionnel <var>portion</var>
vous permet de ne produire qu&textrsquo;une moitié de l&textrsquo;ovale selon ce qui suit :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">t</itemformat></item>
</tableterm><tableitem><para>sélectionne la moitié supérieure ;
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">b</itemformat></item>
</tableterm><tableitem><para>sélectionne la moitié inférieure ;
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">r</itemformat></item>
</tableterm><tableitem><para>sélectionne la moitié de droite ;
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">l</itemformat></item>
</tableterm><tableitem><para>sélectionne la moitié de gauche.
</para></tableitem></tableentry></table>

<para>Il est également possible de ne produire qu&textrsquo;un quart de l&textrsquo;ovale en
réglant <var>portion</var> à <code>tr</code>, <code>br</code>, <code>bl</code>, ou <code>tl</code>.
</para>
<para>L&textrsquo;exemple suivant dessins la moitié supérieure d&textrsquo;un ovale qui est large
de 3, et haut de 7.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\put(5,7)&lbrace;\oval(3,7)[t]&rbrace;
</pre></example>

<noindent></noindent>
<para>Le (5,7) est le centre de l&textrsquo;ovale entier, et non juste le centre de la
moitié supérieure.
</para>
<para>Ces formes ne sont pas des ellipses. Ce sont des rectangles dont les
« coins » sont fabriqués avec des quarts de cercle. Ces cercles ont un
rayon maximal de 20<dmn>pt</dmn> (<pxref label="_005ccircle"><xrefnodename>\circle</xrefnodename></pxref> pour les tailles). Ainsi
les grands ovales sont juste des cadres aux coins quelque peu arrondis.
</para>

</subsection>
<node name="_005cshortstack" spaces=" "><nodename>\shortstack</nodename><nodenext automatic="on">\vector</nodenext><nodeprev automatic="on">\oval</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\shortstack</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="485">\shortstack</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\shortstack[<var>position</var>]&lbrace;<var>ligne-1</var>\\ ...&rbrace;
</pre></example>

<para>La commande <code>\shortstack</code> produit une pile verticale d&textrsquo;objets.
</para>
<para>L&textrsquo;exemple suivant étiquette l&textrsquo;axe des <math>y</math> en écrivant le mot <samp>axe</samp> au dessus du mot <samp><math>y</math></samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\unitlength&rbrace;&lbrace;1cm&rbrace;
\begin&lbrace;picture&rbrace;(5,2.5)(-0.75,0)
   \put(0,0)&lbrace;\vector(1,0)&lbrace;4&rbrace;&rbrace;   % axe des x
   \put(0,0)&lbrace;\vector(0,1)&lbrace;2&rbrace;&rbrace;   % axe des y
   \put(-0.2,2)&lbrace;\makebox(0,0)[r]&lbrace;\shortstack[r]&lbrace;axe\\ $y$&rbrace;&rbrace;&rbrace;
\end&lbrace;picture&rbrace;
</pre></example>

<noindent></noindent>
<para>Pour une pile <code>\shortstack</code>, le point de référence est le coin
inférieur gauche de la pile.  Dans l&textrsquo;exemple plus haut la boîte
<code>\makebox</code> (<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></pxref>) met la pile fer à droite dans
une boîte de largeur nulle, de sorte qu&textrsquo;au bout du compte la pile est
située légèrement à la gauche de l&textrsquo;axe des <math>y</math>.
</para>
<para>Les positions valides sont :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">r</itemformat></item>
</tableterm><tableitem><para>Aligne les objets fer à droite
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">l</itemformat></item>
</tableterm><tableitem><para>Aligne les objets fer à gauche
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">c</itemformat></item>
</tableterm><tableitem><para>Centre les  objets (position par défaut)
</para></tableitem></tableentry></table>

<findex index="fn" spaces=" "><indexterm index="fn" number="486">\\ <r>(pour les  objets <code>\shortstack</code>)</r></indexterm></findex>
<para>Les objets sont séparés en lignes avec <code>\\</code>. « Short stack »
signifie « pile courte » en anglais : ces piles sont courtes au sens où,
contrairement à un environnement <code>tabular</code> ou <code>array</code>, dans
leur cas les lignes ne sont pas espacées d&textrsquo;un interligne
uniforme. Ainsi, dans <code>\shortstack&lbrace;X\\o\\o\\X&rbrace;</code> les première et
dernière lignes sont plus hautes que les deux du milieu, et donc
l&textrsquo;interligne entre les deux du milieu est plus petit que celui entre la
troisième et la dernière ligne. Vous pouvez ajuster les hauteurs et
profondeurs de ligne en mettant l&textrsquo;interligne habituel avec
<code>\shortstack&lbrace;X\\ \strut o\\o\\X&rbrace;</code> (<pxref label="_005cstrut"><xrefnodename>\strut</xrefnodename></pxref>), ou
explicitement, avec une boîte de largeur nulle 
<code>\shortstack&lbrace;X \\ \rule&lbrace;0pt&rbrace;&lbrace;12pt&rbrace; o\\o\\X&rbrace;</code>, ou encore en
utilisant l&textrsquo;argument optionnel de <code>\\</code>, comme dans
<code>\shortstack&lbrace;X\\[2pt] o\\o\\X&rbrace;</code>.
</para>
<para>La commande <code>\shortstack</code> est également disponible hors de
l&textrsquo;environnement <code>picture</code>.
</para>

</subsection>
<node name="_005cvector" spaces=" "><nodename>\vector</nodename><nodenext automatic="on">\makebox (picture)</nodenext><nodeprev automatic="on">\shortstack</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\vector</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="487">\vector</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\vector(<var>xpente</var>,<var>ypente</var>)&lbrace;<var>longueur</var>&rbrace;
</pre></example>

<para>La commande <code>\vector</code> dessine une ligne fléchée de la
<var>longueur</var> et direction <math>(<var>xpente</var>,<var>ypente</var>)</math>
spécifiées. Les valeurs de <math><var>xpente</var></math> et <math><var>ypente</var></math>
doivent être comprises entre &minus;4 and +4 y compris.
</para>
</subsection>
<node name="_005cmakebox-_0028picture_0029" spaces=" "><nodename>\makebox (picture)</nodename><nodenext automatic="on">\framebox (picture)</nodenext><nodeprev automatic="on">\vector</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\makebox</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="488">\makebox (<code>picture</code>)</indexterm></findex>

<para>Synopsis :
</para><example endspaces=" ">
<pre xml:space="preserve">\makebox(<var>largeur</var>,<var>hauteur</var>)[<var>position</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>La commande <code>\makebox</code> pour l&textrsquo;environnement <code>picture</code> est
similaire à la commande normale <code>\makebox</code> à ceci près que vous
devez spécifier une <var>largeur</var> et une <var>hauteur</var> implicitement
multipliés par <code>\unitlength</code>.
</para>
<para>L&textrsquo;argument optionnel, <code>[<var>position</var>]</code>, spécifie le quadrant dans
lequel votre <var>texte</var> apparaît. Vous pouvez sélectionner jusqu&textrsquo;à deux
spécificateurs parmi les suivants :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">t</itemformat></item>
</tableterm><tableitem><para>Place l&textrsquo;article au sommet du rectangle.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">b</itemformat></item>
</tableterm><tableitem><para>Place l&textrsquo;article en bas du rectangle.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">l</itemformat></item>
</tableterm><tableitem><para>Place l&textrsquo;article sur la gauche.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">r</itemformat></item>
</tableterm><tableitem><para>Place l&textrsquo;article sur la droite.
</para>
</tableitem></tableentry></table>

<para><xref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></xref>.
</para>

</subsection>
<node name="_005cframebox-_0028picture_0029" spaces=" "><nodename>\framebox (picture)</nodename><nodenext automatic="on">\frame</nodenext><nodeprev automatic="on">\makebox (picture)</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\framebox</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="489">\framebox</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\framebox(<var>largeur</var>,<var>hauteur</var>)[<var>pos</var>]&lbrace;...&rbrace;
</pre></example>

<para>La commande <code>\framebox</code> est similaire à <code>\makebox</code> (voir
section précédent), à ceci près qu&textrsquo;elle met un cadre autour de
l&textrsquo;extérieur du contenu de la boîte qu&textrsquo;elle créée.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="490">\fboxrule</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="491">\fboxsep</indexterm></findex>
<para>La commande <code>\framebox</code> produit un filet d&textrsquo;épaisseur
<code>\fboxrule</code>, et laisse un espace <code>\fboxsep</code> entre le filet et
le contenu de la boîte.
</para>

</subsection>
<node name="_005cframe" spaces=" "><nodename>\frame</nodename><nodenext automatic="on">\dashbox</nodenext><nodeprev automatic="on">\framebox (picture)</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\frame</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="492">\frame</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\frame&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>La commande <code>\frame</code> met un cadre rectangulaire autour de
<var>texte</var>.  Le point de référence est le coin en bas à gauche du
cadre. Aucun espace supplémentaire n&textrsquo;est mis entre le cadre et l&textrsquo;objet
<var>texte</var>.
</para>

</subsection>
<node name="_005cdashbox" spaces=" "><nodename>\dashbox</nodename><nodeprev automatic="on">\frame</nodeprev><nodeup automatic="on">picture</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\dashbox</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="493">\dashbox</indexterm></findex>

<para>Dessine une boîte avec une ligne en tiretés. Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\dashbox&lbrace;<var>tlong</var>&rbrace;(<var>rlargeur</var>,<var>rhauteur</var>)[<var>pos</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para><code>\dashbox</code> crée un rectangle en tiretés autour de <var>texte</var> au
sein d&textrsquo;un environnement <code>picture</code>. Les tirets sont long de
<var>tlong</var> unités, et le rectangle a pour largeur totale <var>rlargeur</var>
et hauteur totale <var>rhauteur</var>.  Le <var>texte</var> est positionné par l&textrsquo;argument
optionnel <var>pos</var>. <!-- c xxref positions. -->
</para>
<para>Une boîte en tiretés a meilleure allure quand les paramètres
<var>rlargeur</var> et <var>rhauteur</var> sont des multiples de <var>tlong</var>.
</para>
</subsection>
</section>
<node name="quotation-_0026-quote" spaces=" "><nodename>quotation &amp; quote</nodename><nodenext automatic="on">tabbing</nodenext><nodeprev automatic="on">picture</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>quotation</code> et <code>quote</code></sectiontitle>

<anchor name="quotation">quotation</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="494"><r>environnement</r> <code>quotation</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="495"><code>quotation</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="291">citation</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="292">texte cité avec renfoncement des paragraphes, affichage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="293">afficher du texte cité avec renfoncement de paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="294">renfoncement des paragraphes dans du texte cité</indexterm></cindex>
<anchor name="quote">quote</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="496"><r>environnement</r> <code>quote</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="497"><code>quote</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="295">texte cité sans renfoncement des paragraphes, affichage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="296">afficher un texte cité sans renfoncement de paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="297">renfoncement des paragraphes dans un texte cité, omettre</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;quotation&rbrace;
  <var>texte</var>
\end&lbrace;quotation&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;quote&rbrace;
  <var>texte</var>
\end&lbrace;quote&rbrace;
</pre></example>

<para>Cite du texte.
</para>
<para>Dans les deux environnements, les marges sont renfoncées à la fois sur la
gauche et la droite. Le texte est justifié des deux côtés sur la marge.
De même que dans le texte principal, laisser une ligne à blanc au sein
du texte produit un nouveau paragraphe.
</para>
<para>Pour comparer les deux : dans l&textrsquo;environnement <code>quotation</code>, les
paragraphes sont renfoncés de 1,5<dmn>em</dmn> et l&textrsquo;espace entre les
paragraphes est petit, <code>0pt plus 1pt</code>.  Dans l&textrsquo;environnement
<code>quote</code>, les paragraphes ne sont pas renfoncés et il y a un espace
vertical entre les paragraphes (c&textrsquo;est la longueur élastique
<code>\parsep</code>).  Ainsi, l&textrsquo;environnement <code>quotation</code> convient mieux
aux documents où les nouveaux paragraphes sont marqués par un
renfoncement plutôt que par une séparation verticale.  De plus,
<code>quote</code> convient mieux pour des citations courtes ou une suite de
citations courtes.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;quotation&rbrace; \small\it
  Il y a quatre-vingt sept ans
  ... ne disparaîtra jamais de la surface de la terre.
  \hspace&lbrace;1em plus 1fill&rbrace;--- Abraham Lincoln
\end&lbrace;quotation&rbrace;
</pre></example>

</section>
<node name="tabbing" spaces=" "><nodename>tabbing</nodename><nodenext automatic="on">table</nodenext><nodeprev automatic="on">quotation &amp; quote</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>tabbing</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="498"><r>environnement</r> <code>tabbing</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="499"><code>tabbing</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="298">taquets de tabulation, utiliser</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="299">aligner du texte en utilisant des taquets de tabulation</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="300">alignement au moyen de <code>tabbing</code></indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabbing&rbrace;
<var>lgn1col1</var> \= <var>lgn1col2</var> ... \\
<var>lgn2col1</var> \&gt; <var>lgn2col2</var> ... \\
...
\end&lbrace;tabbing&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>tabbing</code> fournit une technique pour aligner du
texte en colonnes. Il fonctionne en réglant des taquets et en tabulant
jusqu&textrsquo;à eux à la façon dont on le faisait avec une machine à écrire
ordinaire.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="500"><r>paquetage</r> <code>algorithm2e</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="501"><code>algorithm2e</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="502"><r>paquetage</r> <code>listings</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="503"><code>listings</code>, <r>paquetage</r></indexterm></findex>
 <findex index="fn" spaces=" "><indexterm index="fn" number="504"><r>paquetage</r> <code>minted</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="505"><code>minted</code>, <r>paquetage</r></indexterm></findex>
 <findex index="fn" spaces=" "><indexterm index="fn" number="506"><r>paquetage</r> <code>fancyvrb</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="507"><code>fancyvrb</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="508"><r>paquetage</r> <code>longtable</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="509"><code>longtable</code>, <r>paquetage</r></indexterm></findex>

<para>L&textrsquo;environnement <code>tabbing</code> est peu utilisé, car en général, pour
formater du code informatique on utilise un environnement verbatim
(<pxref label="verbatim"><xrefnodename>verbatim</xrefnodename></pxref>). À noter également, pour mettre en vedette la
syntaxe, les paquetages <code>algorithm2e</code> pour du pseudo-code, et
<code>fancyvrb</code>, <code>listings</code> ou <code>minted</code> pour du vrai code.
Et pour faire un tableau, on préfère les environnements <code>tabular</code>
(<pxref label="tabular"><xrefnodename>tabular</xrefnodename></pxref>) ou <code>array</code> (<pxref label="array"><xrefnodename>array</xrefnodename></pxref>) pour un petit tableau
qu&textrsquo;on met dans un flottant <code>table</code> (<pxref label="table"><xrefnodename>table</xrefnodename></pxref>) et
l&textrsquo;environnement <code>longtable</code> fourni par le paquetage
<code>longtable</code> pour un tableau pouvant être coupé sur plusieurs pages.
</para>
<para>La description suivante n&textrsquo;est donc fournie que être complet.
</para>
<para>Dans l&textrsquo;exemple suivant la première ligne sert à régler les taquets à des
largeurs explicites, elle se termine par une commande <code>\kill</code>
(décrite plus bas) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabbing&rbrace;
\hspace&lbrace;3cm&rbrace;\=\hspace&lbrace;2.5cm&rbrace;\=\kill
Navire                \&gt;Armement        \&gt;Année   \\
\textit&lbrace;Sophie&rbrace;       \&gt;14              \&gt;1800    \\
\textit&lbrace;Polychrest&rbrace;   \&gt;24              \&gt;1803    \\
\textit&lbrace;Lively&rbrace;       \&gt;38              \&gt;1804    \\
\textit&lbrace;Surprise&rbrace;     \&gt;28              \&gt;1805    \\
\end&lbrace;tabbing&rbrace;
</pre></example>

<noindent></noindent>
<para>Le résultat ressemble à cela :
</para>
<quotation endspaces=" ">
<multitable spaces=" " endspaces=" "><columnfractions line=".2 .17 .17"><columnfraction value=".2"></columnfraction><columnfraction value=".17"></columnfraction><columnfraction value=".17"></columnfraction></columnfractions>
<tbody><row><entry command="item" spaces=" "><para>Navire </para></entry><entry command="tab" spaces=" "><para>Armement </para></entry><entry command="tab" spaces=" "><para>Année
</para></entry></row><row><entry command="item" spaces=" "><para><i>Sophie</i>      </para></entry><entry command="tab" spaces=" "><para>14 </para></entry><entry command="tab" spaces=" "><para>1800
</para></entry></row><row><entry command="item" spaces=" "><para><i>Polychrest</i>  </para></entry><entry command="tab" spaces=" "><para>24 </para></entry><entry command="tab" spaces=" "><para>1803
</para></entry></row><row><entry command="item" spaces=" "><para><i>Lively</i>      </para></entry><entry command="tab" spaces=" "><para>38 </para></entry><entry command="tab" spaces=" "><para>1804
</para></entry></row><row><entry command="item" spaces=" "><para><i>Surprise</i>    </para></entry><entry command="tab" spaces=" "><para>28 </para></entry><entry command="tab" spaces=" "><para>1805
</para></entry></row></tbody></multitable>
</quotation>

<para>L&textrsquo;environnement <code>tabbing</code> se distingue de <code>tabular</code> notamment
parce qu&textrsquo;avec <code>tabbing</code> l&textrsquo;utilisateur est obligé de régler la
position des taquets, et le contenu des colonnes est toujours composé
en mode LR et s&textrsquo;étend sur la colonne suivante s&textrsquo;il est plus large que la
colonne courante, alors qu&textrsquo;avec <code>tabular</code>, l&textrsquo;utilisateur peut selon
le spécificateur de colonne, soit composer le contenu des cellules en
mode LR et laisser &latex; déterminer la largeur de colonne
automatiquement pour que le contenu ne sorte jamais de la colonne, soit
fixer la largeur et composer le contenu des cellules dans une
<code>parbox</code>. Une autre différence est que <code>tabular</code> permet de
faire des filets, notamment de border les colonnes par des filets
verticaux, et d&textrsquo;avoir un espace <code>\tabcolsep</code> entre le contenu et la
bordure de colonne. Une autre distinction est que un <code>tabbing</code> peut
être coupé sur plusieurs pages, alors que <code>tabular</code> génère une
boîte, l&textrsquo;environnement <code>longtable</code> du paquetage <code>longtable</code>
étant préféré à <code>tabbing</code> pour les longs tableaux.
</para>
<para>Finalement, alors que <code>tabular</code> peut être utilisé dans n&textrsquo;importe
quel mode, <code>tabbing</code> ne peut être utilisé qu&textrsquo;en mode paragraphe, et
il démarre un nouveau paragraphe.
</para>
<para>De plus, comme l&textrsquo;illustre l&textrsquo;exemple donné plus haut, il n&textrsquo;est pas
nécessaire d&textrsquo;utiliser la forme étoilée de la commande <code>\hspace</code> au
début d&textrsquo;une ligne tabulée.  La marge de droite de l&textrsquo;environnement
<code>tabbing</code> est la fin de ligne, de sorte que la largeur de
l&textrsquo;environnement est <code>\linewidth</code>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="301">ligne tabulée <r>(<code>tabbing</code>)</r></indexterm></cindex>
<para>L&textrsquo;environnement <code>tabbing</code> contient une suite de <dfn>lignes
tabulées</dfn>, la première ligne tabulée commence immédiatement après
<code>\begin&lbrace;tabbing&rbrace;</code> et chaque ligne se termine par <code>\\</code> ou
<code>\kill</code>. Il est possible d&textrsquo;omettre le <code>\\</code> pour la dernière
ligne et de terminer juste par <code>\end&lbrace;tabbing&rbrace;</code>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="302">motif courant de taquets de tabulation <r>(<code>tabbing</code>)</r></indexterm></cindex>
<para>L&textrsquo;environnement <code>tabbing</code> a un <dfn>motif courant de taquets de
tabulation</dfn> qui est une séquence de <var>n</var> taquets, avec <math><var>n</var>
&gt; 0</math>, numérotés 0, 1, etc. Ceci crée <var>n</var> colonnes
correspondantes. Le taquet № 0 est toujours la marge de gauche
définie par l&textrsquo;environnement englobant. Le taquet numéro <var>i</var> est
réglé quand on lui assigne une position horizontale sur la page avec la
commande <code>\=</code>. Le taquet numéro <var>i</var> ne peut être réglé que si
les autres taquets 0, &dots;, <math><var>i</var>-1</math> ont déjà été réglés.
</para>

<cindex index="cp" spaces=" "><indexterm index="cp" number="303">taquet courant <r>(<code>tabbing</code>)</r></indexterm></cindex>
<para>L&textrsquo;un des taquets du motif courant ayant été réglé comme le <dfn>taquet
courant</dfn>, par défaut tout texte composé par la suite au sein de
l&textrsquo;environnement <code>tabbing</code> est composé en drapeau droit avec le fer à
gauche sur ce taquet, c&textrsquo;est à dire qu&textrsquo;il est aligné à gauche dans la
colonne courante. La composition est faite en mode LR.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="304">taquet de début de ligne courant <r>(<code>tabbing</code>)</r></indexterm></cindex>
<para>Par ailleurs l&textrsquo;environnement <code>tabbing</code> a un <dfn>taquet de début de
ligne courant</dfn>. Par défaut, immédiatement après <code>\begin&lbrace;tabbing&rbrace;</code>
c&textrsquo;est le taquet № 0, et on peut le changer pour les lignes suivantes
avec les commandes <code>\+</code> et <code>\-</code>. Au début de chaque ligne tabulée, le taquet
courant est initialement égal au taquet de début de ligne courant.
Lorsque le motif de taquets est modifié par une commande <code>\=</code>,
alors le taquet de début de ligne redevient le taquet № 0 à partir de la
ligne suivante, à moins qu&textrsquo;une commande <code>\+</code> le change de nouveau
avant le changement de ligne par <code>\\</code> ou <code>\kill</code>. La commande
<code>\pushtabs</code> sauvegarde non seulement les positions de taquets, mais
aussi le taquet de début de ligne, et inversement <code>\poptabs</code> le
restaure.
</para>
<para>La marge de droite de l&textrsquo;environnement <code>tabbing</code> est la fin de
ligne, c.-à-d.&noeos; que la largeur de l&textrsquo;environnement est de longueur
<code>\linewidth</code>. Il n&textrsquo;y a pas par défaut de taquet correspondant à la
marge de droite, même s&textrsquo;il serait possible avec un peu de calcul d&textrsquo;en
définir un à cette position (voir exemples ci-après).
</para>
<para>En ce qui concerne la marge de gauche, ou autrement dit le taquet № 0,
contrairement à l&textrsquo;environnement <code>tabular</code>, il n&textrsquo;est pas nécessaire
de mettre un <code>\noindent</code> devant <code>\begin&lbrace;tabbing&rbrace;</code> pour
éviter un renfoncement : un environnement <code>tabbing</code> commence
toujours un nouveau paragraphe sans renfoncement. De plus il est inutile
d&textrsquo;étoiler une commande <code>\hspace</code> en début de ligne tabulée pour que
l&textrsquo;espace soit pris en compte.
</para>
<para>Normalement, au sein du motif de taquets de tabulation, l&textrsquo;ordre des
taquets correspond à des positions allant de gauche à droite. Il est
cependant possible de positionner n&textrsquo;importe quel taquet, hormis le
taquet № 0 à n&textrsquo;importe quelle position en utilisant des espacements
négatifs ou nuls. En réalité, le fait de ne pas pouvoir changer la
position du taquet № 0 n&textrsquo;est pas restrictif, car on peut utiliser à la
place comme taquet de début de ligne le taquet № 1 grâce à la commande
<code>\+</code>. Ainsi dans l&textrsquo;exemple ci-dessous, alors qu&textrsquo;on a le même
contenu de l&textrsquo;environnement <code>tabbing</code> que dans l&textrsquo;exemple précédent,
la première et la troisième colonne ont été interverties en changeant
uniquement le motif de taquets dans la première ligne se terminant en
<code>\kill</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabbing&rbrace;
\hspace&lbrace;5.5cm&rbrace;\=\hspace&lbrace;-2.5cm&rbrace;\=\hspace&lbrace;-3cm&rbrace;\=\+\kill
Navire              \&gt;Armement         \&gt;Année    \\
\textit&lbrace;Sophie&rbrace;     \&gt;14               \&gt;1800    \\
\textit&lbrace;Polychrest&rbrace; \&gt;24               \&gt;1803    \\
\textit&lbrace;Lively&rbrace;     \&gt;38               \&gt;1804    \\
\textit&lbrace;Surprise&rbrace;   \&gt;28               \&gt;1805    \\
\end&lbrace;tabbing&rbrace;
</pre></example>

<noindent></noindent>
<para>Le résultat ressemble donc à cela :
</para>
<quotation endspaces=" ">
<multitable spaces=" " endspaces=" "><columnfractions line=".2 .17 .17"><columnfraction value=".2"></columnfraction><columnfraction value=".17"></columnfraction><columnfraction value=".17"></columnfraction></columnfractions>
<tbody><row><entry command="item" spaces=" "><para>Année </para></entry><entry command="tab" spaces=" "><para>Armement </para></entry><entry command="tab" spaces=" "><para>Navire
</para></entry></row><row><entry command="item" spaces=" "><para>1800  </para></entry><entry command="tab" spaces=" "><para>14 </para></entry><entry command="tab" spaces=" "><para><i>Sophie</i>
</para></entry></row><row><entry command="item" spaces=" "><para>1803  </para></entry><entry command="tab" spaces=" "><para>24 </para></entry><entry command="tab" spaces=" "><para><i>Polychrest</i>
</para></entry></row><row><entry command="item" spaces=" "><para>1804  </para></entry><entry command="tab" spaces=" "><para>38 </para></entry><entry command="tab" spaces=" "><para><i>Lively</i>
</para></entry></row><row><entry command="item" spaces=" "><para>1805  </para></entry><entry command="tab" spaces=" "><para>28 </para></entry><entry command="tab" spaces=" "><para><i>Surprise</i>
</para></entry></row></tbody></multitable>
</quotation>


<para>Les commandes suivantes peuvent être utilisées au sein d&textrsquo;un
environnement <code>tabbing</code> :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="510">\\ <r>(<code>tabbing</code>)</r></indexterm>\\ <r>(<code>tabbing</code>)</r></itemformat></item>
</tableterm><tableitem><para>Finit une ligne tabulée et la compose. Après cette commande une nouvelle
ligne tabulée commence, et donc le taquet courant redevient le taquet
courant de début de ligne.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="511">\= <r>(<code>tabbing</code>)</r></indexterm>\= <r>(<code>tabbing</code>)</r></itemformat></item>
</tableterm><tableitem><para>Règle le prochain taquet à la position courante, et fait de lui le
taquet courant. Si le taquet courant est le taquet № <var>n</var>, alors une
commande <code>\=</code> règle la position du taquet № <math><var>n</var>+1</math> et
fait de lui le taquet courant. Si on avait déjà au moins
<math><var>n</var>+2</math> taquets, ceci redéfinit la position du taquet
№ <math><var>n</var>+1</math>. Sinon, le nombre de taquets dans le motif courant
était à ce moment <math>(<var>n</var>+1)</math>, c&textrsquo;est à dire que dernier des
taquets en numéro d&textrsquo;ordre était le № <var>n</var>, alors la commande
<code>\=</code> en définissant le taquet № <math><var>n</var>+1</math>, porte le nombre
de taquets de <math><var>n</var>+1</math> à <math><var>n</var>+2</math>.
</para>
<para>La position des taquets peut être définie avec plus de liberté que ce
qui se passait avec un machine à écrire ordinaire. En effet il est
possible de définir à la même position deux taquets de № <var>n</var> et
№ <var>m</var> distincts, voire de faire en sorte que les taquets № <var>n</var>
et № <var>m</var>, avec <math><var>n</var>&lt;<var>m</var></math>, soient à des positions telles
que le taquet № <var>m</var> soit avant le taquet № <var>n</var>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="512">\&gt; <r>(<code>tabbing</code>)</r></indexterm>\&gt; <r>(<code>tabbing</code>)</r></itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="513">\&gt;</indexterm></findex>
<para>Change le taquet courant au taquet suivant dans l&textrsquo;ordre logique,
c.-à-d.&noeos; si le taquet courant est le taquet № <var>n</var>, alors, en
supposant qu&textrsquo;il y ait au moins <math><var>n</var>+2</math> taquets définis, on
passe au taquet № <math><var>n</var>+1</math>, sinon cette commande provoque une
erreur.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="514">\&lt;</indexterm>\&lt;</itemformat></item>
</tableterm><tableitem><para>Change le taquet courant au taquet précédent dans l&textrsquo;ordre logique. Cette
commande ne peut être utilisée qu&textrsquo;au début d&textrsquo;une ligne tabulée, et que
lorsque le taquet de début de ligne courant est le taquet № <var>n</var> avec
<math><var>n</var>&gt;0</math>.  Le taquet courant devient alors le taquet
№ <math><var>n</var>-1</math>.
</para>
<para>Il est en fait possible d&textrsquo;avoir <var>m</var> commandes <code>\&lt;</code> consécutives
à condition que <math><var>m</var>&le;<var>n</var></math>, le taquet courant devient
alors le taquet № <math>(<var>n</var>-<var>m</var>)</math>. Si par contre
<math><var>m</var>&gt;<var>n</var></math>, alors la <math><var>n</var>+1</math> commande <code>\&lt;</code>
provoque une erreur.
</para>
<para>Il est possible, même si c&textrsquo;est absurde, d&textrsquo;avoir ensuite des commandes
<code>\&gt;</code> qui défont ce qu&textrsquo;on fait les commandes <code>\&lt;</code>. Ainsi en
supposant qu&textrsquo;au début d&textrsquo;une ligne tabulée le taquet de début de ligne
courant soit le taquet № 2, faire commencer la ligne par <code>\&lt;\&lt;\&gt;\&gt;</code>
n&textrsquo;a aucun effet. Par contre, <code>\&lt;\&lt;\&lt;\&gt;\&gt;\&gt;</code> provoquera une erreur,
parce que la troisième commande <code>\&lt;</code> est illicite. Dans les mêmes
conditions faire <code>\&lt;\&gt;\&lt;\&gt;</code> provoque également une erreur, car la
seconde commande <code>\&lt;</code> n&textrsquo;est pas consécutive de la première, elle
n&textrsquo;est donc pas, au sens où on l&textrsquo;entend, utilisée en début de ligne.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="515">\+</indexterm>\+</itemformat></item>
</tableterm><tableitem><para>Change le taquet de début de ligne courant au taquet suivant dans
l&textrsquo;ordre logique pour la ligne tabulée suivante, et toutes celles qui
suivent tant qu&textrsquo;une autre commande ne vient pas le modifier. La notion
de taquet suivant dans l&textrsquo;ordre logique suit le même principe que pour la
commande <code>\&gt;</code>, c&textrsquo;est à dire que s&textrsquo;il n&textrsquo;y a que <math><var>n</var>+1</math>
taquets définis, et que le taquet de début de ligne courant est le
taquet № <var>n</var>, alors cette commande provoque une erreur. La
commande <code>\+</code> peut être invoquée n&textrsquo;importe où dans la ligne
tabulée, et on peut avoir plusieurs commandes <code>\+</code> au sein de la
même ligne, du moment que pour chacune d&textrsquo;elle un nombre suffisant de
taquets est déjà défini. Par exemple le code suivant provoque une erreur
parce que bien qu&textrsquo;à la fin de la première ligne on ait trois taquets
définis, au moment où la commande <code>\+</code> est invoquée le nombre de
taquets définis ne vaut que 1, on ne peut donc pas passer du taquet
№ 0 au taquet № 1 :
</para>
<smallexample endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabbing&rbrace;
Vive \+\=la \=France\\
Vive \&gt;la\&gt;République\\
\end&lbrace;tabbing&rbrace;
</pre></smallexample>

<para>En revanche le code suivant fonctionne, car lorsque la commande
<code>\+</code> est passée on a trois taquets définis, les taquets № 0 à 2, on
peut donc passer du taquet № 0 au taquet № 1.
</para>
<smallexample endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabbing&rbrace;
Vive \=la \=France\+\\
Vive \&gt;la\&gt;République\\
\end&lbrace;tabbing&rbrace;
</pre></smallexample>

<para>C&textrsquo;est pourquoi l&textrsquo;usage est que la ou les commandes <code>\+</code> sont
toujours invoquées juste avant la fin de ligne <code>\\</code> ou <code>\kill</code>.
</para>
<para>Il est possible, même si cela est absurde, d&textrsquo;avoir sur la même ligne à
la fois des commandes <code>\+</code> et <code>\-</code> s&textrsquo;annulant l&textrsquo;une l&textrsquo;autre,
du moment qu&textrsquo;aucune d&textrsquo;elle ne fasse passer sur un taquet non défini.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="516">\-</indexterm>\-</itemformat></item>
</tableterm><tableitem><para>Change le taquet de début de ligne courant au taquet précédent dans
l&textrsquo;ordre logique pour la ligne tabulée suivante, et toutes celles qui
suivent tant qu&textrsquo;une autre commande ne vient pas le modifier. C&textrsquo;est à
dire que si le taquet de début de ligne courant est le taquet № <var>n</var>,
et qu&textrsquo;on a <var>m</var> commandes <code>\-</code> avec <math><var>m</var>&ge;<var>n</var></math>,
alors le taquet de début de ligne courant de la ligne suivante devient
le taquet № <math><var>n</var>-<var>m</var></math>. Par contre, si
<math><var>m</var>&gt;<var>n</var></math>, alors la <math>(<var>n</var>+1)</math>ième commande
<code>\+</code> provoque une erreur.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="517">\' <r>(<code>tabbing</code>)</r></indexterm>\' <r>(<code>tabbing</code>)</r></itemformat></item>
</tableterm><tableitem><para>Déplace tout ce que vous avez tapé jusqu&textrsquo;alors dans la colonne courante,
c.-à-d.&noeos; tout ce qui suit la plus récente commande <code>\&gt;</code>,
<code>\&lt;</code>, <code>\'</code>, <code>\\</code>, ou <code>\kill</code>, aligné à droite dans
la colonne précédente, le fer à droite étant espacé du taquet courant
d&textrsquo;une longueur <code>\tabbingsep</code>. Voir aussi <code>\`</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="518">\` <r>(<code>tabbing</code>)</r></indexterm>\` <r>(<code>tabbing</code>)</r></itemformat></item>
</tableterm><tableitem><para>Vous permet de placer du texte justifié à droite en face de n&textrsquo;importe
quel taquet, y compris le taquet 0. Les commandes <code>\`</code> et <code>\'</code>
alignent toutes deux le texte à droite, toutefois elles se distinguent
fortement par deux aspects :
</para><itemize commandarg="bullet" endspaces=" "><itemprepend>&bullet;</itemprepend>
<listitem><prepend>&bullet;</prepend>
<para>Tout d&textrsquo;abord le texte qui est déplacé est, dans le cas de <code>\`</code>, le
texte qui suit la commande <code>\`</code> et qui va jusqu&textrsquo;à la fin de la
ligne tabulée, c.-à-d.&noeos; jusqu&textrsquo;à <code>\\</code> ou <code>\end&lbrace;tabbing&rbrace;</code>.
Il ne doit y avoir aucune commande <code>\&gt;</code> ou <code>\'</code> entre le
<code>\`</code> et la commande <code>\\</code> ou <code>\end&lbrace;tabbing&rbrace;</code> qui termine
la ligne. Dans le cas de la commande <code>\'</code> au contraire, c&textrsquo;est le
texte qui précède la commande <code>\'</code>.
</para></listitem><listitem><prepend>&bullet;</prepend>
<para>Par ailleurs, avec <code>\'</code> l&textrsquo;alignement se fait sur un taquet et avec
un espacement relatif de <code>\tabbingspace</code>, alors qu&textrsquo;avec <code>\`</code>
l&textrsquo;alignement se fait sur la marge de droite et sans espacement relatif.
</para></listitem></itemize>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="519">\a <r>(<code>tabbing</code>)</r></indexterm>\a <r>(<code>tabbing</code>)</r></itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="520">\a' <r>(aigu, accent dans tabbing)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="521">\a` <r>(grave, accent dans tabbing)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="522">\a= <r>(macron, accent dans tabbing)</r></indexterm></findex>
<para>Dans un environnement <code>tabbing</code>, les commandes <code>\=</code>, <code>\'</code>
et <code>\`</code> ne produisent pas d&textrsquo;accents comme d&textrsquo;habitude
(<pxref label="Accents"><xrefnodename>Accents</xrefnodename></pxref>). À leur place, on utilise les commandes <code>\a=</code>,
<code>\a'</code> et <code>\a`</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="523">\kill</indexterm>\kill</itemformat></item>
</tableterm><tableitem><para>Règles les taquets sans produire de texte. Fonctionne tout comme
<code>\\</code> à ceci près que la ligne courante est jetée au lieu de
produire une sortie. L&textrsquo;effet de toute commande <code>\=</code>, <code>\+</code> ou
<code>\-</code> dans cette ligne demeure en vigueur.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="524">\poptabs</indexterm>\poptabs</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="525">\poptabs</indexterm></findex>
<para>Restaure les positions de taquets et le taquet de début de ligne
sauvegardés par le dernier <code>\pushtabs</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="526">\pushtabs</indexterm>\pushtabs</itemformat></item>
</tableterm><tableitem><para>Sauvegarde dans une pile dédiée à cet effet le motif courant de taquets
de tabulation ainsi que le taquet de début de ligne. C&textrsquo;est utile pour
changer temporairement les positions de taquets au milieu d&textrsquo;un
environnement <code>tabbing</code>. Après un <code>\pushtabs</code>, on a un nouveau
motif vierge, c.-à-d.&noeos; ne contenant qu&textrsquo;un seul taquet, le taquet № 0 à
la position de début de ligne. Pour toute commande <code>\pushtabs</code> il
doit y avoir une commande <code>\poptabs</code> avant la fin de
l&textrsquo;environnement, c&textrsquo;est à dire que la pile doit être explicitement vidée
avant le <code>end&lbrace;tabbing&rbrace;</code>.
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="527">\tabbingsep</indexterm>\tabbingsep</itemformat></item>
</tableterm><tableitem><para>Distance du texte déplacé par <code>\'</code> à la gauche du taquet courant.
</para>
</tableitem></tableentry></ftable>

<para>Il est à noter que les espaces en début de ligne, où après <code>\=</code>,
<code>\&gt;</code> ou <code>\&lt;</code> sont gobés, qu&textrsquo;il s&textrsquo;agisse d&textrsquo;espaces produits par
la macro <code>\space</code> ou par le caractère espace. Par contre l&textrsquo;espace
produit par la le caractère de contrôle espace (<code>\<w> </w></code>, c.-à-d.&noeos;
une controblique suivie d&textrsquo;un caractère espace) n&textrsquo;est pas gobé.
</para>
<para>Cet exemple compose une fonction en Pascal dans un format traditionnel :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\ttfamily
\begin&lbrace;tabbing&rbrace;
function \= fact(n : integer) : integer;\+\\
            begin \=\+\\
                  if \= n $&gt;$ 1 then\+\\
                        fact := n * fact(n-1)\-\\
                  else\+\\
                        fact := 1;\-\-\\
            end;\\
\end&lbrace;tabbing&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Le résultat ressemble à cela :
</para><example endspaces=" ">
<pre xml:space="preserve">function fact(n : integer) : integer;
         begin
               if n &gt; 1 then
                  fact := n * fact(n-1);
               else
                  fact := 1;
         end;
</pre></example>


<para>Voici un autre exemple où le taquet № 2 est entre le taquet № 0 et le
taquet № 1 :
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\ttfamily
\begin&lbrace;tabbing&rbrace;
  12\=34\=\kill
  12345678\=9\\
  1\&gt;2\&gt;3\\
\end&lbrace;tabbing&rbrace;&rbrace;
</pre></example>

<para>Le résultat ressemble à cela :
</para><example endspaces=" ">
<pre xml:space="preserve">123456789
1   3   2
</pre></example>

<para>Voici un exemple où les taquets № 0 et № 1 sont confondus, ainsi que les
taquets № 2 et № 3, ce qui permet de superposer le texte aux taquets
impairs sur celui au taquets pairs, par exemple pour souligner ou barrer
comme avec une machine à écrire, en superposant un caractère <code>_</code> ou
un caractère <code>&minus;</code>. Évidemment ce n&textrsquo;est qu&textrsquo;une illustration de
la flexibilité des taquets, et non une méthode convenable pour souligner
ou barrer un mot, d&textrsquo;une part parce que <code>tabbing</code> en soi commençant
un nouveau paragraphe ne permet pas d&textrsquo;agir sur un seul mot, et d&textrsquo;autre
part, parce que le paquetage <code>soul</code> fait cela beaucoup mieux.
<findex index="fn" spaces=" "><indexterm index="fn" number="528"><r>paquetage</r> <code>soul</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="529"><code>soul</code>, <r>paquetage</r></indexterm></findex>
</para>

<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\ttfamily
\begin&lbrace;tabbing&rbrace;
  \=souligne  \=\=\kill
  soulign\a'e\&gt;
  \_&lbrace;&rbrace;\_&lbrace;&rbrace;\_&lbrace;&rbrace;\_&lbrace;&rbrace;\_&lbrace;&rbrace;\_&lbrace;&rbrace;\_&lbrace;&rbrace;\_&lbrace;&rbrace;\&gt;
  barr\a'e\&gt;&lbrace;--&rbrace;&lbrace;--&rbrace;&lbrace;--&rbrace;&lbrace;--&rbrace;&lbrace;--&rbrace;&lbrace;--&rbrace;\\
\end&lbrace;tabbing&rbrace;&rbrace;
</pre></example>


<para>Finalement, voici un exemple où on a placé le taquet № 5 décalé d&textrsquo;une
longueur <code>\tabbingsep</code> à droite de la marge de droite.
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\ttfamily
\begin&lbrace;tabbing&rbrace;
\hspace&lbrace;1cm&rbrace;\=\hspace&lbrace;1cm&rbrace;\=\hspace&lbrace;1cm&rbrace;\=\hspace&lbrace;1cm&rbrace;\=
   \hspace&lbrace;\dimexpr\linewidth-4cm+\tabbingsep&rbrace;\=\kill
1\&gt;2\&gt;X\'3\&gt;4\&gt;5\&gt;\a`a gauche de de la marge de droite
   avec \textbackslash'\'\\
1\&gt;2\&gt;X\'3\&gt;4\&gt;5\`\a`a gauche de de la marge de droite
   avec \textbackslash`\\
\end&lbrace;tabbing&rbrace;&rbrace;
</pre></example>

<para>Le résultat ressemble à cela :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><!-- c 012345678901234567890123456789012345678901234567890123456789 -->
1    2  X 3    4    5            à gauche de la marge de droite avec \'
1    2  X 3    4    5            à gauche de la marge de droite avec \`
</pre></example>


</section>
<node name="table" spaces=" "><nodename>table</nodename><nodenext automatic="on">tabular</nodenext><nodeprev automatic="on">tabbing</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>table</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="530"><r>environnement</r> <code>table</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="531"><code>table</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="305">tableaux, créer</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="306">créer des tableaux</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;table&rbrace;[<var>placement</var>]
  <var>corps-du-tableau</var>
  \caption[<var>titreldt</var>]&lbrace;<var>titre</var>&rbrace; % optionnel
  \label&lbrace;<var>étiquette</var>&rbrace;         % également opionnel
\end&lbrace;table&rbrace;
</pre></example>

<para>Une classe de flottants (<pxref label="Floats"><xrefnodename>Floats</xrefnodename></pxref>). Parce qu&textrsquo;ils ne peuvent pas
être coupés à cheval sur plusieurs pages, il ne sont pas composés en
séquence avec le texte normale, mais à la place sont « flottés » vers un
endroit convenable, tel que le sommet d&textrsquo;une page suivante.
</para>
<para>Dans l&textrsquo;exemple suivant, l&textrsquo;environnement <code>table</code> contient un <code>tabular</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;table&rbrace;
  \centering\small
  \begin&lbrace;tabular&rbrace;&lbrace;ll&rbrace;
    \multicolumn&lbrace;1&rbrace;&lbrace;c&rbrace;&lbrace;\textit&lbrace;Auteur&rbrace;&rbrace;
      &amp;\multicolumn&lbrace;1&rbrace;&lbrace;c&rbrace;&lbrace;\textit&lbrace;Pièce&rbrace;&rbrace;  \\ \hline
    Bach            &amp;Suite  Numéro 1 pour violoncelle\\
    Beethoven       &amp;Sonate Numéro 3 pour violoncelle\\
    Brahms          &amp;Sonate Numéro 1 pour violoncelle
  \end&lbrace;tabular&rbrace;
  \caption&lbrace;Meilleures pièces pour violoncelle&rbrace;
  \label&lbrace;tab:violoncelle&rbrace;
\end&lbrace;table&rbrace;
</pre></example>

<noindent></noindent>
<para>mais vous pouvez placer beaucoup de types différents de contenu au sein
d&textrsquo;une <code>table</code> : le <var>table body</var> peut contenir du texte, des
commandes &latex;, des graphiques, etc. Il est composé dans une
<code>parbox</code> de largeur <code>\textwidth</code>.
</para>
<para>Pour les valeurs possibles de <var>placement</var> et leur effet sur
l&textrsquo;algorithme de placement des flottants, voir <ref label="Floats"><xrefnodename>Floats</xrefnodename></ref>.
</para>
<para>L&textrsquo;étiquette est optionnelle ; elle est utilisée pour les doubles renvois
(<pxref label="Cross-references"><xrefnodename>Cross references</xrefnodename></pxref>).
<findex index="fn" spaces=" "><indexterm index="fn" number="532">\caption</indexterm></findex>
La commande <code>\caption</code> est également optionnelle. Elle spécifie la
légende <var>titre</var> pour le tableau (<pxref label="_005ccaption"><xrefnodename>\caption</xrefnodename></pxref>). La légende est
numérotée par défaut. Si <var>titreldt</var> est présent, il est utilisé dans
la liste des tableaux au lieu de <var>titre</var> (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of contents
etc.</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple suivant le tableau et sa légende flottent jusqu&textrsquo;au bas
d&textrsquo;une page, à moins qu&textrsquo;il soit repoussé jusqu&textrsquo;à une page de flottants à
la fin.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;table&rbrace;[b]
  \centering
  \begin&lbrace;tabular&rbrace;&lbrace;r|p&lbrace;2in&rbrace;&rbrace; \hline
    Un &amp;Le plus solitaire des nombres \\
    Deux &amp;Peut être aussi triste que un.
         C'est le nombre le plus solitaire après le nombre un.
  \end&lbrace;tabular&rbrace;
  \caption&lbrace;Vertus cardinales&rbrace;
  \label&lbrace;tab:VertusCardinales&rbrace;
\end&lbrace;table&rbrace;
</pre></example>


</section>
<node name="tabular" spaces=" "><nodename>tabular</nodename><nodenext automatic="on">thebibliography</nodenext><nodeprev automatic="on">table</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>tabular</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="533"><r>environnement</r> <code>tabular</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="534"><code>tabular</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="307">lignes dans des tableaux</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="308">aligner du texte dans des tableaux</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;[<var>pos</var>]&lbrace;<var>cols</var>&rbrace;
 <var>article colonne 1</var> &amp; <var>article colonne 2</var> ... &amp; <var>article colonne n</var> \\
...
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular*&rbrace;&lbrace;<var>largeur</var>&rbrace;[<var>pos</var>]&lbrace;<var>cols</var>&rbrace;
<var>article colonne 1</var> &amp; <var>article colonne 2</var> ... &amp; <var>article colonne n</var> \\
...
\end&lbrace;tabular*&rbrace;
</pre></example>

<para>Ces environnements produisent une boîte consistant d&textrsquo;une séquence de
lignes horizontales. Chaque ligne consiste en des articles qui sont
alignés verticalement au sein de colonnes. Ci-après une illustration de
beaucoup des caractéristiques.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;l|l&rbrace;
  \textit&lbrace;Nom du joueur&rbrace;  &amp;\textit&lbrace;Coups de circuit de toute sa carrière&rbrace;  \\
  \hline
  Hank Aaron  &amp;755 \\
  Babe Ruth   &amp;714
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>La sortie a deux colonnes alignées à gauche, avec une barre verticales
entre elles. Ceci est spécifié par l&textrsquo;argument <code>&lbrace;l|l&rbrace;</code> de
<code>tabular</code>.
<findex index="fn" spaces=" "><indexterm index="fn" number="535">&amp; <r>(pour cellules de tableau)</r></indexterm></findex>
On place les articles dans des colonnes différentes en les séparant avec
une esperluette <code>&amp;</code>. La fin de chaque ligne est marquée avec une
double controblique, <code>\\</code>.  On met un filet horizontal sous une
ligne en mettant <code>\hline</code> après sa double controblique.
<findex index="fn" spaces=" "><indexterm index="fn" number="536">\\ <r>(pour <code>tabular</code>)</r></indexterm></findex>
Cette <code>\\</code> est optionnelle après la dernière ligne, à moins qu&textrsquo;une
commande <code>\hline</code> suive, pour mettre un filet sous le tableau.
</para>
<para>Les arguments obligatoires et optionnels de <code>tabular</code> consistent
en :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">pos</itemformat></item>
</tableterm><tableitem><para>Optionnel. Spécifie la position verticale du tableau. La valeur par
défaut est d&textrsquo;aligner le tableau de sorte à ce que son centre vertical
s&textrsquo;accorde à la ligne de base du texte autour. Il y a deux autres
alignements possibles : <code>t</code> aligne le tableau de sorte que la
première ligne s&textrsquo;accorde à la ligne de base du texte autour, et
<code>b</code> fait la même chose pour la dernière ligne du tableau.
</para>
<para>Ceci n&textrsquo;a un effet que si il y a du texte autour de la table. Dans le cas
usuel d&textrsquo;un <code>tabular</code> seul au sein d&textrsquo;un environnement <code>center</code>
cette option ne fait aucune différence.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">cols</itemformat></item>
</tableterm><tableitem><para>Obligatoire. Spécifie le formatage des colonnes. Il consiste en une
séquence des spécificateurs suivants, correspondant à la séquence des
colonnes et de la matière inter-colonne.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">l</itemformat></item>
</tableterm><tableitem><para>Une colonne d&textrsquo;articles alignés à gauche.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">r</itemformat></item>
</tableterm><tableitem><para>Une colonne d&textrsquo;article alignés à droite.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">c</itemformat></item>
</tableterm><tableitem><para>Une colonne d&textrsquo;article centrés.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">|</itemformat></item>
</tableterm><tableitem><para>Une ligne verticale s&textrsquo;étendant complètement sur la hauteur et profondeur
de l&textrsquo;environnement.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">&arobase;&lbrace;<var>texte ou espace</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Ceci insère <var>texte ou espace</var> à cette position dans chaque ligne. La
matière <var>texte ou espace</var> est composée en mode LR. Ce texte est
fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Si entre deux spécificateurs de colonne il n&textrsquo;y pas d&textrsquo;expression en
<samp>&arobase;&lbrace;&dots;&rbrace;</samp> alors les classes <code>book</code>, <code>article</code> et
<code>report</code> de &latex; mettent de chaque côté de chaque colonne une
gouttière (espace blanc vertical) de largeur <code>\tabcolsep</code>, qui par
défaut vaut 6<dmn>pt</dmn>. C&textrsquo;est à dire que par défaut des colonnes
adjacentes sont séparées de 12<dmn>pt</dmn> (ainsi <code>\tabcolsep</code> est un
nom trompeur puisque ce n&textrsquo;est pas la séparation entre des colonnes de
tableau). De plus, un espace de <code>\tabcolsep</code> vient aussi avant la
première colonne ainsi qu&textrsquo;après la dernière colonne, à moins que vous
placiez un <samp>&arobase;&lbrace;&dots;&rbrace;</samp> à cet endroit.
</para>
<para>Si vous l&textrsquo;emportez sur la valeur par défaut et utilisez une expression
en <samp>&arobase;&lbrace;&dots;&rbrace;</samp> alors &latex; n&textrsquo;insère pas <code>\tabcolsep</code> et
vous devez insérer tout espace désiré vous-même, comme dans
<code>&arobase;&lbrace;\hspace&lbrace;1em&rbrace;&rbrace;</code>.
</para>
<para>Une expression vide <code>&arobase;&lbrace;&rbrace;</code> élimine l&textrsquo;espace, y compris l&textrsquo;espace
au début ou à la fin, comme dans l&textrsquo;exemple ci-dessous où on veut que les
lignes du tableau soient alignées sur la marge de gauche.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;flushleft&rbrace;
  \begin&lbrace;tabular&rbrace;&lbrace;&arobase;&lbrace;&rbrace;l&rbrace;
    ..
  \end&lbrace;tabular&rbrace;
\end&lbrace;flushleft&rbrace;
</pre></example>

<para>L&textrsquo;exemple suivant montre du texte, une virgule de séparation décimale
entre les colonnes, arrangé de sorte que les nombres dans la table
soient alignés sur cette virgule.
<!-- c xx TODO => siunitx fait ça mieux -->
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;r&arobase;&lbrace;$,$&rbrace;l&rbrace;
  $3$ &amp;$14$  \\
  $9$ &amp;$80665$
\end&lbrace;tabular&rbrace;
</pre></example>


<anchor name="_005cextracolsep">\extracolsep</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="537">\extracolsep</indexterm></findex>
<para>Une commande <code>\extracolsep&lbrace;<var>lrg</var>&rbrace;</code> au sein d&textrsquo;une expression
en <samp>&arobase;&lbrace;&dots;&rbrace;</samp> a pour effet qu&textrsquo;une espace supplémentaire de
largeur <var>lrg</var> apparaît sur la gauche de toutes les colonnes
suivantes, jusqu&textrsquo;à contre-ordre d&textrsquo;une autre commande
<code>\extracolsep</code>.  Contrairement aux à espace inter-colonnes
ordinaires, cette espace supplémentaire n&textrsquo;est pas supprimé par une
expression en <samp>&arobase;&lbrace;&dots;&rbrace;</samp>. Une commande <code>\extracolsep</code>
peut uniquement être utilisée au sein d&textrsquo;une expression en
<samp>&arobase;&lbrace;&dots;&rbrace;</samp> elle-même au sein de l&textrsquo;argument <code>cols</code>.
Ci-dessous, &latex; insère la quantité convenable d&textrsquo;espace intercolonne
our que le tableau fasse 10<dmn>cm</dmn> de large.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \begin&lbrace;tabular*&rbrace;&lbrace;10cm&rbrace;&lbrace;l&arobase;&lbrace;\extracolsep&lbrace;\fill&rbrace;&rbrace;l&rbrace;
    Tomber sept fois, se relever huit \ldots
    &amp;c'est comme ça la vie !
  \end&lbrace;tabular*&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<para>Pour insérer des commandes qui sont automatiquement exécutées avant une
colonne donnée, charger le paquetage <code>array</code> et utilisez le
spécificateur <code>&gt;&lbrace;...&rbrace;</code>.
<!-- c xx should fully explain array, tabularx, and all other base packages... -->
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">p&lbrace;<var>lrg</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Chaque cellule de la colonne est composée au sein d&textrsquo;une parbox de
largeur <var>lrg</var>, comme si c&textrsquo;était l&textrsquo;argument d&textrsquo;une commande
<code>\parbox[t]&lbrace;<var>lrg</var>&rbrace;&lbrace;...&rbrace;</code>.
</para>
<para>Les sauts de ligne de type double-controblique <code>\\</code> ne sont pas
permis au sein d&textrsquo;une telle cellule, sauf à l&textrsquo;intérieur d&textrsquo;un
environnement comme <code>minipage</code>, <code>array</code>, ou <code>tabular</code>, ou
à l&textrsquo;intérieur d&textrsquo;une <code>\parbox</code> explicite, ou dans la portée d&textrsquo;une
déclaration <code>\centering</code>, <code>\raggedright</code>, ou
<code>\raggedleft</code> (quand elles sont utilisées au sein d&textrsquo;une cellule de
colonne en <code>p</code> ces déclarations doivent apparaître entre accolades,
comme dans <code>&lbrace;\centering .. \\ ..&rbrace;</code>. Sans quoi &latex; prendra la
double controblique comme une fin de ligne de tableau. Au lieu de cela, pour
obtenir un saut de ligne dans une cellule de ce type utilisez
<code>\newline</code> (<pxref label="_005cnewline"><xrefnodename>\newline</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">*&lbrace;<var>num</var>&rbrace;&lbrace;<var>cols</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Équivalent à <var>num</var> copies de <var>cols</var>, où <var>num</var> est un entier
positif et <var>cols</var> est toute liste de spécificateurs. Ainsi
<code>\begin&lbrace;tabular&rbrace;&lbrace;|*&lbrace;3&rbrace;&lbrace;l|r&rbrace;|&rbrace;</code> équivaut à
<code>\begin&lbrace;tabular&rbrace;&lbrace;|l|rl|rl|r|&rbrace;</code>. Notez que <var>cols</var> peut
contenir une autre expression en <code>*&lbrace;&dots;&rbrace;&lbrace;&dots;&rbrace;</code>.
</para>
</tableitem></tableentry></table>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">largeur</itemformat></item>
</tableterm><tableitem><para>Obligatoire pour <code>tabular*</code>, non autorisé pour
<code>tabular</code>. Spécifie la largeur de l&textrsquo; environnement
<code>tabular*</code>. Il doit y avoir de l&textrsquo;espace élastique entre les
colonnes, comme avec with <code>&arobase;&lbrace;\extracolsep&lbrace;\fill&rbrace;&rbrace;</code>, de sorte à
permettre au tableau de se dilater ou contracter pour faire la largeur
spécifiée, sans quoi vous aurez probablement l&textrsquo;avertissement
<code>Underfull \hbox (badness 10000) in alignment ..</code>.
</para>
</tableitem></tableentry></table>

<para>Paramètres qui contrôlent le formatage :
<!-- c xx defaults, own node (xref from array)? -->
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="538">\arrayrulewidth</indexterm>\arrayrulewidth</itemformat></item>
</tableterm><tableitem><anchor name="tabular-arrayrulewidth">tabular arrayrulewidth</anchor>
<para>Une longueur qui est l&textrsquo;épaisseur du filet créé par <code>|</code>,
<code>\hline</code>, et <code>\vline</code> au sein des environnements
<code>tabular</code> et <code>array</code>. La valeur par défaut est <samp>.4pt</samp>. On
peut la changer comme dans
<code>\setlength&lbrace;\arrayrulewidth&rbrace;&lbrace;0.8pt&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="539">\arraystretch</indexterm>\arraystretch</itemformat></item>
</tableterm><tableitem><anchor name="tabular-arraystrech">tabular arraystrech</anchor>
<para>Un facteur par lequel l&textrsquo;espacement entre les lignes au sein des
environnements <code>tabular</code> et <code>array</code> est multiplié. La valeur
par défaut est <samp>1</samp> pour aucune dilatation/contraction. On peut la
changer comme dans <code>\renewcommand&lbrace;\arraystretch&rbrace;&lbrace;1.2&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="540">\doublerulesep</indexterm>\doublerulesep</itemformat></item>
</tableterm><tableitem><anchor name="tabular-doublerulesep">tabular doublerulesep</anchor>
<para>Une longueur qui est la distance ente les filets verticaux produit par
le spécificateur <code>||</code>.
<!-- c - vincentb1 pourquoi supprimer le texte: au sein des environnements -->
<!-- c - @code{tabular} et @code{array} -->
La valeur par défaut est <samp>2pt</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="541">\tabcolsep</indexterm>\tabcolsep</itemformat></item>
</tableterm><tableitem><anchor name="tabular-tabcolsep">tabular tabcolsep</anchor>
<para>Une longueur qui est la moitié de l&textrsquo;espace entre les colonnes. La valeur
par défaut est <samp>6pt</samp>. On peut la changer avec <code>\setlength</code>
</para>
</tableitem></tableentry></ftable>

<para>Les commandes suivantes peuvent être utilisées à l&textrsquo;intérieur du corps
d&textrsquo;un environnement <code>tabular</code>, les deux premières au sein d&textrsquo;un
article, et les deux suivantes entre les lignes :
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\multicolumn</menunode><menudescription><pre xml:space="preserve">Faire qu&textrsquo;un article s&textrsquo;étende sur plusieurs colonnes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\vline</menunode><menudescription><pre xml:space="preserve">Dessiner une ligne verticale.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\cline</menunode><menudescription><pre xml:space="preserve">Dessiner une ligne horizontale s&textrsquo;étendant sur quelques colonnes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\hline</menunode><menudescription><pre xml:space="preserve">Dessiner une ligne horizontale s&textrsquo;étendant sur toutes les colonnes.
<!-- c - vincentb1 ce n'est pas le bon menu où mettre ça: * tabularx:: Un -->
<!-- c environnement qui étend les types de colonne de @code{tabular*}. -->
</pre></menudescription></menuentry></menu>


<node name="_005cmulticolumn" spaces=" "><nodename>\multicolumn</nodename><nodenext automatic="on">\vline</nodenext><nodeup automatic="on">tabular</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\multicolumn</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="542">\multicolumn</indexterm></findex>

<para>Synopsis :
</para><example endspaces=" ">
<pre xml:space="preserve">\multicolumn&lbrace;<var>nbrecols</var>&rbrace;&lbrace;<var>patron</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Fabrique une entrée de <code>array</code> ou <code>tabular</code> fusionnée sur
plusieurs colonnes. Le premier argument, <var>nbrecols</var> spécifie le
nombre de colonnes sur lesquelles s&textrsquo;étend la fusion. Le second argument,
<var>patron</var>, est obligatoire et spécifie le format de l&textrsquo;entrée ;
notamment <code>c</code> pour centré, <code>l</code> pour aligné à gauche, <code>r</code>
pour aligné à droite. Le troisième argument, <var>texte</var> spécifie le
texte à mettre dans l&textrsquo;entrée.
</para>
<para>Dans l&textrsquo;exemple suivant les trois première colonnes sont fusionnées en le
titre unique <samp>Nom</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;lccl&rbrace;
  \textit&lbrace;ID&rbrace;     &amp;\multicolumn&lbrace;2&rbrace;&lbrace;c&rbrace;&lbrace;\textit&lbrace;Nom&rbrace;&rbrace; &amp;\textit&lbrace;Âge&rbrace;\\ \hline % ligne 1
  978-0-393-03701-2 &amp;O'Brian &amp;Patrick                         &amp;55            \\ % ligne two
    ...
\end&lbrace;tabular&rbrace;
</pre></example>

<para>On compte comme colonne chaque partie du patron <var>patron</var> de
l&textrsquo;environnement <code>array</code> ou <code>tabular</code> qui, à l&textrsquo;exception de la
première, commence par <code>l</code>, <code>c</code>, <code>r</code>, ou <code>p</code>. Ainsi
à partir de <code>\begin&lbrace;tabular&rbrace;&lbrace;|r|ccp&lbrace;4cm&rbrace;|&rbrace;</code> les parties sont
<code>|r|</code>, <code>c</code>, <code>c</code>, et <code>p&lbrace;1.5in&rbrace;|</code>.
</para>
<para>L&textrsquo;argument <var>patron</var> l&textrsquo;emporte sur la spécification par défaut de
zone inter-colonne de l&textrsquo;environnement <code>array</code> ou <code>tabular</code>
contigüe à cette entrée multi-colonne. Pour affecter cette zone, cet
argument peut contenir des barres verticales <code>|</code> indiquant le
placement de filets verticaux, et d&textrsquo;expression <code>&arobase;&lbrace;...&rbrace;</code>.  Ainsi
si <var>patron</var> est <samp>|c|</samp> alors l&textrsquo;entrée multi-colonne est centrée
et un filet vertical la précède et la suit dans les espaces inter-colonne
de part et d&textrsquo;autre.  Ce tableau nous permet de décrire en détail le
comportement exact.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;|cc|c|c|&rbrace;
  \multicolumn&lbrace;1&rbrace;&lbrace;r&rbrace;&lbrace;w&rbrace;       % entrée un
    &amp;\multicolumn&lbrace;1&rbrace;&lbrace;|r|&rbrace;&lbrace;x&rbrace;  % entrée deux
    &amp;\multicolumn&lbrace;1&rbrace;&lbrace;|r&rbrace;&lbrace;y&rbrace;   % entrée trois
    &amp;z                        % entrée quatre
\end&lbrace;tabular&rbrace;
</pre></example>

<para>Avant la première entrée il n&textrsquo;y a pas de filet verticale en sortie parce
que le <code>\multicolumn</code> a le spécificateur <samp>r</samp> dans <var>patron</var>
sans barre verticales initiale.  Entre les entrées un et deux il y a un
filet vertical ; en effet bien que le premier <var>patron</var> ne se termine
pas par une barre verticale, le second <var>patron</var> en a une à son
commencement.  Entre la deuxième et la troisième entré il y a un seul
filet vertical ; bien que le <var>patron</var> dans les deux
<code>multicolumn</code> correspondant demandent un filet vertical, vous n&textrsquo;en
obtenez qu&textrsquo;un seul.  Entre les entrées trois et quatre il n&textrsquo;y a aucun
filet vertical ; la spécification par défaut en demande un mais le
<var>patron</var> dans le <code>\multicolumn</code> de la troisième entrée n&textrsquo;en
demande pas, et cela l&textrsquo;emporte. Finalement, à la suite de la quatrième
entrée il y a un filet vertical à cause de la spécification par défaut.
</para>
<para>Le nombre de colonnes fusionnées <var>nbrecols</var> peut être 1.  En plus de
donner la possibilité de changer l&textrsquo;alignement horizontal, ceci est aussi
utile pour l&textrsquo;emporter pour l&textrsquo;une des lignes sur la définition
<code>tabular</code> par défaut de la zone inter-colonne, y compris concernant le
placement des filets verticaux.
</para>
<para>Dans l&textrsquo;exemple ci-dessous, dans la définition <code>tabular</code> de la
première colonne on spécifie par défaut de justifier, mais au sein de la
première ligne l&textrsquo;entrée est centrée avec
<code>\multicolumn&lbrace;1&rbrace;&lbrace;c&rbrace;&lbrace;\textsc&lbrace;Période&rbrace;&rbrace;</code>.  De même au sein de
la première ligne, les deuxième et troisième colonnes sont fusionnées
entre elle avec <code>\multicolumn&lbrace;2&rbrace;&lbrace;c&rbrace;&lbrace;\textsc&lbrace;Intervalle&rbrace;&rbrace;</code>,
l&textrsquo;emportant sur la spécification pour centrer ces deux colonnes sur le
trait d&textrsquo;union au sein de la plage de dates.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;l|r&arobase;&lbrace;-&rbrace;l&rbrace;
  \multicolumn&lbrace;1&rbrace;&lbrace;c&rbrace;&lbrace;\textsc&lbrace;Période&rbrace;&rbrace;
    &amp;\multicolumn&lbrace;2&rbrace;&lbrace;c&rbrace;&lbrace;\textsc&lbrace;Dates&rbrace;&rbrace; \\ \hline
  Baroque          &amp;1600           &amp;1760         \\
  Classique        &amp;1730           &amp;1820         \\
  Romantique       &amp;1780           &amp;1910         \\
  Impressioniste   &amp;1875           &amp;1925
\end&lbrace;tabular&rbrace;
</pre></example>

<para>Notez que bien que la spécification <code>tabular</code> par défaut place un
filet vertical entre la première et la deuxième colonne, du fait qu&textrsquo;il
n&textrsquo;y pas pas de barre verticale dans aucun des patrons <var>patron</var> des
commandes <code>\multicolumn</code> des deux premières colonne, alors aucun
filet n&textrsquo;apparaît sur la première ligne.
</para>

</subsection>
<node name="_005cvline" spaces=" "><nodename>\vline</nodename><nodenext automatic="on">\cline</nodenext><nodeprev automatic="on">\multicolumn</nodeprev><nodeup automatic="on">tabular</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\vline</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="543">\vline</indexterm></findex>

<para>La commande <code>\vline</code> dessine une ligne verticale s&textrsquo;étendant sur la
totalité de la hauteur et de la profondeur de sa ligne. Une commande
<code>\hfill</code> peut être utilisée pour déplacer cette ligne verticale
vers le bord de la colonne. La commande <code>\vline</code> peut aussi être
utilisée dans une expression <code>&arobase;&lbrace;&dots;&rbrace;</code>.
</para>
<!-- c @node tabularx -->
<!-- c @comment node-name, next, previous, up -->
<!-- c @subsection @code{tabularx} -->


</subsection>
<node name="_005ccline" spaces=" "><nodename>\cline</nodename><nodenext automatic="on">\hline</nodenext><nodeprev automatic="on">\vline</nodeprev><nodeup automatic="on">tabular</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\cline</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="544">\cline</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\cline&lbrace;<var>i</var>-<var>j</var>&rbrace;
</pre></example>

<para>La commande <code>\cline</code> dessine des lignes horizontales à travers les
colonnes spécifiées en arguments obligatoires, en commençant dans la
<var>i</var> et finissant dans la colonne <var>j</var>.
</para>
</subsection>
<node name="_005chline" spaces=" "><nodename>\hline</nodename><nodeprev automatic="on">\cline</nodeprev><nodeup automatic="on">tabular</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\hline</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="545">\hline</indexterm></findex>

<para>La commande <code>\hline</code> dessine une ligne horizontale de la largeur de
l&textrsquo;environnement <code>tabular</code> ou <code>array</code> susjacent. Elle est la
plupart du temps utilisée pour dessiner une ligne au sommet, bas, et
entre les lignes d&textrsquo;un tableau.
</para>

</subsection>
</section>
<node name="thebibliography" spaces=" "><nodename>thebibliography</nodename><nodenext automatic="on">theorem</nodenext><nodeprev automatic="on">tabular</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>thebibliography</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="546"><r>environnement</r> <code>thebibliography</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="547"><code>thebibliography</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="309">bibliographie, créer (manuellement)</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;thebibliography&rbrace;&lbrace;<var>étiquette-la-plus-large</var>&rbrace;
\bibitem[<var>étiquette</var>]&lbrace;<var>clef_de_cite</var>&rbrace;
...
\end&lbrace;thebibliography&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>thebibliography</code> produit une bibliographie ou une
liste de références.  Il y a deux façons de produire des listes
bibliographiques.  Cet environnement convient quand vous avez un petit
nombre de références et pouvez maintenir la liste manuellement.
<xref label="Using-BibTeX"><xrefnodename>Using BibTeX</xrefnodename></xref>, pour une approche plus sophistiquée.
</para>
<para>L&textrsquo;exemple ci-dessous illustre l&textrsquo;environnement avec deux articles.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Ce travail s'appuie sur \cite&lbrace;latexdps&rbrace;.
Et ensemble à \cite&lbrace;latexdps, texbook&rbrace;.
  ...
\begin&lbrace;thebibliography&rbrace;&lbrace;9&rbrace;
\bibitem&lbrace;latexdps&rbrace;
  Leslie Lamport.
  \textit&lbrace;\LaTeX&lbrace;&rbrace;: a document preparation system&rbrace;.
  Addison-Wesley, Reading, Massachusetts, 1993.
\bibitem&lbrace;texbook&rbrace;
  Donald Ervin Knuth.
  \textit&lbrace;Le Texbook : Composition informatique&rbrace;.
  Vuibert, 1er août 2017.\end&lbrace;thebibliography&rbrace;
</pre></example>

<noindent></noindent>
<para>Cela formate la première référence comme <samp>[1] Leslie ...</samp>, de sorte
que <code>... s'appuie sur \cite&lbrace;latexdps&rbrace;</code> produit <samp>... s'appuie
sur [1]</samp>.  Le second <code>\cite</code> produit <samp>[1, 2]</samp>.  On doit
compile le document deux fois pour que ces numéros de référence soient
résolus.
</para>
<para>L&textrsquo;argument obligatoire <var>étiquette-la-plus-large</var> est un texte qui,
lorsqu&textrsquo;il est composé, est aussi large que la plus large des étiquettes
d&textrsquo;article produit pas les commandes <code>\bibitem</code>.  Traditionnellement
on utilise <code>9</code> pour des bibliographies de moins de 10 références,
<code>99</code> pour celles qui en on moins de 100, etc.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="548">\bibname</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="549">\refname</indexterm></findex>
<para>La liste bibliographique a un titre de bibliographie tel que
<samp>Bibliographie</samp>. Pour le changer il y a deux cas. Dans les classes
<file>book</file> et <file>report</file>, lorsque le niveau de rubricage le plus
élevé est <code>\chapter</code> et le titre par défaut <samp>Bibliographie</samp>,
ce titre est dans la macro <code>\bibname</code>. Pour <file>article</file>, lorsque
le niveau de rubricage le plus élevé est <code>\section</code> et que le titre
par défaut est <samp>Références</samp>, le titre est stocké dans la macro
<code>\refname</code>. Pour le changer redéfinissez la commande, comme dans
<code>\renewcommand&lbrace;\refname&rbrace;&lbrace;Références citées&rbrace;</code>, après
<code>\begin&lbrace;document&rbrace;</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="550"><r>paquetage</r> <code>babel</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="551"><code>babel</code>, <r>paquetage</r></indexterm></findex>

<para>Les paquetages de prise en charge linguistique comme <code>babel</code>
redéfinissent automatiquement <code>\refname</code> ou <code>\bibname</code> pour
s&textrsquo;adapter à la langue sélectionnée.
</para>
<para><xref label="list"><xrefnodename>list</xrefnodename></xref>, pour les paramètres de contrôle de disposition de la liste.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\bibitem</menunode><menudescription><pre xml:space="preserve">Spécifier un article de bibliographie.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\cite</menunode><menudescription><pre xml:space="preserve">Faire référence à un article de bibliographie.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\nocite</menunode><menudescription><pre xml:space="preserve">Inclure un article dans la bibliographie.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Utilisation de BibTex</menutitle><menunode separator=".  ">Using BibTeX</menunode><menudescription><pre xml:space="preserve">Génération automatique de bibliographies.
</pre></menudescription></menuentry></menu>


<node name="_005cbibitem" spaces=" "><nodename>\bibitem</nodename><nodenext automatic="on">\cite</nodenext><nodeup automatic="on">thebibliography</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\bibitem</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="552">\bibitem</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bibitem&lbrace;<var>clef_de_cite</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bibitem[<var>étiquette</var>]&lbrace;<var>clef_de_cite</var>&rbrace;
</pre></example>

<para>La commande <code>\bibitem</code> génère un article étiqueté par défaut par un
numéro généré en utilisant le compteur <code>enumi</code>. L&textrsquo;argument
<var>clef_de_cite</var> est une
<cindex index="cp" spaces=" "><indexterm index="cp" number="310">clef de référence bibliographique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="311">référence bibliographique, clef</indexterm></cindex>
<dfn>clef de référence bibliographique</dfn> consistant
en une chaîne quelconque de lettres, chiffres, et signes de
ponctuation (hormis la virgule).
</para>
<para><xref label="thebibliography"><xrefnodename>thebibliography</xrefnodename></xref>, pour un exemple.
</para>
<para>L&textrsquo;argument optionnel <var>étiquette</var>, lorsqu&textrsquo;il est présent, sert
d&textrsquo;étiquette et le compteur <code>enumi</code> n&textrsquo;est pas incrémenté.  Dans
l&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;thebibliography&rbrace;
\bibitem[Lamport 1993]&lbrace;latexdps&rbrace;
  Leslie Lamport.
  \textit&lbrace;\LaTeX&lbrace;&rbrace;: a document preparation system&rbrace;.
  Addison-Wesley, Reading, Massachusetts, 1993.
\bibitem&lbrace;texbook&rbrace;
  Donald Ervin Knuth.
  \textit&lbrace;Le Texbook : Composition informatique&rbrace;.
  Vuibert, 1er août 2017.
\end&lbrace;thebibliography&rbrace;
</pre></example>

<noindent></noindent>
<para>le premier article est formaté comme <samp>[Lamport 1993] Leslie ...</samp>
(la quantité d&textrsquo;espace horizontal que &latex; laisse pour l&textrsquo;étiquette
dépend de l&textrsquo;argument <var>étiquette-la-plus-large</var> de l&textrsquo;environnement
<code>thebibliography</code> ; voir <ref label="thebibliography"><xrefnodename>thebibliography</xrefnodename></ref>).
De même, <code>... s'appuyant sur \cite&lbrace;latexdps&rbrace;</code> produit
<samp>... s'appuyant sur [Lamport 1994]</samp>.
</para>
<para>Si vous mélangez des articles <code>\bibitem</code> avec et sans
<var>étiquette</var>, alors &latex; numérote ces derniers séquentiellement.
Dans l&textrsquo;exemple ci-dessus l&textrsquo;article <code>texbook</code> apparaît comme
<samp>[1] Donald ...</samp>, bien que ce soit le deuxième article.
</para>
<para>Si vous utilisez la même <var>clef_de_cite</var> deux fois, alors vous
obtenez <samp>LaTeX Warning: There were multiply-defined labels</samp>.
</para>
<para>En coulisse, &latex; se souvient de l&textrsquo;information <var>clef_de_cite</var> et
<var>étiquette</var> parce que <code>\bibitem</code> écrit dans le fichier
auxiliaire <file><var>jobname</var>.aux</file> (<pxref label="Jobname"><xrefnodename>Jobname</xrefnodename></pxref>).  Par exemple dans
l&textrsquo;exemple ci-dessus ce fichier contient
<code>\bibcite&lbrace;latexdps&rbrace;&lbrace;Lamport, 1993&rbrace;</code> et
<code>\bibcite&lbrace;texbook&rbrace;&lbrace;1&rbrace;</code>.  Le fichier <file>.aux</file> est lu par la
commande <code>\begin&lbrace;document&rbrace;</code> et alors l&textrsquo;information devient
disponible pour les commandes <code>\cite</code>.  Ceci explique qu&textrsquo;il est
nécessaire d&textrsquo;exécuter &latex; deux fois pour que les références soient
résolues : une pour l&textrsquo;écrire, et une pour le relire.
</para>
<para>À cause de cet algorithme en deux passes, quand vous ajourez un
<code>\bibitem</code> ou changez sa <var>clef_de_cite</var> vous pouvez obtenir
<samp>LaTeX Warning: Label(s) may have changed. Rerun to get
cross-references right</samp>.  La solution est de recompiler.
</para>
</subsection>
<node name="_005ccite" spaces=" "><nodename>\cite</nodename><nodenext automatic="on">\nocite</nodenext><nodeprev automatic="on">\bibitem</nodeprev><nodeup automatic="on">thebibliography</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\cite</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="553">\cite</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\cite&lbrace;<var>clefs</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\cite[<var>subcite</var>]&lbrace;<var>clefs</var>&rbrace;
</pre></example>


<para>Cette commande génère en sortie une citation des références associées à
<var>clefs</var>.  L&textrsquo;argument <var>clefs</var> est une liste d&textrsquo;une ou plus de
clefs de références bibliographiques (<pxref label="_005cbibitem"><xrefnodename>\bibitem</xrefnodename></pxref>), séparées par
des virgules.
</para>

<para>L&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">La source ultime est \cite&lbrace;texbook&rbrace;.
  ...
\begin&lbrace;thebibliography&rbrace;
\bibitem&lbrace;texbook&rbrace;
  Donald Ervin Knuth.
  \textit&lbrace;Le Texbook : Composition informatique&rbrace;.
  Vuibert, 1er août 2017.
\end&lbrace;thebibliography&rbrace;
</pre></example>

<noindent></noindent>
<para>produit une sortie du genre <samp>... ultime est [1]</samp>.  (Vous pouvez
changer l&textrsquo;apparence de la citation et de la référence en utilisant un
style de bibliographie si vous générez automatiquement l&textrsquo;environnement
<code>thebibliography</code>.  <xref label="Using-BibTeX"><xrefnodename>Using BibTeX</xrefnodename></xref>, pour plus ample
information).
</para>
<para>L&textrsquo;argument optionnel <var>subcite</var> est joint à la citation.  Par
exemple, <code>Voir 14.3 dans \cite[p.~314]&lbrace;texbook&rbrace;</code> pourrait
produire <samp>Voir 14.3 dans [1, p. 314]</samp>.
</para>
<para>En plus de ce qui apparaît en sortie, <code>\cite</code> écrit de
l&textrsquo;information dans le fichier auxiliaire <file><var>jobname</var>.aux</file>
(<pxref label="Jobname"><xrefnodename>Jobname</xrefnodename></pxref>).  Par exemple, <code>\cite&lbrace;latexdps&rbrace;</code> écrit
<samp>\citation&lbrace;latexdps&rbrace;</samp> dans ce fichier.  Cette information est
utilisée par Bib&tex; pour inclure dans vos listes de référence
seulement les ouvrages que vous avez effectivement cités ; voir aussi
<ref label="_005cnocite"><xrefnodename>\nocite</xrefnodename></ref>.
</para>
<para>Si <var>clefs</var> n&textrsquo;est pas dans votre information de bibliographie, alors
vous obtenez <samp>LaTeX Warning: There were undefined references</samp>, et
en sortie la citation s&textrsquo;affiche comme un point d&textrsquo;interrogation en gras
entre crochets.  Il y a deux causes possibles.  Si vous avez fait une
faute de frappe, comme dans <code>\cite&lbrace;texbok&rbrace;</code> alors il n&textrsquo;y a qu&textrsquo;à
la corriger.  Si par contre vous venez juste d&textrsquo;ajouter ou de modifier
l&textrsquo;information bibliographique de sorte que le fichier <file>.aux</file> est
modifié (<pxref label="_005cbibitem"><xrefnodename>\bibitem</xrefnodename></pxref>) alors la solution est d&textrsquo;exécuter de nouveau
&latex;.
</para>

</subsection>
<node name="_005cnocite" spaces=" "><nodename>\nocite</nodename><nodenext automatic="on">Using BibTeX</nodenext><nodeprev automatic="on">\cite</nodeprev><nodeup automatic="on">thebibliography</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\nocite</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="554">\nocite</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><code>\nocite&lbrace;<var>clefs</var>&rbrace;</code>
</pre></example>

<para>La commande <code>\nocite</code> ne produit aucun texte en sortie, mais écrit
<var>clefs</var> dans le fichier auxiliaire <file><var>jobname</var>.aux</file>
(<pxref label="Jobname"><xrefnodename>Jobname</xrefnodename></pxref>).
</para>
<para>L&textrsquo;argument obligatoire <var>clefs</var> est une liste d&textrsquo;une ou plusieurs
clefs de référence bibliographique (<pxref label="_005cbibitem"><xrefnodename>\bibitem</xrefnodename></pxref>). Cette information
est utilisée par Bib&tex; pour inclure ces ouvrages dans votre liste de
références même si vous ne les avez pas cités explicitement
(<pxref label="_005ccite"><xrefnodename>\cite</xrefnodename></pxref>).
</para>

</subsection>
<node name="Using-BibTeX" spaces=" "><nodename>Using BibTeX</nodename><nodeprev automatic="on">\nocite</nodeprev><nodeup automatic="on">thebibliography</nodeup></node>
<subsection spaces=" "><sectiontitle>Utilisation de Bib&tex;</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="312">utilisation de Bib&tex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="313">bib&tex;, utilisation</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="314">bibliographie, créer (automatiquement)</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="555">\bibliographystyle</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="556">\bibliography</indexterm></findex>

<para>Comme décrit dans <code>thebibliography</code> (<pxref label="thebibliography"><xrefnodename>thebibliography</xrefnodename></pxref>), une
approche sophistiqué pour gérer les bibliographies est fournie par le
programme Bib&tex;.  Ceci est uniquement une introduction ; voir la
documentation complète sur le CTAN (<pxref label="CTAN"><xrefnodename>CTAN</xrefnodename></pxref>).
</para>
<para>Avec Bib&tex; vous n&textrsquo;utilisez pas l&textrsquo;environnement
<code>thebibliography</code> directement (<pxref label="thebibliography"><xrefnodename>thebibliography</xrefnodename></pxref>). Au lieu de
cela, vous incluez les lignes :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bibliographystyle&lbrace;<var>stylebib</var>&rbrace;
\bibliography&lbrace;<var>ficbib1</var>,<var>ficbib2</var>, ...&rbrace;
</pre></example>

<noindent></noindent>
<para>L&textrsquo;argument <var>stylebib</var> fait référence à un fichier
<file><var>stylebib</var>.bst</file> définissant l&textrsquo;aspect que doivent avoir vos
référence bibliographique.  Les noms <var>stylebib</var> standards distribués
avec Bib&tex; sont :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">alpha</itemformat></item>
</tableterm><tableitem><para>Les étiquettes sont formées à partir du nom de l&textrsquo;auteur et de l&textrsquo;année de
publication. Les articles bibliographiques sont classés alphabétiquement.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">plain</itemformat></item>
</tableterm><tableitem><para>Les étiquettes sont des numéros.
Les articles sont classés alphabétiquement.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">unsrt</itemformat></item>
</tableterm><tableitem><para>Comme <code>plain</code>, mais les entrées sont dans l&textrsquo;ordre où les références
y sont faites dans le texte.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">abbrv</itemformat></item>
</tableterm><tableitem><para>Comme <code>plain</code>, mais les étiquettes sont plus compactes.
</para></tableitem></tableentry></table>

<noindent></noindent>
<para>De très nombreux autres styles Bib&tex; existent, taillés sur mesure
pour satisfaire les exigences de diverses publications. Voir le sujet
<url><urefurl>https://ctan.org/topic/bibtex-sty</urefurl></url> sur le CTAN.
</para>
<para>La commande <code>\bibliography</code> est ce qui produit pour de bon la
bibliographie. L&textrsquo;argument de <code>\bibliography</code> fait référence aux
fichiers nommés <file><var>ficbib1</var>.bib</file>, <file><var>ficbib2</var>.bib</file>,
&dots;, qui sont censés contenir votre base de données au format
Bib&tex;. L&textrsquo;exemple suivant illustre une paire typique d&textrsquo;entrées dans
ce format.
</para>
<example endspaces=" ">
<pre xml:space="preserve">&arobase;book&lbrace;texbook,
  title     = &lbrace;Le &lbrace;&lbrace;\TeX&rbrace;&rbrace;book~: composition informatique&rbrace;,
  author    = &lbrace;D.E. Knuth&rbrace;,
  isbn      = &lbrace;2-7117-4819-7&rbrace;,
  series    = &lbrace;Vuibert informatique&rbrace;,
  year      = &lbrace;2003&rbrace;,
  publisher = &lbrace;Vuibert&rbrace;
&rbrace;
&arobase;book&lbrace;sexbook,
    author    = &lbrace;W.H. Masters and V.E. Johnson&rbrace;,
    title     = &lbrace;Les r&lbrace;\'e&rbrace;action sexuelles&rbrace;,
    year      = &lbrace;1976&rbrace;,
    publisher = &lbrace;Robert Laffont&rbrace;
&rbrace;
</pre></example>

<para>Seules les entrées désignées par les commandes <code>\cite</code> ou
<code>\nocite</code> sont listées dans la bibliographie du document. De la
sorte, vous pouvez conserver toutes vos sources ensemble dans un
seul fichier, ou un petit nombre de fichiers, et compter sur Bib&tex; pour
inclure dans le document seulement celles que vous avez utilisées.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="315"><samp>*</samp>, pour faire <code>\nocite</code> sur toutes les clefs</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="557">\nocite <r>&lbrace;*&rbrace;, pour toutes les clefs</r></indexterm></findex>
<para>Avec Bib&tex;, l&textrsquo;argument <var>clefs</var> de <code>\nocite</code> peut aussi être
le caractère <samp>*</samp> tout seul.  Ceci veut dire de citer implicitement
tous les articles de toutes les bibliographies données.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">messages d&textrsquo;erreur Bib&tex;</menutitle><menunode>Bib&tex; error messages
</menunode><menudescription></menudescription></menuentry></menu>

<node name="BibTeX-error-messages" spaces=" "><nodename>Bib&tex; error messages</nodename><nodeup automatic="on">Using BibTeX</nodeup></node>
<subsubsection spaces=" "><sectiontitle>Messages d&textrsquo;erreur de Bib&tex;</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="316">Bib&tex;, messages d&textrsquo;erreur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="317">messages d&textrsquo;erreur de Bib&tex;</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="558">.aux <r>fichier et commandes Bib&tex;</r></indexterm></findex>

<para>Si vous oubliez d&textrsquo;utiliser <code>\bibliography</code> ou
<code>\bibliographystyle</code> dans votre document (ou, moins
vraisemblablement, faites un document sans aucune commande <code>\cite</code>
ni <code>\nocite</code>), alors Bib&tex; produit un message d&textrsquo;erreur.  Parce
que Bib&tex; est utilisable avec n&textrsquo;importe quel programme, et pas
seulement &latex;, les messages d&textrsquo;erreur font référence aux commandes
internes lues par Bib&tex; (du fichier <file>.aux</file>), plutôt qu&textrsquo;aux
commandes de niveau utilisateur décrites plus haut.
</para>
<para>Le tableau ci-après montre les commandes internes mentionnées dans les
erreurs Bib&tex;, et les commandes de niveau utilisateur
correspondantes.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="559">\bibdata</indexterm>\bibdata</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="560">\bibliography <r>et <code>\bibdata</code> interne</r></indexterm></findex>
<para><code>\bibliography</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="561">\bibstyle</indexterm>\bibstyle</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="562">\bibliographystyle <r>et <code>\bibstyle</code> interne</r></indexterm></findex>
<para><code>\bibliographystyle</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="563">\citation</indexterm>\citation</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="564">\cite <r>et <code>\citation</code> interne</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="565">\nocite <r>et <code>\citation</code> interne</r></indexterm></findex>
<para><code>\cite</code>, <code>\nocite</code>
</para></tableitem></tableentry></ftable>

<para>Par exemple, si votre document n&textrsquo;a aucune commande
<code>\bibliographystyle</code>, Bib&tex; s&textrsquo;en plaint ainsi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">I found no \bibstyle command---while reading file <var>document</var>.aux
</pre></example>


</subsubsection>
</subsection>
</section>
<node name="theorem" spaces=" "><nodename>theorem</nodename><nodenext automatic="on">titlepage</nodenext><nodeprev automatic="on">thebibliography</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>theorem</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="566"><r>environnement</r> <code>theorem</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="567"><code>theorem</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="318">théorèmes, composition des</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;theorem&rbrace;
  <var>corps du théorème</var>
\end&lbrace;theorem&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>theorem</code> produit « Théorème <var>n</var> » en gras
suivi de <var>corps du théorème</var>, où les possibilités de numérotation pour
<var>n</var> sont décrites par <code>\newtheorem</code> (<pxref label="_005cnewtheorem"><xrefnodename>\newtheorem</xrefnodename></pxref>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newtheorem&lbrace;lem&rbrace;&lbrace;Lemme&rbrace;      % dans le préambule
\newtheorem&lbrace;thm&rbrace;&lbrace;Théorème&rbrace;
  ...
\begin&lbrace;lem&rbrace;                  % dans le corps du document
  texte du lemme
\end&lbrace;lem&rbrace;

Le résultat suivant en découle immédiatement.
\begin&lbrace;thm&rbrace;[Gauss] % place « Gauss » entre parenthèses après le titre
  texte du théorème
\end&lbrace;thm&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="568"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="569"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="570"><r>paquetage</r> <code>amsthm</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="571"><code>amsthm</code>, <r>paquetage</r></indexterm></findex>

<para>La plupart des nouveaux documents utilisent les paquetages <code>amsthm</code>
et <code>amsmath</code> de l&textrsquo;American Mathematical Society.  Entre autres ces
paquetages incluent un grand nombre d&textrsquo;options pour les environnements de
théorèmes, telles que des options de formatage.
</para>

</section>
<node name="titlepage" spaces=" "><nodename>titlepage</nodename><nodenext automatic="on">verbatim</nodenext><nodeprev automatic="on">theorem</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>titlepage</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="572"><r>environnement</r> <code>titlepage</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="573"><code>titlepage</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="319">fabriquer une page de titre</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="320">pages de titre, création</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;titlepage&rbrace;
  ... texte et espacement ...
\end&lbrace;titlepage&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>titlepage</code> crée une page de titre, c&textrsquo;est à dire
une page sur laquelle ne sont inscrit aucun numéro de page ou libellé de
rubrique. Il entraîne aussi que la page suivante a le numéro un.
</para>

<para>Dans l&textrsquo;exemple suivant tout le formatage, y compris l&textrsquo;espacement
vertical, est laissé à l&textrsquo;auteur.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;titlepage&rbrace;
\vspace*&lbrace;\stretch&lbrace;1&rbrace;&rbrace;
\begin&lbrace;center&rbrace;
  &lbrace;\huge\bfseries Thèse \\[1ex]
                  titre&rbrace;                  \\[6.5ex]
  &lbrace;\large\bfseries Nom de l'auteur&rbrace;           \\
  \vspace&lbrace;4ex&rbrace;
  Thèse soumise à                    \\[5pt]
  \textit&lbrace;Nom de l'université&rbrace;                \\[2cm]
  pour obtenir le grade de \\[2cm]
  \textsc&lbrace;\Large Docteeur en&rbrace;    \\[2ex]
  \textsc&lbrace;\large Mathématiques&rbrace;             \\[12ex]
  \vfill
  Departement de Mathématiques               \\
  Adresse                                 \\
  \vfill
  \today
\end&lbrace;center&rbrace;
\vspace&lbrace;\stretch&lbrace;2&rbrace;&rbrace;
\end&lbrace;titlepage&rbrace;
</pre></example>

<para>Pour produire par contre une une page de titre standarde sans utiliser
l&textrsquo;environnement <code>titlepage</code>, utilisez la commande <code>\maketitle</code>
(<pxref label="_005cmaketitle"><xrefnodename>\maketitle</xrefnodename></pxref>).
</para>

</section>
<node name="verbatim" spaces=" "><nodename>verbatim</nodename><nodenext automatic="on">verse</nodenext><nodeprev automatic="on">titlepage</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>verbatim</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="574"><r>environnement</r> <code>verbatim</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="575"><code>verbatim</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="321">texte verbatim</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="322">simuler du texte tapuscrit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="323">texte tapuscrit, simulation de</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="324">code source, composer du</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="325">programmes informatiques, composer du</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;verbatim&rbrace;
<var>texte-litéral</var>
\end&lbrace;verbatim&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>verbatim</code> est un environnement qui fabrique des
paragraphes dans lequel &latex; produit exactement ce qui vous y tapez.
Par exemple au sein de <var>texte-litéral</var> le caractère <code>\</code> ne
commence pas de commande, il produit <samp>\</samp> à l&textrsquo;impression, et les
retours chariot et les blancs sont pris littéralement. La sortie
apparaît dans une police genre tapuscrit (encore appelé « machine à
écrire ») à chasse fixe (<code>\tt</code>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;verbatim&rbrace;
Juron symbolique : %&amp;$#?&eosexcl;.
\end&lbrace;verbatim&rbrace;
</pre></example>

<para>La seule restriction sur <code>text-literale</code> est qu&textrsquo;il ne peut pas
inclure la chaîne <code>\end&lbrace;verbatim&rbrace;</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="576"><r>paquetage</r> <code>cprotect</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="577"><code>cprotect</code>, <r>paquetage</r></indexterm></findex>


<para>Il est impossible d&textrsquo;utiliser l&textrsquo;environnement <code>verbatim</code> au sein
d&textrsquo;un argument de macro, par exemple dans l&textrsquo;argument passé à
<code>\section</code>. Ce n&textrsquo;est pas le même problème que celui des commandes
fragiles (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>), mais c&textrsquo;est juste impossible parce que
l&textrsquo;environnement <code>verbatim</code> change le régime de catcode avant de
traiter son contenu, et le rétablit juste après, or au sein d&textrsquo;un argument
de macro le contenu de l&textrsquo;argument est déjà converti en une liste
d&textrsquo;unités lexicales selon le régime de catcode courant à l&textrsquo;appel de la
macro.  Cependant, le paquetage <code>cprotect</code> peut être utile dans
cette situation.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="578"><r>paquetage</r> <code>listings</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="579"><code>listings</code>, <r>paquetage</r></indexterm></findex>
 <findex index="fn" spaces=" "><indexterm index="fn" number="580"><r>paquetage</r> <code>minted</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="581"><code>minted</code>, <r>paquetage</r></indexterm></findex>

<para>Une utilisation courante d&textrsquo;entrée verbatim est de composer du code
informatique.  Il y a des paquetages qui améliorent l&textrsquo;environnement
<code>verbatim</code>.  Par exemple, une amélioration est de permettre
l&textrsquo;inclusion verbatim de fichiers externes, totalement ou en
partie. Parmi ces paquetages : <code>listings</code> et <code>minted</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="582"><r>paquetage</r> <code>fancyvrb</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="583"><code>fancyvrb</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="584"><r>paquetage</r> <code>verbatimbox</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="585"><code>verbatimbox</code>, <r>paquetage</r></indexterm></findex>

<para>Un paquetage qui offre beaucoup plus d&textrsquo;options pour les environnements
verbatim est <code>fancyvrb</code>.  Un autre <code>verbatimbox</code>.
</para>
<para>Pour une liste complète de tous les paquetages pertinents voir le CTAN (<pxref label="CTAN"><xrefnodename>CTAN</xrefnodename></pxref>).
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\verb</menunode><menudescription><pre xml:space="preserve">La forme macro de l&textrsquo;environnement <code>verbatim</code>.
</pre></menudescription></menuentry></menu>

<node name="_005cverb" spaces=" "><nodename>\verb</nodename><nodeup automatic="on">verbatim</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\verb</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="586">\verb</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="326">texte verbatim, en-ligne</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\verb<var>car</var><var>texte-littéral</var><var>car</var>
\verb*<var>car</var><var>texte-littéral</var><var>car</var>
</pre></example>

<para>La commande <code>\verb</code> compose <var>texte-littéral</var> comme il est
entré, en incluant les caractères spéciaux et les espaces, en utilisant
la police tapuscrit (<code>\tt</code>). Aucun espaces n&textrsquo;est autorisé entre
<code>\verb</code> ou <code>\verb*</code> et le délimiteur <var>car</var> qui marque le
début et la fin du texte verbatim. Le délimiteur ne doit pas apparaître
dans le <var>texte-littéral</var>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="327">espace visible</indexterm></cindex>
<para>La forme étoilée (en <code>*</code>) diffère seulement en ce que les espaces
sont tapés avec un caractère « espace visible ».
<tex endspaces=" ">
</tex>
</para>
<para>La sortie correspondant à ce qui suit utilise un espace visible de part
et d&textrsquo;autre du mot <samp>with</samp> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Le premier argument de la commande est \verb*!filename with extension! et ...
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="587"><r>paquetage</r> <code>url</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="588"><code>url</code>, <r>paquetage</r></indexterm></findex>

<para>Pour composer des adresses réticulaires, appelée aussi URL, le paquetage
<code>url</code> est une option préférable à la commande <code>\verb</code>, puisque
il permet les sauts de ligne.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="589"><r>paquetage</r> <code>listings</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="590"><code>listings</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="591"><r>paquetage</r> <code>minted</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="592"><code>minted</code>, <r>paquetage</r></indexterm></findex>

<para>Pour du code informatique il y a beaucoup de paquetages plus avantageux
que <code>\verb</code>.  L&textrsquo;un est <code>listings</code>, un autre <code>minted</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="593"><r>paquetage</r> <code>cprotect</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="594"><code>cprotect</code>, <r>paquetage</r></indexterm></findex>

<para>Vous ne pouvez pas utiliser <code>\verb</code> au sein d&textrsquo;un argument de macro,
par exemple dans l&textrsquo;argument passé à <code>\section</code>.  Ce n&textrsquo;est pas une
question que <code>\verb</code> serait fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>), mais c&textrsquo;est
juste impossible parce que la commande <code>\verb</code> change le régime de
catcode avant de lire son argument et le rétablit juste après, or au sein
d&textrsquo;un argument de macro le contenu de l&textrsquo;argument a déjà été converti en
une liste d&textrsquo;unités lexicales selon le régime de catcode courant l&textrsquo;appel
de la macro. Cependant, le paquetage <code>cprotect</code> peut être utile
dans cette situation.
</para>

</subsection>
</section>
<node name="verse" spaces=" "><nodename>verse</nodename><nodeprev automatic="on">verbatim</nodeprev><nodeup automatic="on">Environments</nodeup></node>
<section spaces=" "><sectiontitle><code>verse</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="595"><r>environnement</r> <code>verse</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="596"><code>verse</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="328">poésie, un environnement pour la</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;verse&rbrace;
  <var>line1</var> \\
  <var>line2</var> \\
...
\end&lbrace;verse&rbrace;
</pre></example>

<para>L&textrsquo;environnement <code>verse</code> est conçu pour la poésie.
</para>
<para>Voici un vers tiré du <i>Cid</i>  de Pierre Corneille :
</para>
<example endspaces=" ">
<pre xml:space="preserve">% dans le préambule :
\newcommand*\Role[1]&lbrace;\makebox[\linewidth][c]&lbrace;\textbf&lbrace;\textsc&lbrace;#1&rbrace;&rbrace;&rbrace;\\*&rbrace;   
...   
\begin&lbrace;verse&rbrace;
  ...

\Role&lbrace;Chimène&rbrace;
Va, je ne te hais point.\\
\Role&lbrace;Don Rodrigue&rbrace;
\phantom&lbrace;Va, je ne te hais point. &rbrace;Tu le dois.\\
\Role&lbrace;Chimène&rbrace;
\phantom&lbrace;Va, je ne te hais point. Tu le dois. &rbrace;Je ne puis.\\
   ...
\end&lbrace;verse&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="597">\\ <r>(pour <code>verse</code>)</r></indexterm></findex>
<para>Séparez les lignes de chaque strophe avec <code>\\</code>, et utilisez une ou
plusieurs lignes vides pour séparer les strophes.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;verse&rbrace;
\makebox[\linewidth][c]&lbrace;\textit&lbrace;De soy-même&rbrace; --- Clément Marot&rbrace;
  \\[1\baselineskip]
Plus ne suis ce que j'ai été     \\  
Et plus ne saurai jamais l'être  \\
Mon beau printemps et mon été    \\
Ont fait le saut par la fenêtre

Amour tu as été mon maître       \\
Je t'ai servi sur tous les dieux \\
Ah si je pouvais deux fois naître\\
Comme je te servirais mieux
\end&lbrace;verse&rbrace;
</pre></example>

<noindent></noindent>
<para>En sortie, les marges sont renfoncées sur la gauche et la droite, les
paragraphes ne le sont pas, et le texte n&textrsquo;est pas justifié à droite.
</para>
</section>
</chapter>
<node name="Line-breaking" spaces=" "><nodename>Line breaking</nodename><nodenext automatic="on">Page breaking</nodenext><nodeprev automatic="on">Environments</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Saut à la ligne</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="329">saut à la ligne</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="330">sauter à la ligne</indexterm></cindex>

<para>La première chose que &latex; fait lorsqu&textrsquo;il traite du texte ordinaire
est de traduire votre fichier d&textrsquo;entrée en une séquence de glyphes et
d&textrsquo;espaces. Pour produire un document imprimé, cette séquence doit être
rompue en lignes (et ces lignes doivent être rompues en pages).
</para>
<para>D&textrsquo;ordinaire &latex; effectue pour vous les sauts de ligne (et de page)
dans le corps du texte, mais dans certains environnements vous forcez
manuellement les sauts.
</para>
<para>Un flux de production communément utilisé est d&textrsquo;obtenir une version
finale du contenu du document avant de faire une passe finale dessus et
de considérer le sauts de ligne (et de page). La plupart des gens ne
considèrent pas que &latex; est un traitement de texte parce qu&textrsquo;il
n&textrsquo;affiche pas instantanément la sortie. Toutefois, différer la sortie
encourage l&textrsquo;utilisateur à remettre jusqu&textrsquo;à la fin des ajustements de
format, et ainsi évite bien des va-et-vient sur des sauts susceptibles
de rechanger.
</para>
<noindent></noindent>
<para>Différer la sortie a d&textrsquo;autres avantages : cela permet de ne faire aucun
compromis sur la composition, ce qui assure que ce qu&textrsquo;on voit est
exactement ce qu&textrsquo;on obtient, et cela aide également les auteurs à se
concentrer soit sur écrire, soit sur se relire, plutôt que les distraire
en faisant les deux à la fois.
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\\</menunode><menudescription><pre xml:space="preserve">Commencer une nouvelle ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\obeycr &amp; \restorecr</menunode><menudescription><pre xml:space="preserve">Faire que chaque ligne d&textrsquo;entrée commence une nouvelle ligne de sortie.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newline</menunode><menudescription><pre xml:space="preserve">Sauter à la ligne
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">\- (césure)</menutitle><menunode separator=". ">\- (hyphenation)</menunode><menudescription><pre xml:space="preserve">Insérer une césure explicite.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\discretionary</menunode><menudescription><pre xml:space="preserve">Contrôler explicitement le caractère de césure.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\fussy &amp; \sloppy</menunode><menudescription><pre xml:space="preserve">Être plus ou moins exigeant sur le passage à la ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\hyphenation</menunode><menudescription><pre xml:space="preserve">Dire à &latex; comment gérer la césure d&textrsquo;un mot.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\linebreak &amp; \nolinebreak</menunode><menudescription><pre xml:space="preserve">Forcer &amp; éviter les sauts à la ligne.
</pre></menudescription></menuentry></menu>


<node name="_005c_005c" spaces=" "><nodename>\\</nodename><nodenext automatic="on">\obeycr &amp; \restorecr</nodenext><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\\</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="598">\\ <r>(force un saut de ligne)</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="331">nouvelle ligne, commencer une</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="332">saut de ligne, forcer</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\\
\\[<var>espaceenplus</var>]
</pre></example>

<noindent></noindent>
<para>ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\\*
\\*[<var>espaceenplus</var>]
</pre></example>

<para>Finit la ligne courante.  L&textrsquo;argument optionnel <var>espaceenplus</var>
spécifie l&textrsquo;espace supplémentaire vertical à insérer avant la ligne
suivante. C&textrsquo;est une longueur élastique (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>) et elle peut
être négative. Le texte avant le saut est composé à sa longueur normale,
c.-à-d.&noeos; qu&textrsquo;il n&textrsquo;est pas dilaté pour remplir la largeur de la
ligne. Cette commande est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\title&lbrace;Mon histoire~: \\[7mm]
       un conte pathétique&rbrace;
</pre></example>

<noindent></noindent>
<para>La forme étoilée, <code>\\*</code>, dit à &latex; de ne pas commencer une
nouvelle page entre les deux lignes, en émettant un <code>\nobreak</code>.
</para>
<para>Les sauts de ligne explicites au sein du corps de texte sont inhabituels
en &latex;.  En particulier, ne commencez pas un nouveau paragraphe
avec <code>\\</code>, mais laissez une ligne à blanc pour le faire. De même,
on mettez pas une séquence de <code>\\</code> pour créer un espace vertical,
mais utilisez à la place <code>\vspace&lbrace;<var>longueur</var>&rbrace;</code>,
<code>\leavevmode\vspace&lbrace;<var>longueur</var>&rbrace;</code>, ou
<code>\vspace*&lbrace;<var>longueur</var>&rbrace;</code> si on veut que l&textrsquo;espace ne soit pas
supprimé au sommet d&textrsquo;une nouvelle page (<pxref label="_005cvspace"><xrefnodename>\vspace</xrefnodename></pxref>).
</para>
<para>Cette commande est utilisée principalement en dehors du flux principal
de texte comme dans un environnement <code>tabular</code> ou <code>array</code> ou
dans un environnement d&textrsquo;équation.
</para>
<para>La commande <code>\newline</code> est un synonyme de <code>\\</code>
(<pxref label="_005cnewline"><xrefnodename>\newline</xrefnodename></pxref>) dans des circonstances ordinaires (un exemple
d&textrsquo;exception est la colonne de type <code>p&lbrace;...&rbrace;</code> dans un environnement
<code>tabular</code> ; <pxref label="tabular"><xrefnodename>tabular</xrefnodename></pxref>) .
</para>
<!-- c credit: David Carlisle https://tex.stackexchange.com/a/82666 -->
<para>La commande <code>\\</code> est une macro, et sa définition change selon le
contexte, de sorte que sa définition diffère pour chaque cas selon qu&textrsquo;on
est dans du texte normal, ou dans un environnement <code>center</code>, ou
<code>flushleft</code>, ou <code>tabular</code>. Dans du texte normal quand elle
force un saut de ligne, elle est essentiellement un raccourci pour
<code>\newline</code>.  Elle ne termine ni le mode horizontal ni le
paragraphe, mais insère juste un ressort et une pénalité de sorte que
lorsque le paragraphe se termine un saut de ligne se produit à cet
<!-- c xx TODO introduire le terme « ligne creuse ». -->
endroit, avec la ligne plus courte bourrée avec de l&textrsquo;espace blanc.
</para>
<para>Vous obtenez l&textrsquo;erreur <samp>LaTeX Error: There's no line here to end</samp> si
vous utilisez <code>\\</code> pour demander une nouvelle ligne, plutôt que
pour finir la ligne courante. Par exemple si vous avez
<code>\begin&lbrace;document&rbrace;\\</code> ou, plus vraisemblablement, quelque chose du
genre de :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \begin&lbrace;minipage&rbrace;&lbrace;0.5\textwidth&rbrace;
  \\
  Dans cet espace vertical apposez votre marque.
  \end&lbrace;minipage&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<para>La solution est de remplacer la double controblique par quelque chose
du genre de <code>\vspace&lbrace;\baselineskip&rbrace;</code>.
</para>

</section>
<node name="_005cobeycr-_0026-_005crestorecr" spaces=" "><nodename>\obeycr &amp; \restorecr</nodename><nodenext automatic="on">\newline</nodenext><nodeprev automatic="on">\\</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\obeycr</code> &amp; <code>\restorecr</code></sectiontitle>

<anchor name="_005cobeycr">\obeycr</anchor>
<anchor name="_005crestorecr">\restorecr</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="599">\obeycr</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="600">\restorecr</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="333">saut de ligne, sortie semblable à l&textrsquo;entrée pour le</indexterm></cindex>

<para>La commande <code>\obeycr</code> a pour effet qu&textrsquo;un retour chariot dans le
fichier d&textrsquo;entrée (<samp>^^M</samp>, internement) soit traité de la même façon
que <code>\\</code> suivi d&textrsquo;un <code>\relax</code>. Ainsi chaque passage à la ligne
dans l&textrsquo;entrée est aussi un passage à la ligne dans la sortie.  La
commande <code>\restorecr</code> restaure le comportement normal vis à vis des
sauts de ligne.
</para>
<para>Ceci n&textrsquo;est pas la façon d&textrsquo;afficher textuellement du texte ou du code
informatique.  Utilisez plutôt <code>verbatim</code> (<pxref label="verbatim"><xrefnodename>verbatim</xrefnodename></pxref>).
</para>
<para>Avec les réglages par défaut habituels de &latex;, l&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">aaa
bbb

\obeycr
ccc
ddd
   eee

\restorecr
fff
ggg

hhh
iii
</pre></example>

<noindent></noindent>
<para>produit en sortie quelque chose du genre de :
</para>
<example endspaces=" ">
<pre xml:space="preserve">  aaa bbb
  ccc
ddd
eee

fff ggg
  hhh iii
</pre></example>

<noindent></noindent>
<para>où les renfoncements sont des renfoncements de paragraphes.
</para>

</section>
<node name="_005cnewline" spaces=" "><nodename>\newline</nodename><nodenext automatic="on">\- (hyphenation)</nodenext><nodeprev automatic="on">\obeycr &amp; \restorecr</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\newline</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="601">\newline</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="334">nouvelle ligne, commencer une (mode paragraphe)</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="335">saut de ligne</indexterm></cindex>

<para>Dans du texte ordinaire, cette commande termine une ligne d&textrsquo;une façon
qui ne la justifie pas à droite, de sorte que le texte précédent la fin
de ligne n&textrsquo;est pas étiré. c.-à-d.&noeos; que, en mode paragraphe
(<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>), la commande <code>\newline</code> est équivalente à une
double-controblique (<pxref label="_005c_005c"><xrefnodename>\\</xrefnodename></pxref>). Cette commande est fragile
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Toutefois, les deux commandes diffèrent au sein d&textrsquo;un environnement
<code>tabular</code> ou <code>array</code>. Dans une colonne avec un spécificateur
produisant une boîte paragraphe, comme typiquement <code>p&lbrace;..&rbrace;</code>,
<code>\newline</code> insère un saut de ligne au sein de la colonne, c.-à-d.&noeos;
insère une fin de ligne à l&textrsquo;intérieur de la colonne, c.-à-d.&noeos; qu&textrsquo;elle
ne rompt pas la ligne entière de tableau. Pour rompre la ligne entière
utilisez <code>\\</code> ou son équivalent <code>\tabularnewline</code>.
</para>
<para>L&textrsquo;exemple suivant écrit <samp>Nom~:</samp> et <samp>Adresse~:</samp> comme deux
lignes au sein d&textrsquo;une seule cellule du tableau.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;p&lbrace;2.5cm&rbrace;&arobase;&lbrace;\hspace&lbrace;5cm&rbrace;&rbrace;p&lbrace;2.5cm&rbrace;&rbrace;
  Nom~: \newline Adresse~: &amp;Date~: \\ \hline
\end&lbrace;tabular&rbrace;
</pre></example>

<para>La <samp>Date~:</samp> sera alignée sur la ligne de base de <samp>Nom~:</samp>.
</para>
</section>
<node name="_005c_002d-_0028hyphenation_0029" spaces=" "><nodename>\- (hyphenation)</nodename><nodenext automatic="on">\discretionary</nodenext><nodeprev automatic="on">\newline</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\-</code> (césure à gré)</sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="602">\- <r>(césure)</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="336">césure, forcer</indexterm></cindex>

<para>La commande <code>\-</code> dit à &latex; qu&textrsquo;il peut faire une césure du mot
à cet endroit. Quand vous insérez des commandes <code>\-</code> dans un mot,
le mot ne pourra subir de césure qu&textrsquo;à ces endroits et non dans aucun des
autres points de césure que &latex; aurait pu choisir sinon.  Cette
commande est robuste (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>&latex; est bon en ce qui concerne les césures, et il trouve la plupart
des points corrects de césure, tout en n&textrsquo;en utilisant presque jamais un
incorrect. La commande <code>\-</code> est utilisée pour les cas
exceptionnels.
</para>
<para>Par ex., &latex; d&textrsquo;ordinaire ne fait pas de césure dans les mots
contenant un trait d&textrsquo;union. Ci-dessous le mot long et portant une césure
indique que &latex; doit insérer des espaces inacceptablement long pour
composer la colonne étroite :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;rp&lbrace;4.5cm&rbrace;&rbrace;
   Isaac Asimov &amp;La tradition de
   l'anti-intellectualisme
   % l'an\-ti-in\-tel\-lec\-tu\-al\-isme
   a été une tendance constante, qui a fait son chemin dans notre vie
   politique et culturelle, nourrie par la fausse idée que la démocratie
   signifie que mon ignorance vaut autant que votre savoir.
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>Si on met en commentaire la troisième ligne et sort de commentaire la
quatrième, alors les choses s&textrsquo;ajusteront bien mieux.
</para>
<para>La commande <code>\-</code> ne fait qu&textrsquo;autoriser &latex; à faire une césure à
cet endroit, elle ne force pas la césure.  Vous pouvez forcer la césure
avec quelque chose du genre de <code>ef-\linebreak farons</code>.  Bien sûr,
si vous changez plus tard le texte, alors cette césure forcée pourrait
avoir l&textrsquo;air très étrange, c&textrsquo;est pourquoi cette approche demande de
l&textrsquo;attention.
</para>

</section>
<node name="_005cdiscretionary" spaces=" "><nodename>\discretionary</nodename><nodenext automatic="on">\fussy &amp; \sloppy</nodenext><nodeprev automatic="on">\- (hyphenation)</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\discretionary</code> (point de césure généralisé)</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="337">césure discrétionnaire</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="338">césure à gré</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="339">à gré, césure</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="340">discrétionnaire, césure</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\discretionary&lbrace;<var>avant-saut</var>&rbrace;&lbrace;<var>après-saut</var>&rbrace;&lbrace;<var>sans-saut</var>&rbrace;
</pre></example>

<para>Gère la modification d&textrsquo;un mot autour d&textrsquo;une césure. Cette commande est
d&textrsquo;un usage rare dans les documents &latex;.
</para>
<para>Si un saut de ligne survient au point où <code>\discretionary</code> apparaît,
alors &tex; met <var>avant-saut</var> à la fin de la ligne courante et met
<var>après-saut</var> au début de la ligne suivante. S&textrsquo;il n&textrsquo;y a pas de saut à
cet endroit alors &tex; met <var>sans-saut</var>.
</para>
<para>Dans le mot <samp>difficile</samp> les trois lettres <code>ffi</code> forment une
ligature. &tex; peut néanmoins faire un saut entre les deux <samp>f</samp>
avec ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">di\discretionary&lbrace;f-&rbrace;&lbrace;fi&rbrace;&lbrace;ffi&rbrace;cile
</pre></example>

<para>Notez que l&textrsquo;utilisateur n&textrsquo;a pas à faire ceci. C&textrsquo;est typiquement géré
automatiquement par l&textrsquo;algorithme de césure de &tex;.
</para>
<para>Les arguments de <code>\discretionary</code> ne peuvent contenir que des
caractères, des boîtes ou des crénages.
</para>
<para>La commande <code>\discretionary</code> permet de contrôler
finement la césure dans les cas où ne suffisent ni le contrôle standard
de la césure fait l&textrsquo;algorithme de césure de &tex; et les règles de
césures données par les paquetages de gestion linguistiques, ni les
moyens de contrôle explicites offerts par les commandes
<code>\hyphenation</code> (<pxref label="_005chyphenation"><xrefnodename>\hyphenation</xrefnodename></pxref>) et <code>\-</code> (<pxref label="_005c_002d-_0028hyphenation_0029"><xrefnodename>\-
(hyphenation)</xrefnodename><xrefinfoname>\- (césure à gré)</xrefinfoname></pxref>).
</para>
<para>L&textrsquo;usage typique de <code>\discretionary</code> est par exemple de contrôler la
césure au sein d&textrsquo;une formule mathématique en mode ligne (voir aussi
<ref label="Math-miscellany"><xrefnodename>Math miscellany</xrefnodename><xrefinfoname>Miscellanées mathématique (entrée \*)</xrefinfoname></ref>). Ci-dessous
un exemple de contrôle de la césure au sein d&textrsquo;une adresse réticulaire,
où l&textrsquo;on autorise la césure sur les obliques mais en utilisant une
controblique violette en lieu de trait d&textrsquo;union :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\usepackage[T1]&lbrace;fontenc&rbrace;
\usepackage[utf8]&lbrace;inputenc&rbrace;
\usepackage&lbrace;xcolor&rbrace;
\usepackage&lbrace;hyperref&rbrace;
\usepackage&lbrace;french&rbrace;
\newcommand*\DiscrSlash&lbrace;\discretionary&lbrace;\mbox&lbrace;\textcolor
 &lbrace;purple&rbrace;&lbrace;\textbackslash&rbrace;&rbrace;&rbrace;&lbrace;/&rbrace;&lbrace;/&rbrace;&rbrace;
\begin&lbrace;document&rbrace;
Allez donc à \href&lbrace;http://une/tr\%c3\%A8s/tr\%c3\%A8s/longue%
  /mais/vraiment/tr\%c3\%A8s/longue/adresse/r\%C3\%A9ticulaire%
  /index.html&rbrace;&lbrace;http://une\DiscrSlash très\DiscrSlash très\DiscrSlash
  longue\DiscrSlash mais\DiscrSlash vraiment\DiscrSlash
  très\DiscrSlash longue\DiscrSlash adresse\DiscrSlash
  réticulaire\DiscrSlash index.html&rbrace;
\end&lbrace;document&rbrace;
</pre></example>


</section>
<node name="_005cfussy-_0026-_005csloppy" spaces=" "><nodename>\fussy &amp; \sloppy</nodename><nodenext automatic="on">\hyphenation</nodenext><nodeprev automatic="on">\discretionary</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\fussy</code> &amp; <code>\sloppy</code></sectiontitle>

<anchor name="_005cfussy">\fussy</anchor>
<anchor name="_005csloppy">\sloppy</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="603">\fussy</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="604">\sloppy</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="341">sauts de ligne, changer</indexterm></cindex>

<para>Ce sont des déclarations pour que &tex; fasse plus ou moins le difficile
à propos des sauts de ligne. Déclarer <code>\fussy</code> évite en général
trop d&textrsquo;espace entre les mots, au prix d&textrsquo;occasionnellement une boîte trop
pleine ((<samp>overfull \hbox</samp>)). Inversement <code>\sloppy</code> évite les
boîtes trop pleines mais en pâtissant d&textrsquo;un espacement inter-mot relâché.
</para>
<para>Le réglage par défaut est <code>\fussy</code>.  Les sauts de ligne au sein
d&textrsquo;un paragraphe sont contrôlés par celle-là des deux déclarations qui
est en cours à la fin du paragraphe, c.-à-d.&noeos; à la ligne à blanc, la
commande <code>\par</code> ou l&textrsquo;équation hors texte terminant ce
paragraphe. De sorte que pour affecter les sauts de ligne vous devez
inclure la matière qui termine le paragraphe dans la portée de la
commande.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::          ">sloppypar</menunode><menudescription><pre xml:space="preserve">Version environnement de la commande \sloppy.
</pre></menudescription></menuentry></menu>


<node name="sloppypar" spaces=" "><nodename>sloppypar</nodename><nodeup automatic="on">\fussy &amp; \sloppy</nodeup></node>
<subsection spaces=" "><sectiontitle><code>sloppypar</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="605"><r>environnement</r> <code>sloppypar</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="606"><code>sloppypar</code>, <r>environnement</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="342">sloppypar, environnement</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;sloppypar&rbrace;
  ... paragraphes ...
\end&lbrace;sloppypar&rbrace;
</pre></example>

<para>Compose les paragraphes avec <code>\sloppy</code> en vigueur (<pxref label="_005cfussy-_0026-_005csloppy"><xrefnodename>\fussy &amp;
\sloppy</xrefnodename></pxref>).  Utilisez cela pour ajuster localement les sauts de ligne,
pour éviter les erreurs <samp>Overfull box</samp> ou <samp>Underfull box</samp>.
</para>
<para>Voici un exemple simple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;sloppypar&rbrace;
   Son plan arrêté de la sorte pour la matinée, dès qu’elle eut déjeuné,
   elle prit \emph&lbrace;Udolphe&rbrace; et s’assit, décidée à rester toute à sa
   lecture jusqu’à ce que la pendule marquât une heure. Cependant, et
   sans que Catherine en fût importunée (l’habitude\ldots), des phrases
   sans suite fluaient de Mme Allen~: elle ne parlait jamais beaucoup,
   faute de penser, et, pour la même raison, n’était jamais complètement
   silencieuse. Qu’elle perdît son aiguille, cassât son fil, entendît le
   roulement d’une voiture, aperçût une petite tache sur sa robe, elle
   le disait, qu’il y eût là ou non quelqu’un pour la réplique.
\end&lbrace;sloppypar&rbrace;
</pre></example>


</subsection>
</section>
<node name="_005chyphenation" spaces=" "><nodename>\hyphenation</nodename><nodenext automatic="on">\linebreak &amp; \nolinebreak</nodenext><nodeprev automatic="on">\fussy &amp; \sloppy</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\hyphenation</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="607">\hyphenation</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="343">césure, définir</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\hyphenation&lbrace;<var>mot1</var> ...&rbrace;
</pre></example>

<para>La commande <code>\hyphenation</code> déclare les points de césure autorisés
au sein des mots donnés dans la liste. Les mots de cette liste sont
séparés par des espaces. Spécifiez les points de césure autorisés avec
le caractère tiret, <code>-</code>.
</para>
<para>Utilisez des lettres en bas de casse.  &tex; ne fera de césure que si le
mot correspond exactement, aucune désinence n&textrsquo;est essayée. Des commandes
<code>\hyphenation</code> multiples s&textrsquo;accumulent.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="608"><r>paquetage</r> <code>babel</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="609"><code>babel</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="610"><r>paquetage</r> <code>polyglossia</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="611"><code>polyglossia</code>, <r>paquetage</r></indexterm></findex>

<para>Les paquetages d&textrsquo;internationalisation du genre de <code>babel</code> ou
<code>polyglossia</code> chargent déjà les motifs de césure de la langue
courante, aussi on n&textrsquo;utilise la commande <code>\hyphenation</code> que pour
les mots qui n&textrsquo;y existent pas.
</para>
<para>Voici un exemple :
</para>
<!-- c cf. citations d' A. Finkelkraut -->
<example endspaces=" ">
<pre xml:space="preserve">\hyphenation&lbrace;rhi-no-fé-roce sex-cuse doc-tam-bule œdi-peux&rbrace;
</pre></example>


<findex index="fn" spaces=" "><indexterm index="fn" number="612"><r>paquetage</r> <code>fontenc</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="613"><code>fontenc</code>, <r>paquetage</r></indexterm></findex>

<para>Dans une langue s&textrsquo;écrivant avec des diacritiques, comme le français ou
le polonais, la césure ne fonctionne correctement avec le moteur
<command>pdflatex</command> qu&textrsquo;avec des codages modernes (<pxref label="TeX-engines"><xrefnodename>&tex;
engines</xrefnodename></pxref>). Il faut donc charger <code>fontenc</code> avec un autre codage
qu&textrsquo;<code>OT1</code>, typiquement pour le français on utilise <code>T1</code>
(<pxref label="fontenc-package"><xrefnodename>fontenc package</xrefnodename></pxref>).
</para>

</section>
<node name="_005clinebreak-_0026-_005cnolinebreak" spaces=" "><nodename>\linebreak &amp; \nolinebreak</nodename><nodeprev automatic="on">\hyphenation</nodeprev><nodeup automatic="on">Line breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\linebreak</code> &amp; <code>\nolinebreak</code></sectiontitle>

<anchor name="_005clinebreak">\linebreak</anchor>
<anchor name="_005cnolinebreak">\nolinebreak</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="614">\linebreak</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="615">\nolinebreak</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="344">sauts de ligne, forcer</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="345">sauts de ligne, empêcher</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\linebreak
\linebreak[<var>de-zéro-à-quatre</var>]
</pre></example>

<noindent></noindent>
<para>ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\nolinebreak
\nolinebreak[<var>de-zéro-à-quatre</var>]
</pre></example>

<para>Encourage (<code>\linebreak</code>) ou décourage (<code>\nolinebreak</code>) un saut
de ligne. L&textrsquo;argument optionnel <var>de-zéro-à-quatre</var> est un entier
compris entre 0 et 4 qui vous permet d&textrsquo;adoucir l&textrsquo;instruction. Le réglage
par défaut est 4, de sorte que sans l&textrsquo;argument optionnel respectivement
la commande force ou interdit le saut. Mais par exemple,
<code>\nolinebreak[1]</code> est une suggestion qu&textrsquo;il serait préférable de
faire le saut à un autre endroit. Plus le nombre est grand, et plus la
requête est insistante. Les deux commandes sont fragiles
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple suivant on dit à &latex; qu&textrsquo;un bon endroit ou faire un
saut de ligne est après le <code>\blablajuridique</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\blablajuridique&lbrace;&rbrace;\linebreak[2] Nous rappelons que le port de signes
ostentatoires d'appartenance à une communauté religieuse est interdit
parmi le personnel au contact du public.
</pre></example>

<para>Quand vous émettez un <code>\linebreak</code>, les espaces de la ligne sont
dilatés de sorte que le point du saut atteigne la marge de
droite. <xref label="_005c_005c"><xrefnodename>\\</xrefnodename></xref> et <ref label="_005cnewline"><xrefnodename>\newline</xrefnodename></ref>, pour ne pas dilater les espaces.
</para>

</section>
</chapter>
<node name="Page-breaking" spaces=" "><nodename>Page breaking</nodename><nodenext automatic="on">Footnotes</nodenext><nodeprev automatic="on">Line breaking</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Saut de page</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="346">saut de page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="347">pages, saut</indexterm></cindex>

<para>&latex; commence de nouvelles pages de façon asynchrone, lorsque
suffisamment de matière a été accumulée pour remplir une
page. D&textrsquo;ordinaire ceci se produit automatiquement, mais parfois on peut
désirer influencer les sauts.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\clearpage &amp; \cleardoublepage</menunode><menudescription><pre xml:space="preserve">Commence une nouvelle page de droite ; éjecte les flottants.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newpage</menunode><menudescription><pre xml:space="preserve">Commence une nouvelle page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\enlargethispage</menunode><menudescription><pre xml:space="preserve">Agrandit d&textrsquo;un peu la page courante.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\pagebreak &amp; \nopagebreak</menunode><menudescription><pre xml:space="preserve">Forcer &amp; éviter les sauts de page.
</pre></menudescription></menuentry></menu>


<node name="_005cclearpage-_0026-_005ccleardoublepage" spaces=" "><nodename>\clearpage &amp; \cleardoublepage</nodename><nodenext automatic="on">\newpage</nodenext><nodeup automatic="on">Page breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\clearpage</code> &amp; <code>\cleardoublepage</code></sectiontitle>

<anchor name="_005cclearpage">\clearpage</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="616">\clearpage</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="348">débourrer les flottants et commencer une page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="349">commencer une nouvelle page et débourrer les flottants</indexterm></cindex>
<anchor name="_005ccleardoublepage">\cleardoublepage</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="617">\cleardoublepage</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="350">commencer une page de droite</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\clearpage
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\cleardoublepage
</pre></example>

<para>Finit la page courante et envoie en sortie tous les flottants, tableaux
et figures (<pxref label="Floats"><xrefnodename>Floats</xrefnodename></pxref>). S&textrsquo;il y a trop de flottants pour tenir dans
la page, alors &latex; insère des pages supplémentaires contenant
seulement les flottants. Dans le cas d&textrsquo;une impression en style
<code>twoside</code>, <code>\cleardoublepage</code> fait aussi que la nouvelle page
de contenu soit une page de droite (numérotée impaire), en produisant si
nécessaire une page à blanc. La commande <code>\clearpage</code> est robuste
alors que <code>\cleardouble page</code> est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Les sauts de page de &latex; sont optimisés, aussi, d&textrsquo;ordinaire, vous
n&textrsquo;utilisez ces commandes que la touche finale à la dernière version d&textrsquo;un
document, ou au sein de commande.
</para>
<!-- c credit: https://www.tex.ac.uk/FAQ-reallyblank.html -->
<para>La commande <code>\cleardoublepage</code> insère une page à blanc, mais elle contient l&textrsquo;en-tête et le bas de page. Pour obtenir une page vraiment à blanc, utilisez cette commande :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\let\origdoublepage\cleardoublepage
\newcommand&lbrace;\clearemptydoublepage&rbrace;&lbrace;%
  \clearpage
  &lbrace;\pagestyle&lbrace;empty&rbrace;\origdoublepage&rbrace;%
&rbrace;
</pre></example>

<noindent></noindent>
<para>Si vous désirez que la commande standarde <code>\chapter</code> de &latex;
agisse ainsi, alors ajoutez la ligne
<code>\let\cleardoublepage\clearemptydoublepage</code>.
</para>
<para>La commande <code>\newpage</code> (<pxref label="_005cnewpage"><xrefnodename>\newpage</xrefnodename></pxref>) finit également la page
en cours, mais sans débourrer les flottants pendants. Et, si &latex;
est en mode deux-colonnes alors <code>\newpage</code> finit la colonne
courante alors que <code>\clearpage</code> et <code>\cleardoublepage</code> finissent
la page courante.
</para>
</section>
<node name="_005cnewpage" spaces=" "><nodename>\newpage</nodename><nodenext automatic="on">\enlargethispage</nodenext><nodeprev automatic="on">\clearpage &amp; \cleardoublepage</nodeprev><nodeup automatic="on">Page breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\newpage</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="618">\newpage</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="351">nouvelle page, commencer</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="352">commencer une nouvelle page</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newpage
</pre></example>

<para>La commande <code>\newpage</code> finit la page courante. Cette commande est
robuste (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Les sauts de page de &latex; sont optimisés de sorte que d&textrsquo;ordinaire on
n&textrsquo;utilise cette commande dans le corps d&textrsquo;un document que pour les
finitions sur la version finale, ou à l&textrsquo;intérieur de commandes.
</para>
<para>Alors que les commandes <code>\clearpage</code> et <code>\cleardoublepage</code>
finissent également la page courante, en plus de cela elles débourrent
les flottants pendants (<pxref label="_005cclearpage-_0026-_005ccleardoublepage"><xrefnodename>\clearpage &amp; \cleardoublepage</xrefnodename></pxref>).  Et, si
&latex; est en mode deux-colonnes alors <code>\clearpage</code> et
<code>\cleardoublepage</code> finissent las page courante en laissant
possiblement une colonne vide, alors que <code>\newpage</code> finit seulement
la colonne courante.
</para>
<para>Contrairement à <code>\pagebreak</code> (<pxref label="_005cpagebreak-_0026-_005cnopagebreak"><xrefnodename>\pagebreak &amp; \nopagebreak</xrefnodename></pxref>),
la commande <code>\newpage</code> n&textrsquo;a pas pour effet que la nouvelle page
commence exactement là où la requête est faite.  Dans l&textrsquo;exemple suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">Four score and seven years ago our fathers brought forth on this
continent,
\newpage
\noindent a new nation, conceived in Liberty, and dedicated to the
proposition that all men are created equal.
</pre></example>

<noindent></noindent>
<para>la nouvelle page commence après <samp>continent</samp>, et la ligne où se
produit le saut n&textrsquo;est pas justifiée à droite.  De plus, <code>\newpage</code>
n&textrsquo;étire pas verticalement la page, contrairement à <code>\pagebreak</code>.
</para>

</section>
<node name="_005cenlargethispage" spaces=" "><nodename>\enlargethispage</nodename><nodenext automatic="on">\pagebreak &amp; \nopagebreak</nodenext><nodeprev automatic="on">\newpage</nodeprev><nodeup automatic="on">Page breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\enlargethispage</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="619">\enlargethispage</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="353">agrandir la page courante</indexterm></cindex>

<para><code>\enlargethispage&lbrace;size&rbrace;</code>
</para>
<para><code>\enlargethispage*&lbrace;size&rbrace;</code>
</para>
<para>Agrandit la <code>\textheight</code> de la page courante de la quantité
spécifiée ; par exemple <code>\enlargethispage&lbrace;\baselineskip&rbrace;</code> permet
d&textrsquo;avoir une ligne de plus.
</para>
<para>La forme étoilée essaie de comprimer la matière sur la page autant que
possible. Ceci est normalement utilisé en même temps qu&textrsquo;un
<code>\pagebreak</code> explicite.
</para>

</section>
<node name="_005cpagebreak-_0026-_005cnopagebreak" spaces=" "><nodename>\pagebreak &amp; \nopagebreak</nodename><nodeprev automatic="on">\enlargethispage</nodeprev><nodeup automatic="on">Page breaking</nodeup></node>
<section spaces=" "><sectiontitle><code>\pagebreak</code> &amp; <code>\nopagebreak</code></sectiontitle>

<anchor name="_005cpagebreak">\pagebreak</anchor>
<anchor name="_005cnopagebreak">\nopagebreak</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="620">\pagebreak</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="621">\nopagebreak</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="354">saut de page, forcer</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="355">saut de page, empêcher</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\pagebreak[<var>priorité</var>]
\nopagebreak[<var>priorité</var>]
</pre></example>

<para>Par défaut, la commande <code>\pagebreak</code> (<code>\nopagebreak</code>) force
(empêche) un saut de page à la position courante. Avec
<code>\pagebreak</code>, l&textrsquo;espace verticale sur la page est dilatée où c&textrsquo;est
possible de sorte à s&textrsquo;étendre jusqu&textrsquo;à la marge inférieure normale.
</para>
<para>Avec l&textrsquo;argument optionnel <var>priorité</var>, vous pouvez convertir la
commande <code>\pagebreak</code> d&textrsquo;une demande à une exigence. Le nombre doit
être compris entre 0 et 4. Plus grand est le nombre, et plus insistant
est l&textrsquo;exigence.
</para>

</section>
</chapter>
<node name="Footnotes" spaces=" "><nodename>Footnotes</nodename><nodenext automatic="on">Definitions</nodenext><nodeprev automatic="on">Page breaking</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Notes en bas de page</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="356">note en bas de page, créer</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="357">bas de page, créer des notes</indexterm></cindex>

<para>Mettez une note en bas de la page courante avec la commande
<code>\footnote</code>, comme ci-dessous.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Noël Coward a dit plaisamment que lire une note en bas de page, c'est
comme devoir descendre répondre à la porte d'entrée alors qu'on est en
train de faire l'amour\footnote&lbrace;Je n'en sais rien, je ne lis pas les
notes en bas de page.&rbrace;
</pre></example>

<para>Vous pouvez placer beaucoup de notes en bas de page dans une page. Si le
texte devient trop long alors il est continué sur la page suivante.
</para>
<para>Vous pouvez aussi produire des notes en bas de page en combinant les
commandes <code>\footnotemark</code> et <code>\footnotetext</code>, ce qui est
utiles dans des circonstances spéciales.
</para>
<para>Pour faire que les références bibliographiques sortent comme des notes
en bas de page vous devez inclure un style bibliographique avec ce
comportement (<pxref label="Using-BibTeX"><xrefnodename>Using BibTeX</xrefnodename></pxref>).
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\footnote</menunode><menudescription><pre xml:space="preserve">Insérer une note en bas de page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\footnotemark</menunode><menudescription><pre xml:space="preserve">Insérer la marque seulement d&textrsquo;une note en bas de page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\footnotetext</menunode><menudescription><pre xml:space="preserve">Insérer le texte seulement d&textrsquo;une note en bas de page.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Notes en bas de page dans les titres de rubriques</menutitle><menunode separator=".  ">Footnotes in section headings</menunode><menudescription><pre xml:space="preserve">Titre de chapitre ou de rubrique.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Notes dans un tableau</menutitle><menunode separator=". ">Footnotes in a table</menunode><menudescription><pre xml:space="preserve">Notes de tableau.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">Footnotes of footnotes</menunode><menudescription><pre xml:space="preserve">Classes multiples de notes en bas de page.  
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Paramètres des notes en bas de page</menutitle><menunode separator=". ">Footnote parameters</menunode><menudescription><pre xml:space="preserve">Les paramètres pour formater les notes en bas de page.
</pre></menudescription></menuentry></menu>


<node name="_005cfootnote" spaces=" "><nodename>\footnote</nodename><nodenext automatic="on">\footnotemark</nodenext><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle><code>\footnote</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="622">\footnote</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\footnote[<var>numéro</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Place en bas de la page courante une note <var>texte</var> numérotée.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Il y a plus d'un millier de notes en bas de page dans \textit&lbrace;Histoire
Du Déclin Et De La Chute De L'empire Romain&rbrace;\footnote&lbrace;Après la lecture
d'une version préléminaire, David Hume s'est plaint, « On souffre d'un
fléau avec ces notes, selon la méthode actuelle d'imprimer le livre » et
il suggera qu'elles « ne soient seulement imprimée dans la marge ou en
bas de page »&rbrace; d'Édouard Gibbon.
</pre></example>

<para>L&textrsquo;argument optionnel <var>numéro</var> vous permet de spécifier le numéro de
la note. Le compteur <code>footnote</code> donnant le numéro de la note n&textrsquo;est
pas incrémenté si vous utilisez cette option, mais l&textrsquo;est dans le cas
contraire.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="358">note en bas de page, symboles au lieu de numéros</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="623">\fnsymbol<r>, et note en bas de page</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="624">\&arobase;fnsymbol</indexterm></findex>
<para>Changez l&textrsquo;aspect que &latex; donne au compteur de note en bas de page
avec quelque chose du genre de
<code>\renewcommand&lbrace;\thefootnote&rbrace;&lbrace;\fnsymbol&lbrace;footnote&rbrace;&rbrace;</code>, ce qui
utilise une séquence de symboles (<pxref label="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol"><xrefnodename>\alph \Alph \arabic \roman
\Roman \fnsymbol</xrefnodename></pxref>).  Pour rendre ce changement global mettez cela dans
le préambule.  Si vous faites ce changement local alors vous désirerez
sans doute réinitialiser le compteur avec
<code>\setcounter&lbrace;footnote&rbrace;&lbrace;0&rbrace;</code>.  Par défaut &latex; utilise des
nombres arabes.
</para>

<!-- c - @node Symbolic footnotes -->
<!-- c - @section Note en bas de page symboliques -->
<!-- c - -->
<!-- c - @cindex notes en bas de page, symboliques au lieu de numérotées -->
<!-- c - Si vous voulez utiliser des symboles pour les notes en bas de page, -->
<!-- c - plutôt que des numéros croissants, redéfinissez @code{\thefootnote} -->
<!-- c - comme ceci : -->
<!-- c - -->
<!-- c - @example -->
<!-- c - \renewcommand@{\thefootnote@}@{\fnsymbol@{footnote@}@} -->
<!-- c - @end example -->
<!-- c - -->
<!-- c - @findex \fnsymbol@r{, et les notes en bas de page} -->
<!-- c - @findex \@@fnsymbol -->
<!-- c - La commande @code{\fnsymbol} produit une série prédéfinie de symboles -->
<!-- c - (@pxref{\alph \Alph \arabic \roman \Roman \fnsymbol}). Si vous voulez -->
<!-- c - utiliser un symbol différent comme marque de note en bas de page, il -->
<!-- c - vous faut aussi redéfinir @code{\@@fnsymbol}. -->
<!-- c - @c vincentb1: why ``also'' (aussi), isn't that sufficient to redefine \@fnsymbol ? -->

<para>Le comportement par défaut de &latex; met beaucoup de restrictions sur
l&textrsquo;endroit où l&textrsquo;on peut utiliser une <code>\footnote</code> ; par exemple, vous
ne pouvez pas l&textrsquo;utiliser dans l&textrsquo;argument d&textrsquo;une commande de rubricage
telle que <code>\chapter</code> (elle ne peut être utilisée qu&textrsquo;en mode
paragraphe externe ; <pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).  Il y a des contournements ; voir
les rubriques suivantes.
<!-- c xx mention packages that fix this -->
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="359">notes en bas de page, au sein d&textrsquo;une minipage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="360">mpfootnote, compteur</indexterm></cindex>
<para>Au sein d&textrsquo;un environnement <code>minipage</code> la commande <code>\footnote</code>
utilise le compteur <code>mpfootnote</code> au lieu de <code>footnote</code>, de
sorte que les notes sont numérotées indépendemment.  Elles apparaissent
au bas de l&textrsquo;environnement, et non au bas de la page.  Et par défaut
elles apparaissent alphabétiquement. <xref label="minipage"><xrefnodename>minipage</xrefnodename></xref>.
</para>

</section>
<node name="_005cfootnotemark" spaces=" "><nodename>\footnotemark</nodename><nodenext automatic="on">\footnotetext</nodenext><nodeprev automatic="on">\footnote</nodeprev><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle><code>\footnotemark</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="625">\footnotemark</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\footnotemark
\footnotemark[<var>numéro</var>]
</pre></example>

<para>Place dans le texte la marque de la note courante. Pour spécifier le
texte associé de la note voir <ref label="_005cfootnotetext"><xrefnodename>\footnotetext</xrefnodename></ref>. L&textrsquo;argument optionnel
<var>numéro</var> a pour effet que la commande utilise ce numéro pour
déterminer la marque de note en bas de page. Cette commande peut être
utilisée en mode paragraphe interne (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
</para>
<para>Si vous utilisez <code>\footnotemark</code> sans l&textrsquo;argument optionnel alors
elle incrémente le compteur <code>footnote</code>, mais si vous utilisez
l&textrsquo;argument optionnel <var>numéro</var>, alors elle ne l&textrsquo;incrémente
pas. L&textrsquo;exemple suivant produit plusieurs marques de note en bas de page
faisant référence à la même note :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Le premier théorème \footnote&lbrace;Dû à Gauss.&rbrace;
et le deuxième théorème\footnotemark[\value&lbrace;footnote&rbrace;]
ainis que le troisième théorème\footnotemark[\value&lbrace;footnote&rbrace;].
</pre></example>

<para>S&textrsquo;il y a d&textrsquo;autres notes entre celles-ci, alors vous devez mémoriser la
valeur du numéro de la marque commune. L&textrsquo;exemple suivant l&textrsquo;illustre :
</para>
<!-- c xx aligner l'anglais -->
<example endspaces=" ">
<pre xml:space="preserve">\title&lbrace;Un traité sur le théorème du binôme&rbrace;
\newcounter&lbrace;sauvenumnote&rbrace;
...
\setcounter&lbrace;sauvenumnote&rbrace;&lbrace;\value&lbrace;footnote&rbrace;&rbrace;
\author&lbrace;J Moriarty\thanks&lbrace;University of Leeds&rbrace; 
  \and A C Doyle\thanks&lbrace;Durham University&rbrace; 
  \and S Holmes\footnotemark[\value&lbrace;sauvenumnote&rbrace;]&rbrace;
\begin&lbrace;document&rbrace;
\maketitle
</pre></example> 


</section>
<node name="_005cfootnotetext" spaces=" "><nodename>\footnotetext</nodename><nodenext automatic="on">Footnotes in section headings</nodenext><nodeprev automatic="on">\footnotemark</nodeprev><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle><code>\footnotetext</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="626">\footnotetext</indexterm></findex>

<para>Synopsis, l&textrsquo;un des deux :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\footnotetext&lbrace;<var>texte</var>&rbrace;
\footnotetext[<var>numéro</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Place <var>texte</var> au bas de la page comme une note en bas de page. Cette
commande fait équipe avec <code>\footnotemark</code> (<pxref label="_005cfootnotemark"><xrefnodename>\footnotemark</xrefnodename></pxref>)
et peut apparaître n&textrsquo;importe où après cette commande-là, mais doit
apparaître en mode paragraphe externe (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).  L&textrsquo;argument
optionnel <var>numéro</var> change le numéro de note affiché.
</para>
<para><xref label="_005cfootnotemark"><xrefnodename>\footnotemark</xrefnodename></xref> et <ref label="Footnotes-in-a-table"><xrefnodename>Footnotes in a table</xrefnodename></ref>, pour des exemples
d&textrsquo;utilisation.
</para>


</section>
<node name="Footnotes-in-section-headings" spaces=" "><nodename>Footnotes in section headings</nodename><nodenext automatic="on">Footnotes in a table</nodenext><nodeprev automatic="on">\footnotetext</nodeprev><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle>Note en bas de page dont le renvoi est au sein d&textrsquo;un titre de rubrique</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="361">notes en bas de page, dans les titres de rubrique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="362">table des matières, éviter les notes en bas de page</indexterm></cindex>
<para>Mettre une note en bas de page depuis un titre de rubrique, comme dans :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\section&lbrace;Les ensembles complets\protect\footnote&lbrace;Ce texte est dû à ...&rbrace;&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="627"><r>paquetage</r> <code>footmisc</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="628"><code>footmisc</code>, <r>paquetage</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="363"><code>stable</code>, option du paquetage <code>footmisc</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="364">option <code>stable</code> du paquetage <code>footmisc</code></indexterm></cindex>
<noindent></noindent>
<para>a pour effet que la note en bas de page apparaît à la fois en bas de la
page où la rubrique commence, et de celle où son titre apparaît dans la
table des matières, ce qui vraisemblablement n&textrsquo;est pas voulu.  Pour
qu&textrsquo;elle n&textrsquo;apparaisse pas sur la table des matières utilisez le paquetage
<code>footmisc</code> avec l&textrsquo;option <code>stable</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[stable]&lbrace;footmisc&rbrace;
 ..
\begin&lbrace;document&rbrace;
 ..
\section&lbrace;Les ensembles complets\footnote&lbrace;Ce texte est dû à R~Jones.&rbrace;&rbrace;
</pre></example>

<para>Notez que le <code>\protect</code> a disparu ; l&textrsquo;inclure aurait pour effet que
la note en bas de page apparaîtrait de nouveau dans la table des
matières.
</para>

</section>
<node name="Footnotes-in-a-table" spaces=" "><nodename>Footnotes in a table</nodename><nodenext automatic="on">Footnotes of footnotes</nodenext><nodeprev automatic="on">Footnotes in section headings</nodeprev><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle>Notes en bas de page dans un tableau</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="365">Notes en bas de page, dans un tableau</indexterm></cindex>

<para>Au sein d&textrsquo;un environnement <code>tabular</code> ou <code>array</code> la commande
<code>\footnote</code> ne fonctionne pas ; on obtient une marque de note dans
la cellule du tableau mais le texte de la note n&textrsquo;apparaît pas. La
solution est d&textrsquo;utiliser un environnement <code>minipage</code>, comme ci-après
(<pxref label="minipage"><xrefnodename>minipage</xrefnodename></pxref>).
</para>


<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \begin&lbrace;minipage&rbrace;&lbrace;\textwidth&rbrace; \centering
     \begin&lbrace;tabular&rbrace;&lbrace;l|l&rbrace;
     \textsc&lbrace;Navire&rbrace;  &amp;\textsc&lbrace;Roman&rbrace; \\ \hline
     \textit&lbrace;HMS Sophie&rbrace;     &amp;Maître à bord  \\
     \textit&lbrace;HMS Polychrest&rbrace; &amp;Capitaine de vaisseau  \\
     \textit&lbrace;HMS Lively&rbrace;     &amp;Capitaine de vaisseau \\
     \textit&lbrace;HMS Surprise&rbrace;   &amp;Plusieurs romans\footnote&lbrace;Le premier étant
                                \textit&lbrace;La Surprise&rbrace;.&rbrace;
     \end&lbrace;tabular&rbrace;
  \end&lbrace;minipage&rbrace;                              
\end&lbrace;center&rbrace;
</pre></example>

<para>Au sein d&textrsquo;une <code>minipage</code>, les marques de note sont des lettres en
bas de casse. On peut changer cela avec quelque chose du genre de
<code>\renewcommand&lbrace;\thempfootnote&rbrace;&lbrace;\arabic&lbrace;mpfootnote&rbrace;&rbrace;</code>
(<pxref label="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol"><xrefnodename>\alph \Alph \arabic \roman \Roman \fnsymbol</xrefnodename></pxref>).
</para>
<para>Les notes du premier exemple apparaissent en bas de la
<code>minipage</code>. Pour qu&textrsquo;elles apparaissent en bas de la page principale
et fassent partie de la séquence normales des notes en bas de page,
utilisez la pair <code>\footnotemark</code> et <code>\footnotetext</code> ainsi
qu&textrsquo;une instanciation de compteur.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcounter&lbrace;sauvegardeLaValeurDeMpFootnote&rbrace;
\begin&lbrace;center&rbrace;
  \begin&lbrace;minipage&rbrace;&lbrace;\textwidth&rbrace;
    \setcounter&lbrace;sauvegardeLaValeurDeMpFootnote&rbrace;&lbrace;\value&lbrace;footnote&rbrace;&rbrace; \centering
     \begin&lbrace;tabular&rbrace;&lbrace;l|l&rbrace;
       \textsc&lbrace;Femme&rbrace;             &amp;\textsc&lbrace;Relation&rbrace; \\ \hline 
       Mona                       &amp;Liaison\footnotemark  \\ 
       Diana Villiers             &amp;Épouse, à la fin\\  
       Christine Hatherleigh Wood &amp;Fiancée\footnotemark 
     \end&lbrace;tabular&rbrace;
  \end&lbrace;minipage&rbrace;%  le signe pourcent permet de garder roches le texte de la note
  %  et la minipage
  \stepcounter&lbrace;sauvegardeLaValeurDeMpFootnote&rbrace;%
    \footnotetext[\value&lbrace;sauvegardeLaValeurDeMpFootnote&rbrace;]&lbrace;%
      Les circonstances de sa mort sont peu connues.&rbrace;%
  \stepcounter&lbrace;sauvegardeLaValeurDeMpFootnote&rbrace;%
    \footnotetext[\value&lbrace;sauvegardeLaValeurDeMpFootnote&rbrace;]&lbrace;%
      Leur relation n'aboutit pas dans le tome XXI.&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="629"><r>paquetage</r> <code>tablefootnote</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="630"><code>tablefootnote</code>, <r>paquetage</r></indexterm></findex>

<para>Pour un environnement flottant <code>table</code> (<pxref label="table"><xrefnodename>table</xrefnodename></pxref>) utilisez le
paquetage <code>tablefootnote</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;tablefootnote&rbrace;  % dans le préambule
   ...
\begin&lbrace;table&rbrace;
  \centering
     \begin&lbrace;tabular&rbrace;&lbrace;l|l&rbrace;
     \textsc&lbrace;Date&rbrace;  &amp;\textsc&lbrace;Campagne&rbrace; \\ \hline
     1862           &amp;Fort Donelson \\
     1863           &amp;Vicksburg     \\
     1865           &amp;Armée de Virginie du Nord\tablefootnote&lbrace;Fin de la
                     guerre.&rbrace;
     \end&lbrace;tabular&rbrace;
    \caption&lbrace;Forces capturées par le général Grant&rbrace;
\end&lbrace;table&rbrace;
</pre></example>

<noindent></noindent>
<para>La note apparaîtra en bas de la page et sera numérotée dans la même
séquence que les autres notes en bas de page.
</para>

</section>
<node name="Footnotes-of-footnotes" spaces=" "><nodename>Footnotes of footnotes</nodename><nodenext automatic="on">Footnote parameters</nodenext><nodeprev automatic="on">Footnotes in a table</nodeprev><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle>Notes en bas de page sur d&textrsquo;autres notes</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="366">note en bas de page portant sur une autre note</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="367">note en bas de page, récursivement</indexterm></cindex>

<findex index="fn" spaces=" "><indexterm index="fn" number="631"><r>paquetage</r> <code>bigfoot</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="632"><code>bigfoot</code>, <r>paquetage</r></indexterm></findex>


<para>En particulier dans les sciences humaines, les auteurs peuvent avoir
plusieurs classes de notes en bas de pages, y compris une note en bas de
page qui porte sur une autre note en bas de page.  Le paquetage
<code>bigfoot</code> étend le mécanisme de note en bas de page par défaut
de &latex; de bien des manières, y compris pour permettre de faire les
deux notes de l&textrsquo;exemple ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;bigfoot&rbrace;              % dans le préambule
\DeclareNewFootnote&lbrace;Default&rbrace;
\DeclareNewFootnote&lbrace;from&rbrace;[alph]   % crée la classe \footnotefrom&lbrace;&rbrace;
 ...
Le troisième théorème est une réciproque partielle du second.\footnotefrom&lbrace;%
  Remarqué par Wilson.\footnote&lbrace;Deuxième édition seulement.&rbrace;&rbrace;
</pre></example>


</section>
<node name="Footnote-parameters" spaces=" "><nodename>Footnote parameters</nodename><nodeprev automatic="on">Footnotes of footnotes</nodeprev><nodeup automatic="on">Footnotes</nodeup></node>
<section spaces=" "><sectiontitle>Paramètres des notes en bas de page</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="368">notes en bas de page, paramètres</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="369">paramètres, pour notes en bas de page</indexterm></cindex>

<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="633">\footnoterule</indexterm>\footnoterule</itemformat></item>
</tableterm><tableitem><para>Produit le filet de séparation entre texte principal sur une page et les
notes en bas de cette page. Les dimensions par défaut : épaisseur (ou
largeur) <code>0.4pt</code>, et longueur <code>0.4\columnwidth</code> dans les
classes standard de document (à l&textrsquo;exception <code>slide</code>, où elle
n&textrsquo;apparaît pas).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="634">\footnotesep</indexterm>\footnotesep</itemformat></item>
</tableterm><tableitem><anchor name="footnote-footnotesep">footnote footnotesep</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="370">étai</indexterm></cindex>
<para>La hauteur de l&textrsquo;étai placé au début de la note en bas de page. Par
défaut, c&textrsquo;est réglé à l&textrsquo;étai normal pour des polices de taille
<code>\footnotesize</code> (<pxref label="Font-sizes"><xrefnodename>Font sizes</xrefnodename></pxref>), donc il n&textrsquo;y a pas d&textrsquo;espace
supplémentaire entre les notes. Cela vaut <samp>6.65pt</samp> pour des polices
à <samp>10pt</samp>, <samp>7.7pt</samp> pour <samp>11pt</samp>, et <samp>8.4pt</samp> pour
<samp>12pt</samp>.
</para>
</tableitem></tableentry></ftable>


</section>
</chapter>
<node name="Definitions" spaces=" "><nodename>Definitions</nodename><nodenext automatic="on">Counters</nodenext><nodeprev automatic="on">Footnotes</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Définitions</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="371">définitions</indexterm></cindex>

<para>&latex; prend en charges la fabrication de nouvelles commandes de bien
des genres.
</para>
<!-- c xx everything in this chapter needs exemples. -->
<!-- c xx Add DeclareRobustCommand (see clsguide.pdf) -->

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\newcommand &amp; \renewcommand</menunode><menudescription><pre xml:space="preserve">(Re)définir une nouvelle commande.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::  ">\providecommand</menunode><menudescription><pre xml:space="preserve">Définir une commande, si le nom n&textrsquo;est pas utilisé.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">\makeatletter et \makeatother</menutitle><menunode separator=". ">\makeatletter &amp; \makeatother</menunode><menudescription><pre xml:space="preserve">Change la catégorie du caractère arobe.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\&arobase;ifstar</menunode><menudescription><pre xml:space="preserve">Définir vos propres commandes étoilées.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newcounter</menunode><menudescription><pre xml:space="preserve">Définir un nouveau compteur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newlength</menunode><menudescription><pre xml:space="preserve">Définir une nouvelle longueur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newsavebox</menunode><menudescription><pre xml:space="preserve">Définir une nouvelle boîte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newenvironment &amp; \renewenvironment</menunode><menudescription><pre xml:space="preserve">Définir un nouvel environnement.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newtheorem</menunode><menudescription><pre xml:space="preserve">Définir un nouvel environnement de semblable à <code>theorem</code>.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\newfont</menunode><menudescription><pre xml:space="preserve">Définir un nouveau nom de police.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\protect</menunode><menudescription><pre xml:space="preserve">Utiliser des commandes fragiles.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\ignorespaces &amp; \ignorespacesafterend</menunode><menudescription><pre xml:space="preserve">Supprimer des espaces superflus.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">xspace&comma;, paquetage</menutitle><menunode separator=". ">xspace package</menunode><menudescription><pre xml:space="preserve">Espace après une macros, conditionnellement.
</pre></menudescription></menuentry></menu>

<node name="_005cnewcommand-_0026-_005crenewcommand" spaces=" "><nodename>\newcommand &amp; \renewcommand</nodename><nodenext automatic="on">\providecommand</nodenext><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newcommand</code> &amp; <code>\renewcommand</code></sectiontitle>

<anchor name="_005cnewcommand">\newcommand</anchor>
<anchor name="_005crenewcommand">\renewcommand</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="635">\newcommand</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="636">\renewcommand</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="372">commandes, en définir de nouvelles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="373">commandes, redéfinir</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="374">définir une nouvelle commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="375">redéfinir une commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="376">nouvelle commandes, définir</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi (trois formes ordinaires, trois formes étoilées) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\newcommand&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\newcommand&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>][<var>optargdéfaut</var>]&lbrace;<var>défn</var>&rbrace;
\newcommand*&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\newcommand*&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\newcommand*&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>][<var>optargdéfaut</var>]&lbrace;<var>défn</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou toutes les mêmes possibilités avec <code>\renewcommand</code> au lieu de
<code>\newcommand</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\renewcommand&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\renewcommand&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>][<var>optargdéfaut</var>]&lbrace;<var>défn</var>&rbrace;
\renewcommand*&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\renewcommand*&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\renewcommand*&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>][<var>optargdéfaut</var>]&lbrace;<var>défn</var>&rbrace;
</pre></example>

<para>Définit ou redéfinit une commande (voir aussi
<code>\DeclareRobustCommand</code> dans <ref label="Class-and-package-commands"><xrefnodename>Class and package commands</xrefnodename></ref>).
</para>

<cindex index="cp" spaces=" "><indexterm index="cp" number="377">forme en *, définir de nouvelles commandes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="378">forme étoilée, définir de nouvelles commandes</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="637">\long</indexterm></findex>
<para>La forme étoilée (en <code>*</code>) de ces commandes interdit que les
arguments contiennent une multiplicité de paragraphes de texte (la
commande n&textrsquo;est pas <code>\long</code>, dans la terminologie de
&tex; de base).  Avec la forme par défaut, il est possible qu&textrsquo;un
argument soit une multiplicité de paragraphes.
</para>
<para>Description des paramètres (des exemples suivront) :
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">cmd</itemformat></item>
</tableterm><tableitem><para>Obligatoire ; <code>\<var>cmd</var></code> est le nom de la commande. Il doit
commencer par une controblique, <code>\</code>, et ne doit pas commencer avec
la chaîne de 4 caractères <code>\end</code>. Pour <code>\newcommand</code>, il ne
doit pas être déjà défini et ne doit pas commencer avec <code>\end</code> ;
pour <code>\renewcommand</code>, il doit être déjà défini.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">nargs</itemformat></item>
</tableterm><tableitem><para>Optionnel ; un entier compris entre 1 et 9 spécifiant le nombre
d&textrsquo;arguments que la commande prend, y compris un éventuel argument
optionnel. Si cet argument n&textrsquo;est pas présent, alors la spécification par
défaut est que la commande ne prend aucun argument. Lorsque on redéfinit
une commande, la nouvelle version peut prendre un nombre différent
d&textrsquo;arguments par rapport à l&textrsquo;ancienne.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">optargdéfaut</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="379">optionnels, arguments, définir et utiliser</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="380">arguments optionnels, définir et utiliser</indexterm></cindex>
<para>Optionnel ; si cet argument est présent, alors le premier argument de la
commande <code>\<var>cmd</var></code> en définition est optionnel, et sa valeur par
défaut est <var>optargdéfaut</var> (qui peut être une chaîne vide). Si cet
argument n&textrsquo;est pas présent, alors <code>\<var>cmd</var></code> ne prend pas
d&textrsquo;argument optionnel.
</para>
<para>C&textrsquo;est à dire que si <code>\<var>cmd</var></code> est appelée avec à la suite un
argument entre crochets, comme dans <code>\<var>cmd</var>[<var>valopt</var>]</code>,
alors au sein de <var>défn</var> le paramètre <code>#1</code> est réglé à
<var>valopt</var>. Par contre si <code>\<var>cmd</var></code> est appelé sans crochet à
la suite, alors au sein de <var>défn</var> le paramètre <code>#1</code> est réglé à
<var>optargdéfaut</var>. Dans les deux cas, les arguments obligatoires
commencent par <code>#2</code>.
</para>
<para>Omettre <code>[<var>optargdéfaut</var>]</code> d&textrsquo;une définition est très différent
de mettre des crochets vides, comme dans <code>[]</code>. Dans le premier cas
on dit que la commande ainsi définie ne prend pas d&textrsquo;argument optionnel,
de sorte que <code>#1</code> est le premier argument obligatoire (à supposer
que <math><var>nargs</var> &ge; 1</math>) ; dans le second cas on règle
l&textrsquo;argument optionnel <code>#1</code> à être une chaîne vide par défaut,
c.-à-d.&noeos; si aucun argument optionnel n&textrsquo;est donné à l&textrsquo;appel.
</para>
<para>De même, omettre <code>[<var>valopt</var>]</code> d&textrsquo;un appel est également très
différent que de donner des crochets vides, comme dans <code>[]</code>.  Dans
le premier cas on règle <code>#1</code> à la valeur de <var>valopt</var> (à
supposer que la commande a été définie pour prendre un argument
optionnel) ; alors que dans le second on règle <code>#1</code> à la chaîne
vide, comme on le ferait pour n&textrsquo;importe quelle autre valeur.
</para>
<para>Si une commande n&textrsquo;est pas définie pour prendre un argument optionnel,
mais qu&textrsquo;elle est appelée avec un argument optionnel, les résultats sont
imprévisibles : il peut y avoir une erreur &latex;, une sortie
incorrectement composée, ou les deux.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">défn</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="381">paramètres, substitution</indexterm></cindex>
<para>Obligatoire ; le texte par lequel substituer chaque occurrence de
<code>\<var>cmd</var></code>. Les paramètres <code>#1</code>, <code>#2</code>, &dots;,
<code>#<var>nargs</var></code> sont remplacés par les valeurs fournies en appelant
la commande (ou par <var>optargdéfaut</var> dans le cas d&textrsquo;un argument
optionnel non spécifié dans l&textrsquo;appel, comme cela vient d&textrsquo;être expliqué).
</para>
</tableitem></tableentry></table>

<cindex index="cp" spaces=" "><indexterm index="cp" number="382">blancs, après une séquence de contrôle</indexterm></cindex>
<para>&tex; ignore les blancs dans le code source à la suite d&textrsquo;un mot de
contrôle (<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), comme dans <samp>\cmd </samp>. Si vous
désirez une espace réellement à cet endroit, une solution est de taper
<code>&lbrace;&rbrace;</code> après la commande (<samp>\cmd&lbrace;&rbrace; </samp>), et une autre est
d&textrsquo;utiliser un espace de contrôle explicite (<samp>\cmd\ </samp>).
</para>
<para>Un exemple simple de définition d&textrsquo;une nouvelle commande :
<code>\newcommand&lbrace;\JM&rbrace;&lbrace;Jean Martin&rbrace;</code> a pour effet le remplacement de
<code>\JM</code> par le texte plus long de la définition.  La redéfinition
d&textrsquo;une commande existante est similaire :
<code>\renewcommand&lbrace;\symbolecqfd&rbrace;&lbrace;&lbrace;\small CQFD&rbrace;&rbrace;</code>.
</para>
<para>Si vous utilisez <code>\newcommand</code> et que le nom de commande a déjà été
utilisé alors vous obtenez quelque chose du genre de <samp>LaTeX Error:
Command \fred already defined. Or name \end... illegal, see p.192 of the
manual</samp>.  Si vous utilisez <code>\renewcommand</code> et que le nom de
commande n&textrsquo;a pas encore été utilisé alors vous obtenez quelque chose du
genre de <samp>LaTeX Error: \hank undefined</samp>.
</para>
<para>Dans l&textrsquo;exemple suivant la première définition crée une commande sans
argument, et la seconde, une commande avec un argument obligatoire :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\etudiant&rbrace;&lbrace;Melle~O'Leary&rbrace;
\newcommand&lbrace;\defref&rbrace;[1]&lbrace;Définition~\ref&lbrace;#1&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Utilisez la première commande comme dans <code>Je confie \etudiant&lbrace;&rbrace; à
vos bons soins</code>.  La seconde commande a un argument variable, de sorte
que <code>\defref&lbrace;def:base&rbrace;</code> se développe en
<code>Definition~\ref&lbrace;def:base&rbrace;</code>, ce qui en fin de compte se développera en
quelque chose du genre de <samp>Définition~3.14</samp>.
</para>
<para>Un exemple avec deux arguments obligatoires :
<code>\newcommand&lbrace;\nbym&rbrace;[2]&lbrace;$#1 \times #2$&rbrace;</code> est invoqué comme
<code>\nbym&lbrace;2&rbrace;&lbrace;k&rbrace;</code>.
</para>
<para>Un exemple avec un argument optionnel :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\salutation&rbrace;[1][Madame, Monsieur]&lbrace;#1,&rbrace;
</pre></example>

<noindent></noindent><para>Alors, <code>\salutation</code> donne <samp>Madame, Monsieur,</samp> alors
<code>\salutation[Cher Jean]</code> donne <samp>Cher Jean,</samp>.  Et
<code>\salutation[]</code> donne <samp>,</samp>.
</para>
<para>Cet exemple a un argument optionnel et deux arguments obligatoires.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\avocats&rbrace;[3][cie]&lbrace;#2, #3, et~#1&rbrace;
J'emploie \avocats[Odette]&lbrace;Devoie&rbrace;&lbrace;Trichou&rbrace;.
</pre></example>

<noindent></noindent>
<para>En sortie on a <samp>J'emploie Devoie, Trichou, et Odette</samp>.  L&textrsquo;argument
optionnel, c.-à-d.&noeos; <code>Odette</code>, est associé à <code>#1</code>, alors que
<code>Devoie</code> et <code>Trichou</code> le sont à <code>#2</code> et <code>#3</code>.  À
cause de l&textrsquo;argument optionnel, <code>\avocats&lbrace;Devoie&rbrace;&lbrace;Trichou&rbrace;</code>
donne en sortie <samp>J'emploie Devoie, Trichou, et cie</samp>.
</para>
<para>Les accolades autour de <var>défn</var> ne définissent pas un groupe,
c.-à-d.&noeos; qu&textrsquo;elle ne délimitent pas la portée du résultat du
développement de <var>défn</var>.  Ainsi la définition
<code>\newcommand&lbrace;\nomnavire&rbrace;[1]&lbrace;\it #1&rbrace;</code> est problématique dans
cette phrase :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Le \nomnavire&lbrace;Monitor&rbrace; rencontra le \nomnavire&lbrace;Merrimac&rbrace;.
</pre></example>

<noindent></noindent>
<para>les mots <samp>rencontra le</samp>, et le point, sont mis incorrectement en
italique. La solution est de mettre une paire supplémentaire d&textrsquo;accolades
au sein de la définition : <code>\newcommand&lbrace;\nomnavire&rbrace;[1]&lbrace;&lbrace;\it
#1&rbrace;&rbrace;</code>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">Control sequences</menunode><menudescription><pre xml:space="preserve">Séquence de contrôle, mot de contrôle et symbole de contrôle.
</pre></menudescription></menuentry></menu>

<node name="Control-sequences" spaces=" "><nodename>Control sequences</nodename><nodeup automatic="on">\newcommand &amp; \renewcommand</nodeup></node>
<subsection spaces=" "><sectiontitle>Séquence de contrôle, mot de contrôle et symbole de contrôle</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="383">séquences de contrôle</indexterm></cindex>

<para>En lisant l&textrsquo;entrée &tex; convertit le flux des caractères lus en une
séquence d&textrsquo;<dfn>unités lexicales</dfn>, encore appelées
<dfn>lexèmes</dfn><footnote><para>En anglais c&textrsquo;est le terme jeton &textmdash;
token &textmdash; qui est utilisé.</para></footnote>. Lorsque &tex; voit une
controblique <code>\</code>, il gère les caractères suivants d&textrsquo;une manière
spéciale de sorte à former une unité lexicale <dfn>séquence de
contrôle</dfn>.
</para>
<para>Les séquences de contrôle peuvent être classées en deux catégories :
</para>
<itemize commandarg="bullet" endspaces=" "><itemprepend>&bullet;</itemprepend>
<listitem><prepend>&bullet;</prepend>
<cindex index="cp" spaces=" "><indexterm index="cp" number="384">mot de contrôle, défini</indexterm></cindex>
<para>Les <dfn>mots de contrôle</dfn>, quand la séquence de contrôle est formée à
partir d&textrsquo;une <code>\</code> suivie par au moins une lettre ASCII (<code>A-Z</code>
et <code>a-z</code>), suivie par au moins une non-lettre.
</para>
</listitem><listitem><prepend>&bullet;</prepend>
<cindex index="cp" spaces=" "><indexterm index="cp" number="385">symboles de contrôle, défini</indexterm></cindex>
<para>Les <dfn>symboles de contrôle</dfn>, quand la séquence de contrôle est formée
à partir d&textrsquo;une <code>\</code> suivi d&textrsquo;un unique caractère non-lettre.
</para></listitem></itemize>

<para>La séquence des caractères ainsi trouvés après le <code>\</code> est aussi
appelé le <dfn>nom de la séquence de contrôle</dfn>.
</para>
<para>Les blancs suivant un mot de contrôle sont ignorés et ne produisent
aucun espace blanc en sortie (<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></pxref> et
<ref label="_005c_0028SPACE_0029"><xrefnodename>\(SPACE)</xrefnodename></ref>).
</para>
<para>Étant donné que la commande <code>\relax</code> ne fait rien, l&textrsquo;exemple
suivant imprime simplement <samp>Bonjour !</samp><inlinefmt><inlinefmtformat>tex</inlinefmtformat></inlinefmt><inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Bon\relax␣␣␣
␣␣␣jour !
</pre></example>

<noindent></noindent>
<para>Ceci parce que les blancs suivant <code>\relax</code>, y compris le caractère
saut-de-ligne, sont ignorés, et que les blancs en début de ligne sont
aussi ignorés (<pxref label="Leading-blanks"><xrefnodename>Leading blanks</xrefnodename></pxref>).
</para>

</subsection>
</section>
<node name="_005cprovidecommand" spaces=" "><nodename>\providecommand</nodename><nodenext automatic="on">\makeatletter &amp; \makeatother</nodenext><nodeprev automatic="on">\newcommand &amp; \renewcommand</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\providecommand</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="638">\providecommand</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="386">commandes, définir de nouvelles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="387">définir une nouvelle commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="388">nouvelles commandes, définir</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\providecommand&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\providecommand&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\providecommand&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>][<var>optargdéfaut</var>]&lbrace;<var>défn</var>&rbrace;
\providecommand*&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>défn</var>&rbrace;
\providecommand*&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défn</var>&rbrace;
\providecommand*&lbrace;\<var>cmd</var>&rbrace;[<var>nargs</var>][<var>optargdéfaut</var>]&lbrace;<var>défn</var>&rbrace;
</pre></example>

<para>Définit une commande, du moment qu&textrsquo;aucune commande de même nom n&textrsquo;existe
déjà.  Si aucune commande de ce nom n&textrsquo;existe alors ceci a le même effet
que <code>\newcommand</code> (<pxref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></pxref>).  Si une
commande de ce nom existe déjà alors cette définition est sans
effet. Ceci est particulièrement utile dans tout fichier susceptible
d&textrsquo;être chargé plus d&textrsquo;une fois, tel qu&textrsquo;un fichier de style.
<xref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></xref>, pour la description des arguments.
</para>
<para>Dans l&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\providecommand&lbrace;\monaffiliation&rbrace;&lbrace;Saint Michael's College&rbrace;
\providecommand&lbrace;\monaffiliation&rbrace;&lbrace;Lycée Henri IV&rbrace;
Depuis \monaffiliation.
</pre></example>

<noindent></noindent>
<para>on a en sortie <samp>Depuis Saint Michael's College</samp>.  Contrairement à
<code>\newcommand</code>, l&textrsquo;utilisation répétée de <code>\providecommand</code> pour
(essayer de) définir <code>\monaffiliation</code> ne produit pas d&textrsquo;erreur.
</para>

</section>
<node name="_005cmakeatletter-_0026-_005cmakeatother" spaces=" "><nodename>\makeatletter &amp; \makeatother</nodename><nodenext automatic="on">\&arobase;ifstar</nodenext><nodeprev automatic="on">\providecommand</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\makeatletter</code> et <code>\makeatother</code></sectiontitle>

<anchor name="_005cmakeatletter">\makeatletter</anchor>
<anchor name="_005cmakeatother">\makeatother</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="639">\makeatother</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="640">\makeatother</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makeatletter
  ... définition de commande comprenant &arobase; dans leur nom ..
\makeatother
</pre></example>

<para>Utilisez cette paire de commandes quand vous redéfinissez les commandes
&latex; dont le nom comprend un caractère arobe <samp><code>&arobase;</code></samp>.  La
déclaration <code>\makeatletter</code> a pour effet que le caractère arobe ait
le code de catégorie des lettres, c.-à-d.&noeos; le code 11. La déclaration
<code>\makeatother</code> règle de code de catégorie de l&textrsquo;arobe au code 12, sa
valeur d&textrsquo;origine.
</para>
<para>À mesure que chaque caractère est lu par &tex;, un code de catégorie
lui est assigné. On appelle aussi ce code
<cindex index="cp" spaces=" "><indexterm index="cp" number="389">catcode</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="390">code de catégorie de caractère</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="391">catégorie, code de caractère</indexterm></cindex>
<dfn>catcode</dfn> pour faire court.  Par exemple, la controblique <code>\</code>
reçoit le catcode 0. Les noms de commande consistent en un caractère de
catégorie 0, d&textrsquo;ordinaire une controblique, suivi par des lettres,
c.-à-d.&noeos; des caractères de catégorie 11  (à ceci près qu&textrsquo;une commande
peut également consister en un caractère de catégorie 0 suivi d&textrsquo;un
unique caractère qui n&textrsquo;est pas une lettre).
</para>
<para>Le code source de &latex; suit la convention que certaines commandes
utilisent <code>&arobase;</code> dans leur nom. Ces commandes sont principalement
destinées aux auteurs de paquetages ou de classes. Cette convention
empêche les auteurs qui sont juste utilisateurs d&textrsquo;un paquetage ou d&textrsquo;une
classe de remplacer accidentellement une telle commande par une commande
définie par eux, puisque par défaut l&textrsquo;arobe a le catcode 12 (other).
</para>
<para>Utilisez la paire <code>\makeatletter</code> et <code>\makeatother</code> au sein
d&textrsquo;un fichier <file>.tex</file>, typiquement dans le préambule, quand vous
définissez ou redéfinissez des commandes dont le nom comprend <code>&arobase;</code>,
en entourant votre définition par elles.  Ne les utilisez pas au sein de
fichiers <file>.sty</file> ou <file>.cls</file> puisque les commandes
<code>\usepackage</code> et <code>\documentclass</code> font déjà le nécessaire pour
que l&textrsquo;arobe ait le catcode d&textrsquo;une lettre, à savoir 11.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="641"><r>paquetage</r> <code>macros2e</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="642"><code>macros2e</code>, <r>paquetage</r></indexterm></findex>

<para>Pour une liste complète des macros contenant une arobe dans leur nom,
voir le document <url><urefurl>http://ctan.org/pkg/macros2e</urefurl></url>.
<!-- c xx pourquoi est-ce que ceci a été enlevé : -->
<!-- c xx Ces macros sont surtout à l'intention des auteurs de classes et de -->
<!-- c xx paquetages. -->
</para>
<para>Dans l&textrsquo;exemple suivant une commande <code>\these&arobase;nomuniversite</code> se
trouve dans le fichier de classe, et l&textrsquo;utilisateur veut changer sa
définition. Pour cela, il suffit d&textrsquo;insérer les trois lignes suivantes
dans le préambule, avant le <code>\begin&lbrace;document&rbrace;</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makeatletter
\renewcommand&lbrace;\these&arobase;nomuniversite&rbrace;&lbrace;Université Lyon III Jean Moulin&rbrace;
\makeatother
</pre></example>


</section>
<node name="_005c_0040ifstar" spaces=" "><nodename>\&arobase;ifstar</nodename><nodenext automatic="on">\newcounter</nodenext><nodeprev automatic="on">\makeatletter &amp; \makeatother</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\&arobase;ifstar</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="643">\&arobase;ifstar</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="392">commandes, variantes étoilées</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="393">étoilées, variantes de commandes</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\macmd&rbrace;&lbrace;\&arobase;ifstar&lbrace;\macmd&arobase;star&rbrace;&lbrace;\macmd&arobase;nostar&rbrace;&rbrace;
\newcommand&lbrace;\macmd&arobase;nostar&rbrace;[<var>nostar-nbre-args</var>]&lbrace;<var>nostar-corps</var>&rbrace;
\newcommand&lbrace;\macmd&arobase;star&rbrace;[<var>star-nbre-args</var>]&lbrace;<var>star-corps</var>&rbrace;
</pre></example>

<!-- c Inpirée des trucs & astuces de Manuel Pégourié-Gonnard -->
<!-- c (https://elzevir.fr/imj/latex/tips.html#stared) -->

<para>Vous l&textrsquo;avez sans doute remarqué, beaucoup d&textrsquo;environnements ou commandes
standards de &latex; existent sous une variante avec le même nom mais
finissant avec le caractère étoile <code>*</code>, un astérisque. Par exemple
c&textrsquo;est le cas des environnements <code>table</code> et <code>table*</code>, et des
commandes <code>\section</code> et <code>\section*</code>.
</para>
<para>Lorsque on définit un environnement, cela est facile puisque
<code>\newenvironment</code> et <code>\renewenvironment</code> autorisent que le nom
de l&textrsquo;environnement contienne un astérisque.  Il vous suffit donc
d&textrsquo;écrire <code>\newenvironment&lbrace;<var>monenv</var>&rbrace;</code> ou
<code>\newenvironment&lbrace;<var>monenv</var>*&rbrace;</code> et de continuer la définition
comme d&textrsquo;habitude.  Pour les commandes, c&textrsquo;est plus compliqué car l&textrsquo;étoile
n&textrsquo;étant pas une lettre ne peut pas faire partie du nom de la
commande. Comme dans le synopsis ci-dessus, on a donc une commande
utilisateur, donnée ci-dessus comme <code>\macmd</code>, qui doit être capable
de regarder si elle est ou non suivie d&textrsquo;une étoile. Par exemple,
&latex; n&textrsquo;a pas réellement une commande <code>\section*</code> ; au lieu de
cela la commande <code>\section</code> regarde ce qui la suit. Cette première
commande n&textrsquo;accepte d&textrsquo;argument, mais au lieu de cela se développe en
l&textrsquo;une de deux commandes qui elle accepte des arguments. Dans le synopsis
ces commandes sont <code>\macmd&arobase;nostar</code> et <code>\macmd&arobase;star</code>.  Elles
peuvent prendre le même nombre d&textrsquo;arguments ou un nombre différent, ou
pas d&textrsquo;argument du tout.  Comme d&textrsquo;habitude, dans un document &latex; une
commande utilisant l&textrsquo;arobe <code>&arobase;</code> dans son nom doit être comprise au
sein d&textrsquo;un bloc <code>\makeatletter ... \makeatother</code>
(<pxref label="_005cmakeatletter-_0026-_005cmakeatother"><xrefnodename>\makeatletter &amp; \makeatother</xrefnodename></pxref>).
</para>
<para>Dans cet exemple, on définit <code>\ciel</code> comme une commande avec un
argument obligatoire et admettant une variante étoilée <code>\ciel*</code>
également avec un argument obligatoire. Ainsi, <code>\ciel&lbrace;bleu&rbrace;</code>
composera « ciel bleu non étoilé » tandis que <code>\ciel*&lbrace;nocturne&rbrace;</code>
composera « ciel nocturne étoilé ».
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makeatletter
\newcommand*\ciel&arobase;starred[1]&lbrace;ciel #1 étoilé&rbrace;
\newcommand*\ciel&arobase;unstarred[1]&lbrace;ciel #1 non étoilé&rbrace;
\newcommand\ciel&lbrace;\&arobase;ifstar&lbrace;\ciel&arobase;starred&rbrace;&lbrace;\ciel&arobase;unstarred&rbrace;&rbrace;
\makeatother
</pre></example>


<para>Voici un autre exemple, où la variante étoilée prend un nombre
d&textrsquo;arguments différent de la non étoilée. Avec cette définition, la
célèbre réplique de l&textrsquo;agent 007 « <code>Mon nom est
\agentsecret*&lbrace;Bond&rbrace;, \agentsecret&lbrace;James&rbrace;&lbrace;Bond&rbrace;</code>. » est équivalente
à saisir les commandes « <code>Je m'appelle \textsc&lbrace;Bond&rbrace;, \textit&lbrace;James&rbrace;
textsc&lbrace;Bond&rbrace;.</code> »
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makeatletter
\newcommand*\agentsecret&arobase;starred[1]&lbrace;\textsc&lbrace;#1&rbrace;&rbrace;
\newcommand*\agentsecret&arobase;unstarred[2]&lbrace;\textit&lbrace;#1&rbrace; \textsc&lbrace;#2&rbrace;&rbrace;
\newcommand\agentsecret&lbrace;\&arobase;ifstar&lbrace;\agentsecret&arobase;starred&rbrace;&lbrace;\agentsecret&arobase;unstarred&rbrace;&rbrace;
\makeatother
</pre></example>

<para>Après le nom d&textrsquo;une commande, l&textrsquo;étoile est traitée d&textrsquo;une manière
similaire à un argument optionnel.  (Ceci est différent des noms
d&textrsquo;environnement, où l&textrsquo;étoile fait partie du nom lui-même, et peut donc
être à n&textrsquo;importe quelle position).  D&textrsquo;un point de vue purement technique
il est donc possible de mettre un nombre indéfini d&textrsquo;espaces entre la
commande et l&textrsquo;étoile. Ainsi <code>\agentsecret*&lbrace;Bond&rbrace;</code> et
<code>\agentsecret<w> *</w>&lbrace;Bond&rbrace;</code> sont équivalents. Toutefois, la
pratique normale est de ne pas insérer de tels espaces.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="644"><r>paquetage</r> <code>suffix</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="645"><code>suffix</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="646"><r>paquetage</r> <code>xparse</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="647"><code>xparse</code>, <r>paquetage</r></indexterm></findex>


<para>Il y a deux manières pouvant être plus commodes d&textrsquo;accomplir la même
tâche que <code>\&arobase;ifstar</code>.  Le paquetage <code>suffix</code> permet la
construction <code>\newcommand\macommande&lbrace;<var>variante-non-étoilée</var>&rbrace;</code>
suivie de
<code>\WithSuffix\newcommand\macommande*&lbrace;<var>variante-étoilée</var>&rbrace;</code>.  Et
&latex;3 a le paquetage <code>xparse</code> qui permet ce code.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\NewDocumentCommand\toto&lbrace;s&rbrace;&lbrace;\IfBooleanTF#1
  &lbrace;<var>variante-étoilée</var>&rbrace;%
  &lbrace;<var>variante-non-étoilée</var>&rbrace;%
  &rbrace;
</pre></example>

</section>
<node name="_005cnewcounter" spaces=" "><nodename>\newcounter</nodename><nodenext automatic="on">\newlength</nodenext><nodeprev automatic="on">\&arobase;ifstar</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newcounter</code> : allouer un compteur</sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="648">\newcounter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="394">compteurs, définir de nouveaux</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcounter&lbrace;<var>nomcompteur</var>&rbrace;
\newcounter&lbrace;<var>nomcompteur</var>&rbrace;[<var>super</var>]
</pre></example>

<para>La commande <code>\newcounter</code> définit un nouveau compteur nommé <var>nomcompteur</var>.
Le nouveau compteur est initialisé à zéro.
</para>
<para>Quand l&textrsquo;argument optionnel <code>[<var>super</var>]</code> est fourni, le compteur
<var>nomcompteur</var> est réinitialisé à chaque incrémentation du compteur
nommé <var>super</var>.
</para>
<para><xref label="Counters"><xrefnodename>Counters</xrefnodename></xref>, pour plus d&textrsquo;information à propos des compteurs.
</para>

</section>
<node name="_005cnewlength" spaces=" "><nodename>\newlength</nodename><nodenext automatic="on">\newsavebox</nodenext><nodeprev automatic="on">\newcounter</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newlength</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="649">\newlength</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="395">longueurs, allouer de nouvelles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="396">longueurs élastiques, définir de nouvelles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="397">élastiques, définir de nouvelles longueurs</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="398">pas, registre de, &tex; de base</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="399">ressort, registre de, &tex; de base</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\<var>longueur</var>&rbrace;
</pre></example>

<para>Alloue un nouveau registre de longueur (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). L&textrsquo;argument
obligatoire <code>\<var>longueur</var></code> doit être une séquence de contrôle
(<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), et donc commencer par une controblique
<code>\</code> dans les circonstances normales. Le nouveau registre détient
des longueurs (élastiques) telles que <code>72.27pt</code> ou <code>1in
plus.2in minus.1in</code> (un registre de longueur &latex; est ce que
&tex; de base appelle un registre <code>skip</code>, ou registre de
pas). Le registre est créé avec une valeur initiale de zéro. La séquence
de contrôle <code>\<var>longueur</var></code> doit ne pas être déjà définie.
</para>
<para>Voici une exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\graphichgt&rbrace;
</pre></example>

<para>Si vous oubliez la controblique alors vous obtenez l&textrsquo;erreur
<samp>Missing control sequence inserted</samp>.  Si la séquence de contrôle
existe déjà alors vous obtenez quelque chose du genre de <samp>LaTeX
Error: Command \graphichgt already defined.  Or name \end... illegal,
see p.192 of the manual</samp>.
</para>
</section>
<node name="_005cnewsavebox" spaces=" "><nodename>\newsavebox</nodename><nodenext automatic="on">\newenvironment &amp; \renewenvironment</nodenext><nodeprev automatic="on">\newlength</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newsavebox</code> : allouer une boîte</sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="650">\newsavebox</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="400">boîte, allouer une nouvelle</indexterm></cindex>

<para>Alloue un « baquet » pour détenir une boîte. Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newsavebox&lbrace;\<var>cmd</var>&rbrace;
</pre></example>

<para>Définit <code>\<var>cmd</var></code> pour se référer à un nouveau baquet pour stocker
des boîtes. Une telle boîte sert à détenir de la matière composée, pour
l&textrsquo;utiliser plusieurs fois (<pxref label="Boxes"><xrefnodename>Boxes</xrefnodename></pxref>) ou pour le mesurer ou le
manipuler. Le nom <code>\<var>cmd</var></code> doit commencer par une
controblique, et ne doit pas être déjà défini.
</para>
<para>L&textrsquo;allocation d&textrsquo;une boîte est globale. Cette commande est fragile
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>

</section>
<node name="_005cnewenvironment-_0026-_005crenewenvironment" spaces=" "><nodename>\newenvironment &amp; \renewenvironment</nodename><nodenext automatic="on">\newtheorem</nodenext><nodeprev automatic="on">\newsavebox</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newenvironment</code> &amp; <code>\renewenvironment</code></sectiontitle>

<anchor name="_005cnewenvironment">\newenvironment</anchor>
<anchor name="_005crenewenvironment">\renewenvironment</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="651">\newenvironment</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="652">\renewenvironment</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="401">environnements, définir</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="402">définir de nouveaux environnements</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="403">redéfinir des environnements</indexterm></cindex>

<para>Ces commandes définissent ou redéfinissent un environnement <var>env</var>,
c.-à-d., <code>\begin&lbrace;<var>env</var>&rbrace; <var>corps</var> \end&lbrace;<var>env</var>&rbrace;</code>.
</para>
<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">  \newenvironment&lbrace;<var>env</var>&rbrace;[<var>nargs</var>][<var>argoptdéfaut</var>]&lbrace;<var>défdébut</var>&rbrace;&lbrace;<var>déffin</var>&rbrace;
  \newenvironment*&lbrace;<var>env</var>&rbrace;[<var>nargs</var>][<var>argoptdéfaut</var>]&lbrace;<var>défdébut</var>&rbrace;&lbrace;<var>déffin</var>&rbrace;
\renewenvironment&lbrace;<var>env</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défdébut</var>&rbrace;&lbrace;<var>déffin</var>&rbrace;
\renewenvironment*&lbrace;<var>env</var>&rbrace;[<var>nargs</var>]&lbrace;<var>défdébut</var>&rbrace;&lbrace;<var>déffin</var>&rbrace;
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="404">forme étoilée des commandes d&textrsquo;environnement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="405">forme en * des commandes d&textrsquo;environnement</indexterm></cindex>
<para>La forme étoilée de ces commandes exige que les arguments (à ne pas
confondre avec le corps de l&textrsquo;environnement) ne contiennent pas de
paragraphes de texte.
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">env</itemformat></item>
</tableterm><tableitem><para>Obligatoire ; le nom de l&textrsquo;environnement. Il est constitué seulement de
lettres ou du caractère astérisque <code>*</code>, et donc ne commence pas par
une controblique <code>\</code>. Il ne doit pas commencer par la chaîne
<code>end</code>. Pour <code>\newenvironment</code>, <var>env</var> ne doit pas être le
nom d&textrsquo;un environnement déjà existant, et la commande <code>\<var>env</var></code>
ne doit pas être définie. Pour <code>\renewenvironment</code>, <var>env</var> doit
être le nom d&textrsquo;un environnement déjà existant.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">nargs</itemformat></item>
</tableterm><tableitem><para>Optionnel ; un entier de 0 à 9 indiquant le nombre d&textrsquo;arguments que
l&textrsquo;environnement attend. Quand l&textrsquo;environnement est utilisé, ces arguments
apparaissent après le <code>\begin</code>, comme dans
<code>\begin&lbrace;<var>env</var>&rbrace;&lbrace;<var>arg1</var>&rbrace;&dots;&lbrace;<var>argn</var>&rbrace;</code>.  Si cet
argument n&textrsquo;est pas présent, alors par défaut l&textrsquo;environnement n&textrsquo;attend pas
d&textrsquo;argument. Lorsqu&textrsquo;on redéfinit un environnement, la nouvelle version peut
prendre un nombre différent d&textrsquo;arguments que la précédente.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">argoptdéfaut</itemformat></item>
</tableterm><tableitem><para>Optionnel ; si cet argument est présent alors le premier argument de
l&textrsquo;environnement en définition est optionnel, et sa valeur par défaut est
<var>argoptdéfaut</var> (éventuellement une chaîne vide). Si cet argument
n&textrsquo;est pas présent alors l&textrsquo;environnement ne prend pas d&textrsquo;argument
optionnel.
</para>
<para>c.-à-d.&noeos; que si <code>[<var>argoptdéfaut</var>]</code> est présent dans la
définition de l&textrsquo;environnement alors vous pouvez commencer
l&textrsquo;environnement avec des crochets, comme dans
<code>\begin&lbrace;<var>env</var>&rbrace;[<var>valopt</var>]&lbrace;...&rbrace; ... \end&lbrace;<var>env</var>&rbrace;</code>.
Dans ce cas, au sein de <var>défdébut</var>, le paramètre <code>#1</code> est réglé
à la valeur de <var>valopt</var>. Si par contre <code>\begin&lbrace;<var>env</var>&rbrace;</code>
est appelé sans être suivi de crochet, alors, au sein de <var>défdébut</var>,
le paramètre <code>#1</code> est réglé à la valeur par défaut
<var>optargdéfaut</var>.  Dans les deux cas, le premier paramètre
obligatoire, s&textrsquo;il en est, est <code>#2</code>.
</para>
<para>Omettre <code>[<var>valopt</var>]</code> dans l&textrsquo;appel est différent d&textrsquo;avoir des
crochets sans contenu, comme dans <code>[]</code>. Dans le premier cas
<code>#1</code> se développe en <var>argoptdéfaut</var>, et dans le second en une
chaîne vide.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">défdébut</itemformat></item>
</tableterm><tableitem><para>Obligatoire ; le texte qui est développé à toute occurrence de
<code>\begin&lbrace;<var>env</var>&rbrace;</code> ; au sein de <var>défdébut</var>, le <var>n</var>ième
paramètre positionnel, (c.-à-d.&noeos; <code>#<var>n</var></code>), est remplacé au sein
de <var>défdébut</var> par le texte du <var>n</var>ième argument.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">déffin</itemformat></item>
</tableterm><tableitem><para>Obligatoire ; le texte développé à toute occurrence de
<code>\end&lbrace;<var>env</var>&rbrace;</code>. Il ne doit contenir aucun paramètre
positionnel, ainsi <code>#<var>n</var></code> ne peut pas être utilisé ici (mais
voyez l&textrsquo;exemple final ci-après).
</para>
</tableitem></tableentry></table>

<para>Tous les environnements, c&textrsquo;est à dire le code de <var>défdébut</var>, le
corps de l&textrsquo;environnement, et le code <var>déffin</var>, sont traités au sein
d&textrsquo;un groupe.  Ainsi, dans le premier exemple ci-dessous, l&textrsquo;effet de
<code>\small</code> est limité à la citation et ne s&textrsquo;étend pas à la matière qui
suit l&textrsquo;environnement.
</para>
<para>Cet exemple dont un environnement semblable à <code>quotation</code> de
&latex; à ceci près qu&textrsquo;il sera composé dans une taille de police plus
petite :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newenvironment&lbrace;smallquote&rbrace;&lbrace;%
  \small\begin&lbrace;quotation&rbrace;
&rbrace;&lbrace;%
  \end&lbrace;quotation&rbrace;
&rbrace;
</pre></example>

<para>Celui-ci montre l&textrsquo;utilisation des arguments ; cela donne un environnement de
citation qui affiche l&textrsquo;auteur :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newenvironment&lbrace;citequote&rbrace;[1][Corneille]&lbrace;%
  \begin&lbrace;quotation&rbrace;
  \noindent\textit&lbrace;#1&rbrace;:
&rbrace;&lbrace;%
  \end&lbrace;quotation&rbrace;
&rbrace;
</pre></example>

<noindent></noindent><para>Le nom de l&textrsquo;auteur est optionnel, et vaut par défaut <samp>Corneille</samp>.
Dans le document, utilisez l&textrsquo;environnement comme ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;citequote&rbrace;[Clovis, roi des Francs]
  ...
\end&lbrace;citequote&rbrace;
</pre></example>

<para>Ce dernier exemple montre comment sauvegarder la valeur d&textrsquo;un argument
pour l&textrsquo;utiliser dans <var>déffin</var>, dans ce cas dans une boîte
(<pxref label="_005csbox-_0026-_005csavebox"><xrefnodename>\sbox &amp; \savebox</xrefnodename></pxref>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newsavebox&lbrace;\quoteauthor&rbrace;
\newenvironment&lbrace;citequote&rbrace;[1][Corneille]&lbrace;%
  \sbox\quoteauthor&lbrace;#1&rbrace;%
  \begin&lbrace;quotation&rbrace;
&rbrace;&lbrace;%
  \hspace&lbrace;1em plus 1fill&rbrace;---\usebox&lbrace;\quoteauthor&rbrace;
  \end&lbrace;quotation&rbrace;
&rbrace;
</pre></example>


</section>
<node name="_005cnewtheorem" spaces=" "><nodename>\newtheorem</nodename><nodenext automatic="on">\newfont</nodenext><nodeprev automatic="on">\newenvironment &amp; \renewenvironment</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newtheorem</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="653">\newtheorem</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="406">théorèmes, définition</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="407">définir de nouveaux théorèmes</indexterm></cindex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="408">théorème, environnement simili-</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="409">environnement simili-théorème</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newtheorem&lbrace;<var>nom</var>&rbrace;&lbrace;<var>titre</var>&rbrace;
\newtheorem&lbrace;<var>nom</var>&rbrace;&lbrace;<var>titre</var>&rbrace;[<var>numéroté_au_sein_de</var>]
\newtheorem&lbrace;<var>nom</var>&rbrace;[<var>numéroté_comme</var>]&lbrace;<var>titre</var>&rbrace;
</pre></example>

<para>Définit un nouvel <dfn>environnement simili-théorème</dfn>. Vous pouvez
spécifier l&textrsquo;un seul de <var>numéroté_au_sein_de</var> ou
<var>numéroté_comme</var>, ou ni l&textrsquo;un ni l&textrsquo;autre, mais non les deux à la
fois.
</para>
<para>La première forme, <code>\newtheorem&lbrace;<var>nom</var>&rbrace;&lbrace;<var>titre</var>&rbrace;</code>, crée
un environnement qui sera étiqueté avec <var>titre</var> ; voir le premier
exemple ci-dessous.
</para>
<para>La seconde forme,
<code>\newtheorem&lbrace;<var>nom</var>&rbrace;&lbrace;<var>titre</var>&rbrace;</code>[<var>numéroté_au_sein_de</var>],
crée un environnement dont le compteur est subordonné au compteur déjà
existant <var>numéroté_au_sein_de</var>, c.-à-d.&noeos; qui est réinitialisé à
chaque réinitialisation de <var>numéroté_au_sein_de</var>. Voir le second
exemple ci-dessous.
</para>
<para>La troisième forme
<code>\newtheorem&lbrace;<var>nom</var>&rbrace;[<var>numéroté_comme</var>]&lbrace;<var>titre</var>&rbrace;</code>,
avec l&textrsquo;argument optionnel entre les deux arguments obligatoires, crée un
environnement dont le compteur partage le compteur déjà défini
<var>numéroté_comme</var>.  Voir le troisième exemple.
</para>
<para>Cette déclaration est globale. Elle est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<!-- c xx pourquoi a-t-on supprimé cette info, cf. rev 483. -->
<ignore>
Cette commande crée un compteur nommé @var{name}.  De plus, à moins que
l'argument optionnel @var{numéroté_comme} soit utilisé, la valeur
courante de @code{\ref} est celle de
@code{\the@var{numéroté_au_sein_de}} (@pxref{\ref}).
</ignore>

<para>Arguments :
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">nom</itemformat></item>
</tableterm><tableitem><para>Le nom de l&textrsquo;environnement. C&textrsquo;est une chaîne de lettres. Il ne doit pas
commencer avec une controblique (<samp>\</samp>). Il ne doit pas être le nom
d&textrsquo;un environnement déjà existant ; en fait le nom de commande
<code>\<var>nom</var></code> ne doit pas être déjà défini de quelque façon que ce
soit.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">titre</itemformat></item>
</tableterm><tableitem><para>Le texte imprimé au début de l&textrsquo;environnement, avant le numéro. Par
exemple, <samp>Théorème</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">numéroté_au_sein_de</itemformat></item>
</tableterm><tableitem><para>Optionnel ; le nom d&textrsquo;un compteur déjà défini, d&textrsquo;ordinaire une unité
sectionnelle telle que <code>chapter</code> ou <code>section</code>. Lorsque le
compteur <var>numéroté_au_sein_de</var> est réinitialisé, alors le compteur
de l&textrsquo;environnement <var>nom</var> l&textrsquo;est aussi.
</para>
<para>Si cet argument optionnel est omis alors la commande
<code>\the<var>nom</var></code> est définie comme <code>\arabic&lbrace;<var>nom</var>&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">numéroté_comme</itemformat></item>
</tableterm><tableitem><para>Optionnel ; le nom d&textrsquo;un environnement simili-théorème déjà défini. Le
nouvel environnement se numérote en séquence avec <var>numéroté_comme</var>.
</para>
</tableitem></tableentry></table>

<para>En l&textrsquo;absence des arguments optionnels les environnements sont numérotés
en séquence. L&textrsquo;exemple suivant a une déclaration dans le préambule qui
résulte en <samp>Définition 1</samp> et <samp>Définition 2</samp> en
sortie.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newtheorem&lbrace;defn&rbrace;&lbrace;Définition&rbrace;
\begin&lbrace;document&rbrace;
\section&lbrace;...&rbrace;
\begin&lbrace;defn&rbrace;
  Première déf.
\end&lbrace;defn&rbrace;

\section&lbrace;...&rbrace;
\begin&lbrace;defn&rbrace;
  Seconde déf.
\end&lbrace;defn&rbrace;
</pre></example>

<para>L&textrsquo;exemple suivant reprend le même corps de document que l&textrsquo;exemple
précédent. Mais ici l&textrsquo;argument optionnel <var>numéroté_au_sein_de</var> de
<code>\newtheorem</code> est spécifié comme <code>section</code>, aussi la sortie
est du genre de <samp>Définition 1.1</samp> et <samp>Définition 2.1</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newtheorem&lbrace;defn&rbrace;&lbrace;Definition&rbrace;[section]
\begin&lbrace;document&rbrace;
\section&lbrace;...&rbrace;
\begin&lbrace;defn&rbrace;
  Première déf.
\end&lbrace;defn&rbrace;

\section&lbrace;...&rbrace;
\begin&lbrace;defn&rbrace;
  Seconde déf.
\end&lbrace;defn&rbrace;
</pre></example>

<para>Dans l&textrsquo;exemple suivant il y a deux déclarations dans le préambule, la
seconde desquelles appelle le nouvel environnement <code>thm</code> pour
utiliser le même compteur que <code>defn</code>.  Cela donne
<samp>Définition 1.1</samp>, suivi de <samp>Théorème 2.1</samp> et <samp>Définition 2.2</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newtheorem&lbrace;defn&rbrace;&lbrace;Définition&rbrace;[section]
\newtheorem&lbrace;thm&rbrace;[defn]&lbrace;Théorème&rbrace;
\begin&lbrace;document&rbrace;
\section&lbrace;...&rbrace;
\begin&lbrace;defn&rbrace;
  Première déf.
\end&lbrace;defn&rbrace;

\section&lbrace;...&rbrace;
\begin&lbrace;thm&rbrace;
  Premier théorème
\end&lbrace;thm&rbrace;

\begin&lbrace;defn&rbrace;
  Seconde déf.
\end&lbrace;defn&rbrace;
\section&lbrace;...&rbrace;
</pre></example>


</section>
<node name="_005cnewfont" spaces=" "><nodename>\newfont</nodename><nodenext automatic="on">\protect</nodenext><nodeprev automatic="on">\newtheorem</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\newfont</code>: définit une nouvelle police (obsolète)</sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="654">\newfont</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="410">polices, commandes pour déclarer de nouvelles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="411">définir de nouvelles polices</indexterm></cindex>


<para><code>\newfont</code>, désormais obsolète, définit une commande qui commute la
police de caractère. Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newfont&lbrace;\<var>cmd</var>&rbrace;&lbrace;<var>description_police</var>&rbrace;
</pre></example>

<para>Ceci définit une séquence de contrôle <code>\<var>cmd</var></code> qui change la
police courante.  &latex; cherche sur votre système un fichier nommé
<file><var>nompolice</var>.tfm</file>.  La séquence de contrôle ne doit pas être
déjà définie.  Elle doit commencer par une controblique (<samp>\</samp>).
</para>


<findex index="fn" spaces=" "><indexterm index="fn" number="655">.fd <r>fichier</r></indexterm></findex>
<para>Cette commande est obsolète.  c&textrsquo;est une commande de bas niveau pour
mettre en place une police individuelle. De nos jours, les polices sont
pratiquement toujours définies en familles (ce qui vous permet, par
exemple, d&textrsquo;associer un gras et un romain) au travers de ce qu&textrsquo;il est
convenu de nommer le « Nouveau Plan de Sélection de Polices de
caractère », soit en utilisant des fichiers <file>.fd</file> ou à travers
l&textrsquo;utilisation d&textrsquo;un moteur qui sait accéder au système de polices de
caractère, tel que Xe&latex; (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename><xrefinfoname>Les moteurs
&tex;</xrefinfoname></pxref>).
<!-- c xx explain nfss somewhere -->
</para>

<cindex index="cp" spaces=" "><indexterm index="cp" number="412">clause at, au sein d&textrsquo;une définition de police</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="413">taille de conception, au sein d&textrsquo;une définition de police</indexterm></cindex>
<para>Mais puisque cela fait partie de &latex;, voici l&textrsquo;explication : le
paramètre <var>description_police</var> consiste en un <var>nompolice</var> et une
<dfn>clause at</dfn> optionnelle ; celle-ci peut avoir soit la forme <code>at
<var>dimen</var></code> ou <code>scaled <var>facteur</var></code>, où un <var>facteur</var> de
<samp>1000</samp> signifie aucune dilatation/contraction.  Pour l&textrsquo;usage de
&latex;, tout ce que ceci fait est de dilater ou contracter le
caractère et les autres dimensions relatives à la taille de conception de
la police, ce qui est une valeur définie dans le fichier en <file>.tfm</file>.
</para>
<para>Cet exemple définit deux polices équivalentes et compose quelques
caractères dans chacune d&textrsquo;elles :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newfont&lbrace;\testpoliceat&rbrace;&lbrace;cmb10 at 11pt&rbrace;
\newfont&lbrace;\testpolicedilatee&rbrace;&lbrace;cmb10 scaled 1100&rbrace;
\testpoliceat abc
\testpolicedilatee abc
</pre></example>


</section>
<node name="_005cprotect" spaces=" "><nodename>\protect</nodename><nodenext automatic="on">\ignorespaces &amp; \ignorespacesafterend</nodenext><nodeprev automatic="on">\newfont</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\protect</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="656">\protect</indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="414">commandes fragiles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="415">commandes robustes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="416">fragile, commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="417">robuste, commande</indexterm></cindex>

<para>Toutes les commandes de &latex; sont soit <dfn>fragiles</dfn> soit
<dfn>robustes</dfn>. Les notes en bas de page, les sauts de ligne, toute
commande prenant un argument optionnel, et bien d&textrsquo;autres, sont
fragiles. Une commande fragile peut se disloquer et causer une erreur
lorsque elle est utilisée au sein de l&textrsquo;argument de certaines
commandes. Pour empêcher la dislocation de ces commandes l&textrsquo;une des
solutions est de les précéder de la commande <code>\protect</code>.
</para>
<para>Par exemple, lorsque &latex; exécute la commande
<code>\section&lbrace;<var>nom-rubrique</var>&rbrace;</code> il écrit le texte
<var>nom-rubrique</var> dans le fichier auxiliaire <file>.aux</file>, de sorte à
pouvoir le tirer de là pour l&textrsquo;utiliser dans d&textrsquo;autres parties du document
comme la table des matières. On appelle
<cindex index="cp" spaces=" "><indexterm index="cp" number="418">arguments mouvants</indexterm></cindex>
<dfn>argument mouvant</dfn> tout argument qui est développé en interne par
&latex; sans être directement composé en sortie. Une commande est dite
fragile si elle se développe pendant ce processus en un code &tex; non
valide. Certains exemples d&textrsquo;arguments mouvants sont ceux qui apparaissent
au sein des commandes <code>\caption&lbrace;...&rbrace;</code> (<pxref label="figure"><xrefnodename>figure</xrefnodename></pxref>), dans la
commande <code>\thanks&lbrace;...&rbrace;</code> (<pxref label="_005cmaketitle"><xrefnodename>\maketitle</xrefnodename></pxref>), et dans les
expressions en &arobase; des environnements <code>tabular</code> et <code>array</code>
(<pxref label="tabular"><xrefnodename>tabular</xrefnodename></pxref>).
</para>
<para>Si vous obtenez des erreurs étranges de commandes utilisées au sein
d&textrsquo;arguments mouvants, essayez des les précéder d&textrsquo;un <code>\protect</code>. Il
faut un <code>\protect</code> pour chacune des commandes fragiles.
</para>
<para>Bien qu&textrsquo;en général la commande <code>\protect</code> ne fait pas de mal, les
commandes de gestion de longueurs sont robustes et ne devraient pas être
précédées d&textrsquo;une commande <code>\protect</code>. Une commande <code>\protect</code>
ne peut pas non plus être utilisée au sein de l&textrsquo;argument d&textrsquo;une commande
<ref label="_005caddtocounter"><xrefnodename>\addtocounter</xrefnodename><xrefinfoname><code>\addtocounter</code></xrefinfoname></ref> ou
<ref label="_005csetcounter"><xrefnodename>\setcounter</xrefnodename><xrefinfoname><code>\setcounter</code></xrefinfoname></ref>.
</para>
<para>Dans l&textrsquo;exemple qui suit la commande <code>\caption</code> produit une erreur
mystérieuse
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure&rbrace;
  ...
  \caption&lbrace;Company headquarters of A\raisebox&lbrace;1pt&rbrace;&lbrace;B&rbrace;\raisebox&lbrace;-1pt&rbrace;&lbrace;C&rbrace;&rbrace;
\end&lbrace;figure&rbrace;
</pre></example>

<para>Dans l&textrsquo;exemple suivant la commande <code>\tableofcontents</code> produit une
erreur à cause du <code>\(..\)</code> dans le titre de section qui se
développe en code  incorrect &tex; dans le fichier <file>.toc</file>.  Vous
pouvez résoudre ceci en remplaçant  <code>\(..\)</code>
par <code>\protect\(..\protect\)</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;document&rbrace;
\tableofcontents
...
\section&lbrace;Einstein's \( e=mc^2 \)&rbrace;
...
</pre></example>


</section>
<node name="_005cignorespaces-_0026-_005cignorespacesafterend" spaces=" "><nodename>\ignorespaces &amp; \ignorespacesafterend</nodename><nodenext automatic="on">xspace package</nodenext><nodeprev automatic="on">\protect</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle><code>\ignorespaces &amp; \ignorespacesafterend</code></sectiontitle>

<anchor name="_005cignorespaces">\ignorespaces</anchor>
<anchor name="_005cignorespacesafterend">\ignorespacesafterend</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="657">\ignorespaces</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="658">\ignorespacesafterend</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="419">espaces, ignorer au voisinage d&textrsquo;une commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="420">commandes, ignorer les espaces</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ignorespaces
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ignorespacesafterend
</pre></example>

<para>Les deux commandes ont pour effet que &latex; ignore l&textrsquo;espace blanc
après la commande et jusqu&textrsquo;à rencontrer une boîte ou un caractère non
blanc.  La première commande est une commande primitive de &tex;, et la
seconde est spécifique à &latex;.
</para>
<para>La commande <code>\ignorespaces</code> est souvent utilisée quand on définit
des commandes au moyen de <code>\newcommand</code>, ou <code>\newenvironment</code>,
ou <code>\def</code>. Ceci est illustré par l&textrsquo;exemple plus bas. Il permet à un
utilisateur d&textrsquo;afficher dans la marge combien de points rapporte chaque
questions d&textrsquo;un questionnaire, mais il est malcommode parce que, comme
illustré dans la liste <code>enumerate</code>, l&textrsquo;utilisateur ne doit pas
mettre d&textrsquo;espace entre la commande et le texte de la question.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\points&rbrace;[1]&lbrace;\makebox[0pt]&lbrace;\makebox[10em][l]&lbrace;#1~pts&rbrace;&rbrace;
\begin&lbrace;enumerate&rbrace;
  \item\points&lbrace;10&rbrace;aucun espace superflu inséré ici
  \item\points&lbrace;15&rbrace; ici un espace superflu entre le nombre et le mot « ici »
\end&lbrace;enumerate&rbrace;
</pre></example>

<noindent></noindent>
<para>La solution est de modifier comme ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\points&rbrace;[1]&lbrace;%
  \makebox[0pt]&lbrace;\makebox[10em][l]&lbrace;#1~pts&rbrace;&rbrace;\ignorespaces&rbrace;
</pre></example>

<para>Dans le second exemple on illustre comment l&textrsquo;espace blanc est enlevé de
devant le texte. Les commandes ci-dessous permettent à utilisateur
d&textrsquo;attacher uniformément une civilité à un nom. Mais si, quand il est
donné, une civilité commence accidentellement par un espace alors
<code>\nomcomplet</code> le reproduira.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\honorific&rbrace;[1]&lbrace;\def\honorific&lbrace;#1&rbrace;&rbrace; % mémorise le titre
\newcommand&lbrace;\fullname&rbrace;[1]&lbrace;\honorific~#1&rbrace;   % met le titre devant le nom

\begin&lbrace;tabular&rbrace;&lbrace;|l|&rbrace;
\honorific&lbrace;M./Mme&rbrace;  \fullname&lbrace;Jean&rbrace; \\  % sans espace superflu
\honorific&lbrace; M./Mme&rbrace; \fullname&lbrace;Jean&rbrace;     % espace superflu devant la civilité
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>Pour réparer cela, modifier le en
<code>\newcommand&lbrace;\fullname&rbrace;[1]&lbrace;\ignorespaces\honorific~#1&rbrace;</code>.
</para>
<para>Le <code>\ignorespaces</code> est aussi souvent utilisé dans un
<code>\newenvironment</code> à la fin de la clause <var>begin</var>, comme dans
<code>\begin&lbrace;newenvironment&rbrace;&lbrace;<var>env
name</var>&rbrace;&lbrace;... \ignorespaces&rbrace;&lbrace;...&rbrace;</code>.
</para>
<para>Pour enlever l&textrsquo;espace blanc venant immédiatement après un environnement
utilisez <code>\ignorespacesafterend</code>.  Dans l&textrsquo;exemple ci-dessous on
affiche un espace vertical bien plus grand entre le premier et
le deuxième environnements qu&textrsquo;entre le deuxième et le troisième.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newenvironment&lbrace;eq&rbrace;&lbrace;\begin&lbrace;equation&rbrace;&rbrace;&lbrace;\end&lbrace;equation&rbrace;&rbrace;
\begin&lbrace;eq&rbrace;
e=mc^2
\end&lbrace;eq&rbrace;
\begin&lbrace;equation&rbrace;
F=ma
\end&lbrace;equation&rbrace;
\begin&lbrace;equation&rbrace;
E=IR
\end&lbrace;equation&rbrace;
</pre></example>

<para>On peut faire disparaître l&textrsquo;espace vertical en mettant un
caractère <code>%</code> de commentaire immédiatement après le
<code>\end&lbrace;eq&rbrace;</code>, mais cela est malcommode.  La solution est de
modifier en
<code>\newenvironment&lbrace;eq&rbrace;&lbrace;\begin&lbrace;equation&rbrace;&rbrace;&lbrace;\end&lbrace;equation&rbrace;\ignorespacesafterend&rbrace;</code>.
</para>

</section>
<node name="xspace-package" spaces=" "><nodename>xspace package</nodename><nodeprev automatic="on">\ignorespaces &amp; \ignorespacesafterend</nodeprev><nodeup automatic="on">Definitions</nodeup></node>
<section spaces=" "><sectiontitle>xspace package</sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="659">\xspace</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="660"><r>paquetage</r> <code>xspace</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="661"><code>xspace</code>, <r>paquetage</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="421">espaces, ignorer autour des commandes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="422">commandes, ignorer les espaces</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;xspace&rbrace;
  ...
\newcommand&lbrace;...&rbrace;&lbrace;...\xspace&rbrace;
</pre></example>

<para>La macro <code>\xspace</code>, quand utilisée à la fin de la définition d&textrsquo;une
commande, ajoute une espace à moins que la commande soit suivie de
certains caractères de ponctuation.
</para>
<para>Après la séquence de contrôle d&textrsquo;une commande qui est un mot de contrôle
(<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>, contrairement aux symboles de contrôle tels
que <code>\$</code>), &tex; avale les caractères blancs. Ainsi, dans la
première phrase ci-dessous, en sortie on a <samp>Provence</samp> placé
parfaitement contre le point, sans espace entre les deux.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\PR&rbrace;&lbrace;Provence&rbrace;
Notre école est en \PR .
Les étés en \PR&lbrace;&rbrace; sont agréables.
</pre></example>

<para>Mais à cause de l&textrsquo;avalement, la seconde phrase a besoin de l&textrsquo;adjonction
d&textrsquo;accolades vides <code>&lbrace;&rbrace;</code>, sans quoi il n&textrsquo;y aurait pas d&textrsquo;espace
entre <samp>Provence</samp> et <samp>sont</samp>.  (Beaucoup d&textrsquo;auteurs utilisent
plutôt un <code>\ </code> pour cela.  <xref label="_005c_0028SPACE_0029"><xrefnodename>\(SPACE)</xrefnodename></xref>.)
</para>
<para>Le paquetage <code>xspace</code> fournit la commande <code>\xspace</code>.  Elle
sert à écrire des commandes conçues pour être utilisées essentiellement
dans du texte. Elle doit être placée à la toute fin de la définition de
ces commandes. Elle insère un espace après la commande à moins que ce qui
la suive immédiatement soit dans une liste d&textrsquo;exceptions.  Dans l&textrsquo;exemple
suivant, on peut se passer de l&textrsquo;adjonction d&textrsquo;accolades vides.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\PR&rbrace;&lbrace;Provence\xspace&rbrace;
Notre école est en \PR .
Les étés en \PR&lbrace;&rbrace; sont agréables.
</pre></example>

<para>La liste d&textrsquo;exceptions par défaut contient les caractères
<code>,.'/?;:!~-)</code>, ainsi que l&textrsquo;accolade ouvrante, la commande
controblique-espace discutée plus haut, et les commandes
<code>\footnote</code> ou <code>\footnotemark</code>.  On peut ajouter des éléments
à cette liste comme avec <code>\xspaceaddexceptions&lbrace;\manotebdpi
\manotebdpii&rbrace;</code> qui rajoute les séquences de contrôle <code>\manotebdpi</code>
et <code>\manotebdpii</code> à la liste, et retrancher un élément de la liste
comme avec <code>\xspaceremoveexception&lbrace;!&rbrace;</code>.
</para>
<!-- c David Carlisle https://tex.stackexchange.com/a/86620/339 -->
<para>Comment : nombre d&textrsquo;experts préfèrent ne pas utiliser <code>\xspace</code>.  La
mettre dans une définition signifie que la commande sera en général
suivie du bon espacement. Mais il n&textrsquo;est pas aisé de prédire quand
ajouter les accolades vides <code>&lbrace;&rbrace;</code> parce que <code>\xspace</code> se sera
trompé, comme lorsque elle est suivie d&textrsquo;une autre commande, et donc
<code>\xspace</code> peut rendre l&textrsquo;édition d&textrsquo;une matière plus difficile et
plus faillible que de mettre systématiquement les accolades vides.
</para>

</section>
</chapter>
<node name="Counters" spaces=" "><nodename>Counters</nodename><nodenext automatic="on">Lengths</nodenext><nodeprev automatic="on">Definitions</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Compteurs</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="423">compteurs, une liste de</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="424">variables, une liste de</indexterm></cindex>

<para>Tout ce que &latex; numérote pour vous a un compteur associé avec
soi. Le nom du compteur est le même que le nom de l&textrsquo;environnement ou de
la commande qui produit le numéro, sauf qu&textrsquo;il ne pas de <code>\</code>.
(<code>enumi</code>&textndash;<code>enumiv</code> sont utilisés pour les environnements
<code>enumerate</code> imbriqués). Ci-dessous se trouve une liste des
compteurs utilisée dans les classes standardes de documents &latex;
pour contrôler la numérotation.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="662">part, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="663">chapter, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="664">section, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="665">subsection, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="666">subsubsection, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="667">paragraph, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="668">subparagraph, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="669">page, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="670">equation, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="671">figure, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="672">table, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="673">footnote, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="674">mpfootnote, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="675">enumi, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="676">enumii, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="677">enumiii, compteur</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="678">enumiv, compteur</indexterm></findex>
<example endspaces=" ">
<pre xml:space="preserve">part          paragraph    figure     enumi
chapter       subparagraph table      enumii
section       page         footnote   enumiii
subsection    equation     mpfootnote enumiv
subsubsection
</pre></example>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\alph \Alph \arabic \roman \Roman \fnsymbol</menunode><menudescription><pre xml:space="preserve">Taper la valeur d&textrsquo;un compteur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\usecounter</menunode><menudescription><pre xml:space="preserve">Utiliser un  compteur spécifié dans un environnement de liste.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\value</menunode><menudescription><pre xml:space="preserve">Utiliser la valeur d&textrsquo;un compteur dans une expression.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\setcounter</menunode><menudescription><pre xml:space="preserve">Régler la valeur d&textrsquo;un compteur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\addtocounter</menunode><menudescription><pre xml:space="preserve">Ajouter une quantité à un compteur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\refstepcounter</menunode><menudescription><pre xml:space="preserve">Ajouter au compteur, réinitialiser les compteurs subsidiaires.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\stepcounter</menunode><menudescription><pre xml:space="preserve">Ajouter au compteur, réinitialiser les compteurs subsidiaires.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\day &amp; \month &amp; \year</menunode><menudescription><pre xml:space="preserve">Valeur de date numériques.
</pre></menudescription></menuentry></menu>


<node name="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol" spaces=" "><nodename>\alph \Alph \arabic \roman \Roman \fnsymbol</nodename><nodenext automatic="on">\usecounter</nodenext><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\alph \Alph \arabic \roman \Roman \fnsymbol</code>: Taper des compteurs</sectiontitle>

<para>Toutes ces commandes prennent un unique compteur en argument, par
exemple, <code>\alph&lbrace;enumi&rbrace;</code>.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="679">\alph</indexterm>\alph</itemformat></item>
</tableterm><tableitem><para>tape <var>compteur</var> en utilisant des lettres en bas de casse : &textlsquo;a&textrsquo;, &textlsquo;b&textrsquo;, &enddots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="680">\Alph</indexterm>\Alph</itemformat></item>
</tableterm><tableitem><para>Utilise des lettres capitales : &textlsquo;A&textrsquo;, &textlsquo;B&textrsquo;, &enddots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="681">\arabic</indexterm>\arabic</itemformat></item>
</tableterm><tableitem><para>Utilise des numéros en chiffres arabes : &textlsquo;1&textrsquo;, &textlsquo;2&textrsquo;, &enddots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="682">\roman</indexterm>\roman</itemformat></item>
</tableterm><tableitem><para>Utilise des nombres romains en bas de casse : &textlsquo;i&textrsquo;, &textlsquo;ii&textrsquo;, &enddots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="683">\Roman</indexterm>\Roman</itemformat></item>
</tableterm><tableitem><para>Utilise des nombres romains en capitales : &textlsquo;I&textrsquo;, &textlsquo;II&textrsquo;, &enddots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="684">\fnsymbol</indexterm>\fnsymbol</itemformat></item>
</tableterm><tableitem><para>Tape la valeur de <var>compteur</var> dans une séquence spécifique de neuf
symboles (utilisés par convention pour la numérotation des notes en bas
de page). La valeur de <var>compteur</var> doit être comprise entre 1
et 9 inclus.
</para>
<para>Voici ces symboles :
</para>
<multitable spaces="  " endspaces=" "><columnfractions line=".33 .33 .33"><columnfraction value=".33"></columnfraction><columnfraction value=".33"></columnfraction><columnfraction value=".33"></columnfraction></columnfractions>
<thead><row><entry command="headitem" spaces=" "><para>Nom</para></entry><entry command="tab" spaces=" "><para>Commande</para></entry><entry command="tab"><para>Équivalent Unicode<!-- c -->
</para></entry></row></thead><tbody><row><entry command="item">
<para>astérisque</para></entry><entry command="tab"><para><code>\ast</code></para></entry><entry command="tab"><para>*
</para></entry></row><row><entry command="item">
<para>obèle</para></entry><entry command="tab"><para><code>\dagger</code></para></entry><entry command="tab"><para>†
</para></entry></row><row><entry command="item">
<para>double-obèle</para></entry><entry command="tab"><para><code>\ddagger</code></para></entry><entry command="tab"><para>‡
</para></entry></row><row><entry command="item">
<para>marque-de-section</para></entry><entry command="tab"><para><code>\S</code></para></entry><entry command="tab"><para>§
</para></entry></row><row><entry command="item">
<para>marque-de-paragraphe</para></entry><entry command="tab"><para><code>\P</code></para></entry><entry command="tab"><para>¶
</para></entry></row><row><entry command="item">
<para>parallèle</para></entry><entry command="tab"><para><code>\parallel</code></para></entry><entry command="tab"><para>‖
</para></entry></row><row><entry command="item">
<para>astérisque-double</para></entry><entry command="tab"><para><code>\ast\ast</code></para></entry><entry command="tab"><para>**
</para></entry></row><row><entry command="item">
<para>obèle-double</para></entry><entry command="tab"><para><code>\dagger\dagger</code></para></entry><entry command="tab"><para>††
</para></entry></row><row><entry command="item">
<para>double-obèle-double</para></entry><entry command="tab"><para><code>\ddagger\ddagger</code></para></entry><entry command="tab"><para>‡‡
</para></entry></row></tbody></multitable>

</tableitem></tableentry></ftable>


</section>
<node name="_005cusecounter" spaces=" "><nodename>\usecounter</nodename><nodenext automatic="on">\value</nodenext><nodeprev automatic="on">\alph \Alph \arabic \roman \Roman \fnsymbol</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\usecounter&lbrace;<var>compteur</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="685">\usecounter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="425">article d&textrsquo;une liste, compteur spécifiant</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="426">articles numérotés, compteur spécifiant</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usecounter&lbrace;<var>compteur</var>&rbrace;
</pre></example>

<para>La commande <code>\usecounter</code> est utilisée dans le second argument de
l&textrsquo;environnement <code>list</code> pour spécifier le <var>compteur</var> à utiliser
pour numéroter les articles de la liste.
</para>

</section>
<node name="_005cvalue" spaces=" "><nodename>\value</nodename><nodenext automatic="on">\setcounter</nodenext><nodeprev automatic="on">\usecounter</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\value&lbrace;<var>compteur</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="686">\value</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="427">compteurs, obtenir la valeur d&textrsquo;un</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\value&lbrace;<var>compteur</var>&rbrace;
</pre></example>

<para>Cette commande se développe en la valeur de <var>compteur</var>. Elle est
souvent utilisé dans <code>\setcounter</code> ou <code>\addtocoutner</code>, mais
<code>\value</code> peut être utilisé partout là où &latex; attend un
nombre. Elle ne doit pas être précédée par <code>\protect</code>
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>La commande <code>\value</code> n&textrsquo;est pas utiliser pour composer la valeur du
compteur. <xref label="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol"><xrefnodename>\alph \Alph \arabic \roman \Roman \fnsymbol</xrefnodename></xref>.
</para>
<para>Cet exemple produit en sortie <samp>Le compteur essai vaut 6. Le
compteur autre vaut 5</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcounter&lbrace;essai&rbrace; \setcounter&lbrace;essai&rbrace;&lbrace;5&rbrace;
\newcounter&lbrace;autre&rbrace; \setcounter&lbrace;autre&rbrace;&lbrace;\value&lbrace;essai&rbrace;&rbrace;
\addtocounter&lbrace;essai&rbrace;&lbrace;1&rbrace;

Le compteur essai vaut \arabic&lbrace;essai&rbrace;.
Le compteur autre vaut \arabic&lbrace;autre&rbrace;.
</pre></example>

<para>Cet exemple insère <code>\hspace&lbrace;4\parindent&rbrace;</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setcounter&lbrace;moncptr&rbrace;&lbrace;3&rbrace; \addtocounter&lbrace;moncptr&rbrace;&lbrace;1&rbrace;
\hspace&lbrace;\value&lbrace;moncptr&rbrace;\parindent&rbrace;
</pre></example>


</section>
<node name="_005csetcounter" spaces=" "><nodename>\setcounter</nodename><nodenext automatic="on">\addtocounter</nodenext><nodeprev automatic="on">\value</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\setcounter&lbrace;<var>compteur</var>&rbrace;&lbrace;<var>value</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="687">\setcounter</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="428">compteurs, réglage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="429">réglage de compteurs</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setcounter&lbrace;<var>compteur</var>&rbrace;&lbrace;<var>value</var>&rbrace;
</pre></example>

<para>La commande <code>\setcounter</code> règle la valeur de <var>compteur</var> à
l&textrsquo;argument <var>value</var>.
</para>

</section>
<node name="_005caddtocounter" spaces=" "><nodename>\addtocounter</nodename><nodenext automatic="on">\refstepcounter</nodenext><nodeprev automatic="on">\setcounter</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\addtocounter&lbrace;<var>compteur</var>&rbrace;&lbrace;<var>valeur</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="688">\addtocounter</indexterm></findex>

<para>La commande <code>\addtocounter</code> incrémente <var>compteur</var> de la
quantité spécifiée par l&textrsquo;argument <var>valeur</var>, qui peut être négatif.
</para>

</section>
<node name="_005crefstepcounter" spaces=" "><nodename>\refstepcounter</nodename><nodenext automatic="on">\stepcounter</nodenext><nodeprev automatic="on">\addtocounter</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\refstepcounter&lbrace;<var>compteur</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="689">\refstepcounter</indexterm></findex>

<para>La commande <code>\refstepcounter</code> fonctionne de la même façon que
<code>\stepcounter</code> <xref label="_005cstepcounter"><xrefnodename>\stepcounter</xrefnodename></xref>, à ceci près qu&textrsquo;elle définit
également la valeur courante de <code>\ref</code> comme le résultat de
<code>\thecounter</code>.
</para>

</section>
<node name="_005cstepcounter" spaces=" "><nodename>\stepcounter</nodename><nodenext automatic="on">\day &amp; \month &amp; \year</nodenext><nodeprev automatic="on">\refstepcounter</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\stepcounter&lbrace;<var>compteur</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="690">\stepcounter</indexterm></findex>

<para>La commande <code>\stepcounter</code> ajoute un à <var>compteur</var> et
réinitialise tous les compteurs subsidiaires.
</para>

</section>
<node name="_005cday-_0026-_005cmonth-_0026-_005cyear" spaces=" "><nodename>\day &amp; \month &amp; \year</nodename><nodeprev automatic="on">\stepcounter</nodeprev><nodeup automatic="on">Counters</nodeup></node>
<section spaces=" "><sectiontitle><code>\day</code> &amp; <code>\month</code> &amp; <code>\year</code></sectiontitle>

<anchor name="_005cday">\day</anchor>
<anchor name="_005cmonth">\month</anchor>
<anchor name="_005cyear">\year</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="691">\day</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="692">\month</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="693">\year</indexterm></findex>

<para>&latex; définit des compteurs pour <code>\day</code> le quantième du mois
(nominalement avec une valeur entre 1 et 31), <code>\month</code> pour le
mois de l&textrsquo;année (nominalement avec une valeur entre 1 et 12), et
<code>\year</code> pour l&textrsquo;année.  Quand &tex; démarre, ils sont mis à la
valeur courante du système sur lequel &tex; s&textrsquo;exécute.  En relation
avec ces compteurs, la commande <code>\today</code> produit une chaîne
représentant le jour courant (<pxref label="_005ctoday"><xrefnodename>\today</xrefnodename></pxref>).
</para>
<para>Ils ne sont pas remis à jour pendant que le traitement par &tex;
progresse, ainsi en principe ils pourraient être incorrect à la fin. De
plus, &tex; n&textrsquo;effectue aucun contrôle sanitaire :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\day=-2 \month=13 \year=-4 \today
</pre></example>

<noindent></noindent>
<para>ne produit ni erreur ni avertissement, et le résultat est en sortie
<samp>-2, -4</samp> (la valeur de mois erronée ne produit rien en sortie).
</para>
<para><xref label="Command-line-input"><xrefnodename>Command line input</xrefnodename></xref>, pour forcer la date à une valeur donnée sur
la ligne de commande.
</para>
</section>
</chapter>
<node name="Lengths" spaces=" "><nodename>Lengths</nodename><nodenext automatic="on">Making paragraphs</nodenext><nodeprev automatic="on">Counters</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Longueurs</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="430">longueurs, définir et utiliser</indexterm></cindex>

<para>Une <dfn>longueur</dfn> est une mesure de distance. Beaucoup de commandes
&latex; prennent une longueur en argument.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="431">rigides, longueurs</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="432">élastiques, longueurs</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="433">dimen <r>&tex; de base</r></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="434">skip <r>&tex; de base</r></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="435">glue <r>&tex; de base</r></indexterm></cindex>
<para>Il y a deux types de longueur.  Une <dfn>longueur rigide</dfn> telle que
<code>10pt</code> ne contient pas de composante en <code>plus</code> ou
<code>minus</code>.  (En &tex; de base on appelle cela une <dfn>dimen</dfn>).
Une <dfn>longueur élastique</dfn> (ce qu&textrsquo;en &tex; de base on appel un
<dfn>skip</dfn> ou une <dfn>glue</dfn>) telle que dans <code>1cm plus0.05cm
minus0.01cm</code> peut contenir l&textrsquo;un ou l&textrsquo;autre de ces composantes ou les
deux.  Dans cette longueur élastique, le <code>1cm</code> est la <dfn>longueur
naturelle</dfn> alors que les deux autres, les composantes en <code>plus</code> et
<code>minus</code>, permette à &tex; à dilater ou contracter la longueur pour
optimiser la disposition.
</para>
<para>Les exemples qui suivent utilisent ces deux commandes.
</para>
<example endspaces=" ">
<pre xml:space="preserve">% Fait une barre noire de 10pt de haut et #1 de large
\newcommand&lbrace;\blackbar&rbrace;[1]&lbrace;\rule&lbrace;#1&rbrace;&lbrace;10pt&rbrace;&rbrace;

% Fait une boîte autour de #2 qui est #1 de large (sans la bordure)
\newcommand&lbrace;\showhbox&rbrace;[2]&lbrace;%
  \fboxsep=0pt\fbox&lbrace;\hbox to #1&lbrace;#2&rbrace;&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Cet exemple utilise ces commandes pour afficher une barre noire de
100 points de long entre <samp>XXX</samp> et <samp>YYY</samp>. Cette longueur est
rigide.
</para>
<example endspaces=" ">
<pre xml:space="preserve">XXX\showhbox&lbrace;100pt&rbrace;&lbrace;\blackbar&lbrace;100pt&rbrace;&rbrace;YYY
</pre></example>

<para>Quant au longueur élastiques, la contraction est le plus simple des
deux : avec <code>1cm minus 0.05cm</code>, la longueur naturelle est 1<dmn>cm</dmn>
mais &tex; peut la contracter jusqu&textrsquo;à 0,95<dmn>cm</dmn>.  &tex; refuse de
contracter plus que cela.  Ainsi, ci-dessous le premier <code>\showhbox</code>
fonctionne bien, un espace de 98 points étant produit entre les deux
barres.
</para>
<example endspaces=" ">
<pre xml:space="preserve">XXX\showhbox&lbrace;300pt&rbrace;&lbrace;%
  \blackbar&lbrace;101pt&rbrace;\hspace&lbrace;100pt minus 2pt&rbrace;\blackbar&lbrace;101pt&rbrace;&rbrace;YYY

XXX\showhbox&lbrace;300pt&rbrace;&lbrace;%
  \blackbar&lbrace;105pt&rbrace;\hspace&lbrace;100pt minus 1pt&rbrace;\blackbar&lbrace;105pt&rbrace;&rbrace;YYY
</pre></example>

<noindent></noindent>
<para>Mais le second produit un avertissement du genre de <samp>Overfull
\hbox (1.0pt too wide) detected at line 17</samp>.  En sortie le premier
<samp>Y</samp> est écrasé par la fin de la barre noire, parce que la matière
contenue par la boîte est plus large que les 300<dmn>pt</dmn> alloués, et que
&tex; a refusé de contracter le total en deçà de 309 points.
</para>
<para>Dilater est similaire à contracter, à ceci près que si &tex; doit
dilater plus que la quantité disponible, alors il le fait.  Ci-dessous
la première ligne fonctionne bien, et produit un espace de 110 points
entre les barres.
</para>
<example endspaces=" ">
<pre xml:space="preserve">XXX\showhbox&lbrace;300pt&rbrace;&lbrace;%
  \blackbar&lbrace;95pt&rbrace;\hspace&lbrace;100pt plus 10pt&rbrace;\blackbar&lbrace;95pt&rbrace;&rbrace;YYY

XXX\showhbox&lbrace;300pt&rbrace;&lbrace;%
  \blackbar&lbrace;95pt&rbrace;\hspace&lbrace;100pt plus 1pt&rbrace;\blackbar&lbrace;95pt&rbrace;&rbrace;YYY
</pre></example>

<noindent></noindent>
<para>Dans la seconde ligne &tex; a besoin de dilater de 10 points alors que
seulement 1 point a été spécifié.  &tex; dilate l&textrsquo;espace jusqu&textrsquo;à la
longueur requise mais il produit un avertissement du genre de
<samp>Underfull \hbox (badness 10000) detected at line 22</samp>.  (On ne
discute pas ici de ce que signifie « badness »).
</para>
<para>Il est possible de mettre à la fois de la dilatation et de la
contraction dans la même longueur, comme dans <code>1ex plus 0.05ex
minus 0.02ex</code>.
</para>
<para>Si &tex; ajuste plus d&textrsquo;une longueur élastique alors il alloue la
dilatation ou la contraction proportionnellement.
</para>
<example endspaces=" ">
<pre xml:space="preserve">XXX\showhbox&lbrace;300pt&rbrace;&lbrace;%
  \blackbar&lbrace;100pt&rbrace;%  gauche
  \hspace&lbrace;0pt plus 50pt&rbrace;\blackbar&lbrace;80pt&rbrace;\hspace&lbrace;0pt plus 10pt&rbrace;%  milieu
  \blackbar&lbrace;100pt&rbrace;&rbrace;YYY  % droite
</pre></example>

<noindent></noindent>
<para>Les barres de gauche et de droite prennent 100 points, de sorte que celle
du milieu a besoin également de 100. La barre du milieu fait 80 points
et donc les deux <code>\hspace</code> doivent se dilater de 20 points.
Comme les deux sont <code>plus 50pt</code> et <code>plus 10pt</code>, &tex; obtient
5/6 de la dilatation du premier espace et 1/6 du second.
</para>
<para>La composante <code>plus</code> ou <code>minus</code> d&textrsquo;une longueur élastique peut
contenir un composante en <dfn>fill</dfn>, comme dans <code>1in plus2fill</code>.
Cela donne à la longueur une dilatabilité ou contractibilité infinie de
sorte que &tex; puisse l&textrsquo;ajuster à n&textrsquo;importe quelle distance.  Dans
l&textrsquo;exemple suivant les deux figures sont également espacées
horizontalement sur la page.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;minipage&rbrace;&lbrace;\linewidth&rbrace;
  \hspace&lbrace;0pt plus 1fill&rbrace;\includegraphics&lbrace;godel.png&rbrace;%
  \hspace&lbrace;0pt plus 1fill&rbrace;\includegraphics&lbrace;einstein.png&rbrace;%
  \hspace&lbrace;0pt plus 1fill&rbrace;
\end&lbrace;minipage&rbrace;
</pre></example>

<para>&tex; a trois niveaux d&textrsquo;infinité pour les composantes élastiques :
<code>fil</code>, <code>fill</code>, et <code>filll</code> dans l&textrsquo;ordre d&textrsquo;infinité
croissante. D&textrsquo;ordinaire les auteurs de documents n&textrsquo;utilisent que celle
du milieu (<pxref label="_005chfill"><xrefnodename>\hfill</xrefnodename></pxref> et <pxref label="_005cvfill"><xrefnodename>\vfill</xrefnodename></pxref>).
</para>
<para>Multiplier une longueur élastique par un nombre la transforme en une
longueur rigide, de sorte qu&textrsquo;après <code>\setlength&lbrace;\ylength&rbrace;&lbrace;2.5cm
plus 0.5cm&rbrace;</code> et <code>\setlength&lbrace;\zlength&rbrace;&lbrace;3\ylength&rbrace;</code> alors la
valeur de <code>\zlength</code> est <code>2.5cm</code>.
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Unités de longueur</menutitle><menunode separator=". ">Units of length</menunode><menudescription><pre xml:space="preserve">Les unités que &latex; connaît.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\setlength</menunode><menudescription><pre xml:space="preserve">Règle la valeur d&textrsquo;une longueur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\addtolength</menunode><menudescription><pre xml:space="preserve">Ajoute une quantité à une longueur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\settodepth</menunode><menudescription><pre xml:space="preserve">Assigne à une longueur la profondeur de quelque chose.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\settoheight</menunode><menudescription><pre xml:space="preserve">Assigne à une longueur la hauteur de quelque chose.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\settowidth</menunode><menudescription><pre xml:space="preserve">Assigne à une longueur la largeur de quelque chose.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::         ">Expressions</menunode><menudescription><pre xml:space="preserve">Calculer avec des longueurs et des entiers.
<!-- c * Longueurs prédéfinies: Predefined lengths. Les longueurs qui sont, en quelque sorte, prédéfinies. -->
</pre></menudescription></menuentry></menu>

<node name="Units-of-length" spaces=" "><nodename>Units of length</nodename><nodenext automatic="on">\setlength</nodenext><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle>Unités de longueur</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="436">unités, de longueur</indexterm></cindex>

<para>&tex; et &latex; connaissent ces unités aussi bien en mode
mathématique qu&textrsquo;en dehors de celui-ci.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="694">pt</indexterm>pt</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="437">point</indexterm></cindex>
<anchor name="units-of-length-pt">units of length pt</anchor>
<para>Point (1/72,27)<dmn>pouce</dmn>.  La conversion (approximative) en unités
métriques est 1<dmn>point</dmn> = 0,35146<dmn>mm</dmn> = 0,035146<dmn>cm</dmn>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="695">pc</indexterm>pc</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="438">pica</indexterm></cindex>
<anchor name="units-of-length-pc">units of length pc</anchor>
<para>Pica, 12<dmn>pt</dmn>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="696">in</indexterm>in</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="439">pouce (inch)</indexterm></cindex>
<anchor name="units-of-length-in">units of length in</anchor>
<para>Pouce, 72,27<dmn>pt</dmn>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces="  "><itemformat command="code"><indexterm index="fn" number="697">bp</indexterm>bp</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="440">big point</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="441">point PostScript</indexterm></cindex>
<anchor name="units-of-length-bp">units of length bp</anchor>
<para>Big point, 1/72 pouce.  Cette longueur est la définition d&textrsquo;un point en
PostScript et dans beaucoup d&textrsquo;autres systèmes bureautiques d&textrsquo;éditique
(PAO).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="698">mm</indexterm>mm</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="442">millimètre</indexterm></cindex>
<anchor name="units-of-length-mm">units of length mm</anchor>
<para>Millimètre, 2,845<dmn>pt</dmn>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="699">cm</indexterm>cm</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="443">centimètre</indexterm></cindex>
<anchor name="units-of-length-cm">units of length cm</anchor>
<para>Centimètre, 10<dmn>mm</dmn>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="700">dd</indexterm>dd</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="444">point Didot</indexterm></cindex>
<anchor name="units-of-length-dd">units of length dd</anchor>
<para>Point Didot, 1,07<dmn>pt</dmn>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="701">cc</indexterm>cc</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="445">cicéro</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="446">douze</indexterm></cindex>
<anchor name="units-of-length-cc">units of length cc</anchor>
<para>Cicéro, 12<dmn>dd</dmn>, encore appelé <dfn>douze</dfn>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="702">sp</indexterm>sp</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="447">point proportionné (scaled point)</indexterm></cindex>
<anchor name="units-of-length-sp">units of length sp</anchor>
<para>Point proportionné, (1/65536)<dmn>pt</dmn>
</para>
</tableitem></tableentry></ftable>

<para>Trois autres unités sont définies en fonction de la fonte courante,
plutôt que comme des dimensions absolues.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="703">ex</indexterm>ex</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="448">x, hauteur d&textrsquo;un</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="449">ex</indexterm></cindex>
<anchor name="Lengths_002fex">Lengths/ex</anchor>
<anchor name="units-of-length-ex">units of length ex</anchor>
<para>La hauteur <dfn>ex</dfn> d&textrsquo;un x de la fonte courante , traditionnellement la
hauteur de la lettre x en bas de casse, est souvent utilisée pour les
longueurs verticales.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="704">em</indexterm>em</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="450">cadratin</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="451">m, largeur d&textrsquo;un</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="452">em</indexterm></cindex>
<anchor name="Lengths_002fem">Lengths/em</anchor>
<anchor name="units-of-length-em">units of length em</anchor>

<para>De même le <dfn>em</dfn>, traditionnellement la largeur de la lettre M
capitale, est souvent utilisée pour les longueurs horizontales. C&textrsquo;est
également souvent la taille de la fonte en cours, par exemple une fonte
nominalement en 10<dmn>pt</dmn> a 1<dmn>em</dmn> = 10<dmn>pt</dmn>. &latex; a
plusieurs commandes pour produire de l&textrsquo;espace horizontal basé sur le em
(<pxref label="_005censpace-_0026-_005cquad-_0026-_005cqquad"><xrefnodename>\enspace &amp; \quad &amp; \qquad</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="705">mu</indexterm>mu</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="453">mu, unité mathématique</indexterm></cindex>
<anchor name="unit-of-length-mu">unit of length mu</anchor>
<para>Finalement, en mode mathématique, beaucoup de définitions sont exprimées dans
l&textrsquo;unité mathématique <dfn>mu</dfn> donnée par 1<dmn>em</dmn> = 18<dmn>mu</dmn>, où le
em est pris de la famille courante des symboles mathématiques.
<xref label="Spacing-in-math-mode"><xrefnodename>Spacing in math mode</xrefnodename></xref>.
</para>
</tableitem></tableentry></ftable>

 <para>L&textrsquo;utilisation de ces unités peut aider améliorer le fonctionnement
d&textrsquo;une définition lors des changements de fonte. Par exemple, il est plus
probable qu&textrsquo;une définition de l&textrsquo;espace verticale entre les articles
d&textrsquo;une liste donnée comme <code>\setlength&lbrace;\itemsep&rbrace;&lbrace;1ex plus 0.05ex
minus 0.01ex&rbrace;</code> reste raisonnable si la fonte est changée que si elle
était exprimée en points.
</para>
</section>
<node name="_005csetlength" spaces=" "><nodename>\setlength</nodename><nodenext automatic="on">\addtolength</nodenext><nodeprev automatic="on">Units of length</nodeprev><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle><code>\setlength</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="706">\setlength</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="454">longueur, régler une</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\<var>longueur</var>&rbrace;&lbrace;<var>quantité</var>&rbrace;
</pre></example>

<para>La commande <code>\setlength</code> règle la longueur \<var>longueur</var> à
<var>quantité</var>. Le nom <code>\<var>longueur</var></code> doit être une séquence de
contrôle (<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), et donc commencer par une
controblique <code>\</code> dans les circonstances normales. La
<var>quantité</var> peut être une longueur élastique (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). Elle
peut être positive, négative ou nulle, et peut être exprimée dans
n&textrsquo;importe quelle unité comprise par &latex; (<pxref label="Units-of-length"><xrefnodename>Units of length</xrefnodename></pxref>).
</para>
<para>Ci-dessous, avec les réglages par défaut de &latex; le premier
paragraphe est renfoncé alors que le second ne l&textrsquo;est pas.
</para>
<example endspaces=" ">
<pre xml:space="preserve">J'ai dit au docteur que je m'étais cassé la jambe à deux endroits.

\setlength&lbrace;\parindent&rbrace;&lbrace;0em&rbrace;
Il me répondit d'arrêter d'aller à ces endroits.
</pre></example>

<para>Si vous n&textrsquo;avez pas déclaré \<var>longueur</var> avec <code>\newlength</code>, par
exemple si vous faites une faute de frappe dessus comme dans
<code>\newlength&lbrace;\specparindent&rbrace;\setlength&lbrace;\sepcparindent&rbrace;&lbrace;...&rbrace;</code>,
alors vous obtiendrez une erreur du genre de <samp>Undefined control
sequence. &lt;argument&gt; \sepcindent</samp>.  Si vous oubliez la controblique au
début du nom de la longueur alors vous obtiendrez une erreur du genre de
<samp>Missing number, treated as zero.</samp>.
</para>
</section>
<node name="_005caddtolength" spaces=" "><nodename>\addtolength</nodename><nodenext automatic="on">\settodepth</nodenext><nodeprev automatic="on">\setlength</nodeprev><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle><code>\addtolength</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="707">\addtolength</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="455">longueur, ajouter à une</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addtolength&lbrace;\<var>longueur</var>&rbrace;&lbrace;<var>quantité</var>&rbrace;
</pre></example>

<para>Incrémente la longueur <code>\<var>longueur</var></code> par <var>quantité</var>. Le nom
<code>\<var>longueur</var></code> doit être une séquence de contrôle
(<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), et donc commencer par une controblique
<code>\</code> dans les circonstances normales. La <var>quantité</var> peut être
une longueur élastique (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). Elle peut être positive,
négative ou nulle, et peut être exprimée dans n&textrsquo;importe quelle unité
comprise par &latex; (<pxref label="Units-of-length"><xrefnodename>Units of length</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple ci-dessous, si <code>\parskip</code> commence avec la valeur
<code>0pt plus 1pt</code>
</para>
<example endspaces=" ">
<pre xml:space="preserve">Docteur : comment va le garçon qui a avalé une monnaie en argent ?
\addtolength&lbrace;\parskip&rbrace;&lbrace;1pt&rbrace;

Infirmière : aucun changement.
</pre></example>

<noindent></noindent>
<para>alors il a la valeur <code>1pt plus 1pt</code> pour le second paragraphe.
</para>
<para>Si vous n&textrsquo;avez pas déclaré la longueur \<var>longueur</var> avec
<code>\newlength</code>, par exemple si vous faites une faute de frappe dessus
comme dans
<code>\newlength&lbrace;\specparindent&rbrace;\addtolength&lbrace;\sepcparindent&rbrace;&lbrace;...&rbrace;</code>,
alors vous obtiendrez une erreur du genre de <samp>Undefined control
sequence. &lt;argument&gt; \sepcindent</samp>. Si c&textrsquo;est la <var>quantité</var> qui
utilise une longueur qui n&textrsquo;a pas été déclarée, par exemple si vous
faites la faute de frappe comme cela
<code>\addtolength&lbrace;\specparindent&rbrace;&lbrace;0.6\praindent&rbrace;</code>, alors vous
obtenez une erreur du genre de <samp>Undefined control
sequence. &lt;argument&gt; \praindent</samp>.  Si vous oubliez la controblique au
début du nom de la longueur, comme dans
<code>\addtolength&lbrace;parindent&rbrace;&lbrace;1pt&rbrace;</code>, alors vous obtiendrez
quelque chose du genre de <samp>You can't use `the letter p' after
\advance</samp>.
</para>
</section>
<node name="_005csettodepth" spaces=" "><nodename>\settodepth</nodename><nodenext automatic="on">\settoheight</nodenext><nodeprev automatic="on">\addtolength</nodeprev><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle><code>\settodepth</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="708">\settodepth</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\settodepth&lbrace;\<var>longueur</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>La commande <code>\settodepth</code> règle la longueur <code>\<var>longueur</var></code>
à la profondeur de la boîte que &latex; obtient en composant l&textrsquo;argument
<code>texte</code>. Le nom <code>\<var>longueur</var></code> doit être une séquence de
contrôle (<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), et donc commencer par une
controblique <code>\</code> dans les circonstances normales.
</para>
<para>L&textrsquo;exemple ci-dessous imprime la profondeur maximale des descendantes de
l&textrsquo;alphabet :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\alphabetdepth&rbrace;
\settodepth&lbrace;\alphabetdepth&rbrace;&lbrace;abcdefghijklmnopqrstuvwxyz&rbrace;
\the\alphabetdepth
</pre></example>

<para>Si vous n&textrsquo;avez pas déclaré la longueur \<var>longueur</var> avec
<code>\newlength</code>, par exemple si vous faites une faute de frappe dans
l&textrsquo;exemple ci-dessus comme dans
<code>\settodepth&lbrace;\aplhabetdepth&rbrace;&lbrace;abc...&rbrace;</code>, alors vous obtiendrez
quelque chose du genre de <samp>Undefined control sequence. &lt;argument&gt;
\aplhabetdepth</samp>.  Si vous oubliez la controblique au début du nom de la
longueur, comme dans <code>\settodepth&lbrace;alphabetdepth&rbrace;&lbrace;...&rbrace;</code> alors
vous obtiendrez quelque chose du genre de <samp>Missing number, treated
as zero. &lt;to be read again&gt; \setbox</samp>.
</para>
</section>
<node name="_005csettoheight" spaces=" "><nodename>\settoheight</nodename><nodenext automatic="on">\settowidth</nodenext><nodeprev automatic="on">\settodepth</nodeprev><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle><code>\settoheight</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="709">\settoheight</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\settoheight&lbrace;\<var>longueur</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>La commande <code>\settoheight</code> règle la longueur <code>\<var>longueur</var></code>
à la hauteur de la boîte que &latex; obtient en composant l&textrsquo;argument
<code>texte</code>. Le nom <code>\<var>longueur</var></code> doit être une séquence de
contrôle (<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), et donc commencer par une
controblique <code>\</code> dans les circonstances normales.
</para>
<para>L&textrsquo;exemple suivant imprime la hauteur maximale des ascendantes de
l&textrsquo;alphabet ASCII bas de casse :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\alphabetheight&rbrace;
\settoheight&lbrace;\alphabetheight&rbrace;&lbrace;abcdefghijklmnopqrstuvwxyz&rbrace;
\the\alphabetheight
</pre></example>

<para>Si vous n&textrsquo;avez pas déclaré la longueur \<var>longueur</var> avec
<code>\newlength</code>, par exemple si vous faites une faute de frappe dans
l&textrsquo;exemple ci-dessus comme dans
<code>\settoheight&lbrace;\aplhabetheight&rbrace;&lbrace;abc...&rbrace;</code>, alors vous obtiendrez
quelque chose du genre de <samp>Undefined control sequence. &lt;argument&gt;
\aplhabetdepth</samp>.  Si vous oubliez la controblique au début de
\<var>longueur</var>, comme dans <code>\settoheight&lbrace;alphabetheight&rbrace;&lbrace;...&rbrace;</code>
alors vous obtiendrez quelque chose du genre de <samp>Missing number,
treated as zero. &lt;to be read again&gt; \setbox</samp>.
</para>

</section>
<node name="_005csettowidth" spaces=" "><nodename>\settowidth</nodename><nodenext automatic="on">Expressions</nodenext><nodeprev automatic="on">\settoheight</nodeprev><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle><code>\settowidth</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="710">\settowidth</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\settowidth&lbrace;\<var>longueur</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>


<para>La commande <code>\settowidth</code> règle la longueur <code>\<var>longueur</var></code>
à la largeur de la boîte que &latex; obtient en composant l&textrsquo;argument
<code>texte</code>. Le nom <code>\<var>longueur</var></code> doit être une séquence de
contrôle (<pxref label="Control-sequences"><xrefnodename>Control sequences</xrefnodename></pxref>), et donc commencer par une
controblique <code>\</code> dans les circonstances normales.
</para>
<para>L&textrsquo;exemple suivant imprime la largeur de l&textrsquo;alphabet ASCII bas de casse :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\alphabetwidth&rbrace;
\settowidth&lbrace;\alphabetwidth&rbrace;&lbrace;abcdefghijklmnopqrstuvwxyz&rbrace;
\the\alphabetwidth
</pre></example>

<para>Si vous n&textrsquo;avez pas déclaré la longueur \<var>longueur</var> avec
<code>\newlength</code>, par exemple si vous faites une faute de frappe dans
l&textrsquo;exemple ci-dessus comme dans
<code>\settowidth&lbrace;\aplhabetwidth&rbrace;&lbrace;abc...&rbrace;</code>, alors vous obtiendrez
quelque chose du genre de <samp>Undefined control sequence. &lt;argument&gt;
\aplhabetwidth</samp>.  Si vous oubliez la controblique au début de
\<var>longueur</var>, comme dans <code>\settowidth&lbrace;alphabetwidth&rbrace;&lbrace;...&rbrace;</code>
alors vous obtiendrez quelque chose du genre de <samp>Missing number,
treated as zero. &lt;to be read again&gt; \setbox</samp>.
</para>
</section>
<node name="Expressions" spaces=" "><nodename>Expressions</nodename><nodeprev automatic="on">\settowidth</nodeprev><nodeup automatic="on">Lengths</nodeup></node>
<section spaces=" "><sectiontitle>Expressions</sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="711">expressions</indexterm></findex>

<!-- c Much from Joseph Wright's https://tex.stackexchange.com/a/245663/339 -->
<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\numexpr <var>expression</var>
\dimexpr <var>expression</var>
\glueexpr <var>expression</var>
\muglue <var>expression</var>
</pre></example>

<para>En tout lieu où vous pourriez écrire un entier, une dimen, une muglue ou
une glue de &tex;, vous pouvez à la place écrire une expression pour
écrire ce genre de quantité.
</para>
<para>Un exemple est que <code>\the\dimexpr\linewidth-4pt\relax</code> produit en
sortie la longueur égale à quatre points de moins que la largeur de la
ligne (le seul usage de <code>\the</code> est d&textrsquo;afficher le résultat dans le
document).  De même, <code>\romannumeral\numexpr6+3\relax</code> produit
<samp>ix</samp>, et <code>\the\glueexpr 5pt plus 1pt * 2 \relax</code> produit
<samp>10.0pt plus 2.0pt</samp>.
</para>
<para>Une commodité ici par rapport à effectuer les calculs en allouant des
registres et en utilisant <code>\advance</code>, etc., est que l&textrsquo;évaluation
d&textrsquo;expression n&textrsquo;implique par d&textrsquo;affectations et peut donc être effectuée à
des endroits où les affectations ne sont pas autorisées. L&textrsquo;exemple suivant
calcule la largeur de la <code>\parbox</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\offset&rbrace;\setlength&lbrace;\offset&rbrace;&lbrace;2em&rbrace;
\begin&lbrace;center&rbrace;
\parbox&lbrace;\dimexpr\linewidth-\offset*3&rbrace;&lbrace;Sans animosité envers
quiconque, charitables envers tous, et sûrs de notre droit en tant que
Dieu nous en accorde conscience, mettons-nous à l'œuvre afin d'achever
la tâche qui nous occupe, de panser les blessures de notre nation, de
porter soin à l'homme qui a affronté le combat et soulagement à sa veuve
et à son orphelin, enfin de faire tout pour réaliser et honorer une paix
juste et durable entre nous et avec toutes les nations.  --- Abraham
Lincoln, second discours d'investiture, inscrit dans le mémorial
Lincoln&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<para>L&textrsquo;<var>expression</var> consiste en un ou plusieurs termes du même type
(entier, dimension, etc.) qui sont ajoutés ou soustraits.  Un terme est
un type de nombre, dimension, etc., et consiste en un facteur de ce
type, optionnellement multiplié ou divisé par des facteurs.  Un facteur
d&textrsquo;un type est soit une quantité de ce type ou une sous-expression
parenthésés.  L&textrsquo;expression produit un résultat du type donné, de sorte
que <code>\numexpr</code> produit un entier, <code>\dimexpr</code> produit une
dimension dimension, etc.
</para>
<para>Dans l&textrsquo;exemple de citation donné plus haut, changer l&textrsquo;expression en
<code>\dimexpr\linewidth-3*\offset</code> produit l&textrsquo;erreur <code>Illegal unit
of measure (pt inserted)</code>. La raison en est que pour <code>\dimexpr</code> et
<code>\glueexpr</code>, l&textrsquo;entrée consiste en une valeur de dimension ou de
glue suivie par un facteur multiplicatif optionnel, et non
l&textrsquo;inverse. Ainsi <code>\the\dimexpr 1pt*10\relax</code> est valide et produit
<samp>10.0pt</samp>, mais <code>\the\dimexpr 10*1pt\relax</code> produit l&textrsquo;erreur
<code>Illegal unit</code>.
</para>
<para>Les expressions absorbent les unités lexicales et effectuent les
opérations mathématiques appropriées jusqu&textrsquo;à ce qu&textrsquo;un <code>\relax</code> (qui
est absorbé), ou jusqu&textrsquo;à ce que la première unité lexicale non valide
soit rencontrée.  Ainsi, <code>\the\numexpr2+3px</code> imprime <samp>5px</samp>,
parce que &latex; lit le <code>\numexpr2+3</code>, ce qui est composé de
nombres, et ensuite trouve la lettre <code>p</code>, qui ne peut pas faire
partie d&textrsquo;un nombre. Il termine alors l&textrsquo;expression et produit le <samp>5</samp>,
suivi par le texte ordinaire <samp>px</samp>.
</para>
<para>Ce comportement de terminaison est utile dans les comparaisons. Dans
<code>\ifnum\numexpr\parindent*2 &lt; 10pt Oui\else Non\fi</code>, le signe
inférieur à termine l&textrsquo;expression et le résultat est <samp>Non</samp> (dans un
document de classe &latex; standarde article).
</para>
<para>Les expressions peuvent utiliser les opérateurs <code>+</code>, <code>-</code>,
<code>*</code> et <code>/</code> ainsi que les parenthèses pour les
sous-expressions, <code>(...)</code>.  Dans les expressions glue les parties
en <code>plus</code> et <code>minus</code> ne nécessitent pas de parenthèses pour
être affectés par un facteur. Ainsi le résultat de <code>\the\glueexpr
5pt plus 1pt * 2 \relax</code> est <samp>10pt plus 2pt</samp>.
</para>
<para>&tex; convertit les autres types numériques de la même façon que
lorsqu&textrsquo;il fait une affectation à un registre. Ainsi le résultat de
<code>\the\numexpr\dimexpr 1pt\relax\relax</code> est <samp>65536</samp>, ce qui est
<code>1pt</code> exprimé en points proportionnés (<pxref label="units-of-length-sp"><xrefnodename>units of length
sp</xrefnodename><xrefinfoname><code>sp</code></xrefinfoname></pxref>, l&textrsquo;unité interne de &tex;) et ensuite converti en entier.
Si ça avait été une <code>\glueexpr</code>, on aurait laissé tomber la
dilatation et la contraction. Dans l&textrsquo;autre sens, une <code>\numexpr</code> au
sein d&textrsquo;une <code>\dimexpr</code> ou d&textrsquo;une <code>\glueexpr</code> nécessite l&textrsquo;ajout
d&textrsquo;unité appropriées, comme dans <code>\the\dimexpr\numexpr 1 + 2\relax
pt\relax</code>, ce qui produit <samp>3.0pt</samp>.
</para>
<para>Voici les détails de l&textrsquo;arithmétique : chaque facteur est vérifié comme
étant compris dans l&textrsquo;intervalle autorisé, les nombres doivent être
inférieurs à <math>2^{31}</math> en valeur absolue, et les composantes de
dimensions ou glues doivent être inférieures à <math>2^{14}</math> points, ou
<code>mu</code>, ou <code>fil</code>, etc.  Les opérations arithmétiques sont
effectuées individuellement, sauf pour les opérations de dilatation (une
multiplication immédiatement suivie d&textrsquo;une division) qui sont faites
comme une opération combinée avec un produit sur 64-bit comme valeur
intermédiaire. Le résultat de chaque opération est de nouveau vérifié
comme appartenant à l&textrsquo;intervalle autorisé.
</para>
<para>Finalement, on notera que les divisions et dilatations sont faites avec
un arrondi au plus proche (contrairement à l&textrsquo;opération <code>\divide</code> de
&tex; qui prend un arrondi vers zéro).  Ainsi <code>\the\dimexpr
5pt*(3/2)\relax</code> met <samp>10.0pt</samp> dans le document, parce qu&textrsquo;il arrondit
<code>3/2</code> en <code>2</code>, tandis que <code>\the\dimexpr 5pt*(4/3)\relax</code>
produit <samp>5.0pt</samp>.
</para>

<!-- c @node Predefined lengths -->
<!-- c @section Longueurs prédéfinies -->
<!-- c @cindex longueurs prédéfinies -->
<!-- c @cindex prédéfinies, longueurs -->
<!-- c  -->
<!-- c @code{\width} -->
<!-- c @findex \width -->
<!-- c  -->
<!-- c @code{\height} -->
<!-- c @findex \height -->
<!-- c  -->
<!-- c @code{\depth} -->
<!-- c @findex \depth -->
<!-- c  -->
<!-- c @code{\totalheight} -->
<!-- c @findex \totalheight -->
<!-- c  -->
<!-- c Ces paramètres de longueur peuvent être utilisés au sein des arguments -->
<!-- c des commandes de fabrication de boîte (@pxref{Boxes}). Il spécifient la -->
<!-- c largeur naturelle, etc., du texte dans la boîte. @code{\totalheight} -->
<!-- c vaut @math{@code{@backslashchar{}height} + -->
<!-- c @code{@backslashchar{}depth}}. Pour fabriquer une boîte dont le texte -->
<!-- c est dilaté au double de sa taille naturelle, écrivez par ex.@: : -->
<!-- c  -->
<!-- c @example -->
<!-- c \makebox[2\width]@{Dilatez moi@} -->
<!-- c @end example -->
<!-- c  -->
<!-- c  -->
</section>
</chapter>
<node name="Making-paragraphs" spaces=" "><nodename>Making paragraphs</nodename><nodenext automatic="on">Math formulas</nodenext><nodeprev automatic="on">Lengths</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Faire des paragraphes</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="456">Faire des paragraphes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="457">paragraphes</indexterm></cindex>

<para>Pour démarrer un paragraphe, tapez juste du texte. Pour finir le
paragraphe courant, mettez une ligne vide.  Dans l&textrsquo;exemple ci-dessous on
a trois paragraphes, dont la séparation est assurée par deux lignes
vides :
</para>
<example endspaces=" ">
<pre xml:space="preserve">C'est une vérité universellement reconnue qu'un célibataire pourvu d'une
belle fortune doit avoir envie de se marier, et si peu que l'on sache de
son sentiment à cet égard, lorsqu'il arrive dans une nouvelle résidence,
cette idée est si bien fixée dans l'esprit de ses voisins qu'ils le
considère sur-le-champ comme la propriété légitime de l'une ou l'autre
de leurs filles.

« Savez-vous mon cher ami, dit un jour Mrs Bennet à son mari, que
Netherfield Park est enfin loué ? »

Mr Bennet répondit qu'il l'ignorait.
</pre></example>

<para>Le séparateur de paragraphe peut consister en une séquence quelconque
d&textrsquo;au moins une ligne à blanc, dans laquelle au moins une ligne n&textrsquo;est pas
terminée par un commentaire. Une ligne à blanc est une ligne qui est
vide ou ne contient que des caractères blancs tel que l&textrsquo;espace ou la
tabulation. Les commentaires dans le code source sont démarrés par un
<code>%</code> et s&textrsquo;étendent jusqu&textrsquo;à la fin de la ligne. Dans l&textrsquo;exemple
suivant les deux colonnes sont identiques :
</para>

<example endspaces=" ">
<pre xml:space="preserve">\documentclass[twocolumn]&lbrace;article&rbrace;
\begin&lbrace;document&rbrace;
First paragraph.

Second paragraph.
\newpage
First paragraph.
<w>      </w>
  % les lignes de séparation peuvent contenir des blancs.
<w>  	</w>
Second paragraph.
\end&lbrace;document&rbrace;
</pre></example>

<para>Une fois que &latex; a rassemblé tout le contenu d&textrsquo;un paragraphe il
divise le paragraphe en lignes d&textrsquo;une manière qui est optimisée sur
l&textrsquo;entièreté du paragraphe (<pxref label="Line-breaking"><xrefnodename>Line breaking</xrefnodename></pxref>).
</para>
<para>Il y a des endroits où un nouveau paragraphe n&textrsquo;a pas le droit de
commencer. Ne mettez pas de lignes à blanc en mode math
(<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>) ; dans l&textrsquo;exemple suivant la ligne à blanc précédent
<code>\end&lbrace;equation&rbrace;</code>
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  2^&lbrace;|S|&rbrace; &gt; |S|

\end&lbrace;equation&rbrace;
</pre></example>

<noindent></noindent>
<para>produit l&textrsquo;erreur <samp>Missing $ inserted</samp>.  De même, la ligne à blanc au sein de l&textrsquo;argument de ce <code>\section</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\section&lbrace;aaa

bbb&rbrace;
</pre></example>

<noindent></noindent>
<para>produit l&textrsquo;erreur <samp>Runaway argument? &lbrace;aaa ! Paragraph ended before
\&arobase;sect was complete</samp>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::     ">\par</menunode><menudescription><pre xml:space="preserve">Terminer le paragraphe en cours.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\indent &amp; \noindent</menunode><menudescription><pre xml:space="preserve">Passer en mode horizontal, possiblement avec un
  renfoncement.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">\parindent &amp; \parskip</menunode><menudescription><pre xml:space="preserve">L&textrsquo;espace ajouté avant les paragraphes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Notes en marge</menutitle><menunode separator=". ">Marginal notes</menunode><menudescription><pre xml:space="preserve">Mettre des remarques dans la marge.
</pre></menudescription></menuentry></menu>


<node name="_005cpar" spaces=" "><nodename>\par</nodename><nodenext automatic="on">\indent &amp; \noindent</nodenext><nodeup automatic="on">Making paragraphs</nodeup></node>
<section spaces=" "><sectiontitle><code>\par</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="712">\par</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="458">paragraphe, terminaison</indexterm></cindex>

<para>Synopsis (notez que, alors qu&textrsquo;il lit l&textrsquo;entrée, &tex; convertit toute
séquence d&textrsquo;au moins une ligne à blanc en un <code>\par</code>, voir
<ref label="Making-paragraphs"><xrefnodename>Making paragraphs</xrefnodename></ref>) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\par
</pre></example>

<para>Termine le paragraphe en cours.  La manière habituelle de séparer les
paragraphes est avec une ligne à blanc, mais la commande <code>\par</code> est
entièrement équivalente.  Cette commande est robuste (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivant utilise <code>\par</code> plutôt qu&textrsquo;une ligne à blanc
simplement pour la lisibilité.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\coursEnJargonLegal&rbrace;&lbrace;%
  \CeQuEstLaTricherie\par\CeQuiTArriveQuandOnTAttrape&rbrace;
</pre></example>

<para>En mode LR la commande <code>\par</code> ne fait rien et est ignorée.  En mode
paragraphe la commande <code>\par</code> termine le mode paragraphe, et commute
&latex; vers le mode vertical (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
</para>
<para>Vous ne pouvez pas utiliser la commande <code>\par</code> en mode
mathématique.  Vous ne pouvez pas non plus l&textrsquo;utiliser au sein de
l&textrsquo;argument de beaucoup de commandes, telles que les commandes de
rubricage, par ex.&noeos; <code>\section</code> (<pxref label="Making-paragraphs"><xrefnodename>Making paragraphs</xrefnodename></pxref> et
<ref label="_005cnewcommand-_0026-_005crenewcommand"><xrefnodename>\newcommand &amp; \renewcommand</xrefnodename></ref>).
</para>
<para>La commande <code>\par</code> ne fait pas la même chose que la commande
<code>\paragraph</code>. Cette dernière, comme <code>\section</code> ou
<code>\subsection</code>, est une commande de rubricage utilisée par les
classes standardes de document &latex; (<pxref label="_005csubsubsection-_0026-_005cparagraph-_0026-_005csubparagraph"><xrefnodename>\subsubsection &amp;
\paragraph &amp; \subparagraph</xrefnodename></pxref>).
</para>
<para>La commande <code>\par</code> ne fait pas la même chose que <code>\newline</code> ou
que le saut de ligne en double controblique, <code>\\</code>.  La différence
c&textrsquo;est que <code>\par</code> termine le paragraphe, et non pas seulement la
ligne, et ajoute également de l&textrsquo;espace vertical inter-paragraphe
<code>\parskip</code> (<pxref label="_005cparindent-_0026-_005cparskip"><xrefnodename>\parindent &amp; \parskip</xrefnodename></pxref>).
</para>
<para>En sortie de l&textrsquo;exemple suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">xyz

\setlength&lbrace;\parindent&rbrace;&lbrace;8cm&rbrace;
\setlength&lbrace;\parskip&rbrace;&lbrace;13cm&rbrace;
\noindent test\indent test1\par test2
</pre></example>

<noindent></noindent>
<para>on a : après <samp>xyz</samp> il y a un saut vertical de 13<dmn>cm</dmn> et ensuite
<samp>test</samp> apparaît, aligné sur la marge de gauche. Sur la même ligne
on a un espace horizontal vide de 8<dmn>cm</dmn> et ensuite <samp>test1</samp>
apparaît.  Finalement. il y a un espace vertical de 13<dmn>cm</dmn>, suivi par
un nouveau paragraphe avec un renfoncement de 8<dmn>cm</dmn>, et ensuite
&latex; met le texte <samp>test2</samp>.
</para>

</section>
<node name="_005cindent-_0026-_005cnoindent" spaces=" "><nodename>\indent &amp; \noindent</nodename><nodenext automatic="on">\parindent &amp; \parskip</nodenext><nodeprev automatic="on">\par</nodeprev><nodeup automatic="on">Making paragraphs</nodeup></node>
<section spaces=" "><sectiontitle><code>\indent</code> &amp; <code>\noindent</code></sectiontitle>

<anchor name="_005cindent">\indent</anchor>
<anchor name="_005cnoindent">\noindent</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="713">\indent</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="714">\noindent</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="459">renfoncement, forcer</indexterm></cindex>

<para>Synopsis:
</para>
<example endspaces=" ">
<pre xml:space="preserve">\indent
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\noindent
</pre></example>

<para>Passe en mode horizontal (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>). La commande <code>\indent</code>
commence par produire une boîte vide dont la largeur est
<code>\parindent</code>. Ces commandes sont robustes (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>D&textrsquo;ordinaire on crée un nouveau paragraphe en insérant une ligne à
blanc. <xref label="_005cpar"><xrefnodename>\par</xrefnodename></xref>, pour la différence entre cette commande et
<code>\par</code>. Pour commencer un paragraphe sans renfoncement, ou pour
continuer un paragraphe interrompu, utiliser <code>\noindent</code>.
</para>
<para>Au milieu d&textrsquo;un paragraphe la commande <code>\noindent</code> est sans effet,
parce que &latex; y est déjà en mode horizontal. La commande
<code>\indent</code> n&textrsquo;a pour seul effet que de produire une espace en sortie.
</para>
<para>L&textrsquo;exemple suivant démarre un nouveau paragraphe.
</para>
<example endspaces=" ">
<pre xml:space="preserve">... fin du paragraphe précédent.

\noindent Ce paragraphe n'est pas renfoncé.
</pre></example>

<noindent></noindent>
<para>et cet exemple-là continue un paragraphe interrompu :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Les données

\begin&lbrace;center&rbrace;
  \begin&lbrace;tabular&rbrace;&lbrace;rl&rbrace; ... \end&lbrace;tabular&rbrace;
\end&lbrace;center&rbrace;

\noindent montrent clairement ceci.
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="715">\parindent</indexterm></findex>
<para>Pour éliminer le renfoncement de paragraphe dans tout un document,
mettez <code>\setlength&lbrace;\parindent&rbrace;&lbrace;0pt&rbrace;</code> dans le préambule. Si vous
faites cela, vous désirerez peut-être régler également la longueur des
espaces inter-paragraphes, <code>\parskip</code> (<pxref label="_005cparindent-_0026-_005cparskip"><xrefnodename>\parindent &amp;
\parskip</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="716"><r>paquetage</r> <code>indentfirst</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="717"><code>indentfirst</code>, <r>paquetage</r></indexterm></findex>

<para>Les styles &latex; par défaut ont le premier paragraphe suivant une
rubrique qui n&textrsquo;est pas renfoncé, comme cela est traditionnel en
typographie anglo-saxonne.  Pour changer cela, chercher sur le CTAN le
paquetage <code>indentfirst</code>.
</para>

</section>
<node name="_005cparindent-_0026-_005cparskip" spaces=" "><nodename>\parindent &amp; \parskip</nodename><nodenext automatic="on">Marginal notes</nodenext><nodeprev automatic="on">\indent &amp; \noindent</nodeprev><nodeup automatic="on">Making paragraphs</nodeup></node>
<section spaces=" "><sectiontitle><code>\parindent</code> &amp; <code>\parskip</code></sectiontitle>

<anchor name="_005cparindent">\parindent</anchor>
<anchor name="_005cparskip">\parskip</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="718">\parindent</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="719">\parskip</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="460">renfoncement d&textrsquo;un paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="461">retrait d&textrsquo;un paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="462">horizontal, renfoncement d&textrsquo;un paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="463">espace vertical avant les paragraphes</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\parindent&rbrace;&lbrace;<var>longueur-horizontale</var>&rbrace;
\setlength&lbrace;\parskip&rbrace;&lbrace;<var>longueur-verticale</var>&rbrace;
</pre></example>

<para>Toutes deux sont des longueurs élastiques (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).  Elles
affectent respectivement le renfoncement des paragraphes ordinaires, non
des paragraphes au sein de minipages (<pxref label="minipage"><xrefnodename>minipage</xrefnodename></pxref>), et l&textrsquo;espace
vertical entre les paragraphes, respectivement.
</para>
<para>Par exemple, si ce qui suit est mis dans le préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\parindent&rbrace;&lbrace;0em&rbrace;
\setlength&lbrace;\parskip&rbrace;&lbrace;1ex&rbrace;
</pre></example>

<noindent></noindent>
<para>Alors le document aura des paragraphes qui ne sont pas renfoncés, mais
par contre qui sont verticalement séparés d&textrsquo;environ la hauteur d&textrsquo;un
<samp>x</samp> bas-de-casse.
</para>
<para>Dans les documents de classes &latex; standardes, la valeur par défaut
de <code>\parindent</code> pour les documents à une colonne est <code>15pt</code>
quand la taille par défaut du texte est <code>10pt</code>, <code>17pt</code> pour
<code>11pt</code>, et <code>1.5em</code> pour <code>12pt</code>.  Dans les documents en
deux-colonnes c&textrsquo;est <code>1em</code>.  (Ces valeurs sont réglées avant que
&latex; appelle <code>\normalfont</code> de sorte que <code>em</code> est dérivé de
la fonte par défaut, Computer Modern.  Si vous utilisez une fonte
différente alors pour régler <code>\parindent</code> à 1<dmn>em</dmn> en accord
avec cette fonte, mettez dans votre préambule
<code>\AtBeginDocument&lbrace;\setlength&lbrace;\parindent&rbrace;&lbrace;1em&rbrace;&rbrace;</code>).
</para>
<para>La valeur par défaut de <code>\parskip</code> dans les documents de classes
standardes &latex; est <code>0pt plus1pt</code>.
</para>

</section>
<node name="Marginal-notes" spaces=" "><nodename>Marginal notes</nodename><nodeprev automatic="on">\parindent &amp; \parskip</nodeprev><nodeup automatic="on">Making paragraphs</nodeup></node>
<section spaces=" "><sectiontitle>Notes en marge</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="464">Notes en marge</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="465">notes dans la marge</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="466">remarques dans la marge</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="720">\marginpar</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\marginpar&lbrace;<var>droite</var>&rbrace;
\marginpar[<var>gauche</var>]&lbrace;<var>droite</var>&rbrace;
</pre></example>

<para>La commande <code>\marginpar</code> crée une note dans la marge. La première
ligne de la note a la même ligne de base que la ligne dans le texte où le
<code>\marginpar</code> se trouve.
</para>
<para>Lorsque vous spécifiez seulement l&textrsquo;argument obligatoire <var>droite</var>, le texte
est placé
</para>
<itemize spaces="  " endspaces=" "><itemprepend>&textndash;</itemprepend>
<listitem><prepend>&textndash;</prepend>
<para>dans la marge de droite pour une disposition en recto simple (option
<code>oneside</code>, voir <ref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></ref>) ;
</para></listitem><listitem><prepend>&textndash;</prepend>
<para>dans la marge extérieure pour une disposition en recto-verso  (option
<code>twoside</code>, voir <ref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></ref>) ;
</para></listitem><listitem><prepend>&textndash;</prepend>
<para>dans la plus proche pour une disposition à deux-colonnes
(option <code>twocolumn</code>, voir <ref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></ref>).
</para></listitem></itemize>

<findex index="fn" spaces=" "><indexterm index="fn" number="721">\reversemarginpar</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="722">\normalmarginpar</indexterm></findex>
<para>La commande <code>\reversemarginpar</code> place les notes en marge suivante
sur la marge  opposée (interne). <code>\normalmarginpar</code> les replace
dans la  position par défaut.
</para>
<para>Lorsque vous spécifier les deux arguments, <var>gauche</var> est utilisé pour
is used la marge de gauche, et <var>droite</var> est utilisé pour la marge de
is used droite.
</para>
<para>Le premier mot doit normalement ne pas être sujet à une césure ; Vous
pouvez activer la césure à cet endroit en commençant le nœud avec
<code>\hspace&lbrace;0pt&rbrace;</code>.
</para>
<para>Ces paramètres affectent le formatage de la note :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="723">\marginparpush</indexterm>\marginparpush</itemformat></item>
</tableterm><tableitem><para>Espace verticale minimale entre les notes ; par défaut <samp>7pt</samp> pour
des  documents à <samp>12pt</samp>, <samp>5pt</samp> sinon.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="724">\marginparsep</indexterm>\marginparsep</itemformat></item>
</tableterm><tableitem><para>Espace horizontale entre le texte principal et la note ; par défaut
<samp>11pt</samp> pour des documents à <samp>10pt</samp>, <samp>10pt</samp> sinon.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="725">\marginparwidth</indexterm>\marginparwidth</itemformat></item>
</tableterm><tableitem><para>Largeur de la note même ; la valeur par défaut est <samp>90pt</samp> pour un
document en recto simple et à <samp>10pt</samp> , <samp>83pt</samp> pour
<samp>11pt</samp>, et <samp>68pt</samp> pour <samp>12pt</samp> ; <samp>17pt</samp> de plus dans
chacun de ces cas pour un document recto-verso.  En mode deux-colonnes,
la valeur par défaut est <samp>48pt</samp>.
</para>
</tableitem></tableentry></ftable>

<para>La routine standarde de &latex; pour les notes en marge n&textrsquo;empêche pas
les notes de déborder hors du bas de la page.
<!-- c @TeX{} FAQ entry on this topic (xx when there): -->
<!-- c @url{http://www.tex.ac.uk/cgi-bin/texfaq2html?label=marginparside}. -->
<!-- c (+marginfix) -->
</para>

</section>
</chapter>
<node name="Math-formulas" spaces=" "><nodename>Math formulas</nodename><nodenext automatic="on">Modes</nodenext><nodeprev automatic="on">Making paragraphs</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Formules mathématiques</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="467">formules mathématiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="468">formules, math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="469">mode mathématique, entrer</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="726"><r>environnement</r> <code>math</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="727"><code>math</code>, <r>environnement</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="728"><r>environnement</r> <code>displaymath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="729"><code>displaymath</code>, <r>environnement</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="730"><r>environnement</r> <code>equation</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="731"><code>equation</code>, <r>environnement</r></indexterm></findex>


<para>On produit du texte mathématique en mettant &latex; en mode math ou
mode math d&textrsquo;affichage (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>). L&textrsquo;exemple qui suit illustre les
deux :
</para>
<example endspaces=" ">
<pre xml:space="preserve">L'équation d'onde de \( u \) est :
\begin&lbrace;displaymath&rbrace;
  \frac&lbrace;\partial^2u&rbrace;&lbrace;\partial t^2&rbrace; = c^2\nabla^2u
\end&lbrace;displaymath&rbrace;
où \( \nabla^2 \) est le Laplacien spatial et \( c \) une constante.
</pre></example>

<!-- c xx TODO, ajouter « Notez qu'on n'a pas besoin de @code{\noindent} après @code{\end@{displaymath@}} (@pxref{\indent & \noindent}). » -->
<noindent></noindent>
<para>Le mode math est pour des mathématiques en ligne dans le texte. Dans
l&textrsquo;exemple ci-dessus il est invoqué pour démarrer avec le <code>\(</code> et
pour finir avec le <code>\)</code> correspondant. Le mode math d&textrsquo;affichage est
pour des équations hors texte et il est ici invoqué par l&textrsquo;environnement
<code>displaymath</code>.  Notez que tout texte mathématique, y compris
<!-- c xx TODO préciser mode math = mode math en ligne ou d'affichage. -->
consistant d&textrsquo;un seul caractère, est géré en mode math.
</para>
<para>Quand il est en math mode ou mode math d&textrsquo;affichage, &latex; gère
beaucoup d&textrsquo;aspects du texte que vous entrez différemment que dans les
autres mode texte.  Par exemple,
</para>
<example endspaces=" ">
<pre xml:space="preserve">comparez x+y et \( x+y \)
</pre></example>

<noindent></noindent>
<para>en mode math les lettres sont en italique et l&textrsquo;espacement autour du
signe plus est différent.
</para>
<para>Il y a trois manières de mettre &latex; en mode math pour fabriquer des
formules en ligne dans le texte :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\( <var>matière mathématique</var> \)
$ <var>matière mathématique</var> $
\begin&lbrace;math&rbrace; <var>matière mathématique</var> \end&lbrace;math&rbrace;
</pre></example>

<noindent></noindent>
<para>La première forme est préférée et la deuxième est assez fréquente, mais
la troisième est rarement utilisée.
<!-- c xx TODO texte à revoir, ce n'est pas une bonne pratique de mélanger, -->
<!-- c et expliquer la valeur ajoutée de \(…\) par rapport à $…$ -->
Vous pouvez utiliser n&textrsquo;importe laquelle des trois, comme dans
<code>\(x\) and $y$</code>.  Vous pouvez les utiliser en mode paragraphe ou en
mode LR (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
</para>
<para>Pour fabriquer des formules hors texte, faites passer &latex; en mode
math d&textrsquo;affichage avec l&textrsquo;un des deux environnements suivants :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
  <var>matière mathématique</var>
\end&lbrace;displaymath&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  <var>matière mathématique</var>
\end&lbrace;equation&rbrace;
</pre></example>

<noindent></noindent>
<para>(<pxref label="displaymath"><xrefnodename>displaymath</xrefnodename></pxref>, <pxref label="equation"><xrefnodename>equation</xrefnodename></pxref>).  La seule différence est
qu&textrsquo;avec l&textrsquo;environnement <code>equation</code>, &latex; place un numéro de
formule sur le côté de la formule.
<!-- c xxx TODO pourquoi ne pas présenter les trois constructions d'un coup, -->
<!-- c comme pour les formules en ligne -->
La construction <code>\[ <var>math</var> \]</code> est équivalente à
<code>\begin&lbrace;displaymath&rbrace; <var>math</var> \end&lbrace;displaymath&rbrace;</code>.  Ces
environnements ne peuvent être utilisés qu&textrsquo;en mode paragraphe
(<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="732"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="733"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="734"><r>paquetage</r> <code>amsfonts</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="735"><code>amsfonts</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="736"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="737"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>

<para>La American Mathematical Society a publié un ensemble de
paquetages libres d&textrsquo;accès qui étendent largement vos possibilités pour
écrire des mathématiques, <code>amsmath</code> et <code>amssymb</code> (et
notez également le paquetage <code>mathtools</code> qui est une extension
d&textrsquo;<code>amsmath</code> et le charge).  Les nouveaux documents contenant du
texte mathématique devraient utiliser ces paquetages.  Une description
des ces paquetages est hors du champ d&textrsquo;application de ce document ; se
référer à leur documentation sur le CTAN.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Indices inférieurs &amp; supérieurs</menutitle><menunode separator=". ">Subscripts &amp; superscripts</menunode><menudescription><pre xml:space="preserve">Également connus comme exposants ou indices.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Symboles mathématiques</menutitle><menunode separator=". ">Math symbols</menunode><menudescription><pre xml:space="preserve">Gribouillis mathématiques divers.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Fonction mathématiques</menutitle><menunode separator=". ">Math functions</menunode><menudescription><pre xml:space="preserve">Nom de fonctions mathématiques comme sin et exp.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Accents en math</menutitle><menunode separator=". ">Math accents</menunode><menudescription><pre xml:space="preserve">Accents en math.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Sur- et sous-ligner</menutitle><menunode separator=". ">Over- and Underlining</menunode><menudescription><pre xml:space="preserve">Choses au-dessous ou au-dessous d&textrsquo;une formule.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Espacement en mode mathématique</menutitle><menunode separator=". ">Spacing in math mode</menunode><menudescription><pre xml:space="preserve">Espaces épaisses, moyennes, fines, et négatives.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Styles mathématiques</menutitle><menunode separator=". ">Math styles</menunode><menudescription><pre xml:space="preserve">Détermine la taille des choses.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Miscellanées mathématiques</menutitle><menunode separator=". ">Math miscellany</menunode><menudescription><pre xml:space="preserve">Tout ce qu&textrsquo;on n&textrsquo;a pas pu caser ailleurs.
</pre></menudescription></menuentry></menu>


<node name="Subscripts-_0026-superscripts" spaces=" "><nodename>Subscripts &amp; superscripts</nodename><nodenext automatic="on">Math symbols</nodenext><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Indices inférieurs &amp; supérieurs</sectiontitle>

<anchor name="superscript">superscript</anchor>
<anchor name="subscript">subscript</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="470">indice supérieur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="471">indice inférieur</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="738">^ <r>indice supérieur</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="739">_ <r>indice inférieur</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="472">exposant</indexterm></cindex>

<para>Synopsis (en mode math en ligne ou d&textrsquo;affichage), l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><var>base</var>^<var>exp</var>
<var>base</var>^&lbrace;<var>exp</var>&rbrace;
</pre></example>

<noindent></noindent>
<para>ou, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><var>base</var>_<var>exp</var>
<var>base</var>_&lbrace;<var>exp</var>&rbrace;
</pre></example> 

<para>Met <var>exp</var> en indice supérieur de <var>base</var> (avec le caractère
caret <code>^</code>) ou inférieur (avec le tiret bas <code>_</code>).
</para>
<para>Dans cet exemple le <code>0</code> et le <code>1</code> apparaissent comme indices
inférieurs alors que le <code>2</code> est un indice supérieur.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\( (x_0+x_1)^2 \leq (x_0)^2+(x_1)^2 \)
</pre></example>

<para>Pour avoir plus d&textrsquo;un caractère au sein de l&textrsquo;indice inférieur ou
supérieur <var>exp</var>, entourez l&textrsquo;expression <var>exp</var> par des des
accolades comme dans <code>e^&lbrace;-2x&rbrace;</code>.  La quatrième ligne de l&textrsquo;exemple
suivant illustre l&textrsquo;utilisation d&textrsquo;accolades pour grouper une expression
pour l&textrsquo;indice supérieur.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
  (3^3)^3=27^3=19\,683
  \qquad
  3^&lbrace;(3^3)&rbrace;=3^&lbrace;27&rbrace;=7\,625\,597\,484\,987
\end&lbrace;displaymath&rbrace;
</pre></example>

<para>&latex; sait gérer un indice supérieur sur un indice inférieur, ou
inférieur sur inférieur, ou supérieur sur inférieur, ou inférieur sur
supérieur. Ainsi des expressions telles que <code>e^&lbrace;x^2&rbrace;</code> et
<code>x_&lbrace;a_0&rbrace;</code> seront composées comme il faut. Notez l&textrsquo;utilisation
d&textrsquo;accolade pour donner à <var>base</var> un indice <var>exp</var> déterminé. Si
vous saisissez <code>\(3^3^3\)</code>, c&textrsquo;est interprété comme
<code>\(3^&lbrace;3&rbrace;^&lbrace;3&rbrace;\)</code> et vous obtiendrez l&textrsquo;erreur &tex; <samp>Double
superscript</samp>.
</para>
<para>&latex; fait ce qu&textrsquo;il faut quand quelque chose a à la fois un indice
 inférieur et un indice supérieur. Dans cet exemple l&textrsquo;intégrale a les
 deux, ils sont rendus à la bonne place sans intervention de l&textrsquo;auteur.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
  \int_&lbrace;x=a&rbrace;^b f'(x)\,dx = f(b)-f(a)
\end&lbrace;displaymath&rbrace;
</pre></example>

<noindent></noindent>
<para>Notez les accolades autour de <code>x=a</code> pour faire de toute
l&textrsquo;expression un indice inférieur.
</para>
<para>Vous pouvez mettre un indice supérieur ou inférieur avant un symbole
avec une construction telle que <code>&lbrace;&rbrace;_t K^2</code>.  Les accolades vides
<code>&lbrace;&rbrace;</code> donnent à l&textrsquo;indice inférieur quelque chose sur quoi
s&textrsquo;attacher et l&textrsquo;empêchent d&textrsquo;être attaché par accident à quelque symbole
qui le précède dans l&textrsquo;expression.
</para>
<para>En dehors du mode math, ou math d&textrsquo;affichage, l&textrsquo;utilisation d&textrsquo;un indice
inférieur ou supérieur, comme dans <code>l'expression x^2</code>, vous vaudra
l&textrsquo;erreur &tex; <samp>Missing $ inserted</samp>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="740"><r>paquetage</r> <code>mhchem</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="741"><code>mhchem</code>, <r>paquetage</r></indexterm></findex>

<para>Une raison usuelle de désirer des indices inférieurs hors d&textrsquo;un mode math
est de composer des formules chimiques. Il y a des paquetages spécialisés
pour cela, tels que <code>mhchem</code> ; voir le CTAN.
<!-- c xx display mode -->
</para>

</section>
<node name="Math-symbols" spaces=" "><nodename>Math symbols</nodename><nodenext automatic="on">Math functions</nodenext><nodeprev automatic="on">Subscripts &amp; superscripts</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Symboles mathématiques</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="473">symboles mathématiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="474">Lettre grecques</indexterm></cindex>

<findex index="fn" spaces=" "><indexterm index="fn" number="742"><r>paquetage</r> <code>comprehensive</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="743"><code>comprehensive</code>, <r>paquetage</r></indexterm></findex>

<para>&latex; fournit presque tout symbole mathématique dont vous êtes
susceptible d&textrsquo;avoir besoin. Par exemple, si vous incluez <code>$\pi$</code>
dans votre code source, alors vous obtenez le symbole pi π.
Voir le paquetage « Comprehensive &latex; Symbol List »,
<url><urefurl>https://ctan.org/pkg/comprehensive</urefurl></url>.
</para>
<para>Ci-dessous se trouve une liste de symboles usuels. Ce n&textrsquo;est en aucun cas
une liste exhaustive. Chaque symbole y est décrit brièvement et avec sa
classe de symbole (qui détermine l&textrsquo;espacement autour de lui) qui est
donnée entre parenthèses. Les commandes pour ces symboles peuvent, sauf
mention contraire, être utilisées seulement en mode mathématique.  Pour
redéfinir une commande de sorte à pouvoir l&textrsquo;utiliser quel que soit le
mode, voir <ref label="_005censuremath"><xrefnodename>\ensuremath</xrefnodename></ref>.
</para>
<!-- c xx Add Negation: @code{} for negations of relevant symbols -->
<!-- c Useful: http://www.w3.org/TR/WD-math-970515/section6.html -->
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="744">\|</indexterm>\|</itemformat></item>
</tableterm><tableitem><para>∥ Parallèle (relation). Synonyme : <code>\parallel</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="745">\aleph</indexterm>\aleph</itemformat></item>
</tableterm><tableitem><para>ℵ Aleph, cardinal transfini (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="746">\alpha</indexterm>\alpha</itemformat></item>
</tableterm><tableitem><para>α Lettre grecque en bas de casse  alpha (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="747">\amalg</indexterm>\amalg</itemformat></item>
</tableterm><tableitem><para>⨿ Union disjointe (binaire)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="748">\angle</indexterm>\angle</itemformat></item>
</tableterm><tableitem><para>∠ Angle géométrique (ordinaire). Similaire :
signe inférieur-à <code>&lt;</code> et chevron <code>\langle</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="749">\approx</indexterm>\approx</itemformat></item>
</tableterm><tableitem><para>≈ Presque égal à (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="750">\ast</indexterm>\ast</itemformat></item>
</tableterm><tableitem><para>∗ Opérateur astérisque, convolution, à six branches
(binaire). Synonyme : <code>*</code>, ce qui est souvent un indice
supérieur ou inférieur, comme dans l&textrsquo;étoile de
Kleene. Similaire : <code>\star</code>, qui est à cinq branches, et est
quelquefois utilisée comme une opération binaire générale, et
quelquefois réservée pour la corrélation croisée.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="751">\asymp</indexterm>\asymp</itemformat></item>
</tableterm><tableitem><para>≍ Équivalent asymptotiquement (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="752">\backslash</indexterm>\backslash</itemformat></item>
</tableterm><tableitem><para>\ controblique (ordinaire).  Similaire : soustraction
d&textrsquo;ensemble <code>\setminus</code>, et <code>\textbackslash</code> pour une
controblique en dehors du mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="753">\beta</indexterm>\beta</itemformat></item>
</tableterm><tableitem><para>β Lettre grecque en bas de casse  bêta (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="754">\bigcap</indexterm>\bigcap</itemformat></item>
</tableterm><tableitem><para>⋂ De taille Variable, ou n-aire, intersection (opérateur). Similaire :
intersection binaire <code>\cap</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="755">\bigcirc</indexterm>\bigcirc</itemformat></item>
</tableterm><tableitem><para>⚪ Cercle, plus grand (binaire).  Similaire : composition de
fonction <code>\circ</code>.
<!-- c bb Best unicode symbol for this? -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="756">\bigcup</indexterm>\bigcup</itemformat></item>
</tableterm><tableitem><para>⋃ De taille variable, ou n-aire, union (opérateur). Similaire : union
binaire <code>\cup</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="757">\bigodot</indexterm>\bigodot</itemformat></item>
</tableterm><tableitem><para>⨀ De taille variable, ou n-aire,  opérateur point encerclé (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="758">\bigoplus</indexterm>\bigoplus</itemformat></item>
</tableterm><tableitem><para>⨁ De taille variable, ou n-aire, opérateur plus encerclé (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="759">\bigotimes</indexterm>\bigotimes</itemformat></item>
</tableterm><tableitem><para>⨂ De taille variable, ou n-aire, opérateur multiplié encerclé (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="760">\bigtriangledown</indexterm>\bigtriangledown</itemformat></item>
</tableterm><tableitem><para>▽ De taille variable, ou n-aire, triangle ouvert
pointant vers le bas(opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="761">\bigtriangleup</indexterm>\bigtriangleup</itemformat></item>
</tableterm><tableitem><para>△ De taille variable, ou n-aire, triangle ouvert
pointant vers le haut (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="762">\bigsqcup</indexterm>\bigsqcup</itemformat></item>
</tableterm><tableitem><para>⨆ De taille variable, ou n-aire, union carrée (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="763">\biguplus</indexterm>\biguplus</itemformat></item>
</tableterm><tableitem><para>⨄ De taille variable, ou n-aire, opérateur union avec un plus
(opérateur).  (Notez que le nom a juste un p.)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="764">\bigvee</indexterm>\bigvee</itemformat></item>
</tableterm><tableitem><para>⋁ De taille variable, ou n-aire, ou-logique (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="765">\bigwedge</indexterm>\bigwedge</itemformat></item>
</tableterm><tableitem><para>⋀ De taille variable, ou n-aire, et-logique (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="766">\bot</indexterm>\bot</itemformat></item>
</tableterm><tableitem><para>⊥ Taquet vers le haut, minimum, plus petit élément d&textrsquo;un ensemble
partiellement ordonné, ou une contradiction
(ordinaire).  Voir aussi <code>\top</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="767">\bowtie</indexterm>\bowtie</itemformat></item>
</tableterm><tableitem><para>⋈ Jonction naturelle de deux relations (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="768">\Box</indexterm>\Box</itemformat></item>
</tableterm><tableitem><para>□ Opérateur modal pour la nécessité ; boîte ouverte carrée
(ordinaire).  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
<!-- c bb Best Unicode equivalent? -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="769">\bullet</indexterm>\bullet</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="475">symbole puce</indexterm></cindex>
<para>• Puce (binaire).  Similaire : point de
multiplication <code>\cdot</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="770">\cap</indexterm>\cap</itemformat></item>
</tableterm><tableitem><para>∩ Intersection de deux ensembles (binaire).  Similaire :
opérateur de taille variable <code>\bigcap</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="771">\cdot</indexterm>\cdot</itemformat></item>
</tableterm><tableitem><para>⋅ Multiplication (binaire).  Similaire : Point
puce <code>\bullet</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="772">\chi</indexterm>\chi</itemformat></item>
</tableterm><tableitem><para>χ Lettre grecque en bas de casse  chi (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="773">\circ</indexterm>\circ</itemformat></item>
</tableterm><tableitem><para>∘ Composition de fonctions, opérateur rond (binaire).  Similaire :
opérateur de taille variable <code>\bigcirc</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="774">\clubsuit</indexterm>\clubsuit</itemformat></item>
</tableterm><tableitem><para>♣ Trèfle de carte à jouer (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="775">\complement</indexterm>\complement</itemformat></item>
</tableterm><tableitem><para>∁ Complément d&textrsquo;ensemble, utilisée en indice supérieur
comme dans <code>$S^\complement$</code> (ordinaire).  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>. On utilise aussi : <code>$S^&lbrace;\mathsf&lbrace;c&rbrace;&rbrace;$</code>
ou <code>$\bar&lbrace;S&rbrace;$</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="776">\cong</indexterm>\cong</itemformat></item>
</tableterm><tableitem><para>≅ Congruent (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="777">\coprod</indexterm>\coprod</itemformat></item>
</tableterm><tableitem><para>∐ Coproduit (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="778">\cup</indexterm>\cup</itemformat></item>
</tableterm><tableitem><para>∪ Réunion de deux ensembles (binaire).  opérateur de taille
variable <code>\bigcup</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="779">\dagger</indexterm>\dagger</itemformat></item>
</tableterm><tableitem><para>† Relation obèle (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="780">\dashv</indexterm>\dashv</itemformat></item>
</tableterm><tableitem><para>⊣ Taquet gauche, tiret avec barre verticale à droite,
tourniquet pour gauchers (relation).  Similaire : taquet droit,
tourniquet <code>\vdash</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="781">\ddagger</indexterm>\ddagger</itemformat></item>
</tableterm><tableitem><para>‡ Relation double obèle (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="782">\Delta</indexterm>\Delta</itemformat></item>
</tableterm><tableitem><para>Δ Delta grec capital, utilisé pour indiquer une
incrémentation (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="783">\delta</indexterm>\delta</itemformat></item>
</tableterm><tableitem><para>δ Delta grec bas-de-casse (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="784">\Diamond</indexterm>\Diamond</itemformat></item>
</tableterm><tableitem><para>◇ Opérateur grand carreau (ordinaire).  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
<!-- c bb Best Unicode equivalent? -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="785">\diamond</indexterm>\diamond</itemformat></item>
</tableterm><tableitem><para>⋄ Opérateur Carreau, ou puce carreau (binaire).  Similaire : grand
carreau <code>\Diamond</code>, puce disque <code>\bullet</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="786">\diamondsuit</indexterm>\diamondsuit</itemformat></item>
</tableterm><tableitem><para>♢ Carreau de carte à jouer (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="787">\div</indexterm>\div</itemformat></item>
</tableterm><tableitem><para>÷ Signe de division, obélus (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="788">\doteq</indexterm>\doteq</itemformat></item>
</tableterm><tableitem><para>≐ Approche la limite (relation).  Similaire :
géométriquement égal à <code>\Doteq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="789">\downarrow</indexterm>\downarrow</itemformat></item>
</tableterm><tableitem><para>↓ Flèche vers le bas, converge (relation).  Similaire :
flèche à ligne double vers le bas <code>\Downarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="790">\Downarrow</indexterm>\Downarrow</itemformat></item>
</tableterm><tableitem><para>⇓ Flèche à ligne double vers le bas (relation).
Similaire : flèche à ligne simple vers le bas <code>\downarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="791">\ell</indexterm>\ell</itemformat></item>
</tableterm><tableitem><para>ℓ Lettre l bas de casse cursive (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="792">\emptyset</indexterm>\emptyset</itemformat></item>
</tableterm><tableitem><para>∅ Symbole ensemble vide (ordinaire).  La forme en
variante est <code>\varnothing</code>.
<!-- c bb Why Unicode has \revemptyset but no \emptyset? -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="793">\epsilon</indexterm>\epsilon</itemformat></item>
</tableterm><tableitem><para>ϵ Lettre grecque bas de casse epsilon lunaire
(ordinaire).  Semblable à la lettre en texte grec. En mathématiques on
utilise plus fréquemment l&textrsquo;epsilon minuscule de ronde
<code>\varepsilon</code> ε. En relation avec : la relation
ensembliste « appartenir à » <code>\in</code> ∈.
<!-- c src: David Carlisle http://tex.stackexchange.com/a/98018/339 and -->
<!-- c Unicode referenced there asserts varepsilon is much more widely used. -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="794">\equiv</indexterm>\equiv</itemformat></item>
</tableterm><tableitem><para>≡ Équivalence (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="795">\eta</indexterm>\eta</itemformat></item>
</tableterm><tableitem><para>η Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="796">\exists</indexterm>\exists</itemformat></item>
</tableterm><tableitem><para>∃ Quanteur « Il existe » (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="797">\flat</indexterm>\flat</itemformat></item>
</tableterm><tableitem><para>♭ Bémol (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="798">\forall</indexterm>\forall</itemformat></item>
</tableterm><tableitem><para>∀ Quanteur « Pour tout » (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="799">\frown</indexterm>\frown</itemformat></item>
</tableterm><tableitem><para>⌢ Moue (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="800">\Gamma</indexterm>\Gamma</itemformat></item>
</tableterm><tableitem><para>Γ Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="801">\gamma</indexterm>\gamma</itemformat></item>
</tableterm><tableitem><para>γ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="802">\ge</indexterm>\ge</itemformat></item>
</tableterm><tableitem><para>≥ Supérieur ou égal à (relation).  Synonyme : <code>\geq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="803">\geq</indexterm>\geq</itemformat></item>
</tableterm><tableitem><para>≥ Supérieur ou égal à (relation).  Synonyme : <code>\ge</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="804">\gets</indexterm>\gets</itemformat></item>
</tableterm><tableitem><para>← Auquel est assignée la valeur (relation).
Synonyme : <code>\leftarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="805">\gg</indexterm>\gg</itemformat></item>
</tableterm><tableitem><para>≫ Beaucoup plus grand que (relation).  Similaire : Beaucoup
plus petit que <code>\ll</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="806">\hbar</indexterm>\hbar</itemformat></item>
</tableterm><tableitem><para>ℏ Constante de Planck sur deux pi (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="807">\heartsuit</indexterm>\heartsuit</itemformat></item>
</tableterm><tableitem><para>♡ Cœur de carte jouer (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="808">\hookleftarrow</indexterm>\hookleftarrow</itemformat></item>
</tableterm><tableitem><para>↩ Flèche vers la gauche avec crochet (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="809">\hookrightarrow</indexterm>\hookrightarrow</itemformat></item>
</tableterm><tableitem><para>↪ Flèche vers la gauche avec crochet (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="810">\iff</indexterm>\iff</itemformat></item>
</tableterm><tableitem><para>⟷ Si et seulement si (relation).  C&textrsquo;est un  <code>\Longleftrightarrow</code>
avec un <code>\thickmuskip</code> de chaque côté.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="811">\Im</indexterm>\Im</itemformat></item>
</tableterm><tableitem><para>ℑ Partie imaginaire (ordinaire).  Voir aussi : partie réelle <code>\Re</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="812">\imath</indexterm>\imath</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="476">sans point, i, math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="477">i sans point en math</indexterm></cindex>
<para>i sans point ; utilisé quand on place un accent sur un i (<pxref label="Math-accents"><xrefnodename>Math
accents</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="813">\in</indexterm>\in</itemformat></item>
</tableterm><tableitem><para>∈ Appartient à (relation).  Voir aussi : lettre grecque bas de
casse epsilon lunaire <code>\epsilon</code> ϵ et l&textrsquo;epsilon
minuscule de ronde <code>\varepsilon</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="814">\infty</indexterm>\infty</itemformat></item>
</tableterm><tableitem><para>∞ Infini (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="815">\int</indexterm>\int</itemformat></item>
</tableterm><tableitem><para>∫ Intégrale (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="816">\iota</indexterm>\iota</itemformat></item>
</tableterm><tableitem><para>ι Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="817">\Join</indexterm>\Join</itemformat></item>
</tableterm><tableitem><para>⨝ Symbole jointure condensé (relation).  Ceci n&textrsquo;est pas disponible en &tex; de base.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="818">\jmath</indexterm>\jmath</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="478">sans point, j, math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="479">j sans point en math</indexterm></cindex>
<para>j sans point ; utilisé quand on place un accent sur un j (<pxref label="Math-accents"><xrefnodename>Math
accents</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="819">\kappa</indexterm>\kappa</itemformat></item>
</tableterm><tableitem><para>κ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="820">\Lambda</indexterm>\Lambda</itemformat></item>
</tableterm><tableitem><para>Λ Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="821">\lambda</indexterm>\lambda</itemformat></item>
</tableterm><tableitem><para>λ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="822">\land</indexterm>\land</itemformat></item>
</tableterm><tableitem><para>∧ Et logique (binaire).  Synonyme : <code>\wedge</code>.
Voir aussi ou-logique <code>\lor</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="823">\langle</indexterm>\langle</itemformat></item>
</tableterm><tableitem><para>⟨ Chevron mathématique gauche, ou séquence, crochet
(ouvrant).  Similaire : inférieur à <code>&lt;</code>. Correspond
à <code>\rangle</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="824">\lbrace</indexterm>\lbrace</itemformat></item>
</tableterm><tableitem><para>&lbracechar; Accolade gauche
(ouvrant). Synonyme : <code>\&lbrace;</code>. Correspond à <code>\rbrace</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="825">\lbrack</indexterm>\lbrack</itemformat></item>
</tableterm><tableitem><para>[ Crochet gauche (ouvrant).
Synonyme : <code>[</code>. Correspond à <code>\rbrack</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="826">\lceil</indexterm>\lceil</itemformat></item>
</tableterm><tableitem><para>⌈ Plafond à gauche, ressemble à un crochet mais avec le
pied coupé (ouvrant). Correspond à <code>\rceil</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="827">\le</indexterm>\le</itemformat></item>
</tableterm><tableitem><para>≤ Inférieur ou égal à (relation).  C&textrsquo;est un synonyme
de <code>\leq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="828">\leadsto</indexterm>\leadsto</itemformat></item>
</tableterm><tableitem><para>⇝ flèche vers la droite en tire-bouchon (relation).  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="829">\Leftarrow</indexterm>\Leftarrow</itemformat></item>
</tableterm><tableitem><para>⇐ Est impliqué par, flèche vers la gauche à
double-ligne (relation).  Similaire : flèche vers la gauche à simple
ligne <code>\leftarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="830">\leftarrow</indexterm>\leftarrow</itemformat></item>
</tableterm><tableitem><para>← Flèche vers la gauche à simple ligne (relation).
Synonyme : <code>\gets</code>. Similaire : Flèche vers la gauche à
double-ligne <code>\Leftarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="831">\leftharpoondown</indexterm>\leftharpoondown</itemformat></item>
</tableterm><tableitem><para>↽ Harpon vers la gauche à simple ligne avec
crochet vers le bas (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="832">\leftharpoonup</indexterm>\leftharpoonup</itemformat></item>
</tableterm><tableitem><para>↼ Harpon vers la gauche à simple ligne avec
crochet vers le haut (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="833">\Leftrightarrow</indexterm>\Leftrightarrow</itemformat></item>
</tableterm><tableitem><para>⇔ Bi-implication ; double flèche bilatérale
(relation).  Similaire : flèche bilatérale <code>\leftrightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="834">\leftrightarrow</indexterm>\leftrightarrow</itemformat></item>
</tableterm><tableitem><para>↔ Flèche bilatérale (relation).  Similaire :
double flèche bilatérale <code>\Leftrightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="835">\leq</indexterm>\leq</itemformat></item>
</tableterm><tableitem><para>≤ Inférieur ou égal à (relation).  Synonyme : <code>\le</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="836">\lfloor</indexterm>\lfloor</itemformat></item>
</tableterm><tableitem><para>⌊ Plancher à gauche (ouvrant). Correspond à :
<code>\rfloor</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="837">\lhd</indexterm>\lhd</itemformat></item>
</tableterm><tableitem><para>◁ Pointe de flèche, c.-à-d.&noeos; triangle pointant vers la
gauche (binaire).  Pour le symbole normal de sous-groupe on doit charger
<code>amssymb</code> et utiliser <code>\vartriangleleft</code> (qui est une relation et
ainsi donne un meilleur espacement).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="838">\ll</indexterm>\ll</itemformat></item>
</tableterm><tableitem><para>≪ Beaucoup plus petit que (relation).  Similaire : Beaucoup
plus grand que <code>\gg</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="839">\lnot</indexterm>\lnot</itemformat></item>
</tableterm><tableitem><para>¬ Négation logique (ordinaire). Synonyme : <code>\neg</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="840">\longleftarrow</indexterm>\longleftarrow</itemformat></item>
</tableterm><tableitem><para>⟵ Longue flèche vers  la gauche à ligne simple (relation).
Similaire : longue flèche gauche à ligne double <code>\Longleftarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="841">\longleftrightarrow</indexterm>\longleftrightarrow</itemformat></item>
</tableterm><tableitem><para>⟷ Longue flèche bilatérale à ligne simple
(relation).  Similaire : longue flèche bilatérale à ligne
double <code>\Longleftrightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="842">\longmapsto</indexterm>\longmapsto</itemformat></item>
</tableterm><tableitem><para>⟼ Longue flèche d&textrsquo;un taquet vers la droite à ligne
simple (relation).  Similaire : version courte <code>\mapsto</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="843">\longrightarrow</indexterm>\longrightarrow</itemformat></item>
</tableterm><tableitem><para>⟶ Longue flèche vers la droite à ligne simple
(relation).  Similaire : longue flèche vers la droite à ligne
double <code>\Longrightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="844">\lor</indexterm>\lor</itemformat></item>
</tableterm><tableitem><para>∨ Ou-logique (binaire).  Synonyme : <code>\vee</code>. Voir aussi et-logique <code>\land</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="845">\mapsto</indexterm>\mapsto</itemformat></item>
</tableterm><tableitem><para>↦ Flèche d&textrsquo;un taquet vers la droite (relation).
  Similaire : version longue <code>\longmapsto</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="846">\mho</indexterm>\mho</itemformat></item>
</tableterm><tableitem><para>℧ Conductance, symbole Ohm culbuté (ordinaire).  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="847">\mid</indexterm>\mid</itemformat></item>
</tableterm><tableitem><para>∣ Barre verticale à ligne simple (relation). une utilisation
typique de <code>\mid</code> est pour un ensemble <code>\&lbrace;\, x \mid x\geq 5
\,\&rbrace;</code>.
</para>
<para>Similaire : <code>\vert</code> et <code>|</code> produisent le même symbole de barre
verticale à ligne simple mais sans aucun espacement (on les classe comme
« ordinaires ») et vous ne devriez pas les utiliser comme symbole de
relation mais seulement comme des ordinaux, c.-à-d.&noeos; comme des symboles
de note en bas de page. Pour dénoter une valeur absolue, voir l&textrsquo;entrée
de <code>\vert</code> et pour une norme voir l&textrsquo;entrée de <code>\Vert</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="848">\models</indexterm>\models</itemformat></item>
</tableterm><tableitem><para>⊨ inclut ; portillon/tourniquet à double barre, barre
verticale et double tiret court (relation).  Similaire : barre verticale
et double tiret long <code>\vDash</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="849">\mp</indexterm>\mp</itemformat></item>
</tableterm><tableitem><para>∓ Moins ou plus (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="850">\mu</indexterm>\mu</itemformat></item>
</tableterm><tableitem><para>μ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="851">\nabla</indexterm>\nabla</itemformat></item>
</tableterm><tableitem><para>∇ Del de Hamilton, ou
nabla, ou différentiel, opérateur (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="852">\natural</indexterm>\natural</itemformat></item>
</tableterm><tableitem><para>♮ Bécarre (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="853">\ne</indexterm>\ne</itemformat></item>
</tableterm><tableitem><para>≠ Non égal (relation). Synonyme : <code>\neq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="854">\nearrow</indexterm>\nearrow</itemformat></item>
</tableterm><tableitem><para>↗ Flèche nord-est (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="855">\neg</indexterm>\neg</itemformat></item>
</tableterm><tableitem><para>¬ Négation logique (ordinaire).
Synonyme : <code>\lnot</code>. Utilisé parfois au lieu du symbole de
négation: <code>\sim</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="856">\neq</indexterm>\neq</itemformat></item>
</tableterm><tableitem><para>≠ Non égal (relation). Synonyme : <code>\ne</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="857">\ni</indexterm>\ni</itemformat></item>
</tableterm><tableitem><para>∋ Signe d&textrsquo;appartenance réfléchi ; « contient comme élément »
(relation). Synonyme : <code>\owns</code>. Similaire : « appartient
à » <code>\in</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="858">\not</indexterm>\not</itemformat></item>
</tableterm><tableitem><para≯ Barre oblique longue utilisée pour rayer un
 opérateur la suivant (relation).
<!-- c Need blank space for it to overstrike -->
</para>
<para>Beaucoup opérateurs en négation qui n&textrsquo;ont pas besoin de <code>\not</code> sont
disponibles, en particulier avec le paquetage <file>amssymb</file>. Par
exemple, <code>\notin</code> est sans doute préférable à <code>\not\in</code> d&textrsquo;un
point de vue typographique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="859">\notin</indexterm>\notin</itemformat></item>
</tableterm><tableitem><para>∉ N&textrsquo;appartient pas à (relation).  Similaire : non contenu
dans <code>\nsubseteq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="860">\nu</indexterm>\nu</itemformat></item>
</tableterm><tableitem><para>ν Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="861">\nwarrow</indexterm>\nwarrow</itemformat></item>
</tableterm><tableitem><para>↖ Flèche nord-ouest (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="862">\odot</indexterm>\odot</itemformat></item>
</tableterm><tableitem><para>⊙ Point cerclé (binaire).  Similaire : opérateur de taille
variable <code>\bigodot</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="863">\oint</indexterm>\oint</itemformat></item>
</tableterm><tableitem><para>∮ Intégrale de contour, intégrale avec un cercle au milieu (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="864">\Omega</indexterm>\Omega</itemformat></item>
</tableterm><tableitem><para>Ω Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="865">\omega</indexterm>\omega</itemformat></item>
</tableterm><tableitem><para>ω Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="866">\ominus</indexterm>\ominus</itemformat></item>
</tableterm><tableitem><para>⊖ Signe moins, ou tiret, cerclé (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="867">\oplus</indexterm>\oplus</itemformat></item>
</tableterm><tableitem><para>⊕ Signe plus cerclé (binaire).  Similaire : opérateur de
taille variable <code>\bigoplus</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="868">\oslash</indexterm>\oslash</itemformat></item>
</tableterm><tableitem><para>⊘ Barre de fraction, ou barre oblique, cerclée (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="869">\otimes</indexterm>\otimes</itemformat></item>
</tableterm><tableitem><para>⊗ Signe de multiplication, ou croix, cerclé (binaire).  Similaire :
opérateur de taille variable <code>\bigotimes</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="870">\owns</indexterm>\owns</itemformat></item>
</tableterm><tableitem><para>∋ Epsilon d&textrsquo;appartenance réfléchi ; « contient comme
élément » (relation). Synonyme : <code>\ni</code>. Similaire : appartient
à <code>\in</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="871">\parallel</indexterm>\parallel</itemformat></item>
</tableterm><tableitem><para>∥ Parallèle (relation). Synonyme : <code>\|</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="872">\partial</indexterm>\partial</itemformat></item>
</tableterm><tableitem><para>∂ Différentielle partielle (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="873">\perp</indexterm>\perp</itemformat></item>
</tableterm><tableitem><para>⟂ Perpendiculaire (relation).  Similaire : <code>\bot</code>
utilise le même glyphe mais l&textrsquo;espacement est différent parce qu&textrsquo;il est
dans la classe ordinaire.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="874">\Phi</indexterm>\Phi</itemformat></item>
</tableterm><tableitem><para>Φ Lettre grecque capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="875">\phi</indexterm>\phi</itemformat></item>
</tableterm><tableitem><para>ϕ Lettre grecque en bas de casse  (ordinaire).  La forme en variante est
<code>\varphi</code> φ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="876">\Pi</indexterm>\Pi</itemformat></item>
</tableterm><tableitem><para>Π Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="877">\pi</indexterm>\pi</itemformat></item>
</tableterm><tableitem><para>π Lettre grecque en bas de casse  (ordinaire).  La forme en variante est
<code>\varpi</code> ϖ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="878">\pm</indexterm>\pm</itemformat></item>
</tableterm><tableitem><para>± Plus or minus (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="879">\prec</indexterm>\prec</itemformat></item>
</tableterm><tableitem><para>≺ Précède (relation). Similaire : inférieur à <code>&lt;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="880">\preceq</indexterm>\preceq</itemformat></item>
</tableterm><tableitem><para>⪯ Précède ou égal, précède par-dessus signe égal à une
ligne (relation). Similaire : inférieur ou égal <code>\leq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="881">\prime</indexterm>\prime</itemformat></item>
</tableterm><tableitem><para>′ Prime, ou minute au sein d&textrsquo;une expression temporelle
(ordinaire).  Typiquement utilisé en indice supérieur <code>$A^\prime$</code>.
Il est à noter que <code>$f^\prime$</code> et <code>$f'$</code> produisent le même
résultat.  Un avantage de la seconde forme est que <code>$f'''$</code> produit
le symbole désiré, c.-à-d.&noeos; le même résultat que
<code>$f^&lbrace;\prime\prime\prime&rbrace;$</code>, mais en nécessitant moins de
saisie. Il est à noter que vous ne pouvez utiliser <code>\prime</code> qu&textrsquo;en
mode mathématique.  Utiliser le quote <code>'</code> en mode texte produit un
caractère différent (apostrophe ou guillemet anglais simple de droite).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="882">\prod</indexterm>\prod</itemformat></item>
</tableterm><tableitem><para>∏ Produit (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="883">\propto</indexterm>\propto</itemformat></item>
</tableterm><tableitem><para>∝ Proportionnel à (relation)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="884">\Psi</indexterm>\Psi</itemformat></item>
</tableterm><tableitem><para>Ψ Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="885">\psi</indexterm>\psi</itemformat></item>
</tableterm><tableitem><para>ψ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="886">\rangle</indexterm>\rangle</itemformat></item>
</tableterm><tableitem><para>⟩ Chevron mathématique droit, ou séquence, crochet
(fermant). Similaire : supérieur à <code>&gt;</code>.  Correspond
à <code>\langle</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="887">\rbrace</indexterm>\rbrace</itemformat></item>
</tableterm><tableitem><para>&rbracechar; Accolade de droite
(fermante). Synonyme : <code>\&rbrace;</code>. Correspond à <code>\lbrace</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="888">\rbrack</indexterm>\rbrack</itemformat></item>
</tableterm><tableitem><para>] Crochet droit (fermant). Synonyme : <code>]</code>. Correspond
à <code>\lbrack</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="889">\rceil</indexterm>\rceil</itemformat></item>
</tableterm><tableitem><para>⌉ Plafond droit (fermant). Correspond à <code>\lceil</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="890">\Re</indexterm>\Re</itemformat></item>
</tableterm><tableitem><para>ℜ Partie réelle, nombres réels, R capital gothique
(ordinaire). En relation avec : R majuscule ajouré, ou gras de tableau
d&textrsquo;école <code>\mathbb&lbrace;R&rbrace;</code> ; pour accéder à cela charger le paquetage
<file>amsfonts</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="891">\restriction</indexterm>\restriction</itemformat></item>
</tableterm><tableitem><para>↾ Restriction d&textrsquo;une fonction
(relation). Synonyme : <code>\upharpoonright</code>.  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="892">\revemptyset</indexterm>\revemptyset</itemformat></item>
</tableterm><tableitem><para>⦰ Symbole ensemble vide inversé (ordinaire).
En relation avec : <code>\varnothing</code>. Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>stix</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="893">\rfloor</indexterm>\rfloor</itemformat></item>
</tableterm><tableitem><para>⌋ Plancher droit, un crochet droit avec la dent du haut
coupée (fermant). Correspond à <code>\lfloor</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="894">\rhd</indexterm>\rhd</itemformat></item>
</tableterm><tableitem><para>◁ Pointe de flèche, c.-à-d.&noeos; u triangle pointant vers la
droite (binaire).  Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>. Pour le symbole
normal de sous-groupe vous devriez plutôt charger <file>amssymb</file> et
utiliser <code>\vartriangleright</code> (qui est une relation et ainsi donne
un meilleur espacement).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="895">\rho</indexterm>\rho</itemformat></item>
</tableterm><tableitem><para>ρ Lettre grecque en bas de casse  (ordinaire).  La forme en variante est
<code>\varrho</code> ϱ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="896">\Rightarrow</indexterm>\Rightarrow</itemformat></item>
</tableterm><tableitem><para>⇒ Implique, flèche vers la droite à double-ligne
(relation). Similaire : flèche vers la droite <code>\rightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="897">\rightarrow</indexterm>\rightarrow</itemformat></item>
</tableterm><tableitem><para>→ Flèche vers la droite à ligne simple
(relation). Synonyme : <code>\to</code>. Similaire : flèche vers droite à
ligne double <code>\Rightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="898">\rightharpoondown</indexterm>\rightharpoondown</itemformat></item>
</tableterm><tableitem><para>⇁ Harpon vers la droite avec crochet vers le bas
(relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="899">\rightharpoonup</indexterm>\rightharpoonup</itemformat></item>
</tableterm><tableitem><para>⇀ Harpon vers la droite  avec crochet vers la haut (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="900">\rightleftharpoons</indexterm>\rightleftharpoons</itemformat></item>
</tableterm><tableitem><para>⇌ Harpon vers la droite avec crochet vers le
haut au dessus d&textrsquo;un harpon vers la gauche avec crochet vers le bas
(relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="901">\searrow</indexterm>\searrow</itemformat></item>
</tableterm><tableitem><para>↘ Flèche pointant sud-est (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="902">\setminus</indexterm>\setminus</itemformat></item>
</tableterm><tableitem><para>⧵ Différence ensembliste, barre de faction inversée ou
controblique, comme \ (binaire). Similaire :
controblique <code>\backslash</code> et aussi <code>\textbackslash</code> hors du
mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="903">\sharp</indexterm>\sharp</itemformat></item>
</tableterm><tableitem><para>♯ Dièse (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="904">\Sigma</indexterm>\Sigma</itemformat></item>
</tableterm><tableitem><para>Σ Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="905">\sigma</indexterm>\sigma</itemformat></item>
</tableterm><tableitem><para>σ Lettre grecque en bas de casse (ordinaire). La forme en
variante est <code>\varsigma</code> ς.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="906">\sim</indexterm>\sim</itemformat></item>
</tableterm><tableitem><para>∼ Similaire à, dans une relation (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="907">\simeq</indexterm>\simeq</itemformat></item>
</tableterm><tableitem><para>≃ Similaire ou égal à, dans une relation (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="908">\smallint</indexterm>\smallint</itemformat></item>
</tableterm><tableitem><para>∫ Signe intégrale qui ne change pas en taille plus
grande au sein d&textrsquo;une formule hors texte (opérateur).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="909">\smile</indexterm>\smile</itemformat></item>
</tableterm><tableitem><para>⌣ Arc concave en haut, sourire (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="910">\spadesuit</indexterm>\spadesuit</itemformat></item>
</tableterm><tableitem><para>♠ Pique de carte à jouer (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="911">\sqcap</indexterm>\sqcap</itemformat></item>
</tableterm><tableitem><para>⊓ Symbole d&textrsquo;intersection carré (binaire). Similaire :
intersection <code>cap</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="912">\sqcup</indexterm>\sqcup</itemformat></item>
</tableterm><tableitem><para>⊔ Symbole d&textrsquo;union carré (binaire). Similaire :
union <code>\cup</code>. En relation avec : opérateur de taille
variable <code>\bigsqcup</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="913">\sqsubset</indexterm>\sqsubset</itemformat></item>
</tableterm><tableitem><para>⊏ Symbole carré de sous-ensemble (relation). Similaire :
sous-ensemble <code>\subset</code>. Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="914">\sqsubseteq</indexterm>\sqsubseteq</itemformat></item>
</tableterm><tableitem><para>⊑ Symbole carré de sous-ensemble ou égal
(binaire). Similaire : sous-ensemble ou égal <code>\subseteq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="915">\sqsupset</indexterm>\sqsupset</itemformat></item>
</tableterm><tableitem><para>⊐ Symbole carré de sur-ensemble (relation). Similaire :
superset <code>\supset</code>. Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="916">\sqsupseteq</indexterm>\sqsupseteq</itemformat></item>
</tableterm><tableitem><para>⊒ Symbole carré de sur-ensemble ou égal
(binaire). Similaire : sur-ensemble ou égal <code>\supseteq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="917">\star</indexterm>\star</itemformat></item>
</tableterm><tableitem><para>⋆ Étoile à cinq branches, quelquefois utilisée comme une
opération binaire générale mais quelquefois réservée pour la
corrélation croisée (binaire). Similaire : les
synonymes astérisque <code>*</code> et <code>\ast</code>, qui sont à six branches,
et apparaissent plus souvent comme indice supérieur et inférieur, comme
c&textrsquo;est le cas avec l&textrsquo;étoile de Kleene.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="918">\subset</indexterm>\subset</itemformat></item>
</tableterm><tableitem><para>⊂ Est contenu (occasionnellement, est impliqué par) (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="919">\subseteq</indexterm>\subseteq</itemformat></item>
</tableterm><tableitem><para>⊆ Est contenu ou égal à (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="920">\succ</indexterm>\succ</itemformat></item>
</tableterm><tableitem><para>≻ Vient après, suit (relation). Similaire : inférieur
à <code>&gt;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="921">\succeq</indexterm>\succeq</itemformat></item>
</tableterm><tableitem><para>⪰ Suit ou est égal à (relation). Similaire : inférieur ou égal à <code>\leq</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="922">\sum</indexterm>\sum</itemformat></item>
</tableterm><tableitem><para>∑ Summation (opérateur). Similaire : Lettre grecque
capitale <code>\Sigma</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="923">\supset</indexterm>\supset</itemformat></item>
</tableterm><tableitem><para>⊃ Contient (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="924">\supseteq</indexterm>\supseteq</itemformat></item>
</tableterm><tableitem><para>⊇ Contient ou est égal à (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="925">\surd</indexterm>\surd</itemformat></item>
</tableterm><tableitem><para>√ Symbole racine (ordinaire).  La commande &latex;
<code>\sqrt&lbrace;..&rbrace;</code> compose la racine de l&textrsquo;argument, avec une barre qui
s&textrsquo;étend pour couvrir l&textrsquo;argument.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="926">\swarrow</indexterm>\swarrow</itemformat></item>
</tableterm><tableitem><para>↙ Flèche pointant au sud-ouest (relation).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="927">\tau</indexterm>\tau</itemformat></item>
</tableterm><tableitem><para>τ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="928">\theta</indexterm>\theta</itemformat></item>
</tableterm><tableitem><para>θ Lettre grecque en bas de casse (ordinaire). La forme en
variante est <code>\vartheta</code> ϑ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="929">\times</indexterm>\times</itemformat></item>
</tableterm><tableitem><para>× Signe de multiplication d&textrsquo;école primaire (binaire). Voir aussi <code>\cdot</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="930">\to</indexterm>\to</itemformat></item>
</tableterm><tableitem><para>→ Flèche en ligne simple vers la droite (relation).
Synonyme : <code>\rightarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="931">\top</indexterm>\top</itemformat></item>
</tableterm><tableitem><para>⊤ Taquet vers le haut ; dessus, plus grand élément d&textrsquo;un
ensemble partiellement ordonné (ordinaire). Voir aussi <code>\bot</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="932">\triangle</indexterm>\triangle</itemformat></item>
</tableterm><tableitem><para>△ Triangle (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="933">\triangleleft</indexterm>\triangleleft</itemformat></item>
</tableterm><tableitem><para>◁ Triangle non-rempli pointant à gauche
(binaire). Similaire : <code>\lhd</code>. Pour le symbole normal de
sous-groupe vous devez charger <file>amssymb</file> et
utiliser <code>\vartriangleleft</code> (qui est une relation et ainsi
donne un meilleur espacement).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="934">\triangleright</indexterm>\triangleright</itemformat></item>
</tableterm><tableitem><para>▷ Triangle non-rempli pointant à droite
(binaire). Pour le symbole normal de sous-groupe vous devez à la place
charger <file>amssymb</file> et utiliser <code>\vartriangleright</code> (qui
est une relation et ainsi donne un meilleur espacement).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="935">\unlhd</indexterm>\unlhd</itemformat></item>
</tableterm><tableitem><para>⊴ Pointe de flèche non-pleine soulignée pointant vers la
gauche, c.-à-d.&noeos; triangle avec une ligne au-dessous
(binaire). Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>. Pour le symbole normal de sous-groupe
chargez <file>amssymb</file> et utilisez <code>\vartrianglelefteq</code> (qui est
une relation et ainsi donne un meilleur espacement).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="936">\unrhd</indexterm>\unrhd</itemformat></item>
</tableterm><tableitem><para>⊵ Pointe de flèche non-pleine soulignée pointant vers la
droite, c.-à-d.&noeos; triangle avec une ligne au-dessous
(binaire). Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>. Pour le symbole normal de sous-groupe
chargez <file>amssymb</file> et utilisez <code>\vartrianglerighteq</code> (qui est
une relation et ainsi donne un meilleur espacement).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="937">\Uparrow</indexterm>\Uparrow</itemformat></item>
</tableterm><tableitem><para>⇑ Flèche vers le haut à ligne double
(relation). Similaire : flèche vers le haut à ligne
simple <code>\uparrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="938">\uparrow</indexterm>\uparrow</itemformat></item>
</tableterm><tableitem><para>↑ Single-line upward-pointing flèche, diverges (relation). Similaire :
double-line up-pointing flèche <code>\Uparrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="939">\Updownarrow</indexterm>\Updownarrow</itemformat></item>
</tableterm><tableitem><para>⇕ Double-line upward-and-downward-pointing flèche (relation). Similaire :
single-line upward-and-downward-pointing flèche <code>\updownarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="940">\updownarrow</indexterm>\updownarrow</itemformat></item>
</tableterm><tableitem><para>↕ flèche haut et bas à ligne simple (relation). Similaire :
flèche haut et bas à ligne double <code>\Updownarrow</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="941">\upharpoonright</indexterm>\upharpoonright</itemformat></item>
</tableterm><tableitem><para>↾ Harpon vers le haut avec crochet à droite
(relation). Synonyme : <code>&backslashchar;restriction</code>.
Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="942">\uplus</indexterm>\uplus</itemformat></item>
</tableterm><tableitem><para>⊎ Union de multiensemble, un symbole union avec un symbole
plus en son sein (binaire). Similaire : union <code>\cup</code>. En relation
avec : opérateur de taille variable <code>\biguplus</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="943">\Upsilon</indexterm>\Upsilon</itemformat></item>
</tableterm><tableitem><para>Υ Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="944">\upsilon</indexterm>\upsilon</itemformat></item>
</tableterm><tableitem><para>υ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="945">\varepsilon</indexterm>\varepsilon</itemformat></item>
</tableterm><tableitem><para>ε Epsilon de ronde en bas de casse (ordinaire).  Plus
largement utilise en mathématique que la forme non variante epsilon
lunaire <code>\epsilon</code> ϵ. En relation avec :
« appartient à » <code>\in</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="946">\vanothing</indexterm>\vanothing</itemformat></item>
</tableterm><tableitem><para>∅ Symbole ensemble vide. Similaire :
<code>\emptyset</code>. En relation avec :
<code>\revemptyset</code>. Ceci n&textrsquo;est pas disponible en &tex; de base. En &latex; vous devez charger le paquetage <file>amssymb</file>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="947">\varphi</indexterm>\varphi</itemformat></item>
</tableterm><tableitem><para>φ Variante de la lettre grecque bas de casse (ordinaire).
La forme non en variante est <code>\phi</code> ϕ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="948">\varpi</indexterm>\varpi</itemformat></item>
</tableterm><tableitem><para>ϖ Variante de la lettre grecque bas de casse (ordinaire).
La forme non en variante est <code>\pi</code> π.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="949">\varrho</indexterm>\varrho</itemformat></item>
</tableterm><tableitem><para>ϱ Variante de la lettre grecque bas de casse (ordinaire).
La forme non en variante est <code>\rho</code> ρ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="950">\varsigma</indexterm>\varsigma</itemformat></item>
</tableterm><tableitem><para>ς Variante de la lettre grecque bas de casse
(ordinaire).  La forme non en variante est <code>\sigma</code> σ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="951">\vartheta</indexterm>\vartheta</itemformat></item>
</tableterm><tableitem><para>ϑ Variante de la lettre grecque bas de casse
(ordinaire).  La forme non en variante est <code>\theta</code> θ.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="952">\vdash ⊢ Taquet droit ; prouve, implique ;</indexterm>\vdash ⊢ Taquet droit ; prouve, implique ;</itemformat></item>
</tableterm><tableitem><para>portillon/tourniquet ; barre verticale et un tiret
(relation). Similaire : portillon inversé <code>\dashv</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="953">\vee</indexterm>\vee</itemformat></item>
</tableterm><tableitem><para>∨ Ou logique ; une forme de v pointant vers le bas
(binaire). En relation avec : Et logique <code>\wedge</code>. Similaire :
Opérateur de taille variable <code>\bigvee</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="954">\Vert</indexterm>\Vert</itemformat></item>
</tableterm><tableitem><para>‖ Double barre verticale (ordinaire). Similaire : barre
verticale simple <code>\vert</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="955"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="956"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>mathtools</code> vous permet de créer des commandes pour
des délimiteurs appairés.  Par ex., si vous mettez
<code>\DeclarePairedDelimiter\norm&lbrace;\lVert&rbrace;&lbrace;\rVert&rbrace;</code> dans votre 
préambule, ceci vous donne trois variantes de commande pour faire des
barres verticales correctement espacées horizontalement : si dans le
corps du document vous écrivez la version étoilée
<code>$\norm*&lbrace;M^\perp&rbrace;$</code> alors la hauteur des barres verticales
correspond à celle de l&textrsquo;argument, alors qu&textrsquo;avec <code>\norm&lbrace;M^\perp&rbrace;</code>
les barres ne grandissent pas avec la hauteur de l&textrsquo;argument mais à la
place reste de la hauteur par défaut, et
<code>\norm[<var>commande-taille</var>]&lbrace;M^\perp&rbrace;</code> donne aussi des barres
qui ne grandissent pas mais sont de la taille donnée dans la
<var>commande-taille</var>, par ex.&noeos; <code>\Bigg</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="957">\vert</indexterm>\vert</itemformat></item>
</tableterm><tableitem><para>| Barre verticale simple (ordinaire). Similaire : barre à
double-ligne verticale <code>\Vert</code>. Pour usage tel qu&textrsquo;au sein de la
définition d&textrsquo;un ensemble, utilisez <code>\mid</code> parce que c&textrsquo;est une
relation.
</para>
<!-- c xx TODO revoir la trad. -->
<para>Pour une valeur absolue vous pouvez utiliser le paquetage
<code>mathtools</code> et ajouter
<code>\DeclarePairedDelimiter\abs&lbrace;\lvert&rbrace;&lbrace;\rvert&rbrace;</code> à votre
préambule. Ceci vous donne trois variantes de commande pour les barres
simples verticales qui sont correctement espacées verticalement : si
dans le corps du document vous écrivez la version étoilée
<code>$\abs*&lbrace;\frac&lbrace;22&rbrace;&lbrace;7&rbrace;&rbrace;$</code> alors la hauteur des barres
verticales correspond à la hauteur de l&textrsquo;argument, alors qu&textrsquo;avec
<code>\abs&lbrace;\frac&lbrace;22&rbrace;&lbrace;7&rbrace;&rbrace;</code> les barres ne grandissent pas avec
l&textrsquo;argument mais à la place sont de la hauteur par défaut, et
<code>\abs[<var>commande-taille</var>]&lbrace;\frac&lbrace;22&rbrace;&lbrace;7&rbrace;&rbrace;</code> donne aussi des
barres qui ne grandissent pas mais qui sont réglées à la taille donnée
par la <var>commande-taille</var>, par ex.&noeos; <code>\Bigg</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="958">\wedge</indexterm>\wedge</itemformat></item>
</tableterm><tableitem><para>∧ Et logique (binaire).  Synonyme : <code>\land</code>.  Voir aussi
ou logique <code>\vee</code>. Similaire : opérateur de taille variable <code>\bigwedge</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="959">\wp</indexterm>\wp</itemformat></item>
</tableterm><tableitem><para>℘ « p » de Weierstrass, fonction elliptique de
Weierstrass (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="960">\wr</indexterm>\wr</itemformat></item>
</tableterm><tableitem><para>≀ Produit couronne (binaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="961">\Xi</indexterm>\Xi</itemformat></item>
</tableterm><tableitem><para>Ξ Lettre grecque en capitale (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="962">\xi</indexterm>\xi</itemformat></item>
</tableterm><tableitem><para>ξ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="963">\zeta</indexterm>\zeta</itemformat></item>
</tableterm><tableitem><para>ζ Lettre grecque en bas de casse  (ordinaire).
</para>
</tableitem></tableentry></ftable>

<para>Les symboles suivants sont utilisés le plus souvent en texte simple mais
&latex; fourni des versions pour être utilisés dans du texte
mathématique.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="964">\mathdollar</indexterm>\mathdollar</itemformat></item>
</tableterm><tableitem><para>Signe dollar en mode mathématique : $.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="965">\mathparagraph</indexterm>\mathparagraph</itemformat></item>
</tableterm><tableitem><para>Signe paragraphe (pied-de-mouche) en mode mathématique : ¶.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="966">\mathsection</indexterm>\mathsection</itemformat></item>
</tableterm><tableitem><para>Signe section en mode mathématique :  §.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="967">\mathsterling</indexterm>\mathsterling</itemformat></item>
</tableterm><tableitem><para>Signe livre sterling mode mathématique : &pound;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="968">\mathunderscore</indexterm>\mathunderscore</itemformat></item>
</tableterm><tableitem><para>Signe « souligné » en mode mathématique : _.
</para>
</tableitem></tableentry></ftable>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::                     ">Arrows</menunode><menudescription><pre xml:space="preserve">Liste de flèches.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">\boldmath &amp; \unboldmath</menunode><menudescription><pre xml:space="preserve">Symboles en caractères gras.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">Blackboard bold</menunode><menudescription><pre xml:space="preserve">Caractères évidés.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::               ">Calligraphic</menunode><menudescription><pre xml:space="preserve">Caractères scripts.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                 ">Delimiters</menunode><menudescription><pre xml:space="preserve">Parenthèses, accolades, etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                       ">Dots</menunode><menudescription><pre xml:space="preserve">Points de suspension, etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::              ">Greek letters</menunode><menudescription><pre xml:space="preserve">Liste des lettres grecques.
</pre></menudescription></menuentry></menu>


<node name="Arrows" spaces=" "><nodename>Arrows</nodename><nodenext automatic="on">\boldmath &amp; \unboldmath</nodenext><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle>Flèches</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="480">flèches</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="481">symboles, flèches</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="969">math, flèches</indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="970"><r>paquetage</r> <code>amsfonts</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="971"><code>amsfonts</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="972"><r>paquetage</r> <code>latexsym</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="973"><code>latexsym</code>, <r>paquetage</r></indexterm></findex>

<para>Voici les flèches disponibles en standard avec &latex;.  Les paquetages
<code>latexsym</code> et <code>amsfonts</code> en contiennent beaucoup plus.
</para>
<multitable spaces="  " endspaces=" "><columnfractions line=".10 .40 .50"><columnfraction value=".10"></columnfraction><columnfraction value=".40"></columnfraction><columnfraction value=".50"></columnfraction></columnfractions>
<thead><row><entry command="headitem" spaces=" "><para>Symbole</para></entry><entry command="tab" spaces=" "><para>Commande</para></entry><entry command="tab">   
</entry></row></thead><tbody><row><entry command="item">
<para>⇓ </para></entry><entry command="tab" spaces=" "><para><code>\Downarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">
<para>↓ </para></entry><entry command="tab" spaces=" "><para><code>\downarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">      
<para>↩ </para></entry><entry command="tab" spaces=" "><para><code>\hookleftarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">  
<para>↪ </para></entry><entry command="tab" spaces=" "><para><code>\hookrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">    
<para>← </para></entry><entry command="tab" spaces=" "><para><code>\leftarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">      
<para>⇐ </para></entry><entry command="tab" spaces=" "><para><code>\Leftarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">      
<para>⇔ </para></entry><entry command="tab" spaces=" "><para><code>\Leftrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item"> 
<para>↔ </para></entry><entry command="tab" spaces=" "><para><code>\leftrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item"> 
<para>⟵ </para></entry><entry command="tab" spaces=" "><para><code>\longleftarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>⟸ </para></entry><entry command="tab" spaces=" "><para><code>\Longleftarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>⟷ </para></entry><entry command="tab" spaces=" "><para><code>\longleftrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">
<para>⟺ </para></entry><entry command="tab" spaces=" "><para><code>\Longleftrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">
<para>⟼ </para></entry><entry command="tab" spaces=" "><para><code>\longmapsto</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">        
<para>⟹ </para></entry><entry command="tab" spaces=" "><para><code>\Longrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">    
<para>⟶ </para></entry><entry command="tab" spaces=" "><para><code>\longrightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">    
<para>↦ </para></entry><entry command="tab" spaces=" "><para><code>\mapsto</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">            
<para>↗ </para></entry><entry command="tab" spaces=" "><para><code>\nearrow</code> </para></entry><entry command="tab"> 
</entry></row><row><entry command="item">    
<para>↖ </para></entry><entry command="tab" spaces=" "><para><code>\nwarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>⇒ </para></entry><entry command="tab" spaces=" "><para><code>\Rightarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">  
<para>→ </para></entry><entry command="tab" spaces=" "><para><code>\rightarrow</code>, or <code>\to</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">  
<para>↘ </para></entry><entry command="tab" spaces=" "><para><code>\searrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>↙ </para></entry><entry command="tab" spaces=" "><para><code>\swarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>↑ </para></entry><entry command="tab" spaces=" "><para><code>\uparrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>⇑ </para></entry><entry command="tab" spaces=" "><para><code>\Uparrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item">     
<para>↕ </para></entry><entry command="tab" spaces=" "><para><code>\updownarrow</code> </para></entry><entry command="tab">
</entry></row><row><entry command="item"> 
<para>⇕ </para></entry><entry command="tab" spaces=" "><para><code>\Updownarrow</code> </para></entry><entry command="tab">
</entry></row></tbody></multitable>

<para>Un exemple de la différence entre <code>\to</code> et <code>\mapsto</code> est :
<code>\( f\colon D\to C \) given by \( n\mapsto n^2 \)</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="974"><r>paquetage</r> <code>amscd</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="975"><code>amscd</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="976"><r>paquetage</r> <code>tikz-cd</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="977"><code>tikz-cd</code>, <r>paquetage</r></indexterm></findex>

<para>Pour faire des diagrammes cumulatifs il y a de nombreux paquetages, parmi lesquels
<code>tikz-cd</code> et <code>amscd</code>.
</para>

</subsection>
<node name="_005cboldmath-_0026-_005cunboldmath" spaces=" "><nodename>\boldmath &amp; \unboldmath</nodename><nodenext automatic="on">Blackboard bold</nodenext><nodeprev automatic="on">Arrows</nodeprev><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\boldmath</code> &amp; <code>\unboldmath</code></sectiontitle>

<anchor name="_005cboldmath">\boldmath</anchor>
<anchor name="_005cunboldmath">\unboldmath</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="978">\boldmath</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="979">\unboldmath</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="482">gras, caractères, en mathématiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="483">symboles, en caractères gras</indexterm></cindex>

<para>Synopsis (utilisés en mode paragraphe ou mode LR) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\boldmath \( <var>math</var> \)
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\unboldmath \( <var>math</var> \)
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="980">\boldmath</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="981">\unboldmath</indexterm></findex>
<para>Ce sont des déclarations pour mettre en caractères gras les lettres et
symboles dans <var>math</var>, ou pour contredire cela et revenir à la
graisse normale (non-gras) utilisée par défaut. Elles ne doivent être
utilisées ni en mode math, ni en mode math hors texte
(<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>). Les deux commandes sont fragiles (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Voici un exemple dans lequel chaque commande <code>\boldmath</code> a lieu au
sein d&textrsquo;une <code>\mbox</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">on a $\mbox&lbrace;\boldmath \( v \)&rbrace; = 5\cdot\mbox&lbrace;\boldmath \( u \)$&rbrace;$
</pre></example>

<noindent></noindent>
<para>ce qui signifie que <code>\boldmath</code> est seulement utilisé dans un mode
texte, en l&textrsquo;occurrence le mode LR, et explique pourquoi &latex; doit
basculer en mode math pour composer <code>v</code> et <code>u</code>.
</para>
<para>Si vous utilisez l&textrsquo;une ou l&textrsquo;autre des ces commande en mode math, comme
dans <code>Échec : \( \boldmath x \)</code>, alors vous obtenez quelque chose du
genre de <samp>LaTeX Font Warning: Command \boldmath invalid in math
mode on input line 11</samp> et <samp>LaTeX Font Warning: Command \mathversion
invalid in math mode on input line 11</samp>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="982"><r>paquetage</r> <code>bm</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="983"><code>bm</code>, <r>paquetage</r></indexterm></findex>

<para>La commande <code>\boldmath</code> est problématique par bien des aspects. Les
nouveaux documents devraient utiliser le paquetage <code>bm</code> fourni
par l&textrsquo;équipe du projet &latex;.  Une description complète est hors du
champ d&textrsquo;application de ce manuel (voir la documentation complète sur le
CTAN) mais même le petit exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;bm&rbrace;   % dans le préambule
...
on a $\bm&lbrace;v&rbrace; = 5\cdot\bm&lbrace;u&rbrace;$
</pre></example>

<noindent></noindent>
<para>illustre déjà que c&textrsquo;est une amélioration par rapport à <code>\boldmath</code>.
</para>

</subsection>
<node name="Blackboard-bold" spaces=" "><nodename>Blackboard bold</nodename><nodenext automatic="on">Calligraphic</nodenext><nodeprev automatic="on">\boldmath &amp; \unboldmath</nodeprev><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle>Pseudo-gras avec des lettres évidées</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="484">évidées, lettres</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="485">évidées, lettres grasses</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;amssymb&rbrace;   % dans le préambule
  ... 
\mathbb&lbrace;<var>lettre-capitale</var>&rbrace;
</pre></example>

<para>Fournit les lettres mathématiques évidées utilisées traditionnellement
pour noter les noms d&textrsquo;ensembles, comme les entiers naturels, relatifs,
etc.
<!-- c { Dans la version française seulement -->
Le nom <code>\mathbb</code> vient de « <b>b</b>lackboard <b>b</b>old <b>math</b> »
qu&textrsquo;on pourrait traduire par <dfn>caractères mathématiques gras
scolaires</dfn>.
<!-- c } -->
</para>
<para>Dans l&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\( \forall n \in \mathbb&lbrace;N&rbrace;, n^2 \geq 0 \)
</pre></example>

<noindent></noindent>
<para>le <code>\mathbb&lbrace;N&rbrace;</code> donne le symbole gras scolaire
ℕ, représentant les entiers naturels.
</para>
<para>Si vous utilisez autre chose qu&textrsquo;une lettre capitale alors aucune erreur
n&textrsquo;est produite, mais vous obtiendrez des résultats étranges, y compris
des caractères inattendus.
</para>
<para>Il y a des paquetages donnant accès à des symboles autres que les lettres
capitales ; voir sur le CTAN.
</para>

</subsection>
<node name="Calligraphic" spaces=" "><nodename>Calligraphic</nodename><nodenext automatic="on">Delimiters</nodenext><nodeprev automatic="on">Blackboard bold</nodeprev><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle>Math Calligraphic</sectiontitle>

<!-- c French version only: -->
<!-- c Discuté avec J-C. Carpentier sur fctt https://groups.google.com/g/fr.comp.text.tex/c/ZeRGngp0XkA/m/rRuNhtAZDQAJ -->
<!-- c - « scripte » au lieu de « simili-scripte » (« script-like » en anglais) -->
<!-- c - N'utilise pas le terme « cursive » -->
<!-- c - Introduit le terme « Math Calligraphic » pour désigner la fonte -->
<cindex index="cp" spaces=" "><indexterm index="cp" number="486">calligraphique, fontes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="487">scriptes, fontes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="488">fontes scriptes mathématiques</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\mathcal&lbrace;<var>lettres-capitales</var>&rbrace;
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="489">Math Calligraphic</indexterm></cindex>
<para>Utilise une fonte scripte, <dfn>Math Calligraphic</dfn>.
</para>
<para>Dans l&textrsquo;exemple suivant l&textrsquo;identificateur du graphe est produit en sortie
avec la fonte Math Calligraphic :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Soit un graphe \( \mathcal&lbrace;G&rbrace; \).
</pre></example>

<para>Si vous utilisez autre chose que des lettres capitales alors vous
n&textrsquo;aurez pas une erreur mais vous n&textrsquo;aurez pas non plus une sortie en
calligraphique math. Par exemple, <code>\mathcal&lbrace;g&rbrace;</code> produit en sortie
une accolade fermante.
</para>

</subsection>
<node name="Delimiters" spaces=" "><nodename>Delimiters</nodename><nodenext automatic="on">Dots</nodenext><nodeprev automatic="on">Calligraphic</nodeprev><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle>Délimiteurs</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="490">délimiteurs</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="491">parenthèses</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="492">crochets</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="493">accolades</indexterm></cindex>

<para>Les délimiteurs sont les parenthèses, accolades, crochets, ou autres
caractères utilisés pour marquer le début et la fin d&textrsquo;une
sous-formule. Dans l&textrsquo;exemple suivant la formule a trois ensembles de
parenthèses délimitant les trois sous-formules :
</para>
<example endspaces=" ">
<pre xml:space="preserve">(z-z_0)^2 = (x-x_0)^2 + (y-y_0)^2
</pre></example>

<noindent></noindent>
<para>Il n&textrsquo;est pas nécessaire que les délimiteurs se correspondent, ainsi vous
pouvez saisir <code>\( [0,1) \)</code>.
</para>
<para>Voici les délimiteurs usuels :
</para>
<multitable spaces="  " endspaces=" "><columnfractions line=".14 .26 .49 .12"><columnfraction value=".14"></columnfraction><columnfraction value=".26"></columnfraction><columnfraction value=".49"></columnfraction><columnfraction value=".12"></columnfraction></columnfractions>
<thead><row><entry command="headitem" spaces=" "><para>Délimiteur</para></entry><entry command="tab" spaces=" "><para>Commande</para></entry><entry command="tab" spaces=" "><para>Nom
</para></entry></row></thead><tbody><row><entry command="item">
<para>( </para></entry><entry command="tab" spaces=" "><para><code>(</code> </para></entry><entry command="tab" spaces=" "><para>Parenthèse gauche
</para></entry></row><row><entry command="item">
<para>) </para></entry><entry command="tab" spaces=" "><para><code>)</code> </para></entry><entry command="tab" spaces=" "><para>Parenthèse droite
</para></entry></row><row><entry command="item">
<para>\&rbrace; </para></entry><entry command="tab" spaces=" "><para><code>&lbrace;</code> ou <code>\lbrace</code> </para></entry><entry command="tab" spaces=" "><para>Accolade gauche
</para></entry></row><row><entry command="item">
<para>\&lbrace; </para></entry><entry command="tab" spaces=" "><para><code>&rbrace;</code> ou <code>\rbrace</code> </para></entry><entry command="tab" spaces=" "><para>Accolade droite
</para></entry></row><row><entry command="item">
<para>[ </para></entry><entry command="tab" spaces=" "><para><code>[</code> ou <code>\lbrack</code> </para></entry><entry command="tab" spaces=" "><para>Crochet gauche
</para></entry></row><row><entry command="item">
<para>] </para></entry><entry command="tab" spaces=" "><para><code>]</code> ou <code>\rbrack</code> </para></entry><entry command="tab" spaces=" "><para>Crochet droit
</para></entry></row><row><entry command="item">
<para>⌊ </para></entry><entry command="tab" spaces=" "><para><code>\lfloor</code> </para></entry><entry command="tab" spaces=" "><para>Crochet gauche de partie
entière
</para></entry></row><row><entry command="item">
<para>⌋ </para></entry><entry command="tab" spaces=" "><para><code>\rfloor</code> </para></entry><entry command="tab" spaces=" "><para>Crochet droit de partie entière
</para></entry></row><row><entry command="item">
<para>⌈ </para></entry><entry command="tab" spaces=" "><para><code>\lceil</code> </para></entry><entry command="tab" spaces=" "><para>Crochet gauche d&textrsquo;arrondi supérieur
</para></entry></row><row><entry command="item">
<para>⌉ </para></entry><entry command="tab" spaces=" "><para><code>\rceil</code> </para></entry><entry command="tab" spaces=" "><para>Crochet droit d&textrsquo;arrondi supérieur
</para></entry></row><row><entry command="item">
<para>⟨ </para></entry><entry command="tab" spaces=" "><para><code>\langle</code> </para></entry><entry command="tab" spaces=" "><para>Chevron gauche
</para></entry></row><row><entry command="item">
<para>⟩ </para></entry><entry command="tab" spaces=" "><para><code>\rangle</code> </para></entry><entry command="tab" spaces=" "><para>Chevron droit
</para></entry></row><row><entry command="item">
<para>/  </para></entry><entry command="tab" spaces=" "><para><code>/</code> </para></entry><entry command="tab" spaces=" "><para>Oblique, ou oblique vers l&textrsquo;avant
</para></entry></row><row><entry command="item">
<para>\ </para></entry><entry command="tab" spaces=" "><para><code>\backslash</code> </para></entry><entry command="tab" spaces=" "><para>Controblique, ou oblique vers l&textrsquo;arrière
</para></entry></row><row><entry command="item">
<para>| </para></entry><entry command="tab" spaces=" "><para><code>|</code> ou <code>\vert</code> </para></entry><entry command="tab" spaces=" "><para>Barre verticale
</para></entry></row><row><entry command="item">
<para>‖ </para></entry><entry command="tab" spaces=" "><para><code>\|</code> ou <code>\Vert</code> </para></entry><entry command="tab" spaces=" "><para>Barre verticale double
</para></entry></row></tbody></multitable>

<findex index="fn" spaces=" "><indexterm index="fn" number="984"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="985"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>mathtools</code> vous permet de créer des commandes pour
des délimiteurs appairés. Par ex., si vous mettez
<code>\DeclarePairedDelimiter\abs&lbrace;\lvert&rbrace;&lbrace;\rvert&rbrace;</code> dans votre
préambule alors cela vous donne deux commandes pour les barres simples
verticales (qui ne fonctionnent qu&textrsquo;en mode math). La forme étoilée,
comme dans <code>\abs*&lbrace;\frac&lbrace;22&rbrace;&lbrace;7&rbrace;&rbrace;</code>, a la hauteur des barres
verticales accordée à la hauteur de l&textrsquo;argument. La forme non-étoilée,
comme dans <code>\abs&lbrace;\frac&lbrace;22&rbrace;&lbrace;7&rbrace;&rbrace;</code>, a les barres fixées à la
hauteur par défaut. Cette forme accepte un argument optionnel, comme
dans <code>\abs[<var>commande-taille</var>]&lbrace;\frac&lbrace;22&rbrace;&lbrace;7&rbrace;&rbrace;</code>, où la
taille des barres est donnée par la <var>commande-taille</var>, par ex.&noeos;
<code>\Bigg</code>. En utilisant plutôt <code>\lVert</code> et <code>\rVert</code> pour
les symboles, vous obtenez une notation de norme avec le même
comportement.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::      ">\left &amp; \right</menunode><menudescription><pre xml:space="preserve">Délimiteurs de taille réglée automatiquement.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::  ">\bigl &amp; \bigr etc.</menunode><menudescription><pre xml:space="preserve">Délimiteurs de taille réglée manuellement.
</pre></menudescription></menuentry></menu>


<node name="_005cleft-_0026-_005cright" spaces=" "><nodename>\left &amp; \right</nodename><nodenext automatic="on">\bigl &amp; \bigr etc.</nodenext><nodeup automatic="on">Delimiters</nodeup></node>
<subsubsection spaces=" "><sectiontitle><code>\left</code> &amp; <code>\right</code></sectiontitle>

<anchor name="_005cleft">\left</anchor>
<anchor name="_005cright">\right</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="986">\left</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="987">\right</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="494">délimiteurs appairés</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="495">appairés, délimiteurs</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="496">correspondantes, parenthèses</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="497">correspondants, crochets</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="498">délimiteur nul</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="499">nul, délimiteur</indexterm></cindex>

<!-- c Credit: SE userPhilipp https://tex.stackexchange.com/a/12793 -->

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\left <var>délimiteur1</var> ... \right <var>délimiteur2</var>
</pre></example>

<para>Fabrique des parenthèses, crochets, ou autres délimiteurs qui se
correspondent.  &latex; fabrique les délimiteurs juste assez hauts pour
couvrir la taille de la formule qu&textrsquo;ils embrassent.
</para>
<para>L&textrsquo;exemple suivant fabrique un vecteur unitaire entouré par des
parenthèses assez hautes pour couvrir les composantes :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \left(\begin&lbrace;array&rbrace;&lbrace;c&rbrace;
    1   \\
    0   \\
  \end&lbrace;array&rbrace;\right)
\end&lbrace;equation&rbrace;
</pre></example>

<para><xref label="Delimiters"><xrefnodename>Delimiters</xrefnodename></xref>, pour une liste des délimiteurs usuels.
</para>
<para>Chaque <code>\left</code> doit avoir un <code>\right</code> qui lui correspond.
Dans l&textrsquo;exemple plus haut, si on ne met pas le <code>\left(</code> alors on a
le message d&textrsquo;erreur <samp>Extra \right</samp>.  Si c&textrsquo;est le <code>\right)</code>
qu&textrsquo;on ne met pas, alors on obtient <samp>You can't use `\eqno' in math
mode</samp>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="988"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="989"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="990"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="991"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>

<para>Toutefois, il n&textrsquo;est pas nécessaire que <var>délimiteur1</var> et
<var>délimiteur2</var> se correspondent.  Un cas usuel est que vous désiriez
une accolade d&textrsquo;un seul côté, comme ci-dessous. Utilisez un point,
<samp>.</samp>, comme <dfn>délimiteur nul</dfn> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  f(n)=\left\&lbrace;\begin&lbrace;array&rbrace;&lbrace;ll&rbrace;
                1             &amp;\mbox&lbrace;si \(n=0\)&rbrace; \\
                f(n-1)+3n^2   &amp;\mbox&lbrace;sinon&rbrace;       
       \end&lbrace;array&rbrace;\right.
\end&lbrace;equation&rbrace;
</pre></example>

<noindent></noindent>
<para>Notez que pour obtenir une accolade comme délimiteur vous devez la
préfixer d&textrsquo;une controblique, <code>\&lbrace;</code> (<pxref label="Reserved-characters"><xrefnodename>Reserved characters</xrefnodename></pxref>).
(Les paquetages <code>amsmath</code> et <code>mathtools</code> vous permettent
d&textrsquo;obtenir la construction ci-dessus avec un environnement
<code>cases</code>).
</para>
<para>La paire <code>\left ... \right</code> fabrique un groupe. Une conséquence de
cela est que la formule embrassée par la paire <code>\left ... \right</code>
ne peut pas avoir de saut de ligne dans la sortie.  Ceci inclut à la
fois les sauts de lignes manuels, et ceux générés automatiquement par
&latex;.  Dans l&textrsquo;exemple suivant, &latex; insère un saut de ligne pour
que la formule tienne entre les marges :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Lorem ipsum dolor sit amet
\( (a+b+c+d+e+f+g+h+i+j+k+l+m+n+o+p+q+r+s+t+u+v+w+x+y+z) \)
</pre></example>

<noindent></noindent>
<para>Mais avec <code>\left</code> et <code>\right</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Lorem ipsum dolor sit amet
\( \left(a+b+c+d+e+f+g+h+i+j+k+l+m+n+o+p+q+r+s+t+u+v+w+x+y+z\right) \)
</pre></example>

<noindent></noindent>
<para>&latex; n&textrsquo;insère pas de saut, ce qui a pour effet que la formule
s&textrsquo;étende jusque dans la marge.
</para>
<para>Parce que <code>\left ... \right</code> fait un groupe, toutes les règles
habituelles concernant les groupes s&textrsquo;appliquent. Ci-dessous, la valeur de
<code>\testlength</code> réglée au sein de l&textrsquo;équation sera oubliée, en et
sortie on a <samp>1.2pt</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newlength&lbrace;\testlength&rbrace; \setlength&lbrace;\testlength&rbrace;&lbrace;1.2pt&rbrace;
\begin&lbrace;equation&rbrace;
  \left( a+b=c \setlength&lbrace;\testlength&rbrace;&lbrace;3.4pt&rbrace; \right)
  \the\testlength
\end&lbrace;equation&rbrace;
</pre></example>

<para>La paire <code>\left ... \right</code> affecte l&textrsquo;espacement horizontal de la
formule embrassée de deux manières. La première est que dans <code>\(
\sin(x) = \sin\left(x\right) \)</code> le membre de droite a plus d&textrsquo;espace
autour du <code>x</code>.  C&textrsquo;est parce que <code>\left( ... \right)</code> insère un
nœud interne alors que <code>( ... )</code> insère un nœud ouvrant.  La
seconde manière dont l&textrsquo;espacement horizontal est affecté est que parce
que la paire forme un groupe, la sous-formule embrassée sera composée à
sa longueur naturelle, sans dilatation ni contraction pour que la ligne
s&textrsquo;ajuste mieux.
</para>
<para>&tex; dilate les délimiteurs selon la hauteur et profondeur de la
formule embrassée.  Ci-dessous &latex; fait grandir les crochets pour
qu&textrsquo;ils s&textrsquo;étendent sur toute la hauteur de l&textrsquo;intégrale :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \left[ \int_&lbrace;x=r_0&rbrace;^&lbrace;\infty&rbrace; -G\frac&lbrace;Mm&rbrace;&lbrace;r^2&rbrace;\, dr \right] 
\end&lbrace;equation&rbrace;
</pre></example>

<para>Régler la taille manuellement donne souvent un meilleur résultat. Par
exemple, bien que le filet ci-dessous ait une profondeur nulle, &tex;
crée des délimiteurs qui s&textrsquo;étendent sous le filet :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \left( \rule&lbrace;1pt&rbrace;&lbrace;1cm&rbrace; \right)
\end&lbrace;equation&rbrace;
</pre></example>

<noindent></noindent>
<para>&tex; peut choisir des délimiteurs qui sont trop petits, comme dans
<code>\( \left| |x|+|y| \right| \)</code>.  Il peut aussi en choisir de trop
grand, comme ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \left( \sum_&lbrace;0\leq i&lt;n&rbrace; i^k \right)
\end&lbrace;equation&rbrace;
</pre></example>

<noindent></noindent>
<para>Un troisième cas malheureux c&textrsquo;est quand on a une formule hors texte
longue tenant sur plus d&textrsquo;une ligne et que vous devez accorder les
tailles du délimiteur ouvrant et fermant ; vous ne pouvez pas utiliser
<code>\left</code> sur la première ligne et <code>\right</code> sur la dernière
parce qu&textrsquo;ils doivent se correspondre.
</para>
<para>Pour régler manuellement la taille des délimiteurs, voir <ref label="_005cbigl-_0026-_005cbigr-etc_002e"><xrefnodename>\bigl &amp;
\bigr etc.</xrefnodename></ref>.
</para>

</subsubsection>
<node name="_005cbigl-_0026-_005cbigr-etc_002e" spaces=" "><nodename>\bigl &amp; \bigr etc.</nodename><nodeprev automatic="on">\left &amp; \right</nodeprev><nodeup automatic="on">Delimiters</nodeup></node>
<subsubsection spaces=" "><sectiontitle><code>\bigl</code>, <code>\bigr</code>, etc.</sectiontitle>

<anchor name="_005cbigl">\bigl</anchor>
<anchor name="_005cbigr">\bigr</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="992">\bigl</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="993">\bigr</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bigl<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur1</var> ... \bigr<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur2</var>
\Bigl<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur1</var> ... \bigr<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur2</var>
\biggl<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur1</var> ... \biggr<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur2</var>
\Biggl<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur1</var> ... \Biggr<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur2</var>  
</pre></example>

<noindent></noindent>
<para>(comme dans <code>\bigl[...\bigr]</code> ; strictement parlant il n&textrsquo;est pas
nécessaire qu&textrsquo;ils soient appairés, voir ci-dessous), ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bigm<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
\Bigm<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
\biggm<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
\Biggm<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
</pre></example>

<noindent></noindent>
<para>(comme avec <code>\bigm|</code>), ou l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\big<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
\Big<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
\bigg<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
\Bigg<inlinefmt><inlinefmtformat>info</inlinefmtformat></inlinefmt><var>délimiteur</var>
</pre></example>

<noindent></noindent>
<para>(comme avec <code>\big[</code>).
</para>
<para>Produit des délimiteurs de taille réglée manuellement.  Pour des
délimiteurs de taille réglée automatiquement voir <ref label="_005cleft-_0026-_005cright"><xrefnodename>\left &amp; \right</xrefnodename></ref>).
</para>
<para>L&textrsquo;exemple ci-dessous produit des barres verticales externes légèrement
plus grandes :
</para>
<example endspaces=" ">
<pre xml:space="preserve">  \bigl| |x|+|y| \bigr|
</pre></example>

<para>Les commandes ci-dessus sont dans l&textrsquo;ordre des tailles croissantes.  Vous
pouvez utiliser la taille la plus petite comme <code>\bigl...\bigr</code> dans
un paragraphe sans que cela ait pour effet que &latex; écarte les
lignes. Les tailles plus grandes sont destinées aux équations hors
texte.
</para>
<para><xref label="Delimiters"><xrefnodename>Delimiters</xrefnodename></xref>, pour une liste des délimiteurs usuels.  Dans la
famille des commandes en <samp>l</samp> ou <samp>r</samp>, il n&textrsquo;est pas nécessaire
que <var>délimiteur1</var> et <var>délimiteur2</var> se correspondent.
</para>
<para>Les commandes en <samp>l</samp> ou <samp>r</samp> produisent délimiteurs ouvrant et
fermant qui n&textrsquo;insèrent aucun espace horizontal entre un atome précédent
et le délimiteur, alors que les commandes sans <samp>l</samp> ou <samp>r</samp>
insèrent un peut d&textrsquo;espace (parce que chaque délimiteur est réglé comme
une variable ordinaire).  Comparez les deux lignes dans l&textrsquo;exemple
ci-dessous :
</para>
<!-- c credit: Martin Heller https://tex.stackexchange.com/a/1234  -->
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;l&rbrace;
  \(\displaystyle \sin\biggl(\frac&lbrace;1&rbrace;&lbrace;2&rbrace;\biggr) \)  \\  % bon
  \(\displaystyle \sin\bigg(\frac&lbrace;1&rbrace;&lbrace;2&rbrace;\bigg)  \)   \\  % mauvais
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>La gestion typographique traditionnelle est sur la première ligne. Sur
la seconde ligne la sortie a de l&textrsquo;espace supplémentaire entre le
<code>\sin</code> et la parenthèse ouvrante.
</para>
<para>Les commandes sans <samp>l</samp> ou <samp>r</samp> donnent cependant l&textrsquo;espacement
correct dans certaines circonstances, comme avec la grande ligne
verticale dans l&textrsquo;exemple ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \int_&lbrace;x=a&rbrace;^b x^2\,dx = \frac&lbrace;1&rbrace;&lbrace;3&rbrace; x^3 \Big|_&lbrace;x=a&rbrace;^b
\end&lbrace;equation&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="994"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="995"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<noindent></noindent>
<para>(beaucoup d&textrsquo;auteurs préfèrent remplacer <code>\frac</code> par la commande
<code>\tfrac</code> du paquetage <code>amsmath</code>), et comme avec cette
grande oblique :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \lim_&lbrace;n\to\infty&rbrace;\pi(n) \big/ (n/\log n) = 1
\end&lbrace;equation&rbrace;
</pre></example>

<para>Contrairement à la paire <code>\left...\right</code> (<pxref label="_005cleft-_0026-_005cright"><xrefnodename>\left &amp; \right</xrefnodename></pxref>),
les commandes décrites ici et en <samp>l</samp> ou <samp>r</samp> ne forment pas
un groupe. Strictement parlant il n&textrsquo;est pas nécessaire qu&textrsquo;elles soient
appairées, et donc vous pourriez écrire quelque chose du ce genre :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \Biggl[ \pi/6 ] 
\end&lbrace;equation&rbrace;
</pre></example>

<para>Les commandes en <samp>m</samp> sont pour les relations, les choses qui sont
au milieu d&textrsquo;une formule, comme ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \biggl\&lbrace; a\in B \biggm| a=\sum_&lbrace;0\leq i&lt;n&rbrace;3i^2+4 \biggr\&rbrace;
\end&lbrace;equation&rbrace;  
</pre></example>

<!-- c xx Add discussion \bigg\mid not being good -->
<!-- c and \bigg| being right; maybe mention of \middle and braket package? -->


</subsubsection>
</subsection>
<node name="Dots" spaces=" "><nodename>Dots</nodename><nodenext automatic="on">Greek letters</nodenext><nodeprev automatic="on">Delimiters</nodeprev><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle>Points de suspensions, horizontaux ou verticaux</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="500">points de suspension</indexterm></cindex>

<para>Les points de suspension sont les trois points (habituellement trois)
indiquant qu&textrsquo;un motif se prolonge.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;array&rbrace;&lbrace;cccc&rbrace;
  a_&lbrace;0,0&rbrace;    &amp;a_&lbrace;0,1&rbrace;   &amp;a_&lbrace;0,2&rbrace; &amp;\ldots \\
  a_&lbrace;1,0&rbrace;    &amp;\ddots                     \\
  \vdots
\end&lbrace;array&rbrace;
</pre></example>

<para>&latex; fournit ces types de points de suspension :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="ellipses-cdots">ellipses cdots</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="996">\cdots</indexterm>\cdots</itemformat></item>
</tableterm><tableitem>

<para>Des points de suspension horizontaux élevés au centre de la ligne, comme
dans ⋯.  Utilisés comme dans : <code>\( a_0\cdot a_1\cdots
a_&lbrace;n-1&rbrace; \)</code>.
</para>
<anchor name="ellipses-ddots">ellipses ddots</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="997">\ddots</indexterm>\ddots</itemformat></item>
</tableterm><tableitem><para>Des points de suspension en diagonale, ⋱.  Voir l&textrsquo;exemple
plus haut d&textrsquo;un tableau <code>array</code> pour une utilisation.
</para>
<anchor name="ellipses-ldots">ellipses ldots</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="998">\ldots</indexterm>\ldots</itemformat></item>
</tableterm><tableitem><para>Points de suspension sur la ligne de base, ….  Utilisés
comme dans : <code>\( x_0,\ldots x_&lbrace;n-1&rbrace; \)</code>.  Un autre exemple est le
tableau <code>array</code> donné plus haut. Un synonyme est
<code>\mathellipsis</code>.  Un synonyme du paquetage <code>amsmath</code> est
<code>\hdots</code>.
</para>
<para>Vous pouvez également utiliser cette commande au-dehors du mode math,
comme dans <code>La boîte de vitesse, les freins, \ldots&lbrace;&rbrace; tout est
cassé</code>.  (En mode paragraphe ou en mode LR un synonyme de <code>\ldots</code>
est <code>\dots</code>).
</para>
<anchor name="ellipses-vdots">ellipses vdots</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="999">\vdots</indexterm>\vdots</itemformat></item>
</tableterm><tableitem><para>Points de suspension alignés verticalement, ⋮.  Voir
l&textrsquo;exemple plus haut avec un <code>array</code> pour une utilisation possible.
</para>
</tableitem></tableentry></ftable>

<findex index="fn" spaces=" "><indexterm index="fn" number="1000"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1001"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>amsmath</code> a la commande <code>\dots</code> pour baliser
sémantiquement les points de suspension. L&textrsquo;exemple suivant produit deux
sorties d&textrsquo;aspects distincts pour les deux premiers usages de la commande
<code>\dots</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;amsmath&rbrace;  % dans le préambule
  ...
Supposons que \( p_0, p_1, \dots, p_&lbrace;n-1&rbrace; \) soit la liste de tous les nombres premiers.
On remarque que \( p_0\cdot p_1 \dots \cdot p_&lbrace;n-1&rbrace; +1 \) n'est pas un
multiple de l'un quelconque des \( p_i \).
Conclusion : il y a un nombre infini de nombres premiers \( p_0, p_1, \dotsc \).
</pre></example>

<noindent></noindent>
<para>Dans la première ligne &latex; regarde la virgule suivant <code>\dots</code>
pour déterminer qu&textrsquo;il devrait produire en sortie des points de
suspension sur la ligne de base. La seconde ligne a un <code>\cdot</code> qui
suit <code>\dots</code> alors &latex; produit des points de suspension sur
l&textrsquo;axe mathématique, verticalement centrés.  Toutefois, le troisième
usage n&textrsquo;a aucun caractère de suivi, aussi vous devez indiquer à &latex;
que faire.  Vous pouvez utiliser l&textrsquo;une des commandes : <code>\dotsc</code> si
vous avez besoin de points de suspension
 appropriés pour suivre une
virgule, <code>\dotsb</code> si vous avez des points de suspension qui
conviennent quand il y a ensuite un opérateur ou un symbole de relation,
<code>\dotsi</code> pour les points de suspension utilisés avec des
intégrales, ou <code>\dotso</code> pour les autres cas.
</para>

</subsection>
<node name="Greek-letters" spaces=" "><nodename>Greek letters</nodename><nodeprev automatic="on">Dots</nodeprev><nodeup automatic="on">Math symbols</nodeup></node>
<subsection spaces=" "><sectiontitle>Lettres grecques</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="501">grecques, lettres</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="502">lettres grecques</indexterm></cindex>


<para>On ne donne les versions en capitale de ces lettres grecques que lorsque
elle sont distinctes des lettres romaines capitales.
</para>
<multitable spaces="  " endspaces=" "><columnfractions line=".10 .30 .15 .45"><columnfraction value=".10"></columnfraction><columnfraction value=".30"></columnfraction><columnfraction value=".15"></columnfraction><columnfraction value=".45"></columnfraction></columnfractions>
<thead><row><entry command="headitem" spaces=" "><para>Symbole</para></entry><entry command="tab" spaces=" "><para>Commande</para></entry><entry command="tab" spaces=" "><para>Nom</para></entry><entry command="tab">  
</entry></row></thead><tbody><row><entry command="item">
<para>α</para></entry><entry command="tab" spaces=" "><para><code>\alpha</code></para></entry><entry command="tab" spaces=" "><para>Alpha
</para></entry></row><row><entry command="item">
<para>β</para></entry><entry command="tab" spaces="  "><para><code>\beta</code></para></entry><entry command="tab" spaces=" "><para>Bêta
</para></entry></row><row><entry command="item">
<para>γ, Γ</para></entry><entry command="tab" spaces=" "><para><code>\gamma</code>, <code>\Gamma</code></para></entry><entry command="tab" spaces=" "><para>Gamma
</para></entry></row><row><entry command="item">
<para>δ, Δ</para></entry><entry command="tab" spaces=" "><para><code>\delta</code>, <code>\Delta</code></para></entry><entry command="tab" spaces=" "><para>Delta
</para></entry></row><row><entry command="item">
<para>ε, ϵ</para></entry><entry command="tab">
  <para><code>\varepsilon</code>, <code>\epsilon</code></para></entry><entry command="tab" spaces=" "><para>Epsilon
</para></entry></row><row><entry command="item">
<para>ζ</para></entry><entry command="tab" spaces=" "><para><code>\zeta</code></para></entry><entry command="tab" spaces=" "><para>Zêta
</para></entry></row><row><entry command="item">
<para>η</para></entry><entry command="tab" spaces=" "><para><code>\eta</code></para></entry><entry command="tab" spaces=" "><para>Êta
</para></entry></row><row><entry command="item">
<para>θ, ϑ</para></entry><entry command="tab" spaces=" "><para><code>\theta</code>, <code>\vartheta</code></para></entry><entry command="tab">
  <para>Thêta
</para></entry></row><row><entry command="item">
<para>ι</para></entry><entry command="tab" spaces=" "><para><code>\iota</code></para></entry><entry command="tab" spaces=" "><para>Iota
</para></entry></row><row><entry command="item">
<para>κ</para></entry><entry command="tab" spaces=" "><para><code>\kappa</code></para></entry><entry command="tab" spaces=" "><para>Kappa
</para></entry></row><row><entry command="item">
<para>λ, Λ</para></entry><entry command="tab" spaces=" "><para><code>\lambda</code>, <code>\Lambda</code></para></entry><entry command="tab">
  <para>Lambda
</para></entry></row><row><entry command="item">
<para>μ</para></entry><entry command="tab" spaces=" "><para><code>\mu</code></para></entry><entry command="tab" spaces=" "><para>Mu
</para></entry></row><row><entry command="item">
<para>ν</para></entry><entry command="tab" spaces=" "><para><code>\nu</code></para></entry><entry command="tab" spaces=" "><para>Nu
</para></entry></row><row><entry command="item">
<para>ξ, Ξ</para></entry><entry command="tab" spaces=" "><para><code>\xi</code>, <code>\Xi</code></para></entry><entry command="tab" spaces=" "><para>Xi
</para></entry></row><row><entry command="item">
<para>π, Π</para></entry><entry command="tab" spaces=" "><para><code>\pi</code>, <code>\Pi</code></para></entry><entry command="tab" spaces=" "><para>Pi
</para></entry></row><row><entry command="item">
<para>ρ, ϱ</para></entry><entry command="tab" spaces=" "><para><code>\rho</code>, <code>\varrho</code></para></entry><entry command="tab" spaces=" "><para>Rhô
</para></entry></row><row><entry command="item">
<para>σ, Σ</para></entry><entry command="tab" spaces=" "><para><code>\sigma</code>, <code>\Sigma</code></para></entry><entry command="tab" spaces=" "><para>Sigma
</para></entry></row><row><entry command="item">
<para>τ</para></entry><entry command="tab" spaces=" "><para><code>\tau</code></para></entry><entry command="tab" spaces=" "><para>Tau
</para></entry></row><row><entry command="item">
<para>ϕ, φ, Φ</para></entry><entry command="tab">
  <para><code>\phi</code>, <code>\varphi</code>, <code>\Phi</code></para></entry><entry command="tab" spaces=" "><para>Phi
</para></entry></row><row><entry command="item">
<para>χ</para></entry><entry command="tab" spaces=" "><para><code>\chi</code></para></entry><entry command="tab" spaces=" "><para>chi
</para></entry></row><row><entry command="item">
<para>ψ, Ψ</para></entry><entry command="tab" spaces=" "><para><code>\psi</code>, <code>\Psi</code></para></entry><entry command="tab" spaces=" "><para>Psi
</para></entry></row><row><entry command="item">
<para>ω, Ω</para></entry><entry command="tab" spaces=" "><para><code>\omega</code>, <code>\Omega</code></para></entry><entry command="tab" spaces=" "><para>Oméga
</para></entry></row></tbody></multitable>

<findex index="fn" spaces=" "><indexterm index="fn" number="1002"><r>paquetage</r> <code>unicode-math</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1003"><code>unicode-math</code>, <r>paquetage</r></indexterm></findex>

<para>Pour omicron, si vous utiliser la fonte par défaut de &latex; Computer
Modern alors saisissez omicron juste comme <samp>o</samp> ou <samp>O</samp>.  Si
vous désirez avoir le nom ou si votre fonte affiche une différence alors
vous pouvez utiliser quelque chose du genre de
<code>\newcommand\omicron&lbrace;o&rbrace;</code>.  Le paquetage <code>unicode-math</code>
comprend <code>\upomicron</code> pour un omicron droit et <code>\mitomicron</code>
pour l&textrsquo;italique mathématique.
</para>
<para>Alors que le symbole de relation d&textrsquo;appartenance à un ensemble
∈ généré par <code>\in</code> est similaire à epsilon, il n&textrsquo;est
jamais utilisé pour une variable.
</para>

</subsection>
</section>
<node name="Math-functions" spaces=" "><nodename>Math functions</nodename><nodenext automatic="on">Math accents</nodenext><nodeprev automatic="on">Math symbols</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Fonctions mathématiques</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="503">fonctions mathématiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="504">math, fonctions</indexterm></cindex>

<para>En mode mathématique ces commandes produisent des noms de fonction en
police romaine et avec l&textrsquo;espacement adéquat.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1004">\arccos</indexterm>\arccos</itemformat></item>
</tableterm><tableitem><para>Arccosinus, cosinus inverse
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1005">\arcsin</indexterm>\arcsin</itemformat></item>
</tableterm><tableitem><para>Arcsinus, sinus inverse
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1006">\arctan</indexterm>\arctan</itemformat></item>
</tableterm><tableitem><para>Arctangente, tangente inverse
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1007">\arg</indexterm>\arg</itemformat></item>
</tableterm><tableitem><para>Angle entre l&textrsquo;axe des réels et un point dans le plan complexe
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1008">\bmod</indexterm>\bmod</itemformat></item>
</tableterm><tableitem><para>Opérateur modulo binaire, utilisé comme dans <code>\( 5\bmod 3=2 \)</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1009">\cos</indexterm>\cos</itemformat></item>
</tableterm><tableitem><para>Cosinus
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1010">\cosh</indexterm>\cosh</itemformat></item>
</tableterm><tableitem><para>Cosinus hyperbolique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1011">\cot</indexterm>\cot</itemformat></item>
</tableterm><tableitem><para>Cotangente
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1012">\coth</indexterm>\coth</itemformat></item>
</tableterm><tableitem><para>Cotangente hyperbolique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1013">\csc</indexterm>\csc</itemformat></item>
</tableterm><tableitem><para>Cosécante
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1014">\deg</indexterm>\deg</itemformat></item>
</tableterm><tableitem><para>Degrés
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1015">\det</indexterm>\det</itemformat></item>
</tableterm><tableitem><para>Déterminant
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1016">\dim</indexterm>\dim</itemformat></item>
</tableterm><tableitem><para>Dimension
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1017">\exp</indexterm>\exp</itemformat></item>
</tableterm><tableitem><para>Exponentielle
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1018">\gcd</indexterm>\gcd</itemformat></item>
</tableterm><tableitem><para>Plus grand commun diviseur
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1019">\hom</indexterm>\hom</itemformat></item>
</tableterm><tableitem><para>Homomorphisme
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1020">\inf</indexterm>\inf</itemformat></item>
</tableterm><tableitem><para>Infimum
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1021">\ker</indexterm>\ker</itemformat></item>
</tableterm><tableitem><para>Noyau
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1022">\lg</indexterm>\lg</itemformat></item>
</tableterm><tableitem><para>Logarithme en base 2
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1023">\lim</indexterm>\lim</itemformat></item>
</tableterm><tableitem><para>Limite
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1024">\liminf</indexterm>\liminf</itemformat></item>
</tableterm><tableitem><para>Limite inférieure
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1025">\limsup</indexterm>\limsup</itemformat></item>
</tableterm><tableitem><para>Limite supérieure
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1026">\ln</indexterm>\ln</itemformat></item>
</tableterm><tableitem><para>Logarithme népérien
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1027">\log</indexterm>\log</itemformat></item>
</tableterm><tableitem><para>Logarithme
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1028">\max</indexterm>\max</itemformat></item>
</tableterm><tableitem><para>Maximum
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1029">\min</indexterm>\min</itemformat></item>
</tableterm><tableitem><para>Minimum
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1030">\pmod</indexterm>\pmod</itemformat></item>
</tableterm><tableitem><para>Modulo parenthésé, comme dans <code>\( 5\equiv 2\pmod 3 \)</code>
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1031">\Pr</indexterm>\Pr</itemformat></item>
</tableterm><tableitem><para>Probabilité
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1032">\sec</indexterm>\sec</itemformat></item>
</tableterm><tableitem><para>Sécante
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1033">\sin</indexterm>\sin</itemformat></item>
</tableterm><tableitem><para>Sinus
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1034">\sinh</indexterm>\sinh</itemformat></item>
</tableterm><tableitem><para>Sinus hyperbolique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1035">\sup</indexterm>\sup</itemformat></item>
</tableterm><tableitem><para>Supremum
sup
<!-- c don't try to use \sup with dvi/pdf output since that turned into a -->
<!-- c Texinfo command and it's not worth hassling with different versions -->
<!-- c when it's just three roman letters anyway. -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1036">\tan</indexterm>\tan</itemformat></item>
</tableterm><tableitem><para>Tangente
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1037">\tanh</indexterm>\tanh</itemformat></item>
</tableterm><tableitem><para>Tangente hyperbolique
</para>
</tableitem></tableentry></ftable>

<findex index="fn" spaces=" "><indexterm index="fn" number="1038"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1039"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>amsmath</code> ajoute des amélioration à certaines de
ces commandes, et vous permet aussi de définir les vôtres propres. La
documentation complète est sur le CTAN, mais en un mot, vous pouvez
définir une opérateur identité avec
<code>\DeclareMathOperator&lbrace;\identity&rbrace;&lbrace;id&rbrace;</code> qui est comme ceux donnés
plus haut mais s&textrsquo;imprime en <samp>id</samp>.  La forme étoilée
<code>\DeclareMathOperator*&lbrace;\op&rbrace;&lbrace;op&rbrace;</code> règle tout indice supérieur ou
inférieur pour être au-dessus et au-dessous, comme c&textrsquo;est la tradition
pour <code>\lim</code>, <code>\sup</code>, ou <code>\max</code>.
</para>
</section>
<node name="Math-accents" spaces=" "><nodename>Math accents</nodename><nodenext automatic="on">Over- and Underlining</nodenext><nodeprev automatic="on">Math functions</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Accents mathématiques</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="505">Accents mathématiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="506">math, accents</indexterm></cindex>

<para>&latex; fournit diverse commandes pour produire des lettres accentuées en
math. Elles diffèrent de celles concernant les accents en texte normal
(<pxref label="Accents"><xrefnodename>Accents</xrefnodename></pxref>).
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1040">\acute</indexterm>\acute</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="507">accent aigu en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="508">math, accent aigu</indexterm></cindex>
<para>Accent aigu mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1041">\bar</indexterm>\bar</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="509">accent barre suscrite en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="510">accent macron en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="511">math, accent barre suscrite</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="512">math, accent macron</indexterm></cindex>
<para>Accent barre suscrite mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1042">\breve</indexterm>\breve</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="513">accent brève en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="514">math, accent brève</indexterm></cindex>
<para>Accent brève mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1043">\check</indexterm>\check</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="515">accent caron en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="516">accent h<accent type="acute" bracketed="off">a</accent><accent type="caron">c</accent>ek en math</indexterm></cindex>
<para>Accent h<accent type="acute" bracketed="off">a</accent><accent type="caron">c</accent>ek (caron) mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1044">\ddot</indexterm>\ddot</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="517">accent tréma en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="518">accent diérèse en math</indexterm></cindex>
<para>Accent diérèse (tréma) mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1045">\dot</indexterm>\dot</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="519">accent point suscrit en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="520">math, accent point suscrit</indexterm></cindex>
<para>Accent point suscrit mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1046">\grave</indexterm>\grave</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="521">accent grave en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="522">math, accent grave</indexterm></cindex>
<para>Accent grave mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1047">\hat</indexterm>\hat</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="523">accent chapeau en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="524">accent circonflexe en math</indexterm></cindex>
<para>Accent chapeau (circonflexe) mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1048">\mathring</indexterm>\mathring</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="525">accent rond-en-chef en math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="526">math, accent rond-en-chef</indexterm></cindex>
<para>Accent rond-en-chef mathématique <!-- c don't bother implementing in texinfo -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1049">\tilde</indexterm>\tilde</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="527">accent tilde en math</indexterm></cindex>
<para>Accent tilde mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1050">\vec</indexterm>\vec</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="528">symbole vecteur en math</indexterm></cindex>
<para>Symbole vecteur mathématique
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1051">\widehat</indexterm>\widehat</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="529">chapeau large, accent, math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="530">accent mathématique, chapeau large</indexterm></cindex>
<para>Accent chapeau large mathématique
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1052">\widetilde</indexterm>\widetilde</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="531">tilde large, accent, math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="532">accent mathématique, tilde large</indexterm></cindex>
<para>Accent tilde mathématique
</para>
</tableitem></tableentry></ftable>

<para>Quand on place un accent sur un i ou un j, la tradition est d&textrsquo;en
utiliser un sans point, <code>\imath</code> ou <code>jmath</code> (<pxref label="Math-symbols"><xrefnodename>Math
symbols</xrefnodename></pxref>).
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::                 ">\accent</menunode><menudescription><pre xml:space="preserve">Commande de bas niveau pour produire un caractère accentué.
</pre></menudescription></menuentry></menu>


<node name="_005caccent" spaces=" "><nodename>\accent</nodename><nodeup automatic="on">Math accents</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\accent</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1053">\accent</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\accent <var>numéro</var> <var>caractère</var>
</pre></example>

<para>Une commande primitive &tex; utilisée pour générer des caractères
accentués à partir de diacritiques et de lettres. Le diacritique est
sélectionné par <var>numéro</var>, un argument numérique, suivi par un
espace, et ensuite un argument <var>caractère</var> pour construire le
caractère accentué dans la fonte courante.
</para>
<para>Voici les caractères <samp>e</samp> accentués.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\accent18 e
\accent20 e
\accent21 e
\accent22 e
\accent23 e
</pre></example>

<noindent></noindent>
<para>Le premier a un accent grave, le second a un caron, le troisième une
brève, le quatrième un macron, et le dernier un rond-en-chef. Ce qui
donne è ě ĕ ē e̊<!-- c. -->
</para>
<para>La position de l&textrsquo;accent est déterminée par la fonte au moment de sa
conception et ainsi le résultat de <code>\accent</code> peut différer d&textrsquo;une
fonte à l&textrsquo;autre. Dans &latex; il est préférable d&textrsquo;avoir des glyphes
pour les caractères accentués plutôt que de les construire en utilisant
<code>\accent</code>. Utiliser des glyphes qui contiennent déjà les caractères
accentués (comme dans le codage T1) permet d&textrsquo;obtenir une césure correcte
alors que <code>\accent</code> désactive la césure (spécifiquement avec le
codage de fonte OT1 dans lequel il n&textrsquo;y a pas de glyphe avec accent).
</para>
<para>Optionnellement il peut y avoir un changement de fonte entre
<var>numéro</var> et <var>caractère</var>.  Notez aussi que cette commande règle
le paramètre <code>\spacefactor</code> à 1000 (<pxref label="_005cspacefactor"><xrefnodename>\spacefactor</xrefnodename></pxref>).
</para>
<para>Une caractéristique inévitable de certaines lettres cyrilliques et de la
majorité des lettres cyrilliques accentuées est qu&textrsquo;on doit les assembler
à partir de multiples éléments (accents, modificateurs, etc.) alors même
que <code>\accent</code> ne fournit qu&textrsquo;une combinaison entre une seul
diacritique et une seule lettre. Il y a aussi des cas où les accents
doivent apparaître entre des lettres que \accent ne prend pas en charge.
Il y a d&textrsquo;autres cas encore comme les lettres I et J dont les points au
dessus de leurs homologues en bas-de-casse entrent en conflit avec les
diacritiques suscrits. L&textrsquo;utilisation de la commande <code>\accent</code> dans
ces cas ne fonctionnera pas du fait qu&textrsquo;elle ne peut pas distinguer
entre capitales et bas-de-casse.
</para>
</subsection>
</section>
<node name="Over_002d-and-Underlining" spaces=" "><nodename>Over- and Underlining</nodename><nodenext automatic="on">Spacing in math mode</nodenext><nodeprev automatic="on">Math accents</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Sur- et sous-ligner</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="533">sur-ligner</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="534">souligner</indexterm></cindex>

<para>&latex; fournit des commandes pour sur-ligner ou souligner, ou pour
placer des accolades au-dessous ou au-dessous d&textrsquo;une matière.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1054">\underline&lbrace;<var>texte</var>&rbrace;</indexterm>\underline&lbrace;<var>texte</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>A pour effet que <var>texte</var>, ce qui peut être ou non en mode
mathématique, soit souligné.
La ligne est toujours sous le texte, en prenant en compte les jambages,
ainsi dans <code>\(\underline&lbrace;y&rbrace;\)</code> la ligne est plus bas que dans
<code>\(\underline&lbrace;x&rbrace;\)</code>.  Cette commande est fragile
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1055"><r>paquetage</r> <code>ulem</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1056"><code>ulem</code>, <r>paquetage</r></indexterm></findex>

<para>Notez que le paquetage <code>ulem</code> fait du soulignement en mode texte
et permet les sauts de ligne ainsi que plusieurs autres fonctionnalités.
Voir sa documentation sur le CTAN.  Voir aussi <ref label="_005chrulefill-_0026-_005cdotfill"><xrefnodename>\hrulefill &amp;
\dotfill</xrefnodename></ref> pour produire une ligne, pour des choses comme une signature.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1057">\overline&lbrace;<var>texte</var>&rbrace;</indexterm>\overline&lbrace;<var>texte</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Met une ligne horizontale au dessus de <var>texte</var>. Fonctionne en mode
mathématiques, et en dehors.  Par exemple, <code>\overline&lbrace;x+y&rbrace;</code>.
Notez que cette commande diffère de <code>\bar</code> (<pxref label="Math-accents"><xrefnodename>Math accents</xrefnodename></pxref>).
</para>
<!-- c xx TODO mentionner le paquetage abraces -->
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1058">\underbrace&lbrace;<var>math</var>&rbrace;</indexterm>\underbrace&lbrace;<var>math</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Met une accolade au-dessous de <var>math</var>. Par exemple, le code
<code>(1-\underbrace&lbrace;1/2)+(1/2&rbrace;-1/3)</code> met en vedette la partie qui
s&textrsquo;annule.
Attachez du texte à l&textrsquo;accolade en utilisant la commande indice
inférieur, <code>_</code>, ou indice supérieur, <code>^</code>, comme ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
  1+1/2+\underbrace&lbrace;1/3+1/4&rbrace;_&lbrace;&gt;1/2&rbrace;+
       \underbrace&lbrace;1/5+1/6+1/7+1/8&rbrace;_&lbrace;&gt;1/2&rbrace;+\cdots
\end&lbrace;displaymath&rbrace;
</pre></example>

<para>L&textrsquo;indice supérieur apparaît au-dessus de l&textrsquo;expression, aussi il peut
sembler sans relation avec l&textrsquo;accolade du dessous.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1059">\overbrace&lbrace;<var>math</var>&rbrace;</indexterm>\overbrace&lbrace;<var>math</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Met une accolade au-dessus de <var>math</var>.
Par exemple, <code>\overbrace&lbrace;x+x+\cdots +x&rbrace;^&lbrace;\mbox&lbrace;\(k\) fois&rbrace;&rbrace;</code>.
Voir aussi <code>\underbrace</code>.
</para>
</tableitem></tableentry></ftable>

<findex index="fn" spaces=" "><indexterm index="fn" number="1060"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1061"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>mathtools</code> ajoute une accolade par dessus ou par
dessous, ainsi que des améliorations sur les accolades. Voir la
documentation sur le CTAN.
</para>

</section>
<node name="Spacing-in-math-mode" spaces=" "><nodename>Spacing in math mode</nodename><nodenext automatic="on">Math styles</nodenext><nodeprev automatic="on">Over- and Underlining</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Espacement en mode mathématique</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="535">espacement au sein du mode mathématique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="536">mode mathématique, espacement</indexterm></cindex>

<para>Quand il compose des mathématiques, &latex; insère l&textrsquo;espacement selon
les règles normales pour les textes mathématiques. Si vous entrez
<code>y=m x</code> alors &latex; ignore l&textrsquo;espace et dans la sortie le m est
juste à côté du x, comme dans <math>y=mx</math>.
</para>
<para>Mais les règles de &latex; ont occasionnellement besoin de petits ajustements. Par exemple, dans l&textrsquo;intégrale la tradition est de mettre une petite espace supplémentaire entre le <code>f(x)</code> et le <code>dx</code>, obtenue ci-dessous avec la commande <code>\,</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\int_0^1 f(x)\,dx
</pre></example>

<para>&latex; fournit les commandes qui suivent utilisables en mode
mathématique. Beaucoup de ces définitions d&textrsquo;espacement sont exprimées
dans l&textrsquo;unité mathématique <dfn>mu</dfn> donnée par 1 em = 18 mu, où le em est
pris de la famille courante des symboles mathématiques (<pxref label="Units-of-length"><xrefnodename>Units of
length</xrefnodename></pxref>). Ainsi, un <code>\thickspace</code> est typiquement de 5/18 fois la
largeur d&textrsquo;un <samp>M</samp>.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">\;</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="537">thickspace</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1062">\;</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1063">\thickspace</indexterm></findex>
<anchor name="spacing-in-math-mode-thickspace">spacing in math mode thickspace</anchor>
<para>Synonyme : <code>\thickspace</code>. Normalement <code>5.0mu plus 5.0mu</code>.
Avec le paquetage <code>amsmath</code>, ou depuis la parution 2020-10-01 de &latex;, utilisable aussi bien en mode texte qu&textrsquo;en mode mathématique ; sinon, utilisable seulement en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\negthickspace</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1064">\negthickspace</indexterm></findex>
<para>Normalement <code>-5.0mu plus 2.0mu minus 4.0mu</code>.
Avec le paquetage <code>amsmath</code>, ou depuis la parution 2020-10-01 de &latex;, utilisable aussi bien en mode texte qu&textrsquo;en mode mathématique ; sinon, utilisable seulement en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\:</itemformat></item>
<itemx spaces=" "><itemformat command="code">\&gt;</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1065">\:</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1066">\&gt;</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1067">\medspace</indexterm></findex>
<anchor name="spacing-in-math-mode-medspace">spacing in math mode medspace</anchor>

<para>Synonyme : <code>\medspace</code>. Normalement <code>4.0mu plus 2.0mu minus
4.0mu</code>.  Avec le paquetage <code>amsmath</code>, ou depuis la parution 2020-10-01 de &latex;, utilisable aussi bien en mode texte qu&textrsquo;en mode mathématique ; sinon, utilisable seulement en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\negmedspace</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1068">\negmedspace</indexterm></findex>
<para>Normalement <code>-4.0mu plus 2.0mu minus 4.0mu</code>.
Avec le paquetage <code>amsmath</code>, ou depuis la parution 2020-10-01 de &latex;, utilisable aussi bien en mode texte qu&textrsquo;en mode mathématique ; sinon, utilisable seulement en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\,</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="538">espace fine</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="539">fine, espace</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1069">\,</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1070">\thinspace</indexterm></findex>
<anchor name="Spacing-in-math-mode_002f_005cthinspace">Spacing in math mode/\thinspace</anchor>
<anchor name="spacing-in-math-mode-thinspace">spacing in math mode thinspace</anchor>
<para>Synonyme : <code>\thinspace</code>. Espace fine, normalement <code>3mu</code>, c.-à-d.&noeos; 1/6<dmn>mu</dmn>.  Utilisable à
la fois en mode mathématique et en mode texte (<pxref label="_005cthinspace-_0026-_005cnegthinspace"><xrefnodename>\thinspace &amp; \negthinspace</xrefnodename></pxref>).
</para>
<para>Cette espace est très utilisée, par exemple entre la fonction et la
variation infinitésimale dans une intégrale <code>\int f(x)\,dx</code> et, si
un auteur fait cela, avant la ponctuation dans une équation affichée :
</para>
<example endspaces=" ">
<pre xml:space="preserve">La primitive est
\begin&lbrace;equation&rbrace;
  3x^&lbrace;-1/2&rbrace;+3^&lbrace;1/2&rbrace;\,.
\end&lbrace;equation&rbrace;
</pre></example>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\!</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1071">\!</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1072">\negthinspace</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="540">espace fine négative</indexterm></cindex>
<anchor name="spacing-in-math-mode-negthinspace">spacing in math mode negthinspace</anchor>
<para>Une espace fine négative. Normalement <code>-3mu</code>.  Avec le paquetage
<code>amsmath</code>, ou depuis la parution 2020-10-01 de &latex;, utilisable
aussi bien en mode texte qu&textrsquo;en mode mathématique ; sinon, la commande
<code>\!</code> est utilisable seulement en mode mathématique mais la commande
<code>\negthinspace</code> a toujours également fonctionné en mode texte
(<pxref label="_005cthinspace-_0026-_005cnegthinspace"><xrefnodename>\thinspace &amp; \negthinspace</xrefnodename></pxref>).
</para>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\quad</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="541">quad</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1073">\quad</indexterm></findex>
<anchor name="spacing-in-math-mode-quad">spacing in math mode quad</anchor>
<para>Vaut 18<dmn>mu</dmn>, c.-à-d.&noeos; 1<dmn>em</dmn>. Souvent utilisé pour l&textrsquo;espace
entourant les équations ou expressions, par ex.&noeos; pour l&textrsquo;espace entre deux
équation au sein d&textrsquo;un environnement <code>displaymath</code>. Utilisable à la
fois en mode mathématique et en mode texte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\qquad</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1074">\qquad</indexterm></findex>
<anchor name="spacing-in-math-mode-qquad">spacing in math mode qquad</anchor>
<para>Une longueur de 2 quads, soit 36<dmn>mu</dmn> = 2<dmn>em</dmn>.  Utilisable à la
fois en mode mathématique et en mode texte.
</para></tableitem></tableentry></table>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::                           ">\smash</menunode><menudescription><pre xml:space="preserve">Eliminate height or depth of a subformula.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\phantom &amp; \vphantom &amp; \hphantom</menunode><menudescription><pre xml:space="preserve">Make empty box same size as argument.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                       ">\mathstrut</menunode><menudescription><pre xml:space="preserve">Add some vertical space to a formula.
</pre></menudescription></menuentry></menu>

<node name="_005csmash" spaces=" "><nodename>\smash</nodename><nodenext automatic="on">\phantom &amp; \vphantom &amp; \hphantom</nodenext><nodeup automatic="on">Spacing in math mode</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\smash</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="542">espace vertical, mode mathématique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="543">mode mathématique, espace vertical</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\smash&lbrace;<var>sous-formule</var>&rbrace;
</pre></example>

<para>Compose <var>sous-formule</var> en aplatissant sa boîte comme si sa hauteur
et sa profondeur étaient nulles.
</para>
<para>Dans l&textrsquo;exemple suivant l&textrsquo;exponentielle est si haut que sans la commande
<code>\smash</code> &latex; séparerait sa ligne de la ligne juste au-dessus,
et l&textrsquo;irrégularité de l&textrsquo;espacement des lignes pourrait être visuellement
malheureuse.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Pour calculer la tétration $\smash&lbrace;2^&lbrace;2^&lbrace;2^2&rbrace;&rbrace;&rbrace;$,
évaluer de haut en bas, comme $2^&lbrace;2^4&rbrace;=2^&lbrace;16&rbrace;=65536$.
</pre></example>

<para>(À cause du <code>\smash</code> l&textrsquo;expression imprimée pourrait se superposer à
la ligne du dessus, aussi vous voudrez sans doute attendre la version
finale du document avant de faire de tels ajustements).
</para>
<para>Ce qui suit illustre l&textrsquo;effet de <code>\smash</code> en utilisant <code>\fbox</code>
pour cerner la boîte que &latex; met sur la ligne.  La commande
<code>\barrenoire</code> fait une barre s&textrsquo;étendant de 10 points sous la
ligne de base jusqu&textrsquo;à 20 points au-dessus.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\barrenoire&rbrace;&lbrace;\rule[-10pt]&lbrace;5pt&rbrace;&lbrace;30pt&rbrace;&rbrace;
\fbox&lbrace;\barrenoire&rbrace;
\fbox&lbrace;\smash&lbrace;\barrenoire&rbrace;&rbrace;
</pre></example>

<para>La première boîte que &latex; place fait 20 points de haut et 10 points
de profondeur.  Mais la seconde boîte est traitée par &latex; comme
ayant une hauteur et une profondeur nulles, même si l&textrsquo;encre imprimée sur
la page s&textrsquo;étend toujours bien au-dessus et au-dessous de la ligne.
</para>
<para>La commande <code>\smash</code> apparaît souvent en mathématiques pour ajuster
la taille d&textrsquo;un élément qui entoure une sous-formule. Ci-dessous la
première racine s&textrsquo;étend sous la ligne de base alors que la seconde
repose juste sur la ligne de base.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
\sqrt&lbrace;\sum_&lbrace;0\leq k&lt; n&rbrace; f(k)&rbrace;
\sqrt&lbrace;\vphantom&lbrace;\sum&rbrace;\smash&lbrace;\sum_&lbrace;0\leq k&lt; n&rbrace;&rbrace; f(k)&rbrace;
\end&lbrace;equation&rbrace;
</pre></example>

<para>Notez l&textrsquo;usage de <code>\vphantom</code> pour donner à la commande <code>\sqrt</code>
un argument avec la même hauteur que la <code>\sum</code> (<pxref label="_005cphantom-_0026-_005cvphantom-_0026-_005chphantom"><xrefnodename>\phantom &amp;
\vphantom &amp; \hphantom</xrefnodename></pxref>).
</para>
<para>Alors que le plus souvent on l&textrsquo;utilise en mathématique, la commande
<code>\smash</code> peut apparaître dans d&textrsquo;autres contextes.  Toutefois, elle
n&textrsquo;assure pas le passage en horizontal. Ainsi si elle débute un
paragraphe il est préférable de mettre en premier un <code>\leavevmode</code>,
comme dans la dernière ligne de l&textrsquo;exemple ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">xxx xxx xxx

\smash&lbrace;yyy&rbrace;  % sans renfoncement de paragraphe

\leavevmode\smash&lbrace;zzz&rbrace;  % renfoncement normal de paragraphe
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1075"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1076"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>mathtools</code> a des opérateurs qui fournissent un contrôle
encore plus fin de l&textrsquo;aplatissement d&textrsquo;une boîte de sous-formule.
</para>
</subsection>
<node name="_005cphantom-_0026-_005cvphantom-_0026-_005chphantom" spaces=" "><nodename>\phantom &amp; \vphantom &amp; \hphantom</nodename><nodenext automatic="on">\mathstrut</nodenext><nodeprev automatic="on">\smash</nodeprev><nodeup automatic="on">Spacing in math mode</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\phantom</code> &amp; <code>\vphantom</code> &amp; <code>\hphantom</code></sectiontitle>

<anchor name="_005cphantom">\phantom</anchor>
<anchor name="_005cvphantom">\vphantom</anchor>
<anchor name="_005chphantom">\hphantom</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1077">\phantom</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1078">\vphantom</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1079">\hphantom</indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="544">espacement, mode mathématique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="545">horizontal, espacement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="546">vertical, espacement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="547">mode mathématique, espacement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="548">invisible, caractère</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="549">caractère invisible</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\phantom&lbrace;<var>sous-formule</var>&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\vphantom&lbrace;<var>sous-formule</var>&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\hphantom&lbrace;<var>sous-formule</var>&rbrace;
</pre></example>

<para>La commande <code>\phantom</code> crée une boîte de la même hauteur,
profondeur et largeur que <var>sous-formule</var>, mais vide.  c.-à-d.&noeos;
qu&textrsquo;avec cette commande &latex; compose l&textrsquo;espace mais ne le remplit pas
avec la matière.  Dans l&textrsquo;exemple ci-dessous &latex; met un espace
blanc de la largeur correcte pour la réponse, mais il n&textrsquo;affiche pas la
réponse.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
  \int x^2\,dx=\mbox&lbrace;\underline&lbrace;$\phantom&lbrace;(1/3)x^3+C&rbrace;$&rbrace;&rbrace; 
\end&lbrace;displaymath&rbrace;
</pre></example>

<para>La variante <code>\vphantom</code> produit une boîte invisible de la même
taille verticale que <var>sous-formule</var>, la même hauteur et profondeur,
mais ayant une largeur nulle.  Et <code>\hphantom</code> fabrique une boîte
avec la même largeur que <var>sous-formule</var> mais de hauteur et
profondeur nulles.
</para>
<para>Dans l&textrsquo;exemple suivant, la tour des exposants dans l&textrsquo;expression second
opérande de la somme est si haute que &tex; place cette expression plus
bas qu&textrsquo;il ne le ferait par défaut.  Sans ajustement, les deux expressions
opérandes de la somme seraient à des niveaux différents.  Le
<code>\vphantom</code> dans la première expression dit à &tex; de laisser
autant de place verticalement qu&textrsquo;il fait pour la tour, de sorte que les
deux expressions ressortent au même niveau.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;displaymath&rbrace;
    \sum_&lbrace;j\in\&lbrace;0,\ldots\, 10\&rbrace;\vphantom&lbrace;3^&lbrace;3^&lbrace;3^j&rbrace;&rbrace;&rbrace;&rbrace;
      \sum_&lbrace;i\in\&lbrace;0,\ldots\, 3^&lbrace;3^&lbrace;3^j&rbrace;&rbrace;\&rbrace;&rbrace; i\cdot j
\end&lbrace;displaymath&rbrace;
</pre></example>

<para>Ces commandes sont souvent utilisées conjointement avec <code>\smash</code>.
<xref label="_005csmash"><xrefnodename>\smash</xrefnodename></xref>, ce qui inclut un autre exemple d&textrsquo;usage de
<code>\vphantom</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1080"><r>paquetage</r> <code>mathtools</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1081"><code>mathtools</code>, <r>paquetage</r></indexterm></findex>


<para>Les trois commandes en <code>phantom</code> apparaissent souvent mais notez que
&latex; fournit nombre d&textrsquo;autres commandes affectant les tailles de
boîtes qui pourraient être plus commodes, notamment <code>\makebox</code>
(<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></pxref>) et également <code>\settodepth</code>
(<pxref label="_005csettodepth"><xrefnodename>\settodepth</xrefnodename></pxref>), <code>\settoheight</code> (<pxref label="_005csettoheight"><xrefnodename>\settoheight</xrefnodename></pxref>), et
<code>\settowidth</code> (<pxref label="_005csettowidth"><xrefnodename>\settowidth</xrefnodename></pxref>).  De plus, le paquetage
<code>mathtools</code> a beaucoup de commandes qui offrent un contrôle fin de
l&textrsquo;espacement.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1082"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1083"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Les trois commandes produisent une boîte ordinaire, sans aucun statut
mathématique spécial. Ainsi pour faire quelque chose comme attacher un
indice supérieur vous avez à donner un tel statut, par exemple avec la
commande <code>\operatorname</code> du paquetage <code>amsmath</code>.
</para>
<para>Alors que la plupart du temps on les utilise en mathématiques, ces
trois commandes peuvent apparaître dans d&textrsquo;autres contextes.  Toutefois,
elles ne provoquent pas le passage de &latex; en mode horizontal. Ainsi
si l&textrsquo;une de ces commandes débute un paragraphe alors vous avez
typiquement à la précéder d&textrsquo;un <code>\leavevmode</code>.
</para>
</subsection>
<node name="_005cmathstrut" spaces=" "><nodename>\mathstrut</nodename><nodeprev automatic="on">\phantom &amp; \vphantom &amp; \hphantom</nodeprev><nodeup automatic="on">Spacing in math mode</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\mathstrut</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1084"><code>\mathstrut</code></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="550">espacement, mode mathématique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="551">vertical, espacement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="552">mode mathématique, espacement</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="553">invisible, caractère</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="554">caractère invisible</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="555">étai mathématique</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\mathstrut
</pre></example>

<para>L&textrsquo;homologue de <code>\strut</code> pour les mathématiques.  <xref label="_005cstrut"><xrefnodename>\strut</xrefnodename></xref>.
</para>
<para>Entrer <code>$\sqrt&lbrace;x&rbrace; + \sqrt&lbrace;x^i&rbrace;$</code> donne en sortie une seconde
racine plus haute que la première.  Pour ajouter de l&textrsquo;espace vertical
supplémentaire sans aucun espace horizontal, de sorte que les deux aient
la même hauteur, utilisez <code>$\sqrt&lbrace;x\mathstrut&rbrace; +
\sqrt&lbrace;x^i\mathstrut&rbrace;$</code>.
</para>
<para>La commande <code>\mathstrut</code> ajoute la hauteur verticale d&textrsquo;une
parenthèse ouvrante, (, mais aucun espace horizontal.  Elle est
définie comme <code>\vphantom&lbrace;(&rbrace;</code> : voir <ref label="_005cphantom-_0026-_005cvphantom-_0026-_005chphantom"><xrefnodename>\phantom &amp; \vphantom &amp;
\hphantom</xrefnodename></ref> pour plus ample information.  Son avantage par rapport à
<code>\strut</code> est que <code>\mathstrut</code> n&textrsquo;ajoute aucune profondeur, ce
qui est le plus souvent ce qui convient pour les formules. Utiliser la
hauteur d&textrsquo;une parenthèse ouvrante est juste une convention ; pour un
contrôle complet de la quantité d&textrsquo;espace, utilisez <code>\rule</code> avec une
largeur.  <xref label="_005crule"><xrefnodename>\rule</xrefnodename></xref>.
</para>
</subsection>
</section>
<node name="Math-styles" spaces=" "><nodename>Math styles</nodename><nodenext automatic="on">Math miscellany</nodenext><nodeprev automatic="on">Spacing in math mode</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Styles mathématiques</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="556">math, styles</indexterm></cindex>

<para>Les règles de &tex; pour composer une formule dépendent du
contexte. Par exemple, au sein d&textrsquo;une équation hors texte, l&textrsquo;entrée
<code>\sum_&lbrace;0\leq i&lt;n&rbrace;k^m=\frac&lbrace;n^&lbrace;m+1&rbrace;&rbrace;&lbrace;m+1&rbrace;+\mbox&lbrace;termes
d'ordre inférieur&rbrace;</code> donnera une sortie où l&textrsquo;indice de sommation sera
centré sous le symbole de sommation. Mais si cette même entrée est en
ligne dans le texte, alors l&textrsquo;indice de sommation est déporté sur la
droite plutôt que au-dessous, de sorte qu&textrsquo;il n&textrsquo;écarte pas les lignes
alentour. De même, dans un contexte en hors texte, les symboles au
numérateur et dénominateur seront plus grands que pour une formule en
ligne dans le texte, et en hors-texte mathématique les indices
supérieurs et inférieurs sont plus écartés que pour une formule
mathématique en ligne dans le texte.
</para>
<para>&tex; utilise quatre styles mathématiques.
</para>
<itemize spaces=" " endspaces=" "><itemprepend>&textndash;</itemprepend>
<beforefirstitem>
<cindex index="cp" spaces=" "><indexterm index="cp" number="557">style affichage</indexterm></cindex>
</beforefirstitem><listitem><prepend>&textndash;</prepend>
<para>Le style affichage est pour une formule en hors texte sur une ligne
séparée, comme avec <code>\begin&lbrace;equation&rbrace; ... \end&lbrace;equation&rbrace;</code>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="558">style texte</indexterm></cindex>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Le style texte est pour une formule en ligne dans le texte, comme avec
<samp>ainsi nous avons $ ... $</samp>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="559">style script</indexterm></cindex>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Le style script style est pour les parties d&textrsquo;une formule dans un indice
inférieur ou supérieur.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="560">style scriptscript</indexterm></cindex>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Le style scriptscript est pour les parties d&textrsquo;une formule à un second
niveau (ou plus) de placement d&textrsquo;indices inférieurs ou supérieurs.
</para>
</listitem></itemize>

<findex index="fn" spaces=" "><indexterm index="fn" number="1085">\displaystyle</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1086">\textstyle</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1087">\scriptstyle</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1088">\scriptscriptstyle</indexterm></findex>
<para>&tex; détermines un style mathématique par défaut mais vous pouvez
l&textrsquo;emporter dessus avec une déclaration de <code>\displaystyle</code>, ou
<code>\textstyle</code>, ou <code>\scriptstyle</code>, ou <code>\scriptscriptstyle</code>.
</para>
<para>Dans l&textrsquo;exemple suivant, la fraction sur la ligne <samp>Arithmetique</samp>
aura l&textrsquo;air recroquevillée.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;r|cc&rbrace;
  \textsc&lbrace;Nom&rbrace;  &amp;\textsc&lbrace;Séries&rbrace;  &amp;\textsc&lbrace;Somme&rbrace;  \\  \hline
  Arithmetique     &amp;$a+(a+b)+(a+2b)+\cdots+(a+(n-1)b)$
                   &amp;$na+(n-1)n\cdot\frac&lbrace;b&rbrace;&lbrace;2&rbrace;$  \\
  Géometrique      &amp;$a+ab+ab^2+\cdots+ab^&lbrace;n-1&rbrace;$
                   &amp;$\displaystyle a\cdot\frac&lbrace;1-b^n&rbrace;&lbrace;1-b&rbrace;$  \\
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>Mais à cause de la déclaration <code>\displaystyle</code>, la fraction de la
ligne <samp>Géometrique</samp> sera facile à lire, avec des caractères de la
même taille que le reste de la ligne.
</para>
<para>Un autre exemple est que, comparé à la même entrée sans la déclaration, le
résultat de :
</para>
<example endspaces=" ">
<pre xml:space="preserve">on obtient
$\pi=2\cdot&lbrace;\displaystyle\int_&lbrace;x=0&rbrace;^1 \sqrt&lbrace;1-x^2&rbrace;\,dx&rbrace;$
</pre></example>

<noindent></noindent>
<para>aura un signe intégrale bien plus haut. Notez que dans cet exemple le
<code>\displaystyle</code> ne s&textrsquo;applique qu&textrsquo;à une partie de la formule, celle
qui est délimitée entre accolades, comme <samp>&lbrace;\displaystyle ...&rbrace;</samp>.
</para>
<para>Le dernier exemple est une fraction continue.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
a_0+\frac&lbrace;1&rbrace;&lbrace;
       \displaystyle a_1+\frac&lbrace;\mathstrut 1&rbrace;&lbrace;
       \displaystyle a_2+\frac&lbrace;\mathstrut 1&rbrace;&lbrace;
       \displaystyle a_3&rbrace;&rbrace;&rbrace;
\end&lbrace;equation&rbrace;
</pre></example>

<noindent></noindent>
<para>Sans la déclaration <code>\displaystyle</code>, les dénominateurs seraient en
style script et scriptscript.  (Le <code>\mathstrut</code> améliore la hauteur
des dénominateurs ; <pxref label="_005cmathstrut"><xrefnodename>\mathstrut</xrefnodename></pxref>).
</para>

</section>
<node name="Math-miscellany" spaces=" "><nodename>Math miscellany</nodename><nodeprev automatic="on">Math styles</nodeprev><nodeup automatic="on">Math formulas</nodeup></node>
<section spaces=" "><sectiontitle>Recueil de diverses commandes utiles  en math</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="561">math, miscellanées</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="562">miscellanées en math</indexterm></cindex>

<para>&latex; contient moult facilités pour les mathématiques. En voici
quelques-unes qu&textrsquo;on n&textrsquo;a pas pu classer ailleurs.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::    ">Colon character &amp; \colon</menunode><menudescription><pre xml:space="preserve">Colon.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                            ">\*</menunode><menudescription><pre xml:space="preserve">Discretionary multiplication.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                         ">\frac</menunode><menudescription><pre xml:space="preserve">Fraction.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                         ">\sqrt</menunode><menudescription><pre xml:space="preserve">Radicals.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                     ">\stackrel</menunode><menudescription><pre xml:space="preserve">Text over a relation.
</pre></menudescription></menuentry></menu>

<node name="Colon-character-_0026-_005ccolon" spaces=" "><nodename>Colon character &amp; \colon</nodename><nodenext automatic="on">\*</nodenext><nodeup automatic="on">Math miscellany</nodeup></node>
<subsection spaces=" "><sectiontitle>Caractère deux-points <code>:</code> &amp; <code>\colon</code></sectiontitle>

<anchor name="colon">colon</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="563">deux-points, caractère</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1089">: <r>(pour les math)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1090">\colon</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">:
\colon
</pre></example>

<para>En mathématiques, le caractère deux-points, <code>:</code>, est une relation.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Avec des rapport de côtés \( 3:4 \) et \( 4:5 \), le triangle est rectangle.
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1091"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1092"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<noindent></noindent>
<para>De base &latex; définit <code>\colon</code> pour produire le caractère
deux-points avec l&textrsquo;espacement approprié pour une ponctuation, comme dans
la notation de construction d&textrsquo;ensemble <code>\&lbrace;x\colon 0\leq x&lt;1\&rbrace;</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1093"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1094"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>Mais le paquetage largement utilisé <code>amsmath</code> définit
<code>\colon</code> pour être utilisé dans la définition de fonctions
<code>f\colon D\to C</code>. Ainsi si vous désirez utiliser le caractère
deux-points comme une ponctuation, utilisez alors <code>\mathpunct&lbrace;:&rbrace;</code>.
</para>

</subsection>
<node name="_005c_002a" spaces=" "><nodename>\*</nodename><nodenext automatic="on">\frac</nodenext><nodeprev automatic="on">Colon character &amp; \colon</nodeprev><nodeup automatic="on">Math miscellany</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\*</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="564">multiplication discrétionnaire</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="565">symbole de multiplication, saut de ligne discrétionnaire</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1095">\*</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\*
</pre></example>

<para>Un symbole de multiplication <dfn>discrétionnaire</dfn>, sur lequel un saut
de ligne est autorisé. En l&textrsquo;absence de saut, la multiplication est
indiquée implicitement par un espace, alors qu&textrsquo;en cas de saut un symbole
× est imprimé immédiatement avant le saut. Ainsi
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\usepackage[utf8]&lbrace;inputenc&rbrace;
\usepackage&lbrace;french&rbrace;
\begin&lbrace;document&rbrace;
Mais \(A_3 = 0\), ainsi le produit de tous les termes de
\(A_1\) à \(A_4\), c.-à-d.\ \(A_1\* A_2\* A_3 \* A_4\),
est égal à zéro.
\end&lbrace;document&rbrace;
</pre></example>

<para>produit une sortie de ce type<!-- c -->
<w> </w>(on a omis une partie du texte pour faire apparaître la césure au
même endroit que dans une sortie &tex;)<!-- c -->
 :
</para>
<indentedblock endspaces=" ">
<para>Mais <math>A_3 = 0</math>, ainsi
[&dots;]
de <math>A_1</math>
à <math>A_4</math>, c.-à-d.&noeos; <math>A_1 A_2 \times</math>&linebreak;<math>A_3 A_4</math>, est
égal à zéro.
</para></indentedblock>

</subsection>
<node name="_005cfrac" spaces=" "><nodename>\frac</nodename><nodenext automatic="on">\sqrt</nodenext><nodeprev automatic="on">\*</nodeprev><nodeup automatic="on">Math miscellany</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\frac</code> </sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="566">fraction</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1096">\frac</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\frac&lbrace;<var>num</var>&rbrace;&lbrace;<var>dén</var>&rbrace;
</pre></example>


<para>Produit la fraction <var>num</var> divisé par <var>dén</var>.  Utilisé comme :
<code>\begin&lbrace;displaymath&rbrace; \frac&lbrace;1&rbrace;&lbrace;\sqrt&lbrace;2\pi\sigma&rbrace;&rbrace;
\end&lbrace;displaymath&rbrace;</code>.  En mode mathématique en ligne cela ressort
petit ; voir la discussion de <code>\displaystyle</code> (<pxref label="Math-formulas"><xrefnodename>Math
formulas</xrefnodename></pxref>).
</para>
</subsection>
<node name="_005csqrt" spaces=" "><nodename>\sqrt</nodename><nodenext automatic="on">\stackrel</nodenext><nodeprev automatic="on">\frac</nodeprev><nodeup automatic="on">Math miscellany</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\sqrt</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="567">carrée, racine</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="568">racines</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="569">radical</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1097">\sqrt</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve"> \sqrt&lbrace;<var>arg</var>&rbrace;
 \sqrt[<var>nième</var>]&lbrace;<var>arg</var>&rbrace;
</pre></example>

<para>Produit la représentation de la racine carrée, ou optionnellement de la
racine <var>nième</var>, de <var>arg</var>.  L&textrsquo;argument optionnel <var>nième</var>
détermine quelle racine produire, c.-à-d.&noeos; saisissez
<code>$\sqrt[3]&lbrace;x+y&rbrace;$</code> pour la racine cubique de <code>x+y</code>.
La taille du radical croît avec celle de <var>arg</var> (au fur et à mesure
que la hauteur du radical croît, l&textrsquo;angle sur la montant de gauche
devient plus abrupt, jusqu&textrsquo;à pour un <code>arg</code> suffisamment haut,
devenir vertical).
</para>
<para>&latex; a un symbole <code>\surd</code> séparé pour faire une racine carrée
sans <var>are</var> (<pxref label="Math-symbols"><xrefnodename>Math symbols</xrefnodename></pxref>).
</para>
</subsection>
<node name="_005cstackrel" spaces=" "><nodename>\stackrel</nodename><nodeprev automatic="on">\sqrt</nodeprev><nodeup automatic="on">Math miscellany</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\stackrel</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="570">pile, math</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="571">relation, texte au-dessus</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1098">\stackrel</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\stackrel&lbrace;<var>texte</var>&rbrace;&lbrace;<var>relation</var>&rbrace;
</pre></example>

<para>Place <var>texte</var> au dessus de <var>relation</var>.  Pour mettre un nom de
fonction au-dessus d&textrsquo;une flèche entrez
<code>\stackrel&lbrace;f&rbrace;&lbrace;\longrightarrow&rbrace;</code>.
</para>

</subsection>
</section>
</chapter>
<node name="Modes" spaces=" "><nodename>Modes</nodename><nodenext automatic="on">Page styles</nodenext><nodeprev automatic="on">Math formulas</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Modes</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="572">modes</indexterm></cindex>

<para>Au fur et à mesure que &latex; traite votre document, en tout point il
est dans l&textrsquo;un parmi six modes. On peut les classer en trois catégories
de deux modes chacune, les modes horizontaux, les modes mathématiques,
et les modes verticaux. Certaines commandes ne fonctionnent pas dans
tous les modes (en particulier, beaucoup de commandes ne fonctionnent
que dans les modes mathématiques), et des messages d&textrsquo;erreur y font
référence.
</para>
<itemize spaces="  " endspaces=" "><itemprepend>&textndash;</itemprepend>
<listitem><prepend>&textndash;</prepend>
<anchor name="modes-paragraph-mode">modes paragraph mode</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="573">mode paragraphe</indexterm></cindex>
<para><dfn>Mode paragraphe</dfn> (appelé <dfn>mode horizontal</dfn> en &tex; de base)
est le mode dans lequel &latex; se trouve lorsqu&textrsquo;il traite du texte
ordinaire. Il fragmente votre texte en lignes pour former un paragraphe
et détermine les positions des sauts de ligne, de sorte que les sauts de
page puissent être effectués en mode vertical. C&textrsquo;est le mode dans lequel
&latex; est la plupart du temps.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="574">mode gauche-à-droite (left-to-right)</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="575">mode LR</indexterm></cindex>
<anchor name="modes-lr-mode">modes lr mode</anchor>
<para>Le <dfn>mode LR</dfn> (de l&textrsquo;anglais Left-to-Right, c.-à-d.&noeos; gauche-à-droite ;
appelé <dfn>mode horizontal restreint</dfn> en &tex; de base), ce mode est
en vigueur quand &latex; se met à fabriquer une boîte avec une commande
<code>\mbox</code>. Comme en mode paragraphe, &latex; considère la sortie
qu&textrsquo;il produit comme une chaîne de mots avec des espaces entre eux.
Contrairement au mode paragraphe, en mode LR &latex; ne démarre jamais
une nouvelle ligne, il continue juste à progresser de la gauche vers la
droite.  (Bien que &latex; ne se plaigne pas qu&textrsquo;une boîte LR puisse
être trop longue, quand il a fini et essaie ensuite de mettre cette
boîte dans une ligne, il peut se plaindre si la boîte résultante est
trop grande pour tenir dans la ligne).
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<cindex index="cp" spaces=" "><indexterm index="cp" number="576">mode math</indexterm></cindex>
<anchor name="modes-math-mode">modes math mode</anchor>
<para><dfn>Mode math</dfn>, &latex; est dans ce mode quand il est en train de
générer une formule mathématique.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="577">mode math d&textrsquo;affichage</indexterm></cindex>
<para><dfn>Mode math d&textrsquo;affichage</dfn>, &latex; est dans ce mode quand il est en
train de générer une formule mathématique hors texte.  (Les formules
hors texte diffèrent quelque peu des formules en ligne. un exemple est
que le placement des indices sur <code>\int</code> diffère entre les deux
situations).
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="578">mode vertical</indexterm></cindex>
</listitem><listitem spaces=" "><prepend>&textndash;</prepend><para>mode vertical
<anchor name="modes-vertical-mode">modes vertical mode</anchor> <dfn>Mode vertical</dfn>, &latex; est dans ce
mode quand il est en train de construire la liste des lignes et d&textrsquo;autres
matières pour fabriquer la page à sortir, ce qui comprend l&textrsquo;insertion
des sauts de page. C&textrsquo;est le mode dans lequel &latex; quand il démarre
un document.
</para>

<cindex index="cp" spaces=" "><indexterm index="cp" number="579">mode vertical interne</indexterm></cindex>
<anchor name="modes-internal-vertical-mode">modes internal vertical mode</anchor>
<para><dfn>Mode vertical interne</dfn>, ce mode est en vigueur quand &latex; se
met à fabriquer une <code>\vbox</code>.  Il ne comprend pas l&textrsquo;insertion de
sauts de page, ce qui fait de lui l&textrsquo;analogue vertical du mode LR.
</para>
</listitem></itemize>

<noindent></noindent>
<para>Par exemple, si vous commencez un article en &latex; avec <samp>Soit \(
x \) un ...</samp> alors voici les modes : d&textrsquo;abord &latex; démarre tout
document en mode vertical, ensuite il lit le <samp>S</samp> et commute en mode
paragraphe, et puis la commutation suivante survient sur le <samp>\(</samp> où
&latex; passe en mode math, et puis quand il quitte la formule il
revient en mode paragraphe.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="580">interne, mode paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="581">externe, mode paragraphe</indexterm></cindex>
<anchor name="modes-inner-paragraph-mode">modes inner paragraph mode</anchor>
<anchor name="modes-outer-paragraph-mode">modes outer paragraph mode</anchor>
<para>Le mode Paragraphe a deux sous-cas. Si vous utilisez une commande
<code>\parbox</code> ou une <code>minipage</code> alors &latex; est mis en mode
paragraphe.  Mais il n&textrsquo;insérera pas de saut de page à cet endroit. Au
sein de l&textrsquo;une de ces boîtes, appelées <dfn>parbox</dfn>, &latex; est en
<dfn>mode paragraphe interne</dfn>.  Une situation plus habituelle, quand il
peut faire des sauts de page, est le <dfn>mode paragraphe externe</dfn>
(<pxref label="Page-breaking"><xrefnodename>Page breaking</xrefnodename></pxref>).
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\ensuremath</menunode><menudescription><pre xml:space="preserve">Assurer qu&textrsquo;on est en mode mathématique
</pre></menudescription></menuentry></menu>

<node name="_005censuremath" spaces=" "><nodename>\ensuremath</nodename><nodeup automatic="on">Modes</nodeup></node>
<section spaces=" "><sectiontitle><code>\ensuremath</code></sectiontitle>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ensuremath&lbrace;<var>formule</var>&rbrace;
</pre></example>

<para>La commande <code>\ensuremath</code> assure que <var>formule</var> est composée en
mode mathématique.
</para>
<para>Par exemple, vous pouvez redéfinir des commandes qui d&textrsquo;ordinaire ne
peuvent être utilisées qu&textrsquo;en mode mathématique, de sorte qu&textrsquo;elles
puissent être utilisées à la fois en mode mathématique et en texte
simple.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\dx&rbrace;&lbrace;\ensuremath&lbrace;dx&rbrace;&rbrace;
Dans $\int f(x)\, \dx$, le \dx&lbrace;&rbrace; représente une variation
infinitésimale.
</pre></example>

<para>Attention : la commande <code>\ensuremath</code> est utile mais ce n&textrsquo;est pas
la panacée.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\alf&rbrace;&lbrace;\ensuremath&lbrace;\alpha&rbrace;&rbrace;
Vous obtenez un alpha en mode texte : \alf.
Mais comparez l'espacement correct de $\alf+\alf$ avec celui de
\alf+\alf.
</pre></example>

<noindent></noindent>
<para>Le mieux est de composer toute matière mathématique en mode
mathématique.
</para>

</section>
</chapter>
<node name="Page-styles" spaces=" "><nodename>Page styles</nodename><nodenext automatic="on">Spaces</nodenext><nodeprev automatic="on">Modes</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Styles de page</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="582">styles de page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="583">page, styles</indexterm></cindex>

<para>Le style d&textrsquo;une page détermine où &latex; place les composantes de cette
page, telles que l&textrsquo;en-tête et le pied de page, et le corps de
texte. Ceci inclut les pages de la partie principale du document mais
inclut également les pages spéciales telles que la page de titre d&textrsquo;un
livre, une page d&textrsquo;index, ou la première page d&textrsquo;un article.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1099"><r>paquetage</r> <code>fancyhdr</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1100"><code>fancyhdr</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>fancyhdr</code> est très utile pour construire des
styles de page. Voir sa documentation sur le CTAN.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::          ">\maketitle</menunode><menudescription><pre xml:space="preserve">Génère une page de titre.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">\pagenumbering</menunode><menudescription><pre xml:space="preserve">Règle le style utilisé pour les numéros de pages.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::		    ">\pagestyle</menunode><menudescription><pre xml:space="preserve">Change le style des en-têtes et bas de pages.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">\thispagestyle</menunode><menudescription><pre xml:space="preserve">Change le style de l&textrsquo;en-tête et bas de pages de la
  page courante.
</pre></menudescription></menuentry></menu>


<node name="_005cmaketitle" spaces=" "><nodename>\maketitle</nodename><nodenext automatic="on">\pagenumbering</nodenext><nodeup automatic="on">Page styles</nodeup></node>
<section spaces=" "><sectiontitle><code>\maketitle</code></sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="584">titres, fabrication</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1101">\maketitle</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\maketitle
</pre></example>

<para>La commande <code>\maketitle</code> génère un titre. Dans les classes
standardes le titre apparaît sur une page séparée &textmdash; hormis dans la
classe <code>article</code> où il est au sommet de la première
page. (<xref label="Document-class-options"><xrefnodename>Document class options</xrefnodename></xref>), pour plus ample information sur
l&textrsquo;option <code>titlepage</code> de classe de document).
</para>
<para>L&textrsquo;exemple qui suit illustre la commande <code>\maketitle</code> apparaissant à
sa place habituelle, immédiatement après <code>\begin&lbrace;document&rbrace;</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\title&lbrace;Construction d'un réacteur nucléaire en n'utilisant que des noix de coco&rbrace;
\author&lbrace;Jonas Grumby\thanks&lbrace;%
    Avec le soutien de Ginger Grant de la Roy Hinkley Society.&rbrace; \\
  Skipper, \textit&lbrace;Minnow&rbrace;
  \and
  Willy Gilligan\thanks&lbrace;%
    Remerciement à la fondation Mary Ann Summers
    et à Thurston et Lovey Howell.&rbrace;           \\
  Second, \textit&lbrace;Minnow&rbrace;
  &rbrace;
\date&lbrace;26 septembre 1964&rbrace;
\begin&lbrace;document&rbrace;
\maketitle
Assieds toi un peu pour entendre ce conte, le conte  d'un voyage fatidique.
Partis de ce port sous les tropiques, à bord de ce petit navire. Le second était
un vieux loup de mer, le Skipper, courageux et sûr. Cinq passagers firent
voile ce jour-là, pour une balade de trois heures. Une balade de trois heures.
  ...

</pre></example>

<para>Vous donnez à &latex; l&textrsquo;information nécessaire à la production du titre
en faisant les déclarations suivantes. Elles doivent se faire avant le
<code>\maketitle</code>, soit dans le préambule, soit dans le corps du document.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1102">\author&lbrace;<var>nom1</var> \and <var>nom2</var> \and ...&rbrace;</indexterm>\author&lbrace;<var>nom1</var> \and <var>nom2</var> \and ...&rbrace;</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="585">auteur, pour la page de titre</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1103">\\ <r>(pour <code>\author</code>)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1104">\and <r>(pour <code>\author</code>)</r></indexterm></findex>
<para>Obligatoire.  Déclare l&textrsquo;auteur, ou les auteurs du document.  L&textrsquo;argument
est une liste d&textrsquo;auteurs séparés par des commandes <code>\and</code>.  Pour
séparer les lignes au sein d&textrsquo;une seule entrée d&textrsquo;auteur, par exemple pour
donner l&textrsquo;institution ou l&textrsquo;adresse de l&textrsquo;auteur, utiliser une double
controblique, <code>\\</code>.  Si vous omettez la déclaration <code>\author</code>
alors vous obtiendrez un avertissement <samp>LaTeX Warning: No \author
given</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1105">\date&lbrace;<var>texte</var>&rbrace;</indexterm>\date&lbrace;<var>texte</var>&rbrace;</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="586">date, pour la page de titre</indexterm></cindex>
<para>Optionnel. Déclare que <var>texte</var> est la date du document.  Le
<var>texte</var> n&textrsquo;est pas nécessairement dans un format de date ; cela peut
être un texte quelconque.  Si vous omettez <code>\date</code> alors &latex;
utilise la date courante (<pxref label="_005ctoday"><xrefnodename>\today</xrefnodename></pxref>).  Pour omettre la date,
utilisez plutôt <code>\date&lbrace;&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1106">\thanks&lbrace;<var>texte</var>&rbrace;</indexterm>\thanks&lbrace;<var>texte</var>&rbrace;</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="587">remerciements, pour la page de titre</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="588">crédits, note en bas de page</indexterm></cindex>
<para>Optionnel.  Produit une note en bas de page. Vous pouvez l&textrsquo;utiliser dans
l&textrsquo;information sur l&textrsquo;auteur pour insérer des remerciement comme illustré
dans l&textrsquo;exemple plus haut, mais vous pouvez également l&textrsquo;utiliser dans le
titre, ou en tout lieu où une marque de note en bas de page est
susceptible de se trouver. Cela peut être un texte quelconque et donc
vous pouvez l&textrsquo;utiliser pour n&textrsquo;importe quoi, comme pour imprimer une
adresse mél.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1107">\title&lbrace;<var>texte</var>&rbrace;</indexterm>\title&lbrace;<var>texte</var>&rbrace;</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="589">titre, pour la page de titre</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1108">\\ <r>(pour <code>\title</code>)</r></indexterm></findex>
<para>Obligatoire.  Déclare que <var>texte</var> est le titre du document.  On
obtient des sauts de ligne au sein de <var>texte</var> avec une double
controblique, <code>\\</code>.  Si vous omettez la déclaration <code>\title</code>
alors la commande <code>\maketitle</code> produit l&textrsquo;erreur <samp>LaTeX Error:
No \title given</samp>.
</para>
</tableitem></tableentry></ftable>

<para>Pour fabriquer votre propre page de titre, voir <ref label="titlepage"><xrefnodename>titlepage</xrefnodename></ref>. Vous
pouvez soit la créer pour une unique fois ou l&textrsquo;inclure comme faisant
partie d&textrsquo;une commande <code>\maketitle</code> redéfinie.  (Beaucoup d&textrsquo;éditeurs
fournissent une classe à utiliser à la place de <code>article</code> et
formatant le titre selon les exigences de leur maison).
</para>
</section>
<node name="_005cpagenumbering" spaces=" "><nodename>\pagenumbering</nodename><nodenext automatic="on">\pagestyle</nodenext><nodeprev automatic="on">\maketitle</nodeprev><nodeup automatic="on">Page styles</nodeup></node>
<section spaces=" "><sectiontitle><code>\pagenumbering</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1109">\pagenumbering</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="590">numérotation de page, style</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="591">style de numérotation de page</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\pagenumbering&lbrace;<var>style</var>&rbrace;
</pre></example>

<para>Spécifie le style des numéros de page, et réinitialise également le
numéro de page. Le style de numérotation est reflété sur la page, et
aussi dans la table des matières et d&textrsquo;autres références de page. Cette
déclaration a une portée globale, ainsi son effet ne s&textrsquo;arrête pas à une
fin de groupe comme une accolade fermante ou une fin d&textrsquo;environnement.
</para>
<para>Dans l&textrsquo;exemple suivant, avant la rubrique <samp>Principale</samp> les pages
sont numérotées <samp>a</samp>, etc.  À partir de la page contenant l&textrsquo;appel à
<code>\pagenumbering</code> fait dans cette rubrique, les pages sont
numérotées <samp>1</samp>, etc.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;document&rbrace;\pagenumbering&lbrace;alph&rbrace;
  ...
\section&lbrace;Principale&rbrace;\pagenumbering&lbrace;arabic&rbrace;
  ...
</pre></example>


<para>L&textrsquo;argument <var>style</var> peut prendre les valeurs suivantes (voir
aussi <ref label="_005calph-_005cAlph-_005carabic-_005croman-_005cRoman-_005cfnsymbol"><xrefnodename>\alph \Alph \arabic \roman \Roman \fnsymbol</xrefnodename></ref>) :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">arabic</itemformat></item>
</tableterm><tableitem><para>nombres arabes : 1, 2, &dots; 
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">roman</itemformat></item>
</tableterm><tableitem><para>Nombres romain en bas de casse : i, ii, &dots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">Roman</itemformat></item>
</tableterm><tableitem><para>Nombres romain en capitales : I, II, &dots;
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">alph</itemformat></item>
</tableterm><tableitem><para>Lettres en bas de casse : a, b, &dots; Si vous avez plus de 26 pages
alors vous obtenez <samp>LaTeX Error: Counter too large</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">Alph</itemformat></item>
</tableterm><tableitem><para>Lettre en capitales : A, B, &dots; Si vous avez plus de 26 pages
alors vous obtenez <samp>LaTeX Error: Counter too large</samp>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">gobble</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1110"><r>paquetage</r> <code>hyperref</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1111"><code>hyperref</code>, <r>paquetage</r></indexterm></findex>
 <para>&latex; ne produit pas de numéro de page en sortie,
bien qu&textrsquo;il ne soit pas réinitialisé.  Les références à cette page
sont également à blanc.  (Ceci ne fonctionne pas avec le paquetage
populaire <code>hyperref</code>, de sorte que pour empêcher le numéro de
page d&textrsquo;apparaître une alternative est d&textrsquo;utiliser
<code>\pagestyle&lbrace;empty&rbrace;</code> ou <code>\thispagestyle&lbrace;empty&rbrace;</code>.)
</para>
</tableitem></tableentry></table>

<para>Traditionnellement, si un document a des matières
préliminaires &textmdash; préface, table des matières, etc. &textmdash; alors les pages
y sont numérotées en chiffres romains bas de casse. Les pages de la
matière principale d&textrsquo;un document sont en chiffres arabes.
<xref label="_005cfrontmatter-_0026-_005cmainmatter-_0026-_005cbackmatter"><xrefnodename>\frontmatter &amp; \mainmatter &amp; \backmatter</xrefnodename></xref>.
</para>
<para>Si vous désirez changer l&textrsquo;emplacement du numéro de page sur la page,
voir <ref label="_005cpagestyle"><xrefnodename>\pagestyle</xrefnodename></ref>.  Si vous désirez changer la valeur du numéro de
page, alors manipulez le compteur <code>page</code> (<pxref label="Counters"><xrefnodename>Counters</xrefnodename></pxref>).
</para>

</section>
<node name="_005cpagestyle" spaces=" "><nodename>\pagestyle</nodename><nodenext automatic="on">\thispagestyle</nodenext><nodeprev automatic="on">\pagenumbering</nodeprev><nodeup automatic="on">Page styles</nodeup></node>
<section spaces=" "><sectiontitle><code>\pagestyle</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1112">\pagestyle</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="592">en-tête de page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="593">pied de page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="594">style d&textrsquo;en-tête et pied de page</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\pagestyle&lbrace;<var>style</var>&rbrace;
</pre></example>

<para>Déclaration spécifiant comment les en-têtes et pieds de page sont
composés à partir de la page courante.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1113"><r>paquetage</r> <code>fancyhdr</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1114"><code>fancyhdr</code>, <r>paquetage</r></indexterm></findex>

<para>Une discussion avec un exemple suivent.  À noter tout d&textrsquo;abord que le
paquetage <code>fancyhdr</code> est actuellement la manière standarde de
manipuler les en-têtes et pieds de page. Les nouveaux documents pour
lesquels on désire quoi que ce soit d&textrsquo;autre que les options standardes
listées ci-dessous devraient utiliser ce paquetage. Se référer à sa
documentation sur le CTAN.
</para>
<para>Valeurs pour <var>style</var> :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">plain</itemformat></item>
</tableterm><tableitem><para>L&textrsquo;en-tête est vide.  Le pied de page ne contient qu&textrsquo;un numéro de page,
centré.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">empty</itemformat></item>
</tableterm><tableitem><para>L&textrsquo;en-tête et le pied de page sont tous deux vides.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">headings</itemformat></item>
</tableterm><tableitem><para>Place des en-têtes et pieds de page sur chaque page. Le style de
document spécifie ce qu&textrsquo;ils contiennent ; voir la discussion plus bas.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">myheadings</itemformat></item>
</tableterm><tableitem><para>En-têtes personnalisés, spécifiés via les commandes <code>\markboth</code> ou
<code>\markright</code>.
</para>
</tableitem></tableentry></table>

<para>Discuter la motivation du mécanisme de &latex; vous aidera à faire
fonctionner les options <code>headings</code> ou <code>myheadings</code>.  Le
document source ci-dessous produit un article, en recto-verso, avec le
style de page <code>headings</code>.  Sur les pages de gauche de ce document,
&latex; désire (en plus du numéro de page) le titre de la rubrique de
niveau <code>\section</code> en cours.  Sur les pages de droite &latex;
désire le titre de la rubrique de niveau <code>\subsection</code> en cours.
Quand il fabrique une page, &latex; obtient ces informations à partir
des commandes <code>\leftmark</code> et <code>\rightmark</code>.  De sorte que c&textrsquo;est
aux commandes <code>\section</code> et <code>\subsection</code> de stocker ces
informations là.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[twoside]&lbrace;article&rbrace;
\pagestyle&lbrace;headings&rbrace;
\begin&lbrace;document&rbrace;
  ... \section&lbrace;Section 1&rbrace; ... \subsection&lbrace;Subsection 1.1&rbrace; ...
\section&lbrace;Section 2&rbrace;
  ...
\subsection&lbrace;Subsection 2.1&rbrace;
  ...
\subsection&lbrace;Subsection 2.2&rbrace;
  ...
</pre></example>

<noindent></noindent>
<para>Supposez que la seconde rubrique de niveau <code>\section</code> tombe sur une
page de gauche.  Même si quand la page commence elle est dans la
première rubrique de niveau <code>\section</code>, &latex; placera
<samp>Section&nbsp;2</samp> dans l&textrsquo;en-ête de la page de gauche.  Quant à
l&textrsquo;en-tête de droite, si aucune rubrique de niveau <code>\subsection</code> ne
commence avant la fin de la page de droite alors &latex; laisse en
blanc l&textrsquo;en-tête de droite.  Si une rubrique de niveau <code>\subsection</code>
apparaît avant que la page de droite ne finisse alors il y a deux
cas. Si au moins une rubrique de niveau <code>\subsection</code> commence sur
la page de droite alors &latex; place dans l&textrsquo;en-tête de droite le titre
de la première rubrique de niveau <code>\subsection</code> commençant sur
cette page de droite. Si au moins l&textrsquo;un parmi 2.1, 2.2, &dots;, commence
sur la page de gauche mais qu&textrsquo;aucune ne commence sur la droite alors
&latex; place dans l&textrsquo;en-tête de droite le titre de la dernière rubrique
de niveau <code>\subsection</code> à avoir commencé, c.-à-d.&noeos; celle qui est
en cours pendant la page de droite.
</para>
<para>Pour accomplir cela, dans un article en recto-verso, &latex; fait que
<code>\section</code> génère une commande <code>\markboth</code> réglant
<code>\leftmark</code> à <samp>Section&nbsp;2</samp> et réglant <code>\rightmark</code> à
un contenu vide.  Et, &latex; fait que <code>\subsection</code> génère une
commande <code>\markright</code>, réglant <code>\rightmark</code> à
<samp>Subsection&nbsp;2.1</samp>, etc.
</para>
<para>Ci-après on trouvera les descriptions de <code>\markboth</code> et
<code>\markright</code> :
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1115">\markboth&lbrace;<var>en-tête-gauche</var>&rbrace;&lbrace;<var>en-tête-droite</var>&rbrace;</indexterm>\markboth&lbrace;<var>en-tête-gauche</var>&rbrace;&lbrace;<var>en-tête-droite</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Règle l&textrsquo;information d&textrsquo;en-tête à la fois sur la page de gauche et sur
celle de droite dans le cas d&textrsquo;un style de page <code>headings</code> ou
<code>myheadings</code>.  Un en-tête <var>en-tête-gauche</var> de page de gauche
est généré par la dernière commande <code>\markboth</code> avant la fin de la
page.  Un en-tête <var>en-tête-droite</var> de page de droite est généré par
le premier <code>\markboth</code> ou <code>\markright</code>, s&textrsquo;il y en a un, de la
page, ou sinon par le dernier se trouvant avant cette page.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1116">\markright&lbrace;<var>en-tête-droite</var>&rbrace;</indexterm>\markright&lbrace;<var>en-tête-droite</var>&rbrace;</itemformat></item>
</tableterm><tableitem><para>Règle l&textrsquo;en-tête de la page de droite, en laissant celle de gauche
inchangée.
</para>
</tableitem></tableentry></ftable>


</section>
<node name="_005cthispagestyle" spaces=" "><nodename>\thispagestyle</nodename><nodeprev automatic="on">\pagestyle</nodeprev><nodeup automatic="on">Page styles</nodeup></node>
<section spaces=" "><sectiontitle><code>\thispagestyle&lbrace;<var>style</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1117">\thispagestyle</indexterm></findex>

<para>La commande <code>\thispagestyle</code> fonctionne de la même manière que la
commande <code>\pagestyle</code> (voir section précédente) à ceci près qu&textrsquo;elle
change en <var>style</var> pour la page courante seulement.
</para>

</section>
</chapter>
<node name="Spaces" spaces=" "><nodename>Spaces</nodename><nodenext automatic="on">Boxes</nodenext><nodeprev automatic="on">Page styles</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Espaces</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="595">espaces</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="596">espace blanc</indexterm></cindex>

<para>&latex; a beaucoup de façons de produire de l&textrsquo;espace blanc (ou
rempli). Certaines d&textrsquo;entre elles conviennent mieux à du texte
mathématique à ce propos, voir <ref label="Spacing-in-math-mode"><xrefnodename>Spacing in math mode</xrefnodename></ref>.
</para>
<!-- c Une autre commande produisant de l'espace est @code{\,} pour produire une -->
<!-- c espace « fine » (d'habitude 1/6@dmn{quad}).  Elle peut être utilisée en -->
<!-- c mode texte, mais est le plus souvent utile en mode math (@pxref{Spacing -->
<!-- c in math mode,Espacement en mode mathématique}). -->

<!-- c xxx Realigner sur l'anglais -->
<menu endspaces=" ">
<menucomment><pre xml:space="preserve">Espace horizontal
</pre></menucomment><menuentry leadingtext="* "><menunode separator="::  ">\enspace &amp; \quad &amp; \qquad</menunode><menudescription><pre xml:space="preserve">Espaces horizontaux traditionnels.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">\hspace</menunode><menudescription><pre xml:space="preserve">Espace horizontal quelconque.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::              ">\hfill</menunode><menudescription><pre xml:space="preserve">Espace horizontal extensible.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                ">\hss</menunode><menudescription><pre xml:space="preserve">Espace horizontal infiniment dilatable/contractible.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::        ">\spacefactor</menunode><menudescription><pre xml:space="preserve">Dilatabilité de l&textrsquo;espace qui suit
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">\<key>&lt;espace&gt;</key></menutitle><menunode separator=". ">\(SPACE)</menunode><menudescription><pre xml:space="preserve">Controblique-espace, et espace explicite.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                   ">~</menunode><menudescription><pre xml:space="preserve">Tilde, un espace insécable.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::          ">\thinspace &amp; \negthinspace</menunode><menudescription><pre xml:space="preserve">Un sixième d&textrsquo;<dmn>em</dmn>, en positif et en négatif.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                  ">\/</menunode><menudescription><pre xml:space="preserve">Correction italique.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::          ">\hrulefill &amp; \dotfill</menunode><menudescription><pre xml:space="preserve">Filet ou pointillés horizontaux extensibles.
</pre></menudescription></menuentry><menucomment><pre xml:space="preserve">
Espace vertical
</pre></menucomment><menuentry leadingtext="* "><menunode separator="::  ">\bigskip &amp; \medskip &amp; \smallskip</menunode><menudescription><pre xml:space="preserve">Espaces verticaux fixes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::  ">\bigbreak &amp; \medbreak &amp; \smallbreak</menunode><menudescription><pre xml:space="preserve">Epsace inter-paragraphe et sauts de pages.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                            ">\strut</menunode><menudescription><pre xml:space="preserve">Assure la hauteur d&textrsquo;une ligne.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                       ">\vspace</menunode><menudescription><pre xml:space="preserve">Espace vertical.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                        ">\vfill</menunode><menudescription><pre xml:space="preserve">Espace vertical extensible indéfiniment.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                    ">\addvspace</menunode><menudescription><pre xml:space="preserve">Ajouter un espace vertical arbitraire si besoin est.
</pre></menudescription></menuentry></menu>


<node name="_005censpace-_0026-_005cquad-_0026-_005cqquad" spaces=" "><nodename>\enspace &amp; \quad &amp; \qquad</nodename><nodenext automatic="on">\hspace</nodenext><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\enspace</code> &amp; <code>\quad</code> &amp; <code>\qquad</code></sectiontitle>

<anchor name="_005censpace">\enspace</anchor>
<anchor name="_005cquad">\quad</anchor>
<anchor name="_005cqquad">\qquad</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1118">\enspace</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1119">\quad</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1120">\qquad</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\enspace
\quad
\qquad
</pre></example>

<para>Insère un espace horizontal de 1/2<dmn>em</dmn>, 1<dmn>em</dmn>, ou 2<dmn>em</dmn>. Le
em est une longueur définie par les auteurs de polices de caractères,
généralement considérée comme la largeur d&textrsquo;un M capital.  Un avantage de
décrire l&textrsquo;espace en termes d&textrsquo;em est que cela peut être plus portable
d&textrsquo;un document à l&textrsquo;autre qu&textrsquo;utiliser une mesure absolue telle que des
points (<pxref label="Lengths_002fem"><xrefnodename>Lengths/em</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivant met l&textrsquo;espace adéquat entre les deux graphiques.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \includegraphics&lbrace;souriredefemmes.png&rbrace;%
  \qquad\includegraphics&lbrace;souriredemecs.png&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<noindent></noindent>
<para><xref label="Spacing-in-math-mode"><xrefnodename>Spacing in math mode</xrefnodename></xref>, pour <code>\quad</code> et <code>\qquad</code>.  Ce
sont des longueurs utilisées depuis des siècles en typographie et donc
dans de nombreux cas seraient un meilleur choix que des longueurs
arbitraires, comme celles que l&textrsquo;on obtient avec <code>\hspace</code>.
</para>
</section>
<node name="_005chspace" spaces=" "><nodename>\hspace</nodename><nodenext automatic="on">\hfill</nodenext><nodeprev automatic="on">\enspace &amp; \quad &amp; \qquad</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\hspace</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1121">\hspace</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\hspace&lbrace;<var>longueur</var>&rbrace;
\hspace*&lbrace;<var>longueur</var>&rbrace;
</pre></example>

<para>La commande <code>\hspace</code> ajoute la quantité d&textrsquo;espace horizontal
<var>longueur</var>. L&textrsquo;argument <var>longueur</var> peut être positif, négatif, ou
nul ; ajouter une longueur négative d&textrsquo;espace revient à retourner en
arrière. C&textrsquo;est une longueur élastique, c.-à-d.&noeos; qu&textrsquo;elle peut contenir
une composante <code>plus</code> ou <code>minus</code>, ou les deux
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). Comme l&textrsquo;espace est dilatable ou contractible on
l&textrsquo;appelle parfois <dfn>glue</dfn>.
</para>
<para>L&textrsquo;exemple suivant fabrique une ligne dans laquelle <samp>Nom~:</samp> est à
2,5<dmn>cm</dmn> de la marge de droite.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\noindent\makebox[\linewidth][r]&lbrace;Nom~:\hspace&lbrace;2.5cm&rbrace;&rbrace;
</pre></example>

<para>La forme en <code>*</code> insère de l&textrsquo;espace horizontal non
suppressible. Plus précisément, quand &tex; découpe un paragraphe en
lignes, tout espace blanc &textmdash; glues ou crénages &textmdash; qui se trouve à un
saut de ligne est supprimé. La forme étoilée évite ceci (techniquement,
elle ajoute un objet invisible non-supprimable devant l&textrsquo;espace).
</para>
<para>Dans l&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[a4paper]&lbrace;article&rbrace;
\begin&lbrace;document&rbrace;
\parbox&lbrace;.9\linewidth&rbrace;&lbrace;Remplir chaque blanc~: Le peuple français proclame
  solennellement son attachement aux Droits de \hspace*&lbrace;2.5cm&rbrace; et aux
  principes de la \hspace*&lbrace;2.5cm&rbrace; nationale tels qu’ils ont été définis
  par la Déclaration de 1789, \ldots&rbrace;
\end&lbrace;document&rbrace;
</pre></example>
<noindent></noindent>
<para>le blanc de 2,5<dmn>cm</dmn> suivant <samp>principes de la</samp> tombe au début de la
ligne. Si vous enlevez la <code>*</code> alors &latex; supprime le blanc.
</para>
<para>Ci-dessous le <code>\hspace</code> sépare les trois graphiques.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \includegraphics&lbrace;lion.png&rbrace;% le commentaire empêche l'ajout d'un espace
  \hspace&lbrace;1cm minus 0.25cm&rbrace;\includegraphics&lbrace;tiger.png&rbrace;%
  \hspace&lbrace;1cm minus 0.25cm&rbrace;\includegraphics&lbrace;bear.png&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<noindent></noindent>
<para>Parce que l&textrsquo;argument de chaque <code>\hspace</code> comprend <code>minus
0.25cm</code>, chacun peut se contracter un peu si les trois figures sont trop
larges. Mais chaque espace ne peut contracter plus que 0,25<dmn>cm</dmn>
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).
</para>
</section>
<node name="_005chfill" spaces=" "><nodename>\hfill</nodename><nodenext automatic="on">\hss</nodenext><nodeprev automatic="on">\hspace</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\hfill</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1122">\hfill</indexterm></findex>
<para>La commande <code>\hfill</code> de remplissage produit une &textldquo;longueur
élastique&textrdquo; qui n&textrsquo;a aucun espace naturel mais peut s&textrsquo;allonger ou se
rétrécir horizontalement autant que nécessaire.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1123">\fill</indexterm></findex>
<para>Le paramètre <code>\fill</code> est la longueur élastique elle-même (c.-à-d.&noeos;
pour parler technique, la valeur de glue <samp>0pt plus1fill</samp>) ; ainsi,
<code>\hspace\fill</code> équivaut à <code>\hfill</code>.
</para>
</section>
<node name="_005chss" spaces=" "><nodename>\hss</nodename><nodenext automatic="on">\spacefactor</nodenext><nodeprev automatic="on">\hfill</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\hss</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1124">\hss</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="597">horizontal, espace</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="598">espace horizontal</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="599">espace horizontal dilatable</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="600">espace, insérer de l&textrsquo;espace horizontal</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\hss
</pre></example>

<para>Produit un espace horizontal indéfiniment dilatable ou contractible
(cette commande est une primitive &tex;).  Les auteurs &latex;
devraient chercher en premier la commande <code>\makebox</code> pour obtenir
les effets de <code>\hss</code> (<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple suivant, le <code>\hss</code> de la première ligne a pour effet
de coller le Z à droite, le superposant au Y.  Dans la seconde ligne, le
Z dépasse sur la gauche, et se superpose au X.
</para>
<example endspaces=" ">
<pre xml:space="preserve">X\hbox to 0pt&lbrace;Z\hss&rbrace;Y
X\hbox to 0pt&lbrace;\hss Z&rbrace;Y
</pre></example>

<noindent></noindent>
<para>Sans le <code>\hss</code> vous auriez quelque chose du genre <samp>Overfull
\hbox (6.11111pt too wide) detected at line 20</samp>.
</para>
</section>
<node name="_005cspacefactor" spaces=" "><nodename>\spacefactor</nodename><nodenext automatic="on">\(SPACE)</nodenext><nodeprev automatic="on">\hss</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\spacefactor</code></sectiontitle>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\spacefactor=<var>entier</var>
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1125">\spacefactor</indexterm></findex>
<para>Influence le comportement de &latex; en termes de dilatation /
contraction de glue. La plupart des documents de niveau d&textrsquo;utilisateur ne
font pas usage de cette commande.
</para>
<para>Alors que &latex; compose la matière, il peut dilater ou contracter
les espaces entre les mots.  (Cet espace n&textrsquo;est pas un caractère ; on
l&textrsquo;appelle la <dfn>glue inter-mot</dfn> ; <pxref label="_005chspace"><xrefnodename>\hspace</xrefnodename></pxref>).  La commande
<code>\spacefactor</code> (issue de &tex; de base) vous permet, par
exemple, d&textrsquo;avoir l&textrsquo;espace après un point qui se dilate plus que l&textrsquo;espace
après une lettre terminant un mot.
</para>
<para>Après que &latex; a placé chaque caractère, ou filet ou autre boîte, il
règle un paramètre qu&textrsquo;on appelle le <dfn>facteur d&textrsquo;espace</dfn>.  Si ce qui
suit en entrée est une espace alors ce paramètre affecte la quantité de
dilatation ou de contraction pouvant survenir.  Un facteur d&textrsquo;espace plus
grand que la valeur normale signifie que la glue peut se dilater
davantage, et moins se contracter.  Normalement, le facteur d&textrsquo;espace
vaut 1000. Cette valeur est en vigueur après la plupart des caractères,
et toute boîte qui n&textrsquo;est pas un caractère, ou formule mathématique.
Mais il vaut 3000 après un point, un point d&textrsquo;exclamation, ou
d&textrsquo;interrogation, il vaut 2000 après un caractère deux-points, 1500 après
un point-virgule, 1250 après une virgule, et 0 après une parenthèse
fermante ou un crochet fermant, ou un guillemet anglais fermant double,
ou simple.  Finalement, il faut 999 après une lettre capitale.
</para>
<para>Si le facteur d&textrsquo;espace <var>f</var> vaut 1000 alors l&textrsquo;espace de glue sera de
la taille normale d&textrsquo;une espace dans la police courante (pour Computer
Modern Roman en 10 point, cela vaut 3,3333 points).  Sinon, si le
facteur d&textrsquo;espace <var>f</var> est supérieur à 2000 alors &tex; ajoute la
valeur d&textrsquo;espace supplémentaire définie pour la police courante (pour
Computer Modern Roman en 10 point cela vaut 1,11111 points), et ensuite
la valeur de dilatation normale de la police est multipliée par
<math>f /1000</math> et la valeur normale de contraction par <math>1000/f</math>
(pour Computer Modern Roman en 10 point elles valent 1,66666 et
1,11111 points).
</para>
<para>Par exemple, considérez le point à la fin de <code>Le meilleur ami d'un
homme est son chien.</code>  Après celui-ci, &tex; place un espace
supplémentaire fixé, et également permet à la glue de se dilater trois
fois plus et de se contracter par 1/3 fois plus que la glue après
<code>ami</code>, ce mot ne se terminant pas sur un point.
</para>
<para>Les règles de fonctionnement des facteurs d&textrsquo;espace sont en fait encore
plus complexes car elles jouent d&textrsquo;autres rôles. En pratique, il y a deux
conséquences.  Tout d&textrsquo;abord, si un point ou une autre ponctuation est
suivie d&textrsquo;une parenthèse ou d&textrsquo;un crochet fermant, ou d&textrsquo;un guillemet
anglais fermant simple ou double, alors l&textrsquo;effet sur l&textrsquo;espacement de ce
point se propage à travers ces caractères (c.-à-d.&noeos; que la glue qui suit
aura plus de dilatation ou de contraction).  Deuxièmement, si la
ponctuation suit une lettre capitale alors son effet n&textrsquo;est pas là de
sorte que vous obtenez un espacement ordinaire.  Ce second cas affecte
également les abréviations qui ne se terminent pas par une lettre
capitale (<pxref label="_005c_0040"><xrefnodename>\&arobase;</xrefnodename></pxref>).
</para>
<para>Vous pouvez utiliser <code>\spacefactor</code> seulement en mode paragraphe ou
en mode LR (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).  Vous pouvez voir la valeur courante avec
<code>\the\spacefactor</code> ou <code>\showthe\spacefactor</code>.
</para>
<para>(Commentaire, ne concernant pas vraiment <code>\spacefactor</code> : si vous
avez des erreurs du genre de <samp>You can't use `\spacefactor' in
vertical mode</samp>, ou <samp>You can't use `\spacefactor' in math mode.</samp>, ou
<samp>Improper \spacefactor</samp> alors c&textrsquo;est que vous avez probablement
essayer de redéfinir une commande interne.  <xref label="_005cmakeatletter-_0026-_005cmakeatother"><xrefnodename>\makeatletter &amp;
\makeatother</xrefnodename></xref>.)
</para>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator=":: ">\&arobase;</menunode><menudescription><pre xml:space="preserve">Distingue les points terminant une phrase de ceux terminant une
  abréviation.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\frenchspacing &amp; \nonfrenchspacing</menunode><menudescription><pre xml:space="preserve">Rendre égaux les espacements inter-phrase et inter-mot.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">\normalsfcodes</menunode><menudescription><pre xml:space="preserve">Restore space factor settings to the default.
</pre></menudescription></menuentry></menu>


<node name="_005c_0040" spaces=" "><nodename>\&arobase;</nodename><nodenext automatic="on">\frenchspacing &amp; \nonfrenchspacing</nodenext><nodeup automatic="on">\spacefactor</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\&arobase;</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1126">\&arobase;</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1127">arobe</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="601">point terminant une phrase</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="602">point terminant une abréviation</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="603">point, espacement après</indexterm></cindex>
<anchor name="_005cAT">\AT</anchor><!-- c ancien nom -->

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><var>lettre-capitale</var>\&arobase;.
</pre></example>

<para>Traite un point comme terminant une phrase, là où &latex; penserait
sinon qu&textrsquo;il fait partie d&textrsquo;une abréviation.  &latex; pense qu&textrsquo;un point
termine une abréviation si le point suit une lettre capitale, et sinon
il pense que ce point termine une phrase.  Par défaut, en justifiant une
ligne &latex; ajuste l&textrsquo;espacement après un point terminant une phrase
(ou après un point d&textrsquo;interrogation, d&textrsquo;exclamation, une virgule, ou un
caractère deux-points) plus qu&textrsquo;il n&textrsquo;ajuste l&textrsquo;espace inter-mot
(<pxref label="_005cspacefactor"><xrefnodename>\spacefactor</xrefnodename></pxref>).
</para>
<para>Cet exemple montre les deux cas dont il faut se souvenir :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Les chansons \textit&lbrace;Red Guitar&rbrace;, etc.\ sont de Loudon Wainwright~III\&arobase;.
</pre></example>

<noindent></noindent>
<para>Le second point termine la phrase, bien que précédé d&textrsquo;une capitale. On
dit à &latex; qu&textrsquo;il termine la phrase en mettant <code>\&arobase;</code> devant.  Le
premier point termine l&textrsquo;abréviation <samp>etc.</samp> mais non la phrase.  Le
controblique-espace, <code>\ </code>, produit un espace en milieu de phrase.
</para>
<para>Ainsi donc : lorsqu&textrsquo;on a une capitale suivie d&textrsquo;un point qui termine une
phrase, alors on met <code>\&arobase;</code> devant le point.  Cela vaut même s’il y
a une parenthèse droite ou un crochet, ou un guillemet droit simple ou
double, parce que la portée de l’effet sur l&textrsquo;espacement du point n&textrsquo;est
pas limitée par ces caractères.  Dans l&textrsquo;exemple suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">Utilisez le \textit&lbrace;Instructional Practices Guide&rbrace;, (un livre de la
MAA)\&arobase;.
</pre></example>

<noindent></noindent>
<para>on obtient l&textrsquo;espacement inter-phrase correctement après le point.
</para>
<para>La commande <code>\&arobase;</code> ne convient que pour le mode texte. Si vous
l&textrsquo;utilisez hors de ce mode alors vous obtiendrez <samp>You can't use
`\spacefactor' in vertical mode</samp> (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
</para>
<para>Commentaire : le cas réciproque c&textrsquo;est lorsque un point termine une
abréviation dont la dernière lettre n&textrsquo;est pas une capitale, et que cette
abréviation n&textrsquo;est pas le dernier mot de la phrase.  Pour ce cas faites
suivre le point d&textrsquo;une controblique-espace, (<code>\ </code>), ou un tilde,
(<code>~</code>), ou <code>\&arobase;</code>.  Par exemple <code>Nat.\ Acad.\ Science</code>,
<code>Mr.~Bean</code>, et <code>(fumier, etc.\&arobase;) à vendre</code> (notez que dans le
dernier cas <code>\&arobase;</code> est placé avant la parenthèse fermante).
</para>

</subsection>
<node name="_005cfrenchspacing-_0026-_005cnonfrenchspacing" spaces=" "><nodename>\frenchspacing &amp; \nonfrenchspacing</nodename><nodenext automatic="on">\normalsfcodes</nodenext><nodeprev automatic="on">\&arobase;</nodeprev><nodeup automatic="on">\spacefactor</nodeup></node>
<anchor name="_005cfrenchspacing">\frenchspacing</anchor><!-- c old node name -->
<subsection spaces=" "><sectiontitle><code>\frenchspacing</code> &amp; <code>\nonfrenchspacing</code></sectiontitle>

<anchor name="_005cnonfrenchspacing">\nonfrenchspacing</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1128">\frenchspacing</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1129">\nonfrenchspacing</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="604">espacement inter-phrase</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\frenchspacing
\nonfrenchspacing
</pre></example>

<para>La première déclaration a pour effet que &latex; traite l&textrsquo;espacement
entre les phrases de la même manière que l&textrsquo;espacement entre les mots
d&textrsquo;une phrase. L&textrsquo;effet de la seconde est de revenir au traitement par
défaut où l&textrsquo;espacement entre les phrases se dilate ou contracte
davantage (<pxref label="_005cspacefactor"><xrefnodename>\spacefactor</xrefnodename></pxref>).
</para>
<para>Dans certaines traditions typographiques, y compris l&textrsquo;anglaise, on
préfère ajuster l&textrsquo;espace entre les phrases (ou les espaces suivant un
point d&textrsquo;interrogation, d&textrsquo;exclamation, une virgule, ou un point virgule)
plus que l&textrsquo;espace entre les mots du milieu de la phrase. La déclaration
<code>\frenchspacing</code> (la commande vient de &tex; de base) commute
vers la tradition où tous les espaces sont traités de la même façon.
</para>
</subsection>
<node name="_005cnormalsfcodes" spaces=" "><nodename>\normalsfcodes</nodename><nodeprev automatic="on">\frenchspacing &amp; \nonfrenchspacing</nodeprev><nodeup automatic="on">\spacefactor</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\normalsfcodes</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1130">\normalsfcodes</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="605">espacement inter-phrase</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\normalsfcodes
</pre></example>

<para>Réinitialise les facteurs d&textrsquo;espacement de &latex; à leur valeur
défaut (<pxref label="_005cspacefactor"><xrefnodename>\spacefactor</xrefnodename></pxref>).
</para>
</subsection>
</section>
<node name="_005c_0028SPACE_0029" spaces=" "><nodename>\(SPACE)</nodename><nodenext automatic="on">~</nodenext><nodeprev automatic="on">\spacefactor</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle>Controblique-espace <code>\ </code></sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="606">\<key>SAUTDELIGNE</key></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="607">\<key>ESPACE</key></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="608">\<key>TABULATION</key></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="609">\<w> </w> (controblique-espace)</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1131">\<w> </w> (controblique-espace)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1132">\<key>ESPACE</key></indexterm></findex>

<para>Cette rubrique concerne la commande qui consiste en deux caractères, une
controblique suivie d&textrsquo;un espace.&linebreak;Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\<w> </w>
</pre></example>

<para>Produit un espace. Par défaut elle produit de l&textrsquo;espace blanc de longueur
3.33333<dmn>pt</dmn> plus 1.66666<dmn>pt</dmn> minus 1.11111<dmn>pt</dmn>.
</para>
<para>Quand vous tapez un ou plusieurs blancs entre des mots, &latex; produit
de l&textrsquo;espace blanc. Mais ceci diffère d&textrsquo;un espace explicite, comme
illustré ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;rl&rbrace;
Un blanc~:&amp; fabrique de l'espace\\
Trois blancs~:&amp;   à la suite\\
Trois espaces~:&amp;\ \ \ à la suite\\
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>Sur la première ligne &latex; met de l&textrsquo;espace après le deux-points.
Sur la deuxième ligne &latex; compte les trois blancs comme un seul
pour mettre un seul espace blanc, de sorte que vous obtenez après le
deux-points le même espace que dans la première ligne.  &latex;
compterait de la même façon un seul espace blanc si l&textrsquo;un ou plusieurs
des blancs étaient remplacés par des caractères tabulation ou saut de
ligne.  Toutefois, la ligne du bas demandant trois espaces la zone en
blanc est plus large. c.-à-d.&noeos; que la commande controblique-espace crée
une quantité fixe d&textrsquo;espace horizontal.  (Notez que vous pouvez définir
un espace horizontal d&textrsquo;une largeur quelconque avec <code>\hspace</code>;
voir &nbsp;<ref label="_005chspace"><xrefnodename>\hspace</xrefnodename></ref>).
</para>
<para>La commande controblique-espace a deux usages principaux.  Elle est
souvent utilisée après une séquence de contrôle pour l&textrsquo;empêcher d&textrsquo;avaler
le blanc qui suit, comme après <code>\TeX</code> dans <code>\TeX\ (ou
\LaTeX)</code>.  (Mais l&textrsquo;utilisation d&textrsquo;accolades a l&textrsquo;avantage de fonctionner
systématiquement, que la séquence de contrôle soit suivie d&textrsquo;un blanc ou
de tout autre non-lettre, comme dans <code>\TeX&lbrace;&rbrace; (ou \LaTeX&lbrace;&rbrace;)</code> où
<code>&lbrace;&rbrace;</code> peut être rajouté aussi bien après <code>\LaTeX</code> qu&textrsquo;après
<code>\TeX</code>).  L&textrsquo;autre utilisation usuelle est de marquer qu&textrsquo;un point
termine une abréviation et non une phrase, comme dans <code>Prof.\
Fabre</code> or <code>Jean et al.\ (1993)</code> (<pxref label="_005c_0040"><xrefnodename>\&arobase;</xrefnodename></pxref>).
</para>
<para>Dans les circonstances normales, <code>\</code><key>tabulation</key> et
<code>\</code><key>sautdeligne</key> sont équivalents à controblique-espace,
<code>\ </code>.
</para>
<anchor name="Leading-blanks">Leading blanks</anchor>
<para>Veuillez aussi noter que de sorte à autoriser le renfoncement du code,
dans les circonstances normales, &tex; ignore les blancs au début de
chaque ligne. Ainsi l&textrsquo;exemple suivant imprime <samp>À moi comte deux
mots</samp>:
</para>
<example endspaces=" ">
<pre xml:space="preserve">À moi, Comte,
 deux mots !
</pre></example>

<noindent></noindent>
<para>où l&textrsquo;espace blanc entre <samp>Comte,</samp> et <samp>deux</samp> est produit par le
saut de ligne après <samp>Comte</samp>, et non par l&textrsquo;espace avant <samp>deux</samp>.
</para>
</section>
<node name="_007e" spaces=" "><nodename>~</nodename><nodenext automatic="on">\thinspace &amp; \negthinspace</nodenext><nodeprev automatic="on">\(SPACE)</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>~</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1133">~</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="610">espace insécable</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="611">insécable, espace</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="612">NBSP</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><var>avant</var>~<var>après</var>
</pre></example>

<para>Le caractère tilde, <code>~</code>, produit une espace <dfn>insécable</dfn> entre
<var>avant</var> et <var>après</var>, c&textrsquo;est à dire une espace où un saut de ligne
n&textrsquo;est pas autorisé. Par défaut l&textrsquo;espace blanc a une longueur de
3.33333<dmn>pt</dmn> plus 1.66666<dmn>pt</dmn> minus 1.11111<dmn>pt</dmn>
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple suivant &latex; ne fait pas de saut de ligne entre les
deux derniers mots.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Remerciements au Prof.~Lerman.
</pre></example>

<noindent></noindent>
<para>De plus, en dépit du point, &latex; n&textrsquo;utilise pas l&textrsquo;espacement de fin
de phrase (<pxref label="_005c_0040"><xrefnodename>\&arobase;</xrefnodename></pxref>).
</para>
<para>Les insécables empêchent qu&textrsquo;une fin de ligne sépare des choses là où cela
prêterait à confusion. Ils n&textrsquo;empêchent par contre pas la césure (de l&textrsquo;un ou
l&textrsquo;autre des mots de part et d&textrsquo;autre), de sorte qu&textrsquo;ils sont en général
préférables à mettre deux mots consécutifs dans une <code>\mbox</code>
(<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></pxref>).
</para>
<para>Ils sont aussi une question de goût, parfois très dogmatique, parmi les
lecteurs. Néanmoins, on présente ci-après quelques usages, dont la
plupart sont issus du <cite>&tex;book</cite>.
</para>
<itemize spaces=" " endspaces=" "><itemprepend>&textndash;</itemprepend>
<listitem><prepend>&textndash;</prepend>
<para>Entre l&textrsquo;étiquette et le numéro d&textrsquo;un énumérateur, comme dans les références :
<code>Chapitre~12</code>, or <code>Théorème~\ref&lbrace;th:Wilsons&rbrace;</code>, ou
<code>Figure~\ref&lbrace;fig:KGraph&rbrace;</code>.
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Lorsque des alternatives sont énumérés en ligne : <code>(b)~Montrez que $f(x)$ est
(1)~continue, et (2)~bornée</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1134"><r>paquetage</r> <code>siunitx</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1135"><code>siunitx</code>, <r>paquetage</r></indexterm></findex>

</listitem><listitem><prepend>&textndash;</prepend>
<para>Entre un nombre et son unité : <code>$745.7.8$~watts</code> (le paquetage
<code>siunitx</code> a des fonctions spécifiques pour cela) ou
<code>144~œufs</code>. Ceci comprend le cas du quantième et du nom du mois
dans une date : <code>12~octobre</code> ou <code>12~oct</code>. En général, dans
toute expression où un nombre et une abréviation ou un symbole sont
séparés par une espace : <code>565~ap.~\mbox&lbrace;J.-C.&rbrace;</code>, ou
<code>2:50~pm</code>, ou <code>Airbus~A320</code>, ou <code>26~rue des Oliviers
Road</code>, ou <code>\$$1.4$~billion</code>. D&textrsquo;autres choix usuels sont l&textrsquo;espace fine (<pxref label="_005cthinspace-_0026-_005cnegthinspace"><xrefnodename>\thinspace &amp; \negthinspace</xrefnodename></pxref>) et aucune espace du tout.
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Quand des expressions mathématiques sont rendues en mots :
<code>égal~$n$</code>, ou <code>inférieur à~$\epsilon$</code>, ou <code>soit~$X$</code>,
ou <code>modulo~$p^e$ pour tout~$n$</code> (mais comparez <code>vaut~$15$</code>
avec <code>vaut $15$~fois la hauteur</code>). Entre symboles mathématiques en
apposition avec des noms : <code>dimension~$d$</code> ou
<code>fonction~$f(x)$</code> (mais comparez avec <code>de longueur $l$~ou
plus</code>). Quand un symbole est un objet étroitement lié à une préposition :
<code>de~$x$</code>, ou <code>de $0$ à~$1$</code>, ou <code>en commun avec~$m$</code>.
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Entre les symboles d&textrsquo;une série : <code>$1$,~$2$, ou~$3$</code> ou <code>$1$,~$2$,
\ldots,~$n$</code>.
</para>
</listitem><listitem><prepend>&textndash;</prepend>
<para>Entre les prénoms d&textrsquo;une personne et entre des noms de famille
multiples : <code>Donald~E. Knuth</code>, ou <code>Luis~I. Trabb~Pardo</code>, ou
<code>Charles~XII</code> &textmdash; mais vous devez donner à &tex; des endroits où
faire un saut de ligne, par exemple comme dans <code>Charles Louis
Xavier~Joseph de~la Vall\'ee~Poussin</code>.
</para>
</listitem></itemize>

</section>
<node name="_005cthinspace-_0026-_005cnegthinspace" spaces=" "><nodename>\thinspace &amp; \negthinspace</nodename><nodenext automatic="on">\/</nodenext><nodeprev automatic="on">~</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\thinspace</code> &amp; <code>\negthinspace</code></sectiontitle>

<anchor name="_005cthinspace">\thinspace</anchor>
<anchor name="_005cnegthinspace">\negthinspace</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1136">\thinspace</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1137">\negthinspace</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="613">fine, espace</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="614">espace fine</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="615">fine, espace, négative</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="616">espace fine négative</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\thinspace
\negthinspace
</pre></example>

<para>Produisent une espace insécable et non-élastique qui vaut 1/6 d&textrsquo;<dmn>em</dmn>
et 1/6 d&textrsquo;<dmn>em</dmn> respectivement. Ce sont les équivalents mode texte de
<code>\,</code> and <code>\!</code> (<pxref label="Spacing-in-math-mode_002f_005cthinspace"><xrefnodename>Spacing in math mode/\thinspace</xrefnodename></pxref>).
</para>
<para>On peut utiliser <code>\,</code> comme synonyme de <code>\thinspace</code> en mode texte.
</para>
<para>Une utilisation usuelle de <code>\thinspace</code> est en typographie anglaise
comme l&textrsquo;espace entre des guillemets anglais simples emboîtés :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Killick répondit : ``J'ai entendu le capitaine dire `Ohé du bâteau~!'\thinspace''
</pre></example>

<noindent></noindent>
<para>Une autre utilisation est que certains guides de style demandent un
<code>\thinspace</code> entre les points de suspension et un point terminant
une phrase (dans d&textrsquo;autres guides de style on considère que les points de
suspension et/ou les points de suspension et le quatrième point
suffisent).  Une autre utilisation spécifique au style est entre les
initiales, comme dans <code>D.\thinspace E.\ Knuth</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1138"><r>paquetage</r> <code>amsmath</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1139"><code>amsmath</code>, <r>paquetage</r></indexterm></findex>

<para>&latex; fournit diverses commandes d&textrsquo;espacement similaires pour le mode
mathématique (<pxref label="Spacing-in-math-mode"><xrefnodename>Spacing in math mode</xrefnodename></pxref>).  Avec le paquetage
<code>amsmath</code>, ou depuis la parution 2020-10-01 de &latex;, elle sont
utilisables aussi bien en mode texte qu&textrsquo;en mode mathématique, y compris
<code>\!</code> pour <code>\negthinspace</code> ; mais sinon, elles ne sont disponibles
qu&textrsquo;en mode mathématique.
</para>

</section>
<node name="_005c_002f" spaces=" "><nodename>\/</nodename><nodenext automatic="on">\hrulefill &amp; \dotfill</nodenext><nodeprev automatic="on">\thinspace &amp; \negthinspace</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\/</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1140">\/</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="617">Correction italique</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><var>caractère-précédent</var>\/<var>caractère-suivant</var>
</pre></example>

<para>La commande <code>\/</code> produit une <dfn>correction italique</dfn>.  C&textrsquo;est une
petite espace définie par l&textrsquo;auteur de la fonte pour chacun des caractères
(elle peut être nulle). Quand vous utilisez <code>\/</code>, &latex; prend la
correction dans le fichier de métriques de fonte, la dilate/contracte de
la même façon que la fonte si tant est que la taille de celle-ci fût
dilatée/contractée, et ensuite insère cette quantité d&textrsquo;espace.
</para>
<para>Dans l&textrsquo;exemple ci-dessous, sans le <code>\/</code>, le
<var>caractère-précédent</var> f italique taperait dans le
<var>caractère-suivant</var> H romain :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\logoentreprise&rbrace;&lbrace;&lbrace;\it f&rbrace;\/H&rbrace;
</pre></example>

<noindent></noindent>
<para>parce que la lettre f italique penche loin vers la droite.
</para>
<para>Si <var>caractère-suivant</var> est un point ou une virgule, il n&textrsquo;est pas
nécessaire d&textrsquo;insérer une correction italique, puisque ces symboles de
ponctuation sont d&textrsquo;une faible hauteur. Toutefois, avec les
points-virgules ou les deux-points, de même qu&textrsquo;avec les lettres normales,
elle peut être utile. On l&textrsquo;utilise typiquement à l&textrsquo;endroit où l&textrsquo;on passe
d&textrsquo;une fonte italique ou inclinée à une fonte droite.
</para>
<para>Quand vous utilisez des commandes telles que <code>\emph</code>,
<code>\textit</code> ou <code>\textsl</code> pour changer la fonte, &latex; insère
automatiquement la correction italique là où besoin est (<pxref label="Font-styles"><xrefnodename>Font
styles</xrefnodename></pxref>).  Toutefois, des déclarations telle que <code>\em</code>, <code>\itshape</code>
ou <code>\slshape</code> n&textrsquo;insèrent pas automatiquement de correction italique.
</para>
<para>Les caractères droits peuvent aussi avoir une correction italique. Un
exemple où elle est nécessaire est le nom <code>pdf\/\TeX</code>. Toutefois,
la plupart des caractères droits ont une correction italique
nulle. Certains auteurs de fonte n&textrsquo;incluent pas de valeur de correction
italique même pour les fontes italiques.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1141">\fontdimen1</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="618">dimension de fonte, inclinaison</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="619">fonte, dimension, inclinaison</indexterm></cindex>
<para>Techniquement, &latex; utilise une autre valeur spécifique à la fonte,
appelé <dfn>paramètre d&textrsquo;inclinaison</dfn> (nommément <code>\fontdimen1</code>),
pour déterminer s&textrsquo;il est possible d&textrsquo;insérer une correction italique, au
lieu d&textrsquo;attacher cette action à des commandes particulières de contrôle
de la fonte.
</para>
<para>Le concept de correction italique n&textrsquo;existe pas en mode mathématique ;
l&textrsquo;espacement y est fait d&textrsquo;une façon différente.
</para>

</section>
<node name="_005chrulefill-_0026-_005cdotfill" spaces=" "><nodename>\hrulefill &amp; \dotfill</nodename><nodenext automatic="on">\bigskip &amp; \medskip &amp; \smallskip</nodenext><nodeprev automatic="on">\/</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\hrulefill</code> &amp; <code>\dotfill</code></sectiontitle>

<anchor name="_005chrulefill">\hrulefill</anchor>
<anchor name="_005cdotfill">\dotfill</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1142">\hrulefill</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1143">\dotfill</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\hrulefill
\dotfill
</pre></example>

<para>Produit une longueur élastique infinie (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>) remplie avec un
filet horizontal (c.-à-d.&noeos; une ligne) ou avec des pointillés, au lieu
d&textrsquo;espace blanc.
</para>
<para>L&textrsquo;exemple ci-dessous produit une ligne de 5<dmn>cm</dmn> de long :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Nom:~\makebox[5cm]&lbrace;\hrulefill&rbrace;
</pre></example>

<para>Quand on le place entre deux lignes à blanc cet exemple crée un
paragraphe qui est justifié à gauche et à droite, et où l&textrsquo;espace au
milieu est rempli avec des pointillés uniformément espacés.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\noindent Capt Robert Surcouf\dotfill&lbrace;&rbrace; Saint-Malo
</pre></example>

<para>Pour que le filet ou les pointillés aillent jusqu&textrsquo;au bout de la ligne
utilisez <code>\null</code> au début ou à la fin.
</para>
<para>Pour changer l&textrsquo;épaisseur du filet, copiez la définition et ajustez là,
comme ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\hrulefill&rbrace;&lbrace;%
   \leavevmode\leaders\hrule height 1pt\hfill\kern\z&arobase;&rbrace;
</pre></example>

<noindent></noindent>
<para>ce qui change l&textrsquo;épaisseur par défaut de 0.4<dmn>pt</dmn> à 1<dmn>pt</dmn>.  De
même, ajustez l&textrsquo;espacement inter-pointillé comme avec :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\dotfill&rbrace;&lbrace;%
  \leavevmode\cleaders\hb&arobase;xt&arobase;1.00em&lbrace;\hss .\hss &rbrace;\hfill\kern\z&arobase;&rbrace;
</pre></example>

<noindent></noindent>
<para>ce qui change la longueur par défaut de 0.33<dmn>em</dmn> à 1.00<dmn>em</dmn>.
</para>
<para>L&textrsquo;exemple suivant produit une ligne pour signer :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;minipage&rbrace;&lbrace;4cm&rbrace;
  \centering
  Signature:\\
  \hrulefill
\end&lbrace;minipage&rbrace;
</pre></example>

<noindent></noindent>
<para>La ligne fait 4<dmn>cm</dmn> de long.
</para>

</section>
<node name="_005cbigskip-_0026-_005cmedskip-_0026-_005csmallskip" spaces=" "><nodename>\bigskip &amp; \medskip &amp; \smallskip</nodename><nodenext automatic="on">\bigbreak &amp; \medbreak &amp; \smallbreak</nodenext><nodeprev automatic="on">\hrulefill &amp; \dotfill</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\bigskip</code> &amp; <code>\medskip</code> &amp; <code>\smallskip</code></sectiontitle>
<anchor name="_005cbigskip">\bigskip</anchor>
<anchor name="_005cmedskip">\medskip</anchor>
<anchor name="_005csmallskip">\smallskip</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1144">\bigskip</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1145">\medskip</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1146">\smallskip</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bigskip
\medskip
\smallskip
</pre></example>

<para>Produit une certaine quantité d&textrsquo;espace vertical, grand, de taille
moyenne, ou petit. Ces commandes sont fragiles (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple ci-dessous le saut suggère le passage du temps (tiré de
<i>L&textrsquo;océan d&textrsquo;or</i> de Patrick O&textrsquo;Brian).
</para>
<example endspaces=" ">
<pre xml:space="preserve">Mr Saumarez aurait eu à lui dire quelque grossièreté, sans aucun
doute : il était de nouveau comme chez lui, et c'était un plaisir.

\bigskip
« Cent cinquante-sept miles et un tiers, en vingt-quatre heures », dit Peter.
</pre></example>

<para>Chaque commande est associée à une longueur définie dans le source de la
classe du document.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="bigskip">bigskip</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1147">\bigskip</indexterm>\bigskip</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1148">\bigskipamount</indexterm></findex>
<para>La même chose que <code>\vspace&lbrace;\bigskipamount&rbrace;</code>, ordinairement environ
l&textrsquo;espace d&textrsquo;une ligne, avec dilatation et rétrécissement. La valeur par
défaut pour les classes <code>book</code> et <code>article</code> est <code>12pt
plus 4pt minus 4pt</code>.
</para>
<anchor name="medskip">medskip</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1149">\medskip</indexterm>\medskip</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1150">\medskipamount</indexterm></findex>
<para>La même chose que <code>\vspace&lbrace;\medskipamount&rbrace;</code>, ordinairement
environ la moitié de l&textrsquo;espace d&textrsquo;une ligne, avec dilatation et
rétrécissement. La valeur par défaut pour les classes <code>book</code> et
<code>article</code> est <code>6pt plus 2pt minus 2pt</code>).
</para>
<anchor name="smallskip">smallskip</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1151">\smallskip</indexterm>\smallskip</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1152">\smallskipamount</indexterm></findex>
<para>La même chose que <code>\vspace&lbrace;\smallskipamount&rbrace;</code>, ordinairement
environ le quart de l&textrsquo;espace d&textrsquo;une ligne, avec dilatation et
rétrécissement. la valeur par défaut pour les classes <code>book</code> et
<code>article</code> est <code>3pt plus 1pt minus 1pt</code>.
</para>
</tableitem></tableentry></ftable>

<para>Comme chaque commande est un <code>\vspace</code>, si vous l&textrsquo;utilisez au
milieu d&textrsquo;un paragraphe, alors elle insère son espace vertical entre la
ligne dans laquelle vous l&textrsquo;utilisez et la ligne suivante, et non pas
nécessairement à l&textrsquo;endroit où vous l&textrsquo;utilisez. Ainsi il est préférable
d&textrsquo;utiliser ces commandes entre les paragraphes.
</para>
<para>Les commandes <code>\bigbreak</code>, <code>\medbreak</code>, et <code>\smallbreak</code>
sont similaires mais suggèrent également à &latex; que l&textrsquo;endroit
est adéquat pour un saut de page (<pxref label="_005cbigbreak-_0026-_005cmedbreak-_0026-_005csmallbreak"><xrefnodename>\bigbreak &amp;
\medbreak &amp; \smallbreak</xrefnodename></pxref>.
</para>

</section>
<node name="_005cbigbreak-_0026-_005cmedbreak-_0026-_005csmallbreak" spaces=" "><nodename>\bigbreak &amp; \medbreak &amp; \smallbreak</nodename><nodenext automatic="on">\strut</nodenext><nodeprev automatic="on">\bigskip &amp; \medskip &amp; \smallskip</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\bigbreak</code> &amp; <code>\medbreak</code> &amp; <code>\smallbreak</code></sectiontitle>

<anchor name="_005cbigbreak">\bigbreak</anchor>
<anchor name="_005cmedbreak">\medbreak</anchor>
<anchor name="_005csmallbreak">\smallbreak</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1153">\bigbreak</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1154">\medbreak</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1155">\smallbreak</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\bigbreak
\medbreak
\smallbreak
</pre></example>

<para>Produit un espace vertical grand, de taille moyenne ou petit, et suggère
à &latex; que l&textrsquo;endroit est adéquat pour un saut de page.  (Les
pénalités associées sont respectivement &minus;200, &minus;100, et
&minus;50).
</para>
<para><xref label="_005cbigskip-_0026-_005cmedskip-_0026-_005csmallskip"><xrefnodename>\bigskip &amp; \medskip &amp; \smallskip</xrefnodename></xref>, pour plus ample information.
Ces commandes produisent le même espace vertical mais diffèrent en ce
qu&textrsquo;elles suppriment également un espace vertical précédent s&textrsquo;il est
inférieur à ce qu&textrsquo;elles inséreraient (comme avec <code>\addvspace</code>).  De
plus, elles terminent le paragraphe où on les utilise. Dans cet
exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">abc\bigbreak def ghi

jkl mno pqr
</pre></example>

<noindent></noindent>
<para>on a en sortie trois paragraphes, le premier se termine en <samp>abc</samp> et
le deuxième commence, après un espace vertical supplémentaire et un
renfoncement, par <samp>def</samp>.
</para>

</section>
<node name="_005cstrut" spaces=" "><nodename>\strut</nodename><nodenext automatic="on">\vspace</nodenext><nodeprev automatic="on">\bigbreak &amp; \medbreak &amp; \smallbreak</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\strut</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1156">\strut</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="620">étai</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\strut
</pre></example>

<para>Étai. Assure que la ligne courante a une hauteur d&textrsquo;au moins
<code>0.7\baselineskip</code> et une profondeur d&textrsquo;au moins
<code>0.3\baselineskip</code>.  Pour l&textrsquo;essentiel, &latex; insère dans la
ligne un rectangle de largeur nulle,
<code>\rule[-0.3\baselineskip]&lbrace;0pt&rbrace;&lbrace;\baselineskip&rbrace;</code> (<pxref label="_005crule"><xrefnodename>\rule</xrefnodename></pxref>).
Le <code>\baselineskip</code> change avec la fonte courante ou sa taille.
</para>
<para>Dans l&textrsquo;exemple suivant le <code>\strut</code> empêche la boîte d&textrsquo;avoir une
hauteur nulle.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\fboxsep&rbrace;&lbrace;0pt&rbrace;\framebox[5cm]&lbrace;\strut&rbrace;
</pre></example>

<para>L&textrsquo;exemple suivant comprend quatre listes. Dans la première il y a un
espace bien plus large entre les articles 2 et 3 qu&textrsquo;il n&textrsquo;y a entre les
articles 1 et 2. La seconde liste répare cela avec un <code>\strut</code> à la
fin de la deuxième ligne du premier article.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\fboxsep&rbrace;&lbrace;0pt&rbrace;
\noindent\begin&lbrace;minipage&rbrace;[t]&lbrace;0.2\linewidth&rbrace;
\begin&lbrace;enumerate&rbrace;
  \item \parbox[t]&lbrace;15pt&rbrace;&lbrace;test \\ test&rbrace;
  \item test
  \item test
\end&lbrace;enumerate&rbrace;
\end&lbrace;minipage&rbrace;%
\begin&lbrace;minipage&rbrace;[t]&lbrace;0.2\linewidth&rbrace;
\begin&lbrace;enumerate&rbrace;
  \item \parbox[t]&lbrace;15pt&rbrace;&lbrace;test \\ test\strut&rbrace;
  \item test
  \item test
\end&lbrace;enumerate&rbrace;
\end&lbrace;minipage&rbrace;%
\begin&lbrace;minipage&rbrace;[t]&lbrace;0.2\linewidth&rbrace;
\begin&lbrace;enumerate&rbrace;
  \item \fbox&lbrace;\parbox[t]&lbrace;15pt&rbrace;&lbrace;test \\ test&rbrace;&rbrace;
  \item \fbox&lbrace;test&rbrace;
  \item \fbox&lbrace;test&rbrace;
\end&lbrace;enumerate&rbrace;
\end&lbrace;minipage&rbrace;%
\begin&lbrace;minipage&rbrace;[t]&lbrace;0.2\linewidth&rbrace;
\begin&lbrace;enumerate&rbrace;
  \item \fbox&lbrace;\parbox[t]&lbrace;15pt&rbrace;&lbrace;test \\ test\strut&rbrace;&rbrace;
  \item \fbox&lbrace;test&rbrace;
  \item \fbox&lbrace;test&rbrace;
\end&lbrace;enumerate&rbrace;
\end&lbrace;minipage&rbrace;%
</pre></example>

<noindent></noindent>
<para>Les deux dernières listes utilisent <code>\fbox</code> pour montrer ce qui se
passe. La <code>\parbox</code> du premier article de la troisième liste ne va
que jusqu&textrsquo;au bas du second <samp>test</samp>, or ce mot ne comprend aucun
caractère descendant sous la ligne de base.  Le <code>\strut</code> ajouté
dans la quatrième liste donne sous la ligne de base l&textrsquo;espace
supplémentaire requis.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1157"><r>paquetage</r> <code>TikZ</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1158"><code>TikZ</code>, <r>paquetage</r></indexterm></findex>
 <findex index="fn" spaces=" "><indexterm index="fn" number="1159"><r>paquetage</r> <code>Asymptote</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1160"><code>Asymptote</code>, <r>paquetage</r></indexterm></findex>


<para>La commande <code>\strut</code> est souvent utile pour les graphiques, comme en
<code>TikZ</code> ou <code>Asymptote</code>.  Par exemple, vous pourriez avoir une
commande telle que <code>\graphnode&lbrace;<var>nom-nœud</var>&rbrace;</code> qui ajuste un
cercle autour de <var>nom-nœud</var>. Toutefois, à moins que vous preniez
certaines précautions, prendre <samp>x</samp> ou <samp>y</samp> pour <var>nom-nœud</var>
produit des cercles de diamètres différents parce que les caractères ont
des tailles différentes.  Une précaution possible contre cela serait que
<code>\graphnode</code> insère <code>\strut</code> juste avant <var>nom-nœud</var>, et
ne dessine le cercle qu&textrsquo;après cela.
</para>
<para>L&textrsquo;approche générale d&textrsquo;utiliser une <code>\rule</code> de largeur nulle est
utile dans de nombreuses circonstances. Dans le tableau ci-dessous, le
filet de largeur nulle empêche le haut de la première intégrale de taper
dans la <code>\hline</code>. De même, le second filet empêche la seconde
intégrale de taper sur la première.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;rl&rbrace;
  \textsc&lbrace;Intégrale&rbrace;   &amp;\textsc&lbrace;Valeur&rbrace;           \\
  \hline
  $\int_0^x t\, dt$   &amp;$x^2/2$  \rule&lbrace;0em&rbrace;&lbrace;2.5ex&rbrace; \\
  $\int_0^x t^2\, dt$ &amp;$x^3/3$  \rule&lbrace;0em&rbrace;&lbrace;2.5ex&rbrace;
\end&lbrace;tabular&rbrace;
</pre></example>

<noindent></noindent>
<para>(Bien que la commande double controblique de terminaison de ligne
dispose d&textrsquo;un argument optionnel pour changer la valeur de l&textrsquo;interligne
correspondant, cela ne fonctionne pas pour résoudre ce problème.
Changer la première double controblique en quelque chose du genre de
<code>\\[2.5ex]</code> augmente l&textrsquo;espace entre la ligne d&textrsquo;en-têtes de colonne
et le filet <code>\hline</code>, et l&textrsquo;intégrale de la deuxième ligne taperait
encore dans le filet).
</para>
</section>
<node name="_005cvspace" spaces=" "><nodename>\vspace</nodename><nodenext automatic="on">\vfill</nodenext><nodeprev automatic="on">\strut</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\vspace</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1161">\vspace</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="621">espace verticale</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="622">verticale, espace</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\vspace&lbrace;<var>longueur</var>&rbrace;
\vspace*&lbrace;<var>longueur</var>&rbrace;
</pre></example>

<para>Ajoute l&textrsquo;espace verticale <var>longueur</var>.  Celle-ci peut-être positive,
négative, ou nulle.  C&textrsquo;est une longueur élastique &textmdash; elle peut contenir
une composante <code>plus</code> ou <code>minus</code> (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple ci-dessous met de l&textrsquo;espace entre les deux paragraphes :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Et je dormis.

\vspace&lbrace;1ex plus 0.5ex&rbrace;
L'aube fraiche d'un nouveau jour.
</pre></example>
<noindent></noindent>
<para>(<xref label="_005cbigskip-_0026-_005cmedskip-_0026-_005csmallskip"><xrefnodename>\bigskip &amp; \medskip &amp; \smallskip</xrefnodename></xref>, pour les espaces
inter-paragraphes usuelles).
</para>
<para>La forme en <code>*</code> insère de l&textrsquo;espace vertical non suppressible. Plus
précisément, &latex; supprime l&textrsquo;espace vertical au sauts de page et la
forme en <code>*</code> a pour effet de conserver l&textrsquo;espace. Cet exemple ménage
une espace entre les deux questions :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Question~: trouver l'intégrale de \( 5x^4+5 \).

\vspace*&lbrace;2cm plus 0.5cm&rbrace;
Question~: trouver la dérivée de \( x^5+5x+9 \).
</pre></example>

<noindent></noindent>
<para>Cette espace sera présente même si un saut de page survient entre les
questions.
</para>
<para>Si <code>\vspace</code> est utilisée au milieu d&textrsquo;un paragraphe (c.-à-d.&noeos; en
mode horizontal), l&textrsquo;espace est insérée <emph>après</emph> la ligne comprenant
la commande <code>\vspace</code> sans commencer un nouveau paragraphe.
</para>
<para>Dans cet exemple les deux questions sont espacées uniformément
verticalement sur la page, avec au moins 2,5<dmn>cm</dmn> d&textrsquo;espace sous
chacune d&textrsquo;elle.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;document&rbrace;
1) Z'avez pas vu Mirza ? Oh la la la la la la
\vspace&lbrace;2.5cm plus 1fill&rbrace;

2) Où est donc passé ce chien ? Je le cherche partout
\vspace&lbrace;2.5cm plus 1fill&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

</section>
<node name="_005cvfill" spaces=" "><nodename>\vfill</nodename><nodenext automatic="on">\addvspace</nodenext><nodeprev automatic="on">\vspace</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<!-- c xx Realigner sur l'anglais -->
<section spaces=" "><sectiontitle><code>\vfill</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1162">\vfill</indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="623">dilatation verticale infinie</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="624">verticale infinie, dilatation</indexterm></cindex>

<para>Finit le paragraphe courant et insère une longueur élastique verticale
(<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>) qui est infinie, de sorte qu&textrsquo;elle puisse se dilater ou
se rétrécir autant que nécessaire.
</para>
<para>On l&textrsquo;utilise souvent de la même façon que <code>\vspace&lbrace;\fill&rbrace;</code>, à
ceci près que <code>\vfill</code> finit le paragraphe courant, tandis que
<code>\vspace&lbrace;\fill&rbrace;</code> ajoute un espace vertical infini sous sa
ligne sans tenir compte de la structure du paragraphe.  Dans les deux
cas cet espace disparaît à la fin de la page ; pour éviter cela
voir <ref label="_005cvspace"><xrefnodename>\vspace</xrefnodename></ref>.
</para>
<para>Dans l&textrsquo;exemple qui suit la page est remplie, de sorte que les lignes en
haut et en bas contiennent le texte <samp>Chien perdu !</samp> et que le
troisième <samp>Chien perdu !</samp> est exactement à mi-chemin entre eux.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;document&rbrace;
Chien perdu !
\vfill
Chien perdu !
\vfill
Chien perdu !
\end&lbrace;document&rbrace;
</pre></example>

</section>
<node name="_005caddvspace" spaces=" "><nodename>\addvspace</nodename><nodeprev automatic="on">\vfill</nodeprev><nodeup automatic="on">Spaces</nodeup></node>
<section spaces=" "><sectiontitle><code>\addvspace</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1163">\addvspace</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="625">espace vertical</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="626">espace vertical, insérer</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addvspace&lbrace;<var>long-vert</var>&rbrace;
</pre></example>

<para>Ajoute un espace vertical de longueur <var>long-vert</var>.  Toutefois, si il
y a deux ou plus <code>\addvspace</code> à la suite, alors elles ajoutent
seulement l&textrsquo;espace nécessaire à fabriquer la longueur naturelle égale au
maximum des <var>long-vert</var> correspondant. Cette commande est fragile
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>). La longueur <var>long-vert</var> est une longueur
élastique (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivante illustre l&textrsquo;usage de la commande.  L&textrsquo;environnement
<code>picture</code> dessine une échelle sur laquelle deux filets sont
posés. Dans un document &latex; de classe standarde <code>article</code> la
longueur <code>\baselineskip</code> vaut 12<dmn>pt</dmn>.  Comme l&textrsquo;indique
l&textrsquo;échelle, les deux filets sont écartés de 22<dmn>pt</dmn> : la somme des
<code>\baselineskip</code> et de 10<dmn>pt</dmn> provenant du premier
<code>\addvspace</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\usepackage&lbrace;color&rbrace;
\begin&lbrace;document&rbrace;
\setlength&lbrace;\unitlength&rbrace;&lbrace;2pt&rbrace;%
\noindent\begin&lbrace;picture&rbrace;(0,0)%
  \multiput(0,0)(0,-1)&lbrace;25&rbrace;&lbrace;&lbrace;\color&lbrace;blue&rbrace;\line(1,0)&lbrace;1&rbrace;&rbrace;&rbrace;
  \multiput(0,0)(0,-5)&lbrace;6&rbrace;&lbrace;&lbrace;\color&lbrace;red&rbrace;\line(1,0)&lbrace;2&rbrace;&rbrace;&rbrace;
\end&lbrace;picture&rbrace;%
\rule&lbrace;0.25\linewidth&rbrace;&lbrace;0.1pt&rbrace;%
\par\addvspace&lbrace;10pt&rbrace;% \addvspace&lbrace;20pt&rbrace;%
\par\noindent\rule&lbrace;0.25\linewidth&rbrace;&lbrace;0.1pt&rbrace;%
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>Si dans l&textrsquo;exemple précédent on décommente le second <code>\addvspace</code>,
l&textrsquo;écart entre les deux filets ne croit pas de 20<dmn>pt</dmn> ; mais au lieu
de cela l&textrsquo;écart devient la somme de <code>\baselineskip</code> et de
20<dmn>pt</dmn>. De sorte que <code>\addvspace</code> en un sens fait le contraire
de ce que son nom laisse entendre &textmdash; elle vérifie que des espaces
verticaux multiples ne s&textrsquo;accumulent pas, mais qu&textrsquo;au lieu de cela seul le
plus grand d&textrsquo;eux est utilisé.
</para>
<para>&latex; utilise cette commande pour ajuster l&textrsquo;espace vertical au-dessus
ou au-dessous d&textrsquo;un environnement qui commence un nouveau paragraphe. Par
exemple, un environnement <code>theorem</code> commence et finit avec une
<code>\addvspace</code> de sorte que deux <code>theorem</code> consécutifs sont séparés par
un espace vertical, et non deux.
</para>
<para>Une erreur <samp>Something's wrong--perhaps a missing \item</samp> pointant
sur un <code>\addvspace</code> signifie que vous n&textrsquo;étiez pas en mode vertical
quand vous avez invoqué cette commande ; une façon pour sortir de cela
et de faire précéder <code>\addvspace</code> d&textrsquo;une commande <code>\par</code>
(<pxref label="_005cpar"><xrefnodename>\par</xrefnodename></pxref>), comme dans l&textrsquo;exemple plus haut.
</para>
</section>
</chapter>
<node name="Boxes" spaces=" "><nodename>Boxes</nodename><nodenext automatic="on">Color</nodenext><nodeprev automatic="on">Spaces</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Boîtes</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="627">boîtes</indexterm></cindex>

<para>Dans le fond, &latex; met des choses dans des boîtes et ensuite met ces
boîtes sur une page. Aussi les commandes qui suivent sont centrales.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1164"><r>paquetage</r> <code>adjustbox</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1165"><code>adjustbox</code>, <r>paquetage</r></indexterm></findex>

<para>De nombreux paquetages sur le CTAN sont utiles pour la manipulation de
boîtes. Un ajout utile aux commandes décrites ici est <code>adjustbox</code>.
</para>
<!-- c xx Vérifier que la référence @pxref{Predefined lengths} est donnée -->
<!-- c par la suite. -->
<ignore>
Tous les paramètres de longueurs prédéfinies
(@pxref{Predefined lengths}) peuvent être utilisés au sein des arguments
des commandes de fabrication de boîtes.
</ignore>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::    ">\mbox &amp; \makebox</menunode><menudescription><pre xml:space="preserve">Boîtes horizontales.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator=":: ">\fbox &amp; \framebox</menunode><menudescription><pre xml:space="preserve">Mettre un cadre autour d&textrsquo;une boîte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">\parbox</menunode><menudescription><pre xml:space="preserve">Boîte avec du texte en mode paragraphe.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::           ">\raisebox</menunode><menudescription><pre xml:space="preserve">Élève ou abaisse le texte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">\sbox &amp; \savebox</menunode><menudescription><pre xml:space="preserve">Comme <code>\makebox</code>, mais sauvegarde le texte pour usage ultérieur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::               ">lrbox</menunode><menudescription><pre xml:space="preserve">Un environnement similaire à <code>\sbox</code>.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">\usebox</menunode><menudescription><pre xml:space="preserve">Compose le texte sauvegardé.
</pre></menudescription></menuentry></menu>


<node name="_005cmbox-_0026-_005cmakebox" spaces=" "><nodename>\mbox &amp; \makebox</nodename><nodenext automatic="on">\fbox &amp; \framebox</nodenext><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>\mbox</code> &amp; <code>\makebox</code></sectiontitle>

<anchor name="_005cmbox">\mbox</anchor>
<anchor name="_005cmakebox">\makebox</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1166">\mbox</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1167">\makebox</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="628">boîte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="629">fabriquer une boîte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="630">césure, empêcher</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="631">coupure de mot, empêcher</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi les suivants :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\mbox&lbrace;<var>texte</var>&rbrace;
\makebox&lbrace;<var>texte</var>&rbrace;
\makebox[<var>largeur</var>]&lbrace;<var>texte</var>&rbrace;
\makebox[<var>largeur</var>][<var>position</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>La commande <code>\mbox</code> crée un boîte, un conteneur pour de la
matière. Le <var>texte</var> est composé en mode LR (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>) ainsi il
n&textrsquo;est pas coupé en plusieurs lignes.  La commande <code>\mbox</code> est
robuste, alors que <code>\makebox</code> est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Comme <code>texte</code> n&textrsquo;est pas coupé en plusieurs lignes, on peut utiliser
<code>\mbox</code> pour empêcher une césure. Dans l&textrsquo;exemple suivant, &latex;
ne peut pas faire de césure dans le nom du char,
<samp>T-34</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Le char soviétique \mbox&lbrace;T-34&rbrace; est l'un des symboles de la victoire
sur le nazisme.
</pre></example>

<para>Dans les deux premières versions du synopsis, <code>\mbox</code> et
<code>\makebox</code> sont sensiblement équivalentes. Elles créent une boîte
juste assez large pour contenir le <var>texte</var>. (Elle sont comme le
<code>\hbox</code> du &tex; de base).
</para>
<para>Dans la troisième version l&textrsquo;argument optionnel <var>largeur</var> spécifie la
largeur de la boîte.  Notez que l&textrsquo;espace occupé par le texte n&textrsquo;est pas
nécessairement équivalent à la largeur de la boîte. D&textrsquo;une part,
<var>texte</var> peut être trop petit ; l&textrsquo;exemple suivant crée une boîte
d&textrsquo;une ligne entière de largeur :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makebox[\linewidth]&lbrace;Examen du chapitre&rbrace;
</pre></example>

<noindent></noindent>
<para>où <samp>Examen du chapitre</samp> est centré.  Mais <var>texte</var> peut aussi
être trop large pour <var>largeur</var>.  Voir l&textrsquo;exemple plus bas pour des
boîtes de largeur nulle.
</para>
<anchor name="mbox-makebox-depth">mbox makebox depth</anchor>
<anchor name="mbox-makebox-height">mbox makebox height</anchor>
<anchor name="mbox-makebox-width">mbox makebox width</anchor>
<anchor name="mbox-makebox-totalheight">mbox makebox totalheight</anchor>
<para>Au sein de l&textrsquo;argument <var>largeur</var> vous pouvez utiliser les longueurs
suivantes qui font référence aux dimensions de la boîte que &latex;
obtient en composant <var>texte</var> : <code>\depth</code>, <code>\height</code>,
<code>\width</code>, <code>\totalheight</code> (la somme de la hauteur et de la
profondeur de la boîte).  Par exemple, pour fabriquer une boîte où le
texte est dilaté au double de sa largeur naturelle vous pouvez écrire
ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makebox[2\width]&lbrace;Get a stretcher&rbrace;
</pre></example>

<para>Pour la quatrième version du synopsis, la position du texte au sein de
la boîte est déterminée par l&textrsquo;argument optionnel <var>position</var> qui peut
prendre l&textrsquo;une des valeurs suivantes :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">c</itemformat></item>
</tableterm><tableitem><para>Centré (par défaut).
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">l</itemformat></item>
</tableterm><tableitem><para>(Left) fer à gauche.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">r</itemformat></item>
</tableterm><tableitem><para>(Right) fer à droite.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">s</itemformat></item>
</tableterm><tableitem><!-- c xx TODO add a generic node to make clear that some statement may be -->
<!-- c not true for some internationalization or some script. Eg. in Arabic -->
<!-- c script or with microtype package I think that the strech also plays -->
<!-- c on word width -->
<para>(Stretch) dilate l&textrsquo;espace inter-mot dans <var>texte</var> sur la
<var>largeur</var> entière ; <var>texte</var> doit contenir de l&textrsquo;espace dilatable
pour que cela marche.  Par exemple, ceci pourrait être le libellé d&textrsquo;un
communiqué de presse :
<code>\noindent\makebox[\textwidth][s]&lbrace;\large\hfil DÉPÊCHE\hfil
IMMÉDIATE\hfil&rbrace;</code>
</para></tableitem></tableentry></table>

<para>Une utilisation courante de <code>\makebox</code> est de fabriquer des boîtes
de texte de largeur nulle.  Dans l&textrsquo;exemple suivant on place dans un
questionnaire la valeur des questions à leur gauche.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\pts&rbrace;[1]&lbrace;\makebox[0em][r]&lbrace;#1 points\hspace*&lbrace;1em&rbrace;&rbrace;&rbrace;
\pts&lbrace;10&rbrace;Quelle est la vitesse aérodynamique d'une hirondelle à vide ?

\pts&lbrace;90&rbrace;Une hirondelle africaine ou européenne ?
</pre></example>

<noindent></noindent>
<para><findex index="fn" spaces=" "><indexterm index="fn" number="1168"><r>paquetage</r> <code>TikZ</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1169"><code>TikZ</code>, <r>paquetage</r></indexterm></findex>
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1170"><r>paquetage</r> <code>Asymptote</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1171"><code>Asymptote</code>, <r>paquetage</r></indexterm></findex>

<para>Le bord droit de la sortie <samp>10 points </samp> (notez l&textrsquo;espace finale
après <samp>points</samp>) est juste avant le <samp>Quelle</samp>.  Vous pouvez
utiliser <code>\makebox</code> de la même manière quand vous faites des
graphiques, comme en <code>TikZ</code> ou <code>Asymptote</code>, où vous mettez le
bord du texte à une position connue, quelle que soit la longueur de ce
texte.
</para>
<para>Pour des boîtes avec cadre voir <ref label="_005cfbox-_0026-_005cframebox"><xrefnodename>\fbox &amp; \framebox</xrefnodename></ref>. Pour des boîtes
de couleurs voir <ref label="Colored-boxes"><xrefnodename>Colored boxes</xrefnodename></ref>.
</para>
<para>Il y a une version apparentée de <code>\makebox</code> qui utilisée au sein de
l&textrsquo;environnement <code>picture</code>, où la longueur est données en termes
d&textrsquo;<code>\unitlength</code> (<pxref label="_005cmakebox-_0028picture_0029"><xrefnodename>\makebox (picture)</xrefnodename></pxref>).
</para>
<para>Comme <var>texte</var> est composé en mode LR, ni une double controblique
<code>\\</code>, ni <code>\par</code> ne produisent un saut de ligne ; par exemple
<code>\makebox&lbrace;abc def \\ ghi&rbrace;</code> produit en sortie <samp>abc defghi</samp>
alors que <code>\makebox&lbrace;abc def \par ghi&rbrace;</code> produit <samp>abc def
ghi</samp>, tout deux sur une seule ligne.  Pour obtenir des lignes multiples
voir <ref label="_005cparbox"><xrefnodename>\parbox</xrefnodename></ref> et <ref label="minipage"><xrefnodename>minipage</xrefnodename></ref>.
</para>
</section>
<node name="_005cfbox-_0026-_005cframebox" spaces=" "><nodename>\fbox &amp; \framebox</nodename><nodenext automatic="on">\parbox</nodenext><nodeprev automatic="on">\mbox &amp; \makebox</nodeprev><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>\fbox</code> &amp; <code>\framebox</code></sectiontitle>

<anchor name="_005cfbox">\fbox</anchor>
<anchor name="_005cframebox">\framebox</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1172">\fbox</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1173">\framebox</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\fbox&lbrace;<var>texte</var>&rbrace;
\framebox&lbrace;<var>texte</var>&rbrace;
\framebox[<var>largeur</var>]&lbrace;<var>texte</var>&rbrace;
\framebox[<var>largeur</var>][<var>position</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Crée une boîte dans un cadre englobant, c.-à-d.&noeos; quatre filets entourant
le <var>texte</var>.  Les commandes <code>\fbox</code> et <code>\framebox</code> sont
similaires à <code>\mbox</code> et <code>\makebox</code>, au cadre près
(<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></pxref>). La commande <code>\fbox</code> est robuste, la
commande <code>\framebox</code> est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Dans l&textrsquo;exemple suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">\fbox&lbrace;Avertissement ! Tout devoir non rendu obtiendra une note de zéro.&rbrace;
</pre></example>

<noindent></noindent>
<para>&latex; met le texte dans une boîte, le texte ne peut subir de
césure. Autour de la boîte, séparés d&textrsquo;elle par une petit écart, quatre
filets forment un cadre.
</para>
<para>Les deux premières invocations de la commande, <code>\fbox&lbrace;...&rbrace;</code> et
<code>\framebox&lbrace;...&rbrace;</code>, sont sensiblement équivalentes. Quant aux
troisième et quatrième invocations, les arguments optionnels permettent
de spécifier la largeur de la boîte comme <var>largeur</var> (une longueur),
et la position du texte au sein de la boîte comme <var>position</var>.
<xref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></xref>, pour la description complète, mais ci-après
suit un exemple créant une boîte vide de 0,75<dmn>cm</dmn> de large.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\setlength&lbrace;\fboxsep&rbrace;&lbrace;0pt&rbrace;\framebox[0.75cm]&lbrace;\strut&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Le <code>\strut</code> assure que la hauteur totale soit de
<code>\baselineskip</code> (<pxref label="_005cstrut"><xrefnodename>\strut</xrefnodename></pxref>).
</para>
<para>Les paramètres suivant déterminent la disposition du cadre.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="fbox-framebox-fboxrule">fbox framebox fboxrule</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1174">\fboxrule</indexterm>\fboxrule</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1175">cadre, épaisseur du filet</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="632">\fboxrule</indexterm></cindex>
<para>L&textrsquo;épaisseur des filets autour de la boîte englobée. Par défaut elle vaut
0.2<dmn>pt</dmn>.  On la change avec une commande telle que
<code>\setlength&lbrace;\fboxrule&rbrace;&lbrace;0.8pt&rbrace;</code> (<pxref label="_005csetlength"><xrefnodename>\setlength</xrefnodename></pxref>).
</para>
<anchor name="fbox-framebox-fboxsep">fbox framebox fboxsep</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1176">\fboxsep</indexterm>\fboxsep</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1177">cadre, séparation d'avec le contenu</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="633">\fboxsep</indexterm></cindex>
<para>La distance du cadre à la boîte englobée. Vaut par défaut 3<dmn>pt</dmn>.  On
la change avec une commande telle que
<code>\setlength&lbrace;\fboxsep&rbrace;&lbrace;0pt&rbrace;</code> (<pxref label="_005csetlength"><xrefnodename>\setlength</xrefnodename></pxref>).  La régler à
0<dmn>pt</dmn> peut parfois être utile : cela met un cadre autour d&textrsquo;une image
sans bordure blanche.
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\setlength&lbrace;\fboxsep&rbrace;&lbrace;0pt&rbrace;%
 \framebox&lbrace;%
   \includegraphics[width=0.5\textwidth]&lbrace;prudence.jpg&rbrace;&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Les accolades supplémentaires rendent local l&textrsquo;effet du
<code>\setlength</code>.
</para>
</tableitem></tableentry></ftable>

<para>Comme avec <code>\mbox</code> et <code>\makebox</code>, &latex; ne fait pas de
sauts de ligne au sein de <var>texte</var>.  Mais l&textrsquo;exemple ci-dessous a pour
effet que &latex; effectue des sauts de ligne pour fabriquer un
paragraphe, puis encadre le résultat.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\framebox&lbrace;%
  \begin&lbrace;minipage&rbrace;&lbrace;0.6\linewidth&rbrace;
    « On va bien lentement dans ton pays ! Ici, vois-tu, on est obligé
    de courir tant qu’on peut pour rester au même endroit, dit la
    reine. Si tu veux te déplacer, tu dois courir au moins deux fois
    plus vite ! »
  \end&lbrace;minipage&rbrace;&rbrace;
</pre></example>

<para><xref label="Colored-boxes"><xrefnodename>Colored boxes</xrefnodename></xref>, pour des couleurs autres que noir et blanc.
</para>
<para>L&textrsquo;environnement <code>picture</code> a une version de la commande
<code>\framebox</code> où les unités dépendent du <code>\unitlength</code> de
<code>picture</code> (<pxref label="_005cframebox-_0028picture_0029"><xrefnodename>\framebox (picture)</xrefnodename></pxref>).
</para>

</section>
<node name="_005cparbox" spaces=" "><nodename>\parbox</nodename><nodenext automatic="on">\raisebox</nodenext><nodeprev automatic="on">\fbox &amp; \framebox</nodeprev><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>\parbox</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1178">\parbox</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="634">paragraphe, mode</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="635">paragraphe, dans une boîte</indexterm></cindex>


<para>Synopsis, l&textrsquo;un parmi les suivants :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\parbox&lbrace;<var>largeur</var>&rbrace;&lbrace;<var>contenu</var>&rbrace;
\parbox[<var>position</var>]&lbrace;<var>largeur</var>&rbrace;&lbrace;<var>contenu</var>&rbrace;
\parbox[<var>position</var>][<var>hauteur</var>]&lbrace;<var>largeur</var>&rbrace;&lbrace;<var>contenu</var>&rbrace;
\parbox[<var>position</var>][<var>hauteur</var>][<var>pos-interne</var>]&lbrace;<var>largeur</var>&rbrace;&lbrace;<var>contenu</var>&rbrace;
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="636">mode paragraphe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="637">paragraphe, mode</indexterm></cindex>
<para>La commande <code>\parbox</code> produit une boîte de texte de largeur
<code>largeur</code>. Cette commande peut être utilisée pour fabriquer une
boîte à partir de petits morceaux de texte, et contenant un seul
paragraphe. Cette commande est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;picture&rbrace;(0,0)
  ...
  \put(1,2)&lbrace;\parbox&lbrace;4.5cm&rbrace;&lbrace;\raggedright Le graphique étant une
    droite sur une échelle logarithmique, la relation est
    exponentielle.&rbrace;&rbrace;
\end&lbrace;picture&rbrace;
</pre></example>

<para>Le <var>contenu</var> est traité en mode texte (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>) ainsi
&latex; fait des sauts de ligne de sorte à former un paragraphe. Mais
il ne fabriquera pas plusieurs paragraphes ; pour cela, utilisez un
environnement <code>minipage</code> (<pxref label="minipage"><xrefnodename>minipage</xrefnodename></pxref>).
</para>
<para>Les options d&textrsquo;une <code>\parbox</code> (à l&textrsquo;exception du <var>contenu</var>) sont
les mêmes que pour une <code>minipage</code>. Par commodité on rappelle ces
options ici plus bas, mais se référer à <ref label="minipage"><xrefnodename>minipage</xrefnodename></ref> pour une
description complète.
</para>
<para>Il y a deux arguments obligatoires. La <var>largeur</var> est une longueur
rigide (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). Elle règle la largeur de la boîte dans
laquelle &latex; compose le <code>contenu</code>. Le <code>contenu</code> est le
texte qui est placé dans cette boîte. Il ne devrait pas avoir de
composants qui fabriquent des paragraphes.
</para>
<para>Il y a trois arguments optionnels, <var>position</var>, <var>hauteur</var>, et
<var>pos-interne</var>. La <var>position</var> donne l&textrsquo;alignement vertical de la
<dfn>parbox</dfn> relativement au texte alentour. La valeurs prises en charge
sont <code>c</code> ou <code>m</code> pour que le centre selon la dimension
verticale de la parbox soit aligné avec le centre de la ligne de texte
adjacente (c&textrsquo;est le réglage par défaut), ou <code>t</code> pour accorder la
ligne du haut de la parbox avec la ligne de base du texte alentour, ou
<code>b</code> pour accorder la ligne du bas.
</para>
<para>L&textrsquo;argument optionnel <var>hauteur</var> l&textrsquo;emporte sur la hauteur naturelle de
la boîte.
</para>
<para>L&textrsquo;argument optionnel <var>pos-interne</var> contrôle la position du
<var>contenu</var> au sein de la parbox. Sa valeur par défaut est la valeur
de <var>position</var>. Les valeurs possibles sont : <code>t</code> pour placer le
<var>contenu</var> en haut de la boîte, <code>c</code> pour le centrer
verticalement, <code>b</code> pour le place en bas de la boîte, et <code>s</code>
pour le dilater verticalement (pour cela, le texte doit contenir de
l&textrsquo;espace vertical élastique).
</para>
</section>
<node name="_005craisebox" spaces=" "><nodename>\raisebox</nodename><nodenext automatic="on">\sbox &amp; \savebox</nodenext><nodeprev automatic="on">\parbox</nodeprev><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>\raisebox</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1179">\raisebox</indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi les suivants :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\raisebox&lbrace;<var>distance</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
\raisebox&lbrace;<var>distance</var>&rbrace;[<var>hauteur</var>]&lbrace;<var>texte</var>&rbrace;
\raisebox&lbrace;<var>distance</var>&rbrace;[<var>hauteur</var>][<var>profondeur</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>La commande <code>\raisebox</code> élève ou abaisse du <var>texte</var>.  Cette
commande est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivant fabrique une commande pour noter la restriction d&textrsquo;une
fonction en abaissant le symbole barre verticale.
</para>
<!-- c credit: egreg https://tex.stackexchange.com/a/278631/121234 -->
<example endspaces=" ">
<pre xml:space="preserve">\newcommand*\restreinte[1]&lbrace;\raisebox&lbrace;-.5ex&rbrace;&lbrace;$|$&rbrace;_&lbrace;#1&rbrace;&rbrace;
$f\restreinte&lbrace;A&rbrace;$
</pre></example>

<para>Le premier argument obligatoire spécifie la longueur dont le <var>texte</var>
doit être élevé. C&textrsquo;est une longueur rigide (<pxref label="Lengths"><xrefnodename>Lengths</xrefnodename></pxref>). Si elle
est négative alors <var>texte</var> est abaissé. Le <var>texte</var> lui-même est
traité en mode LR, aussi il ne doit pas contenir de saut de ligne
(<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
</para>
<para>Les arguments optionnels <var>hauteur</var> et <var>profondeur</var> sont des
dimensions.  S&textrsquo;ils sont spécifiés, ils l&textrsquo;emportent sur les hauteur et
profondeur naturelles de la boîte que &latex; obtient en composant
<var>texte</var>.
</para>
<anchor name="raisebox-depth">raisebox depth</anchor>
<anchor name="raisebox-height">raisebox height</anchor>
<anchor name="raisebox-width">raisebox width</anchor>
<anchor name="raisebox-totalheight">raisebox totalheight</anchor>
<para>Au sein des arguments <var>distance</var>, <var>hauteur</var>, et <var>profondeur</var>
vous pouvez utiliser les longueurs suivantes qui font référence à la
dimension de la boîte que &latex; obtient en composant <var>texte</var> :
<code>\depth</code>, <code>\height</code>, <code>\width</code>, <code>\totalheight</code> (qui
est la somme de la hauteur et de la profondeur de la boîte).
</para>
<para>L&textrsquo;exemple suivant aligne deux graphiques sur leur bord supérieur (<pxref label="Graphics"><xrefnodename>Graphics</xrefnodename></pxref>).
</para>
<!-- c credit: FAQ https://texfaq.org/FAQ-topgraph -->
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;graphicx,calc&rbrace;  % dans le préambule
   ...
\begin&lbrace;center&rbrace;
  \raisebox&lbrace;1ex-\height&rbrace;&lbrace;%
    \includegraphics[width=0.4\linewidth]&lbrace;lion.png&rbrace;&rbrace;
  \qquad
  \raisebox&lbrace;1ex-\height&rbrace;&lbrace;%
    \includegraphics[width=0.4\linewidth]&lbrace;meta.png&rbrace;&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<noindent></noindent>
<para>Le premier <code>\height</code> est la hauteur de <file>lion.png</file> alors que le
second est celle de <file>meta.png</file>.
</para>

</section>
<node name="_005csbox-_0026-_005csavebox" spaces=" "><nodename>\sbox &amp; \savebox</nodename><nodenext automatic="on">lrbox</nodenext><nodeprev automatic="on">\raisebox</nodeprev><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>\sbox</code> &amp; <code>\savebox</code></sectiontitle>

<anchor name="_005csbox">\sbox</anchor>
<anchor name="_005csavebox">\savebox</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1180">\sbox</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1181">\savebox</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="638">boîte, sauvegarde</indexterm></cindex>


<para>Synopsis, l&textrsquo;un parmi les suivants :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\sbox&lbrace;<var>cmd-boîte</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
\savebox&lbrace;<var>cmd-boîte</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
\savebox&lbrace;<var>cmd-boîte</var>&rbrace;[<var>largeur</var>]&lbrace;<var>texte</var>&rbrace;
\savebox&lbrace;<var>cmd-boîte</var>&rbrace;[<var>largeur</var>][<var>pos</var>]&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Cette commande compose <var>texte</var> dans une boîte de la même façon
qu&textrsquo;avec <code>\makebox</code> (<pxref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></pxref>), à ceci près qu&textrsquo;au
lieu de sortir la boîte résultante, elle la sauvegarde dans un registre
boîte référencé par la variable nommée <var>cmd-boîte</var>. Le nom de
variable <var>cmd-boîte</var> commence avec une controblique, <code>\</code>. Vous
devez préalablement avoir alloué le registre boîte <var>cmd-boîte</var> avec avec
<code>\newsavebox</code> (<pxref label="_005cnewsavebox"><xrefnodename>\newsavebox</xrefnodename></pxref>). La commande <code>\sbox</code> est
robuste, alors que <code>\savebox</code> est fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivant crée et utilise un registre boîte.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newsavebox&lbrace;\nomcomplet&rbrace;
\sbox&lbrace;\nomcomplet&rbrace;&lbrace;Cadet Rousselle&rbrace;
  ...
\usebox&lbrace;\nomcomplet&rbrace; a trois maisons qui n'ont ni poutres, ni chevrons !
C'est pour loger les hirondelles,
Que direz-vous d'\usebox&lbrace;\nomcomplet&rbrace; ?
</pre></example>

<noindent></noindent>
<para>Un avantage de l&textrsquo;usage répété d&textrsquo;un registre boîte par rapport à une
variable macro <code>\newcommand</code> est l&textrsquo;efficacité, c.-à-d.&noeos; que
&latex; n&textrsquo;a pas besoin de répéter la composition du contenu.  Voir
l&textrsquo;exemple plus bas.
</para>
<para>Les deux invocations de commande
<code>\sbox&lbrace;<var>cmd-boîte</var>&rbrace;&lbrace;<var>texte</var>&rbrace;</code> et
<code>\savebox&lbrace;<var>cmd-boîte</var>&rbrace;&lbrace;<var>texte</var>&rbrace;</code> sont sensiblement
équivalentes.  Quant aux troisième et quatrième, les arguments
optionnels vous permettent de spécifier la largeur de la boîte comme
<var>largeur</var>, et la position du texte au sein de cette boîte comme
<var>position</var>.  <xref label="_005cmbox-_0026-_005cmakebox"><xrefnodename>\mbox &amp; \makebox</xrefnodename></xref>, pour une description complète.
</para>
<para>Dans les commandes <code>\sbox</code> et <code>\savebox</code> le <var>texte</var> est
composé en mode LR, aussi il n&textrsquo;a pas de sauts de lignes (<pxref label="Modes"><xrefnodename>Modes</xrefnodename></pxref>).
Si vous utilisez ce qui suit alors &latex; ne produit pas d&textrsquo;erreur mais
ignore ce que vous voulez faire : si vous entrez
<code>\sbox&lbrace;\nouvreg&rbrace;&lbrace;test \\ test&rbrace;</code> et <code>\usebox&lbrace;\nouvreg&rbrace;</code>
alors vous obtenez <samp>testtest</samp>, et si vous entrez
<code>\sbox&lbrace;\nouvreg&rbrace;&lbrace;test \par test&rbrace;</code> et <code>\usebox&lbrace;\nouvreg&rbrace;</code>
alors vous obtenez <samp>test test</samp>, mais ni erreur ni avertissement.
La solution est d&textrsquo;utiliser une <code>\parbox</code> ou une <code>minipage</code>
comme dans l&textrsquo;exemple qui suit :
</para>
<!-- c credit: egreg https://tex.stackexchange.com/a/41668/121234 -->
<example endspaces=" ">
<pre xml:space="preserve">\newsavebox&lbrace;\unreg&rbrace;
\savebox&lbrace;\unreg&rbrace;&lbrace;%
  \begin&lbrace;minipage&rbrace;&lbrace;\linewidth&rbrace;
    \begin&lbrace;enumerate&rbrace;
      \item Premier article
      \item Second article
    \end&lbrace;enumerate&rbrace;
  \end&lbrace;minipage&rbrace;&rbrace;
  ...
\usebox&lbrace;\unreg&rbrace;
</pre></example>

<para>En exemple de l&textrsquo;efficacité de réutiliser le contenu d&textrsquo;un registre boîte,
ce qui suit place la même image sur chaque page du document en le
plaçant dans l&textrsquo;en-tête.  &latex; ne la compose qu&textrsquo;une fois.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;graphicx&rbrace;  % tout cela dans le préambule
\newsavebox&lbrace;\cachetreg&rbrace;
\savebox&lbrace;\cachetreg&rbrace;&lbrace;%
  \setlength&lbrace;\unitlength&rbrace;&lbrace;2.5cm&rbrace;%
  \begin&lbrace;picture&rbrace;(0,0)%
     \put(1.5,-2.5)&lbrace;%
       \begin&lbrace;tabular&rbrace;&lbrace;c&rbrace;
          \includegraphics[height=5cm]&lbrace;companylogo.png&rbrace; \\
          Bureau du Président
       \end&lbrace;tabular&rbrace;&rbrace;
  \end&lbrace;picture&rbrace;%
&rbrace;
\markright&lbrace;\usebox&lbrace;\cachetreg&rbrace;&rbrace;
\pagestyle&lbrace;headings&rbrace;
</pre></example>

<noindent></noindent>
<para>L&textrsquo;environnement <code>picture</code> est bien adapté pour régler finement le
placement.
</para>
<para>Si le registre <code>\noreg</code> n&textrsquo;a pas déjà été défini alors vous obtenez
quelque chose du genre de <samp>Undefined control sequence. &lt;argument&gt;
\noreg</samp>.
</para>
</section>
<node name="lrbox" spaces=" "><nodename>lrbox</nodename><nodenext automatic="on">\usebox</nodenext><nodeprev automatic="on">\sbox &amp; \savebox</nodeprev><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>lrbox</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1182">lrbox</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;lrbox&rbrace;&lbrace;<var>cmd-boîte</var>&rbrace;
  <var>texte </var>
\end&lbrace;lrbox&rbrace;
</pre></example>

<para>Ceci est la forme par environnement des commandes <code>\sbox</code> et
<code>\savebox</code>, et leur est équivalente. <xref label="_005csbox-_0026-_005csavebox"><xrefnodename>\sbox &amp; \savebox</xrefnodename></xref>, pour
une description complète.
</para>
<para>Le <var>texte</var> au sein de l&textrsquo;environnement est sauvegardé dans un
registre boîte auquel la variable <code><var>cmd-boîte</var></code> fait
référence. Le nom de variable <var>cmd-boîte</var> doit commencer par une
controblique, <code>\</code>. Vous devez avoir alloué ce registre boîte
préalablement avec <code>\newsavebox</code> (<pxref label="_005cnewsavebox"><xrefnodename>\newsavebox</xrefnodename></pxref>). Dans
l&textrsquo;exemple suivant l&textrsquo;environnement est commode pour entrer le
<code>tabular</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newsavebox&lbrace;\jhreg&rbrace;
\begin&lbrace;lrbox&rbrace;&lbrace;\jhreg&rbrace;
  \begin&lbrace;tabular&rbrace;&lbrace;c&rbrace;
    \includegraphics[height=1in]&lbrace;jh.png&rbrace; \\
    Jim Hef&lbrace;&rbrace;feron
  \end&lbrace;tabular&rbrace;
\end&lbrace;lrbox&rbrace;
  ...
\usebox&lbrace;\jhreg&rbrace;
</pre></example>


</section>
<node name="_005cusebox" spaces=" "><nodename>\usebox</nodename><nodeprev automatic="on">lrbox</nodeprev><nodeup automatic="on">Boxes</nodeup></node>
<section spaces=" "><sectiontitle><code>\usebox</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1183">\usebox</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="639">boîte, utilise une boîte sauvegardée</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usebox&lbrace;<var>cmd-boîte</var>&rbrace;
</pre></example>

<para>La commande <code>\usebox</code> produit la boîte la plus récemment
sauvegardée dans le registre boîte <var>cmd-boîte</var> par une commande
<code>\sbox</code> ou <code>\savebox</code>, ou l&textrsquo;environnement
<code>lrbox</code>. <xref label="_005csbox-_0026-_005csavebox"><xrefnodename>\sbox &amp; \savebox</xrefnodename></xref>, pour plus ample information et
des exemples. (Notez que le nom de la variable <var>cmd-boîte</var> commence
par une controblique, <code>\</code>). Cette commande est robuste
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
</section>
</chapter>
<node name="Color" spaces=" "><nodename>Color</nodename><nodenext automatic="on">Graphics</nodenext><nodeprev automatic="on">Boxes</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Couleur</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="640">couleur</indexterm></cindex>

<para>Vous pouvez colorer du texte, des filets, etc. Vous pouvez également
colorer l&textrsquo;intérieur d&textrsquo;une boîte ou une page entière et écrire du texte
par dessus.
</para>
<para>La prise en charge des couleurs se fait via un paquetage
supplémentaire. Aussi, toutes les commandes qui suivent ne fonctionnent
que si le préambule de votre document contient
<code>\usepackage&lbrace;color&rbrace;</code>, qui fournit le paquetage standard.
</para>
<para>Beaucoup d&textrsquo;autres paquetages complètent également les possibilités de
&latex; en matière de couleurs.  Notamment <file>xcolor</file> est largement
utilisé et étend significativement les possibilités décrites ici, y
compris par l&textrsquo;ajout des modèles de couleur <samp>HTML</samp> et <samp>Hsb</samp>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Option du paquetage color</menutitle><menunode separator=". ">Color package options</menunode><menudescription><pre xml:space="preserve">Options de chargement du paquetage standard.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Modèles de couleur</menutitle><menunode separator=".                 ">Color models</menunode><menudescription><pre xml:space="preserve">Comment sont représentées les couleurs.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Commandes pour <code>color</code></menutitle><menunode separator=".           ">Commands for color</menunode><menudescription><pre xml:space="preserve">Les commandes disponibles.
</pre></menudescription></menuentry></menu>


<node name="Color-package-options" spaces=" "><nodename>Color package options</nodename><nodenext automatic="on">Color models</nodenext><nodeup automatic="on">Color</nodeup></node>
<section spaces=" "><sectiontitle>Options du paquetage <code>color</code></sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="641">color options du paquetage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="642">options, paquetage color</indexterm></cindex>

<para>Synopsis (à mettre dans le préambule du document) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>liste d'option séparées par des virgules</var>]&lbrace;color&rbrace;
</pre></example>

<para>Quand vous chargez le paquetage <file>color</file> il y a deux types d&textrsquo;options
disponibles.
</para>
<para>Le premier spécifie le <dfn>pilote d&textrsquo;impression</dfn>.  &latex; ne contient
pas d&textrsquo;information sur les différents systèmes de sortie, mais au lieu de
cela dépend de l&textrsquo;information stockée dans un fichier.  Normalement vous
ne devriez pas spécifier les options de pilote dans le document, mais au
lieu de cela vous vous reposez sur les valeurs par défaut de votre
système. Un avantage de procéder ainsi est que cela rend votre document
portable entre systèmes.  Pour être complet nous incluons une liste des
pilotes.  Ceux présentement pertinents sont : <file>dvipdfmx</file>,
<file>dvips</file>, <file>dvisvgm</file>, <file>luatex</file>, <file>pdftex</file>,
<file>xetex</file>.  Les deux pilotes <file>xdvi</file> et <file>oztex</file> sont pour
l&textrsquo;essentiel des alias de <file>dvips</file> (et <file>xdvi</file> est monochrome).
Ceux qui ne devraient pas être utilisés pour de nouveaux systèmes récent
sont : <file>dvipdf</file>, <file>dvipdfm</file>, <file>dviwin</file>, <file>dvipsone</file>,
<file>emtex</file>, <file>pctexps</file>, <file>pctexwin</file>, <file>pctexhp</file>,
<file>pctex32</file>, <file>truetex</file>, <file>tcidvi</file>, <file>vtex</file> (et
<file>dviwindo</file> est un alias de <file>dvipsone</file>).
</para>
<para>Les options du second type, autres que les pilotes, sont listées ci-dessous.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">monochrome</itemformat></item>
</tableterm><tableitem><para>Désactive les commandes de couleur, de sorte qu&textrsquo;elles ne produisent pas
d&textrsquo;erreur, mais ne produisent pas non plus de couleurs.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">dvipsnames</itemformat></item>
</tableterm><tableitem><para>Rend disponible une liste de 68 noms de couleur qui sont d&textrsquo;usage
fréquent, en particulier dans des documents qui ne sont pas modernes.
Ces noms de couleurs étaient à l&textrsquo;origine fournis par le pilote
<file>dvips</file>, d&textrsquo;où le nom de l&textrsquo;option.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">nodvipsnames</itemformat></item>
</tableterm><tableitem><para>Ne charge pas cette liste de noms de couleur, faisant faire à &latex;
une toute petite économie d&textrsquo;espace mémoire.
</para>
</tableitem></tableentry></table>


</section>
<node name="Color-models" spaces=" "><nodename>Color models</nodename><nodenext automatic="on">Commands for color</nodenext><nodeprev automatic="on">Color package options</nodeprev><nodeup automatic="on">Color</nodeup></node>
<section spaces=" "><sectiontitle>Modèles de couleur</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="643">modèles de couleur</indexterm></cindex>

<para>Un <dfn>modèle de couleur</dfn> est une façon de représenter les couleurs.
Les possibilités de &latex; dépendent du pilote d&textrsquo;impression. Toutefois,
les pilotes <file>pdftex</file>, <file>xetex</file>, et <file>luatex</file> sont de nos
jours de loin les plus largement utilisés. Les modèles ci-après
fonctionnent pour ces pilotes. À une exception près ils sont également
pris en charge par tous les autres pilotes d&textrsquo;impression utilisés
aujourd&textrsquo;hui.
</para>
<para>Il est à noter qu&textrsquo;une combinaison de couleur peut être additive, ou
soustractive.  Les combinaisons additives mélangent les couleurs de la
lumière, de sorte que par exemple combiner des intensités pleines de
rouge, vert et bleu produit du blanc. Les combinaisons soustractives
mélangent les pigments, tels que les encres, de sorte que combiner des
intensités pleine de cyan, magenta et jaune produit du noir.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="color-models-cmyk">color models cmyk</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">cmyk</itemformat></item>
</tableterm><tableitem><para>Un liste séparée de virgule avec quatre nombres réel compris entre 0 et
1 inclus.  Le premier nombre est l&textrsquo;intensité du cyan, le deuxième celle
du magenta, et les autres celle du jaune et du noir.  Un valeur du
nombre de 0 signifie l&textrsquo;intensité minimale, alors que 1 correspond à
l&textrsquo;intensité pleine.  Ce modèle est fréquemment utilisé pour l&textrsquo;impression
de couleur. C&textrsquo;est un modèle soustractif.
</para>
<anchor name="color-models-gray">color models gray</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">gray</itemformat></item>
</tableterm><tableitem><para>Un unique nombre réel compris entre 0 et 1 inclus.  Les couleurs sont
des nuances de gris. Le nombre 0 produit du noir, alors que le 1 donne
du blanc.
<anchor name="color-models-rgb">color models rgb</anchor>
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">rgb</itemformat></item>
</tableterm><tableitem><para>Une liste séparée de virgules avec trois nombres réels compris entre 0
et 1, inclusive.  Le premier nombre est l&textrsquo;intensité de la composante
rouge, le deuxième correspond au vert, et le troisième au bleu. Une
valeur de 0 donnée au nombre signifie qu&textrsquo;en rien cette composante n&textrsquo;est
ajouté à la couleur, alors que 1 signifie que cela est fait à pleine
intensité.  C&textrsquo;est un modèle additif.
</para>
<anchor name="color-models-RGB">color models RGB</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">RGB</itemformat></item>
</tableterm><tableitem><para>(pilotes <file>pdftex</file>, <file>xetex</file>, <file>luatex</file>) Une liste séparée
par des virgules avec trois entiers compris entre 0 et 255 inclus. Ce
modèle est une commodité pour utiliser <code>rgb</code> étant donnée qu&textrsquo;en
dehors de &latex; les couleurs sont souvent décrites dans un modèle
rouge-vert-bleu utilisant des nombres dans cette plage.  Les valeurs
entrées sont converties vers le modèle <code>rgb</code> en divisant par 255.
</para>
<anchor name="color-models-named">color models named</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">named</itemformat></item>
</tableterm><tableitem><para>On accède au couleur par des noms tels que <samp>PrussianBlue</samp>.  La
liste des noms dépend du pilote, mais tous prennent en charge les noms
<samp>black</samp>, <samp>blue</samp>, <samp>cyan</samp>, <samp>green</samp>, <samp>magenta</samp>,
<samp>red</samp>, <samp>white</samp>, et <samp>yellow</samp> (Voir l&textrsquo;option
<code>dvipsnames</code> dans <ref label="Color-package-options"><xrefnodename>Color package options</xrefnodename></ref>).
</para>
</tableitem></tableentry></table>


</section>
<node name="Commands-for-color" spaces=" "><nodename>Commands for color</nodename><nodeprev automatic="on">Color models</nodeprev><nodeup automatic="on">Color</nodeup></node>
<section spaces=" "><sectiontitle>Commandes pour <code>color</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="644">color, commandes du paquetage</indexterm></cindex>

<para>Voici les commandes disponibles avec le paquetage <file>color</file>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::            ">Define colors</menunode><menudescription><pre xml:space="preserve">Nommer une couleur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">Colored text</menunode><menudescription><pre xml:space="preserve">Du texte ou des filets en couleur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">Colored boxes</menunode><menudescription><pre xml:space="preserve">Une boîte en couleur, par dessus laquelle écrire.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">Colored pages</menunode><menudescription><pre xml:space="preserve">Une page entière en couleur.
</pre></menudescription></menuentry></menu>


<node name="Define-colors" spaces=" "><nodename>Define colors</nodename><nodenext automatic="on">Colored text</nodenext><nodeup automatic="on">Commands for color</nodeup></node>
<subsection spaces=" "><sectiontitle>Définir des couleurs</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="645">couleur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="646">définir une couleur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="647">couleur, définir</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\definecolor&lbrace;<var>nom</var>&rbrace;&lbrace;<var>model</var>&rbrace;&lbrace;<var>spécification</var>&rbrace;
</pre></example>

<para>Donne le nom <var>nom</var> à la couleur. Par exemple, après
<code>\definecolor&lbrace;silver&rbrace;&lbrace;rgb&rbrace;&lbrace;0.75,0.75,0.74&rbrace;</code> vous pouvez
utiliser cette couleur avec <code>Hé ho,
\textcolor&lbrace;silver&rbrace;&lbrace;Silver&rbrace;~!</code>.
</para>
<para>Cet exemple donne à la couleur un nom plus abstrait, de sort qu&textrsquo;on
puisse la changer sans que cela prête à confusion.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\definecolor&lbrace;logocolor&rbrace;&lbrace;RGB&rbrace;&lbrace;145,92,131&rbrace;    % RGB nécessite pdflatex
\newcommand&lbrace;\logo&rbrace;&lbrace;\textcolor&lbrace;logocolor&rbrace;&lbrace;Les Brioches de Robert&rbrace;&rbrace;
</pre></example>

<para>Il est fréquent que les couleurs d&textrsquo;un document soient définies dans son
préambule, ou dans sa classe
<!-- c différence entre classe et style ? -->
ou style, plutôt que dans le corps du document.
</para>
</subsection>
<node name="Colored-text" spaces=" "><nodename>Colored text</nodename><nodenext automatic="on">Colored boxes</nodenext><nodeprev automatic="on">Define colors</nodeprev><nodeup automatic="on">Commands for color</nodeup></node>
<subsection spaces=" "><sectiontitle>Mettre du texte en couleur</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="648">couleur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="649">coloré, texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="650">texte en couleur</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\textcolor&lbrace;<var>nom</var>&rbrace;&lbrace;...&rbrace;
\textcolor[<var>modèle de couleur</var>]&lbrace;<var>spécification de couleur</var>&rbrace;&lbrace;...&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\color&lbrace;<var>nom</var>&rbrace;
\color[<var>modèle de couleur</var>]&lbrace;<var>spécification</var>&rbrace;
</pre></example>

<para>Le texte affecté prend la couleur correspondante.  La ligne suivante
</para>
<example endspaces=" ">
<pre xml:space="preserve">\textcolor&lbrace;magenta&rbrace;&lbrace;Je suis Ozymandias, roi des rois~:&rbrace; Voyez mon œuvre, ô puissants, et desespérez~!
</pre></example>

<noindent></noindent>
<para>met la première moitié en magenta alors que le reste est en noir.  Vous
pouvez utiliser une couleur déclarée avec <code>\definecolor</code> exactement
de la même façon dont nous venons d&textrsquo;utiliser la couleur prédéfinie
<samp>magenta</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\definecolor&lbrace;CriseDeLaQuarantaine&rbrace;&lbrace;rgb&rbrace;&lbrace;1.0,0.11,0.0&rbrace;
Je considère l'idée de m'acheter une \textcolor&lbrace;CriseDeLaQuarantaine&rbrace;&lbrace;voiture de sport&rbrace;.
</pre></example>

<para>Les deux formes de commandes <code>\textcolor</code> et <code>\color</code>
diffèrent en ce que la première forme prend le texte à colorer en
argument.  Ceci est souvent plus commode, ou tout du moins plus
explicite.  La seconde forme est une déclaration, comme dans <code>La
lune est composé de fromage &lbrace;\color&lbrace;vert&rbrace;&rbrace;</code>, de sorte qu&textrsquo;elle est en
vigueur jusqu&textrsquo;à la fin du groupe ou de l&textrsquo;environnement courant.  Ceci
est parfois utile quand on écrit des macros, ou comme ci-dessous où on
colore tout le contenu de l&textrsquo;environnement <code>center</code>, y compris les
lignes verticales et horizontales.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace; \color&lbrace;blue&rbrace;
  \begin&lbrace;tabular&rbrace;&lbrace;l|r&rbrace;
    HG &amp;HD \\ \hline
    BG &amp;BD
  \end&lbrace;tabular&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<para>Vous pouvez utiliser des couleurs dans les équations.  Un document peut
avoir <code>\definecolor&lbrace;couleurvedette&rbrace;&lbrace;RGB&rbrace;&lbrace;225,15,0&rbrace;</code> dans le
préambule, et ensuite contenir cette équation :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;equation&rbrace;
  \int_a^b \textcolor&lbrace;couleurvedette&rbrace;&lbrace;f'(x)&rbrace;\,dx=f(b)-f(a)
\end&lbrace;equation&rbrace;
</pre></example>

<para>Typiquement les couleurs utilisées dans un document sont déclarée dans
une classe ou dans un style mais il arrive qu&textrsquo;on désire fonctionner au
coup par coup.  C&textrsquo;est le cas d&textrsquo;usage des secondes forme du synopsis.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Des couleurs de \textcolor[rgb]&lbrace;0.33,0.14,0.47&rbrace;&lbrace;violet&rbrace; et &lbrace;\color[rgb]&lbrace;0.72,0.60,0.37&rbrace;doré&rbrace; pour l'équipe
</pre></example>

<para>Le format de <var>spécification de couleur</var> dépend du modèle de couleur
(<pxref label="Color-models"><xrefnodename>Color models</xrefnodename></pxref>).  Par exemple, alors que <code>rgb</code> prend trois
nombres, <code>gray</code> n&textrsquo;en prend qu&textrsquo;un.
</para>
<example endspaces=" ">
<pre xml:space="preserve">La sélection a été \textcolor[gray]&lbrace;0.5&rbrace;&lbrace;grisée&rbrace;.
</pre></example>

<para>Des couleurs au sein d&textrsquo;autres couleurs ne se combinent pas.  Ainsi
</para>
<example endspaces=" ">
<pre xml:space="preserve">\textcolor&lbrace;green&rbrace;&lbrace;une sorte de \textcolor&lbrace;blue&rbrace;&lbrace;bleu&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>se termine par un mot en bleu, et non pas dans une combinaison de bleu
et de vert.
</para>
<!-- c xx address coloring a line of a table? -->


</subsection>
<node name="Colored-boxes" spaces=" "><nodename>Colored boxes</nodename><nodenext automatic="on">Colored pages</nodenext><nodeprev automatic="on">Colored text</nodeprev><nodeup automatic="on">Commands for color</nodeup></node>
<subsection spaces=" "><sectiontitle>Faire des boîtes en couleur</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="651">couleur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="652">colorées, boîtes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="653">boîtes colorées</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\colorbox&lbrace;<var>nom</var>&rbrace;&lbrace;...&rbrace;
\colorbox[<var>nom modèle</var>]&lbrace;<var>spécification couleur arrière-plan boîte</var>&rbrace;&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\fcolorbox&lbrace;<var>couleur cadre</var>&rbrace;&lbrace;<var>couleur arrière-plan boîte</var>&rbrace;&lbrace;...&rbrace;
\fcolorbox[<var>nom modèle</var>]&lbrace;<var>spécification couleur cadre</var>&rbrace;&lbrace;<var>spécification arrière-plan boîte</var>&rbrace;&lbrace;...&rbrace;
</pre></example>

<para>Fabrique une boite avec la couleur d&textrsquo;arrière-plan indiquée.  La commande <code>\fcolorbox</code>
place un cadre autour de la boîte.  Par exemple ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Nom~:~\colorbox&lbrace;cyan&rbrace;&lbrace;\makebox[5cm][l]&lbrace;\strut&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>fabrique une boîte de couleur cyan qui fait cinq centimètres de long et
dont la profondeur et la hauteur sont déterminées par le <code>\strut</code>
(de sorte que la profondeur est <code>-.3\baselineskip</code> et la hauteur
est <code>\baselineskip</code>).  Ceci met un texte blanc sur un arrière plan
bleu :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\colorbox&lbrace;blue&rbrace;&lbrace;\textcolor&lbrace;white&rbrace;&lbrace;Welcome to the machine.&rbrace;&rbrace;
</pre></example>

<para>La commande <code>\fcolorbox</code> utilise les mêmes paramètres que
<code>\fbox</code> (<pxref label="_005cfbox-_0026-_005cframebox"><xrefnodename>\fbox &amp; \framebox</xrefnodename></pxref>), à savoir <code>\fboxrule</code> et
<code>\fboxsep</code>, pour régler l&textrsquo;épaisseur du filet et de la séparation
entre l&textrsquo;intérieur de la boîte et le filet l&textrsquo;entourant.  Les valeurs par
défaut de &latex; sont <code>0.4pt</code> et <code>3pt</code> respectivement.
</para>
<para>L&textrsquo;exemple suivant change l&textrsquo;épaisseur de la bordure en 0,8 points.
Notez qu&textrsquo;il est entre accolades de sorte que le changement cesse d&textrsquo;être
en vigueur à la fin de la seconde ligne.
</para>
<example endspaces=" ">
<pre xml:space="preserve">&lbrace;\setlength&lbrace;\fboxrule&rbrace;&lbrace;0.8pt&rbrace;
\fcolorbox&lbrace;black&rbrace;&lbrace;red&rbrace;&lbrace;En aucun cas ne tournez cette poignée.&rbrace;&rbrace;
</pre></example>

</subsection>
<node name="Colored-pages" spaces=" "><nodename>Colored pages</nodename><nodeprev automatic="on">Colored boxes</nodeprev><nodeup automatic="on">Commands for color</nodeup></node>
<subsection spaces=" "><sectiontitle>Faire des pages en couleur</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="654">couleur</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="655">colorée, page</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="656">page colorée</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="657">arrière-plan coloré</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\pagecolor&lbrace;<var>nom</var>&rbrace;
\pagecolor[<var>modèle de couleur</var>]&lbrace;<var>spécification de couleur</var>&rbrace;
\nopagecolor
</pre></example>

<para>Les deux premières commandes règlent l&textrsquo;arrière-plan de la page, et de
toutes les pages suivantes, à la couleur indiquée. Pour une explication
de la spécification dans la seconde forme <pxref label="Colored-text"><xrefnodename>Colored text</xrefnodename></pxref>.  La
troisième fait revenir l&textrsquo;arrière-plan à la normale, c.-à-d.&noeos; un
arrière-plan transparent.  (Si cela n&textrsquo;est pas pris en charge, alors
utilisez <code>\pagecolor&lbrace;white&rbrace;</code>, bien que cela produit un
arrière-plan blanc au lieu de l&textrsquo;arrière-plan transparent par défaut.)
</para>
<example endspaces=" ">
<pre xml:space="preserve"> ...
\pagecolor&lbrace;cyan&rbrace;
 ...
\nopagecolor
</pre></example>


</subsection>
</section>
</chapter>
<node name="Graphics" spaces=" "><nodename>Graphics</nodename><nodenext automatic="on">Special insertions</nodenext><nodeprev automatic="on">Color</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Graphiques</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="658">graphiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="659">graphics, paquetage</indexterm></cindex>

<para>Vous pouvez utiliser des graphiques tel que des fichiers PNG ou PDF dans
vos documents &latex;.  Vous aurez besoin d&textrsquo;un paquetage supplémentaire
standard de &latex;.  Cet exemple montre en bref comment :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\include&lbrace;graphicx&rbrace;  % dans le préambule
  ...
\includegraphics[width=0.5\linewidth]&lbrace;graphique.pdf&rbrace;
</pre></example>

<para>Pour utiliser les commandes décrites ici, le préambule de votre document
doit contenir soit <code>\usepackage&lbrace;graphicx&rbrace;</code>, soit
<code>\usepackage&lbrace;graphics&rbrace;</code>. (Le plus souvent, c&textrsquo;est <file>graphicx</file>
qui est préférable.)
</para>
<para>Les graphiques peuvent être de deux types, matriciels ou vectoriels.
&latex; peut utiliser les deux.  Dans les graphiques matriciels le
fichier comprend pour chaque position dans un tableau une entrée
décrivant la couleur de celle-ci.  Un exemple de ceci est une
photographie en format JPG.  Dans un graphique vectoriel, le fichier
contient une liste d&textrsquo;instructions telles que <samp>dessine un cercle
avec tel rayon et tel centre</samp>.  Un exemple de ceci est le dessin d&textrsquo;une
ligne produit par le programme Asymptote en format PDF.  En général les
graphiques vectoriels sont plus utiles car on peut les redimensionner
sans pixélisation ou autres problèmes, et parce que la plupart du temps
ils ont une taille plus petite.
</para>
<para>Il y a des systèmes particulièrement bien adaptés pour produire des
graphiques pour un document &latex;.  Par exemple, qui vous permettent
d&textrsquo;utiliser les mêmes polices que dans votre document.  &latex; comprend
un environnement <code>picture</code> (<pxref label="picture"><xrefnodename>picture</xrefnodename></pxref>) qui a des possibilités
de base.  En plus de cela, il y a d&textrsquo;autres façons d&textrsquo;inclure des
commandes de production de graphiques dans le document. Deux systèmes
pour cela sont les paquetages PSTricks et TikZ.  Il y a aussi des
systèmes externes à &latex; qui génèrent un graphique qu&textrsquo;on peut
inclure en utilisant les commandes de ce chapitre.  Il y a aussi deux
autres systèmes qui utilisent un langage de programmation : Asymptote et
MetaPost.  Encore un autre système qui utilise une interface graphique :
Xfig.  Une description complète des ces systèmes est hors du champ
d&textrsquo;application de ce document ; reportez vous à leur documentation sur le
CTAN.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Options du paquetage graphics</menutitle><menunode separator=". ">Graphics package options</menunode><menudescription><pre xml:space="preserve">Options au chargement du paquetage.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Configuration du paquetage graphics</menutitle><menunode separator=".   ">Graphics package configuration</menunode><menudescription><pre xml:space="preserve">Où sont les fichiers, quels types de fichiers.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Commandes pour graphiques</menutitle><menunode separator=".  ">Commands for graphics</menunode><menudescription><pre xml:space="preserve">Les commandes disponibles.
</pre></menudescription></menuentry></menu>


<node name="Graphics-package-options" spaces=" "><nodename>Graphics package options</nodename><nodenext automatic="on">Graphics package configuration</nodenext><nodeup automatic="on">Graphics</nodeup></node>
<section spaces=" "><sectiontitle>Options du paquetage <code>graphics</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="660">graphics, options du paquetage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="661">options, paquetage graphics</indexterm></cindex>

<para>Synopsis (à placer dans le préambule du document) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>liste d'option séparée par des virgules</var>]&lbrace;graphics&rbrace;
</pre></example>

<noindent></noindent><para>ou
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>liste d'option séparée par des virgules</var>]&lbrace;graphicx&rbrace;
</pre></example>

<para>Le paquetage <code>graphicx</code> a un format pour les arguments optionnels
passés à <code>\includegraphics</code> qui est commode (c&textrsquo;est le format
clef/valeur), ainsi c&textrsquo;est le meilleur des deux choix pour les nouveaux
documents. Quand vous chargez les paquetages <file>graphics</file> ou
<code>graphicx</code> avec <code>\usepackage</code> il y a deux sortes d&textrsquo;options
disponibles.
</para>
<para>La première est que &latex; ne contient pas d&textrsquo;information concernant
les différents systèmes de sortie, mais au lieu de cela dépend de
l&textrsquo;information stockée dans un fichier <dfn>pilote d&textrsquo;impression</dfn>.
Normalement vous ne devriez pas spécifier l&textrsquo;option de pilote dans le
document, mais au lieu de cela vous reposer sur les valeurs par défaut
du système. Un avantage de procéder ainsi et que cela rend les documents
portables entre systèmes.
</para>
<para>Pour être complet voici une liste des pilotes.  Ceux qui sont
actuellement pertinents sont : <file>dvipdfmx</file>, <file>dvips</file>,
<file>dvisvgm</file>, <file>luatex</file>, <file>pdftex</file>, <file>xetex</file>.  Les deux
pilotes <file>xdvi</file> and <file>oztex</file> sont essentiellement des alias de
<file>dvips</file> (et <file>xdvi</file> est monochrome).  Ceux qu&textrsquo;on ne devrait pas
utiliser pour de nouveaux systèmes sont : <file>dvipdfmx</file>, <file>dvips</file>,
<file>dvisvgm</file>, <file>luatex</file>, <file>pdftex</file>, <file>xetex</file>.  Les deux
pilotes <file>xdvi</file> et <file>oztex</file> sont essentiellement des alias de
<file>dvips</file> (et <file>xdvi</file> est monochrome).  Ceux qui ne devraient pas
être utilisés pour de nouveaux systèmes sont : <file>dvipdf</file>,
<file>dvipdfm</file>, <file>dviwin</file>, <file>dvipsone</file>, <file>emtex</file>,
<file>pctexps</file>, <file>pctexwin</file>, <file>pctexhp</file>, <file>pctex32</file>,
<file>truetex</file>, <file>tcidvi</file>, <file>vtex</file> (et <file>dviwindo</file> est un
alias de <file>dvipsone</file>).  Ces pilotes sont stockés dans des fichiers
avec une extension <file>.def</file>, tels que <file>pdftex.def</file>.
</para>
<para>La seconde sorte d&textrsquo;options est décrite ci-après.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">demo</itemformat></item>
</tableterm><tableitem><para>Au lieu d&textrsquo;un fichier d&textrsquo;image, &latex; met un rectangle de 150 pt
sur 100 pt (à moins qu&textrsquo;une autre taille soit spécifiée dans la
commande <code>\includegraphics</code>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">draft</itemformat></item>
</tableterm><tableitem><para>Aucun des fichiers graphiques n&textrsquo;est affiché, mais au lieu de cela le nom
du fichier est imprimé au sein d&textrsquo;une boîte de la bonne taille.  De sorte
à ce que la taille soit déterminée, le fichier doit être présent.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">final</itemformat></item>
</tableterm><tableitem><para>(Option par défaut) L&textrsquo;emporte sur toute options <code>draft</code> précédente,
de sorte que le document afficher le contenu des fichiers graphiques.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">hiderotate</itemformat></item>
</tableterm><tableitem><para>Ne montre pas le texte ayant subi une rotation.  (Ceci permet d&textrsquo;utiliser
une visionneuse ne prenant pas en charge le texte ayant subi une
rotation).
<!-- c what does it show? -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">hidescale</itemformat></item>
</tableterm><tableitem><para>Ne montre pas le texte rétréci/dilaté.  (Ceci permet d&textrsquo;utiliser une
visionneuse ne prenant pas en charge le texte ayant subi un
rétrécissement/une dilatation.)
<!-- c what does it show? -->
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">hiresbb</itemformat></item>
</tableterm><tableitem><para>Dans un fichier PS ou EPS la taille du graphique peut être spécifiée de
deux façons.  Les lignes <code>%%BoundingBox</code> décrivent la taille du
graphique en utilisant des multiples entiers d&textrsquo;un point PostScript,
c.-à-d.&noeos; des multiples entiers d&textrsquo; 1/72 de pouce.  Une addition plus
récente au langage PostScript autorise les multiples décimaux, tel que
1.23, dans les lignes <code>%%HiResBoundingBox</code>.  Cette option fait que
&latex; lit la taille à partir de <code>%%HiResBoundingBox</code> plutôt que
de <code>%%BoundingBox</code>.
</para>
</tableitem></tableentry></table>

</section>
<node name="Graphics-package-configuration" spaces=" "><nodename>Graphics package configuration</nodename><nodenext automatic="on">Commands for graphics</nodenext><nodeprev automatic="on">Graphics package options</nodeprev><nodeup automatic="on">Graphics</nodeup></node>
<section spaces="  "><sectiontitle>Configuration du paquetage <code>graphics</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="662">graphics</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="663">graphics, paquetage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="664">configuration du paquetage graphics</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="665">EPS, fichiers</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="666">JPEG, fichiers</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="667">JPG, fichiers</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="668">PDF, fichiers graphiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="669">PNG, fichiers</indexterm></cindex>

<para>Ces commandes configurent la façon dont &latex; recherche le graphique
dans le système le fichier.
</para>
<para>Le comportement du code de recherche dans le système de fichier dépend
nécessairement de la plateforme.  Dans ce document nous couvrons
GNU/Linux, Macintosh, et Windows, étant
donné que ces systèmes ont des configurations typiques.  Pour les autres
situations consultez la documentation dans <file>grfguide.pdf</file>, ou le
source &latex;, ou la documentation de votre distribution &tex;.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::                ">\graphicspath</menunode><menudescription><pre xml:space="preserve">Répertoire dans lequel chercher.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">\DeclareGraphicsExtensions</menunode><menudescription><pre xml:space="preserve">Types de fichier, tels que JPG ou EPS.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::         ">\DeclareGraphicsRule</menunode><menudescription><pre xml:space="preserve">Comment manipuler les types de fichier.
</pre></menudescription></menuentry></menu>


<node name="_005cgraphicspath" spaces=" "><nodename>\graphicspath</nodename><nodenext automatic="on">\DeclareGraphicsExtensions</nodenext><nodeup automatic="on">Graphics package configuration</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\graphicspath</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1184">\graphicspath</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\graphicspath&lbrace;<var>liste des répertoires entre les accolades</var>&rbrace;
</pre></example>

<para>Déclare une liste de répertoires dans lesquels rechercher des fichiers
graphiques.  Ceci permet d&textrsquo;écrire plus tard quelque chose du genre de
<code>\includegraphics&lbrace;lion.png&rbrace;</code> au lieu de donner son chemin.
</para>
<para>&latex; recherche toujours en premier les fichiers graphiques dans le
répertoire courant (et dans le répertoire de sortie, si spécifié ;
<pxref label="output-directory"><xrefnodename>output directory</xrefnodename></pxref>). La déclaration ci-dessous dit au système de
regarder ensuite dans le sous-répertoire <file>img</file>, et ensuite
<file>../img</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;graphicx&rbrace;   % ou graphics; à mettre dans le préambule
  ...
\graphicspath&lbrace; &lbrace;img/&rbrace; &lbrace;../img/&rbrace; &rbrace;
</pre></example>

<para>La déclaration <code>\graphicspath</code> est optionnelle.  Si vous ne
l&textrsquo;incluez pas, alors le comportement par défaut de &latex; est de
rechercher dans tous les endroits où il recherche d&textrsquo;habitude un fichier
(il utilise la commande <code>\input&arobase;path</code> de &latex;).  En
particulier, dans ce cas l&textrsquo;un l&textrsquo;un des endroits où il regarde est le
répertoire courant.
</para>
<para>Mettez chaque nom de répertoire entre accolades ; en particulier,
ci-dessus on a écrit <samp><code>&lbrace;img&rbrace;</code></samp>.  Faites ainsi même si il n&textrsquo;y
a qu&textrsquo;un seul répertoire.  Chaque nom de répertoire doit se terminer par
une oblique vers l&textrsquo;avant <file>/</file>.  Ceci est vrai même sur Windows, où
la bonne pratique est d&textrsquo;utiliser des obliques vers l&textrsquo;avant pour tous les
séparateurs de répertoire puisque cela rend le document portable vers
d&textrsquo;autres plateformes.  Si vous avez des espaces dans votre nom de
répertoire alors utilisez des guillemets anglais, comme dans
<code>&lbrace;&quot;mes docs/&quot;&rbrace;</code>. Enfreindre l&textrsquo;une de ces règles aura pour effet
que &latex; rapportera une erreur <code>Error: File `<var>filename</var>' not found</code>.
</para>
<para>Pour faire simple, l&textrsquo;algorithme est que dans l&textrsquo;exemple qui suit, après
avoir regardé dans le répertoire courant,
</para>
<example endspaces=" ">
<pre xml:space="preserve">\graphicspath&lbrace; &lbrace;img/&rbrace; &lbrace;../img/&rbrace; &rbrace;
...
\usepackage&lbrace;lion.png&rbrace;
</pre></example>

<noindent></noindent>
<para>pour chacun des répertoires listés, &latex; le concatène avec le nom du
fichier et recherche le fichier ainsi nommé, eh cherchant
<file>img/lion.png</file> et puis <file>../img/lion.png</file>.  Cet algorithme
signifie que la commande <code>\graphicspath</code> ne recherche pas
récursivement dans les sous-répertoires : si vous faites
<code>\graphicspath&lbrace;&lbrace;a/&rbrace;&rbrace;</code> et que le graphique est dans
<file>a/b/lion.png</file> alors &latex; ne le trouvera pas.  Cela signifie
aussi que vous pouvez utiliser des chemins absolus tels que
<code>\graphicspath&lbrace;&lbrace;/home/jim/logos/&rbrace;&rbrace;</code> ou
<code>\graphicspath&lbrace;&lbrace;C:/Users/Albert/Pictures/&rbrace;&rbrace;</code>.  Toutefois, faire
cela rend votre document non portable.  (Vous pourriez préserver la
portabilité en ajustant vos le paramètre <code>TEXINPUTS</code> du fichier de
configuration des réglages système &tex; ; voir la documentation de
votre système).
</para>
<para>Vous pouvez utiliser <code>\graphicspath</code> n&textrsquo;importe où dans le
document. Vous pouvez l&textrsquo;utiliser plus d&textrsquo;une fois.  Sa valeur peut être
affichée avec <code>\makeatletter\typeout&lbrace;\Ginput&arobase;path&rbrace;\makeatother</code>.
</para>
<para>Les répertoires sont à donner relativement au fichier de base.  Pour
faire clair, supposez que vous travaillez sur un document basé sur
<file>livre/livre.tex</file> et qu&textrsquo;il contienne
<code>\include&lbrace;chapitres/chap1&rbrace;</code>.  Si dans <file>chap1.tex</file> vous
mettez <code>\graphicspath&lbrace;&lbrace;graphiques/&rbrace;&rbrace;</code> alors &latex; ne
cherchera pas les graphiques dans <file>livre/chapitres/graphiques</file>,
mais dans <file>livre/graphiques</file>.
</para>

</subsection>
<node name="_005cDeclareGraphicsExtensions" spaces=" "><nodename>\DeclareGraphicsExtensions</nodename><nodenext automatic="on">\DeclareGraphicsRule</nodenext><nodeprev automatic="on">\graphicspath</nodeprev><nodeup automatic="on">Graphics package configuration</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareGraphicsExtensions</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1185">\DeclareGraphicsExtensions</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareGraphicsExtensions&lbrace;<var>liste séparée par des virgules d'extensions de fichier</var>&rbrace;
</pre></example>

<para>Déclare les extensions de nom de fichier à essayer.  Ceci vous permet de
spécifier l&textrsquo;ordre dans lequel les formats graphiques sont choisis quant
les fichiers graphiques sont inclus en donnant le nom de fichier sans
l&textrsquo;extension, comme dans <code>\includegraphics&lbrace;courbe_de_fonction&rbrace;</code>.
</para>
<para>Dans l&textrsquo;exemple qui suit, &latex; trouve les fichiers au format PNG
avant les fichiers PDF.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareGraphicsExtensions&lbrace;.png,PNG,.pdf,.PDF&rbrace;
  ...
\includegraphics&lbrace;lion&rbrace;   % trouve <file>lion.png</file> avant <file>lion.pdf</file>
</pre></example>

<noindent></noindent>
<para>Du fait que le nom <file>lion</file> ne contient pas de point, &latex;
utilise la liste d&textrsquo;extension.  Pour chacun des répertoires dans la liste
de chemins graphiques (<pxref label="_005cgraphicspath"><xrefnodename>\graphicspath</xrefnodename></pxref>), &latex; essaie les
extensions dans l&textrsquo;ordre donné.  S&textrsquo;il ne trouve aucun fichier
correspondant après avoir essayé tous les répertoires et toutes les
extensions, alors il renvoie une erreur <samp>! LaTeX Error: File
`<file>lion</file>' not found</samp>.  Notez que vous devez inclure le point au
début de chaque extension.
</para>
<para>Du fait que les noms de fichiers sous GNU/Linux et
Macintosh sont sensibles à la casse, la liste des
extensions de fichier est sensible à la casse sur ces plateformes.  La
plateforme Windows n&textrsquo;est pas sensible à la casse.
</para>
<para>Vous n&textrsquo;êtes pas tenu d&textrsquo;inclure <code>\DeclareGraphicsExtensions</code> dans
votre document ; le pilote d&textrsquo;impression a une valeur par défaut
raisonnable.  Par exemple, la version la plus récente de
<file>pdftex.def</file> a cette liste d&textrsquo;extensions.
</para>
<example endspaces=" ">
<pre xml:space="preserve">.pdf,.png,.jpg,.mps,.jpeg,.jbig2,.jb2,.PDF,.PNG,.JPG,.JPEG,.JBIG2,.JB2
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1186"><r>paquetage</r> <code>grfext</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1187"><code>grfext</code>, <r>paquetage</r></indexterm></findex>

<para>Pour modifier cet ordre, utilisez le paquetage <code>grfext</code>.
</para>
<para>Vous pouvez utiliser cette commande n&textrsquo;importe où dans le document.  Vous
pouvez l&textrsquo;utiliser plus d&textrsquo;une fois.  On peut afficher la valeur courante
avec <code>\makeatletter\typeout&lbrace;\Gin&arobase;extensions&rbrace;\makeatother</code>.
</para>

</subsection>
<node name="_005cDeclareGraphicsRule" spaces=" "><nodename>\DeclareGraphicsRule</nodename><nodeprev automatic="on">\DeclareGraphicsExtensions</nodeprev><nodeup automatic="on">Graphics package configuration</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\DeclareGraphicsRule</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1188">\DeclareGraphicsRule</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareGraphicsRule&lbrace;<var>extension</var>&rbrace;&lbrace;<var>type</var>&rbrace;&lbrace;<var>extension taille-fic</var>&rbrace;&lbrace;<var>commande</var>&rbrace;
</pre></example>

<para>Déclare comment gérer les fichiers graphiques dont le nom se termine en
<var>extension</var>.
</para>
<para>L&textrsquo;exemple suivant déclare que tous les fichiers dont le nom est de la
forme <file>nomfichier-sans-point.mps</file> doivent être traités comme une
sortie de MetaPost, ce qui signifie que le pilote d&textrsquo;impression utilisera
son code de gestion MetaPost pour traiter le fichier en entrée.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareGraphicsRule&lbrace;.mps&rbrace;&lbrace;mps&rbrace;&lbrace;.mps&rbrace;&lbrace;&rbrace;
</pre></example>

<para>La déclaration suivante
</para>
<example endspaces=" ">
<pre xml:space="preserve">\DeclareGraphicsRule&lbrace;*&rbrace;&lbrace;mps&rbrace;&lbrace;*&rbrace;&lbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>dit à &latex; qu&textrsquo;il doit traiter comme une sortie MetaPost tout fichier
avec extension non couverte par une autre règle, ainsi il couvre
<file>nomfichier.1</file>, <file>nomfichier.2</file>, etc.
</para>
<para>Ici on décrit les quatre arguments.
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">extension</itemformat></item>
</tableterm><tableitem><para>L&textrsquo;extension de nom de fichier à laquelle la règle considérée
s&textrsquo;applique. L&textrsquo;extension commence au premier point dans le nom de
fichier, en incluant le point.  Utiliser l&textrsquo;astérisque, <code>*</code>, pour
désigner la comportement par défaut pour toutes les extensions non
déclarées.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">type</itemformat></item>
</tableterm><tableitem><para>Le type du fichier considéré.  Ce type est une chaîne de caractères qui
doit être définie dans le pilote d&textrsquo;impression. Par exemple, les fichiers
avec les extensions <file>.ps</file>, <file>.eps</file>, ou <file>.ps.gz</file> peuvent
tous être classifiés sous le type <code>eps</code>.  Tous les fichiers de même
type sont traités en entrée avec la même commande interne par le pilote
d&textrsquo;impression. Par exemple, les types de fichiers reconnus par
<file>pdftex</file> sont : <code>jpg</code>, <code>jbig2</code>, <code>mps</code>, <code>pdf</code>,
<code>png</code>, <code>tif</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">extension taille-fic</itemformat></item>
</tableterm><tableitem><para>L&textrsquo;extension du fichier à lire pour déterminer la taille du graphique, si
un tel fichier existe. Elle peut être la même que <var>extension</var> mais
aussi être différente.
</para>
<para>Considérons par exemple un graphique PostScript.  Pour le rendre plus
petit, il peut être compressé en un fichier <file>.ps.gz</file>.  Les fichiers
compressé ne sont pas lu simplement par &latex; aussi vous pouvez
mettre l&textrsquo;information de boîte englobante dans une fichier séparé. Si
<var>extension taille-fic</var> est vide, alors vous devez spécifier
l&textrsquo;information de taille dans les arguments de <code>\includegraphics</code>.
</para>
<para>Si le fichier pilote a une procédure pour lire les tailles de fichier
pour <code>type</code> alors elle est utilisée, sinon il utilise la procédure
pour lire les fichiers <file>.eps</file>.  (Ainsi vous pourriez spécifier la
taille d&textrsquo;un fichier <file>.bmp</file> dans un fichier avec une ligne
<code>%%BoundingBox</code> de style PostScript si aucun autre format
n&textrsquo;est disponible).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">commande</itemformat></item>
</tableterm><tableitem><para>Une commande à appliquer au fichier. La plupart du temps on laisse cet
argument vide. Cette commande doit commencer avec un caractère accent
grave.  Ainsi,
<code>\DeclareGraphicsRule&lbrace;.eps.gz&rbrace;&lbrace;eps&rbrace;&lbrace;.eps.bb&rbrace;&lbrace;`gunzip -c
#1&rbrace;</code> spécifie que tout fichier ayant une extension <file>.eps.gz</file> doit
être traité comme un fichier <code>eps</code>, avec l&textrsquo;information de boîte
englobante stockée dans le fichier ayant l&textrsquo;extension <file>.eps.bb</file>, et
que la commande <code>gunzip -c</code> sera exécuté sur votre plateforme pour
décompresser le fichier.
</para>
<para>Une telle commande est spécifique à votre plateforme.  De plus, votre
système &tex; doit autoriser l&textrsquo;exécution de commandes externes ; par
mesure de sécurité les systèmes modernes restreignent l&textrsquo;exécution de
commandes à moins que vous l&textrsquo;autorisiez explicitement. Se référer à la
documentation de votre distribution &tex;.
</para>
</tableitem></tableentry></table>

</subsection>
</section>
<node name="Commands-for-graphics" spaces=" "><nodename>Commands for graphics</nodename><nodeprev automatic="on">Graphics package configuration</nodeprev><nodeup automatic="on">Graphics</nodeup></node>
<section spaces=" "><sectiontitle>Commandes du paquetage <code>graphics</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="670">graphics, commandes du paquetage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="671">commandes, paquetage graphics</indexterm></cindex>

<para>Voici les commandes disponibles dans les paquetages <file>graphics</file> et
<file>graphicx</file>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::     ">\includegraphics</menunode><menudescription><pre xml:space="preserve">Utiliser un graphique dans votre document.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::           ">\rotatebox</menunode><menudescription><pre xml:space="preserve">Faire une rotation sur une boîte incluant un graphique.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">\scalebox</menunode><menudescription><pre xml:space="preserve">Dilater ou rétrécir une boîte incluant un graphique.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::           ">\resizebox</menunode><menudescription><pre xml:space="preserve">Dilater ou rétrécir une boîte incluant un graphique à un taille donnée.
</pre></menudescription></menuentry></menu>


<node name="_005cincludegraphics" spaces=" "><nodename>\includegraphics</nodename><nodenext automatic="on">\rotatebox</nodenext><nodeup automatic="on">Commands for graphics</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\includegraphics</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="672">graphiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="673">graphics, paquetage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="674">inclure des graphiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="675">importer des graphiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="676">EPS, fichiers</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="677">JPEG, fichiers</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="678">JPG, fichiers</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="679">PDF, fichiers graphiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="680">PNG, fichiers</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1189">\includegraphics</indexterm></findex>

<para>Synopsis pour le paquetage <file>graphics</file> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics[<var>urx</var>,<var>ury</var>]&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics[<var>llx</var>,<var>lly</var>][<var>urx</var>,<var>ury</var>]&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics*&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics*[<var>urx</var>,<var>ury</var>]&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics*[<var>llx</var>,<var>lly</var>][<var>urx</var>,<var>ury</var>]&lbrace;<var>nomfichier</var>&rbrace;
</pre></example>

<para>Synopsis pour le paquetage <file>graphicx</file> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics[<var>liste-à-clefs-valeurs</var>]&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics*&lbrace;<var>nomfichier</var>&rbrace;
\includegraphics*[<var>liste-à-clefs-valeurs</var>]&lbrace;<var>nomfichier</var>&rbrace;
</pre></example>

<para>Inclut un fichier graphique.  La forme étoilée <code>\includegraphics*</code>
rogne le graphique à la taille spécifiée, alors que pour la forme
non-étoilée toute partie du graphique en dehors de la boîte de la taille
spécifiée se superpose à ce qui l&textrsquo;entoure.
</para>
<para>Dans cet exemple
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;graphicx&rbrace;  % dans le préambule
  ...
\begin&lbrace;center&rbrace;
  \includegraphics&lbrace;trace.pdf&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<noindent></noindent>
<para>on incorpore dans le document le graphique dans <file>plot.pdf</file>, centré
et à sa taille nominale.  Vous pouvez aussi donner un chemin au fichier,
comme dans <code>\includegraphics&lbrace;graphiques/trace.pdf&rbrace;</code>.  Pour
spécifier une liste de répertoire ou rechercher le fichier,
<pxref label="_005cgraphicspath"><xrefnodename>\graphicspath</xrefnodename></pxref>.
</para>
<para>Si votre nom de fichier comprend des espaces, alors placer le entre
guillemets anglais. Par exemple comme dans
<code>\includegraphics&lbrace;&quot;image complementaire.jpg&quot;&rbrace;</code>.
</para>
<para>La commande <code>\includegraphics&lbrace;<var>nomfichier</var>&rbrace;</code> décide du type
de graphique en segmentant <var>nomfichier</var> sur le premier point
(<samp>.</samp>). Vous pouvez utiliser <var>nomfichier</var> sans extension de nom
de fichier, comme dans <code>\includegraphics&lbrace;turing&rbrace;</code> et &latex;
essaie une séquence d&textrsquo;extension telle que <code>.png</code> et <code>.pdf</code>
jusqu&textrsquo;à ce qu&textrsquo;il trouve un fichier avec cette extension
(<pxref label="_005cDeclareGraphicsExtensions"><xrefnodename>\DeclareGraphicsExtensions</xrefnodename></pxref>).
</para>
<para>Si votre fichier comprend des points avant l&textrsquo;extension alors vous
pouvez les cacher avec des accolades, comme dans
<code>\includegraphics&lbrace;&lbrace;plot.2018.03.12.a&rbrace;.pdf&rbrace;</code>.  Ou, si vous
utilisez le paquetage <file>graphicx</file> alors vous pouvez utiliser les
options <code>type</code> et <code>ext</code> ; voir plus bas.  Ces problèmes de
noms de fichiers, et d&textrsquo;autres sont aussi traités par le paquetage
<file>grffile</file>.
</para>
<para>L&textrsquo;exemple ci-après place un graphique dans un environnement
<code>figure</code> de sorte que &latex; puisse le déplacer sur la page
suivante si le faire rentrer dans la page courante rend mal
(<pxref label="figure"><xrefnodename>figure</xrefnodename></pxref>).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;figure&rbrace;
  \centering
  \includegraphics[width=3cm]&lbrace;rayonxpoumon.jpg&rbrace;
  \caption&lbrace;Ça saute aux yeux : vous ne devriez arrêter de fumer&rbrace;  \label&lbrace;fig:rayon-x&rbrace;
\end&lbrace;figure&rbrace;
</pre></example>

<para>L&textrsquo;exemple suivant place un graphique non flottant, de sorte à garantir
qu&textrsquo;il apparaisse à ce point-ci du document même si cela oblige &latex;
à dilater le texte ou à recourir à des zones blanches sur la page.  Le
graphique est centré est a une légende.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;caption&rbrace;  % dans le préambule
  ...
\begin&lbrace;center&rbrace;
  \includegraphics&lbrace;sans/images.png&rbrace;
  \captionof&lbrace;figure&rbrace;&lbrace;L'esprit de la nuit&rbrace; \label&lbrace;sans:images&rbrace; % optionnel
\end&lbrace;center&rbrace;
</pre></example>

<para>L&textrsquo;exemple suivant place une boîte avec un graphique le long d&textrsquo;une autre
boîte contenant du texte, les deux boîtes étant verticalement centrées :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand*&lbrace;\vcenteredhbox&rbrace;[1]&lbrace;\begin&lbrace;tabular&rbrace;&lbrace;&arobase;&lbrace;&rbrace;c&arobase;&lbrace;&rbrace;&rbrace;#1\end&lbrace;tabular&rbrace;&rbrace;
  ...
\begin&lbrace;center&rbrace;
  \vcenteredhbox&lbrace;\includegraphics[width=0.4\textwidth]&lbrace;trace&rbrace;&rbrace;
  \hspace&lbrace;1em&rbrace;
  \vcenteredhbox&lbrace;\begin&lbrace;minipage&rbrace;&lbrace;0.4\textwidth&rbrace;
                   \begin&lbrace;displaymath&rbrace;
                     f(x)=x\cdot \sin (1/x)
                   \end&lbrace;displaymath&rbrace;
                 \end&lbrace;minipage&rbrace;&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<para>Si vous utilisez le paquetage <file>graphics</file> alors les seules options
disponibles concernent la taille du graphique (mais voir
<ref label="_005crotatebox"><xrefnodename>\rotatebox</xrefnodename></ref> et <ref label="_005cscalebox"><xrefnodename>\scalebox</xrefnodename></ref>).  Quand un argument optionnel est
présent alors c&textrsquo;est <code>[<var>urx</var>,<var>ury</var>]</code> et il donne les
coordonnées du coin en haut à droite de l&textrsquo;image, comme une paire de
dimensions &tex; (<pxref label="Units-of-length"><xrefnodename>Units of length</xrefnodename></pxref>).  Si les unités sont omises,
alors par défaut l&textrsquo;unité considérée est le <code>bp</code>.  Dans ce cas, le
coin en bas à gauche de l&textrsquo;image est supposé être à <code>(0,0)</code>.  Si deux
arguments optionnels sont présents alors le premier est
<code>[<var>llx</var>,<var>lly</var>]</code>, et il spécifie les coordonnées du coin en
bas à gauche de l&textrsquo;image.  Ainsi,
<code>\includegraphics[1in,0.618in]&lbrace;...&rbrace;</code> demande que le graphique
soit placé de sorte a avoir 1 pouce de largeur et 0,618 pouces de hauteur
et donc son origine est à (0,0).
</para>
<para>Le paquetage <file>graphicx</file> vous offre beaucoup plus d&textrsquo;options.
Spécifiez les sous la forme de paires clef-valeur, comme ci-après :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \includegraphics[width=3cm,angle=90]&lbrace;lion&rbrace;
  \hspace&lbrace;2em&rbrace;
  \includegraphics[angle=90,width=3cm]&lbrace;lion&rbrace;
\end&lbrace;center&rbrace;
</pre></example>

<noindent></noindent>
<para>Les options sont lues de gauche à droite. Ainsi le premier graphique
ci-dessus est dilaté à une largeur de 3<dmn>cm</dmn>, et ensuite subit une
rotation de 90<dmn>degrés</dmn>, alors que le second subit la rotation en
premier et ensuite est dilaté à 3<dmn>cm</dmn> de largeur.  Ainsi, à moins
que le graphique soit parfaitement carré, à la fin les deux n&textrsquo;ont pas
les mêmes largeurs et hauteurs.
</para>
<para>Il y a beaucoup d&textrsquo;options.  Les principales sont listées en premier.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="681">boîte englobante</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="682">englobante, boîte</indexterm></cindex>
<para>Notez qu&textrsquo;un graphique est placé par &latex; dans une boîte, qu&textrsquo;on
désigne traditionnellement comme sa <dfn>boîte englobante</dfn> (distincte de
la BoundingBox PostScript décrite plus bas).  La zone sur laquelle le
graphique s&textrsquo;imprime peut aller au delà de cette boîte, ou s&textrsquo;inscrire
dans cette boîte, mais quand &latex; fabrique une page il assemble des
boîtes, et celle-ci est la boîte allouée pour le graphique.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="includegraphics-width">includegraphics width</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">width</itemformat></item>
</tableterm><tableitem><para>Le graphique est affiché de sorte que sa boîte englobante ait cette
largeur.  Un exemple est <code>\includegraphics[width=2.5cm]&lbrace;trace&rbrace;</code>.
Vous pouvez utiliser les unités de longueur standardes de &tex;
(<pxref label="Units-of-length"><xrefnodename>Units of length</xrefnodename></pxref>) et également il est commode d&textrsquo;utiliser
<code>\linewidth</code>, ou, dans un document recto-verso, <code>\columnwidth</code>
(<pxref label="Page-layout-parameters"><xrefnodename>Page layout parameters</xrefnodename></pxref>).  Un exemple est qu&textrsquo;en utilisant le
paquetage <file>calc</file> vous pouvez rendre le graphique 1<dmn>cm</dmn> plus
étroit que la largeur du texte avec
<code>\includegraphics[width=\linewidth-1.0cm]&lbrace;hefferon.jpg&rbrace;</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">height</itemformat></item>
</tableterm><tableitem><anchor name="includegraphics-height">includegraphics height</anchor>

<para>Le graphique est affiché de sorte que sa boîte englobante est de cette
hauteur.  Vous pouvez utiliser les unités de longueur standardes de
&tex; (<pxref label="Units-of-length"><xrefnodename>Units of length</xrefnodename></pxref>), et également il est commode d&textrsquo;utiliser
<code>\pageheight</code> et <code>\textheight</code> (<pxref label="Page-layout-parameters"><xrefnodename>Page layout
parameters</xrefnodename></pxref>).  Par exemple, la commande
<code>\includegraphics[height=0.25\textheight]&lbrace;godel&rbrace;</code> rend le
graphique d&textrsquo;une hauteur d&textrsquo;un quart de celle de la zone de texte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">totalheight</itemformat></item>
</tableterm><tableitem><anchor name="includegraphics-totalheight">includegraphics totalheight</anchor>

<para>Le graphique est affiché de sorte que sa boîte englobante ait cette
hauteur plus profondeur.  Ceci diffère de la hauteur si le graphique a
subi une rotation. Par exemple, s&textrsquo;il a subi une rotation de -90 degrés
alors il a une hauteur nulle mais une grande profondeur.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">keepaspectratio</itemformat></item>
</tableterm><tableitem><anchor name="includegraphics-keepaspectratio">includegraphics keepaspectratio</anchor>
<para>Si réglé à <code>true</code>, ou juste spécifié comme ci-dessous
</para>
<example endspaces=" ">
<pre xml:space="preserve"><code>\includegraphics[...,keepaspectratio,...]&lbrace;...&rbrace;</code>
</pre></example>

<noindent></noindent>
<para>et que vous donnez en option à la fois <code>width</code> et <code>height</code> (ou
<code>totalheight</code>), alors &latex; rendra le graphique aussi grand que
possible sans le déformer. C&textrsquo;est à dire que &latex; assure que le
graphique n&textrsquo;est ni plus large que <code>width</code> ni plus haut que
<code>height</code> (ou <code>totalheight</code>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">scale</itemformat></item>
</tableterm><tableitem><para>Facteur par lequel dilater/contracter le graphique.  On peut rendre
 graphique à deux fois sa taille nominale avec
 <code>\includegraphics[scale=2.0]&lbrace;...&rbrace;</code>.  Ce nombre peut prendre
 n&textrsquo;importe quelle valeur ; un nombre entre 0 et 1 contracte le graphique
 et un nombre négatif lui applique une réflexion.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">angle</itemformat></item>
</tableterm><tableitem><para>Applique une rotation au graphique.  L&textrsquo;angle est exprimé en degrés et
dans le sens antihoraire.  La rotation est effectuée autour de l&textrsquo;origine
donnée par l&textrsquo;option <code>origin</code> ; s&textrsquo;y référer.  Pour une description
complète de la composition de matière ayant subi une rotation,
<pxref label="_005crotatebox"><xrefnodename>\rotatebox</xrefnodename></pxref>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">origin</itemformat></item>
</tableterm><tableitem><para>Le point du graphique autour duquel la rotation s&textrsquo;effectue.  Les valeurs
possibles sont toute chaîne contenant un ou deux caractères parmi :
<code>l</code> pour gauche (left), <code>r</code> pour droite (right), <code>b</code> pour
bas, <code>c</code> pour centré, <code>t</code> pour haut (top), et <code>B</code> pour
ligne de base.  Ainsi, saisir la commande
<code>\includegraphics[angle=180,origin=c]&lbrace;moon&rbrace;</code> a pour effet de
mettre la figure tête en bas en tournant autour du centre de l&textrsquo;image,
alors que la commande
<code>\includegraphics[angle=180,origin=lB]&lbrace;LeBateau&rbrace;</code> fait la
rotation autour du point gauche de la ligne de base.  (Le caractère
<code>c</code> désigne le centre horizontal dans <code>bc</code> ou <code>tc</code>, mais
le centre vertical dans <code>lc</code> <code>rc</code>). Le réglage par défaut est
<code>lB</code>.
</para>
<para>Pour faire une rotation autour d&textrsquo;un point arbitraire,
<pxref label="_005crotatebox"><xrefnodename>\rotatebox</xrefnodename></pxref>.
</para>
</tableitem></tableentry></table>

<para>Voici maintenant des options moins usuelles.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="includegraphics-viewport">includegraphics viewport</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">viewport</itemformat></item>
</tableterm><tableitem><para>Désigne une sous-région du graphique à afficher.  Prend quatre
arguments, séparés par des espaces et exprimés comme des dimensions
&tex;, comme dans <code>\includegraphics[.., viewport=0in 0in 1in
0.618in]&lbrace;...&rbrace;</code>.  Quand l&textrsquo;unité est omise, les dimensions sont par
défaut en big points, <code>bp</code>.  Elle sont prises relativement à
l&textrsquo;origine spécifiée par la boîte englobante.  Voir aussi l&textrsquo;option
<code>trim</code>.
</para>
<anchor name="includegraphics-trim">includegraphics trim</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">trim</itemformat></item>
</tableterm><tableitem><para>Désigne les parties du graphique à ne pas afficher.  Prend quatre
arguments, séparés par des espaces, et exprimés comme des dimensions
&tex; dimensions, comme dans <code>\includegraphics[.., trim= 0in 0.1in
0.2in 0.3in, ...]&lbrace;...&rbrace;</code>.  Ceci donne la quantité du graphique à ne pas
afficher, c.-à-d.&noeos; que &latex; rogne l&textrsquo;image de 0 pouce sur la gauche
left, 0.1 pouce sur la bas, 0.2 pouce sur la droite, et 0.3 pouce sur le
haut.  Voir aussi l&textrsquo;option <code>viewport</code>.
</para>
<anchor name="includegraphics-clip">includegraphics clip</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">clip</itemformat></item>
</tableterm><tableitem><para>Si réglé à <code>true</code>, ou juste spécifié comme ci-dessous
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics[...,clip,...]&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>alors le graphique est rogné à sa boîte englobante.  Ceci revient au
même que d&textrsquo;utiliser la forme étoilée de la commande,
<code>\includegraphics*[...]&lbrace;...&rbrace;</code>.
</para>
<anchor name="includegraphics-page">includegraphics page</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">page</itemformat></item>
</tableterm><tableitem><para>Donne le numéro de page pour un fichier PDF multi-page.  La valeur par
défaut est <code>page=1</code>.
</para>
<anchor name="includegraphics-pagebox">includegraphics pagebox</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">pagebox</itemformat></item>
</tableterm><tableitem><para>Spécifie quelle boîte englobante utiliser pour les fichiers PDF parmi
les suivantes <code>mediabox</code>, <code>cropbox</code>, <code>bleedbox</code>,
<code>trimbox</code>, ou <code>artbox</code>.  Les fichiers PDF n&textrsquo;ont pas la
BoundingBox que les fichiers PostScript ont, mais peuvent spécifier
jusqu&textrsquo;à quatre rectangles prédéfinis. La boîte <code>mediabox</code> donne les
frontières du médium physique. La boîte <code>cropbox</code> est la région à
laquelle le contenu de la page devrait être épinglé quand il est
affiché.  La boite <code>bleedbox</code> la région à laquelle le contenu de la
page devrait être épinglé en production. La boîte <code>trimbox</code> est
correspond aux dimensions désirées de la page finie.  La boîte
<code>artbox</code> est de l&textrsquo;étendue du contenu de la page ayant du sens.  Le
pilote règle la taille de l&textrsquo;image en se basant sur la <code>cropbox</code> si
elle est présente, sinon il n&textrsquo;utilise pas les autres, avec un ordre de
préférence propre au pilote. La boîte <code>mediabox</code> est toujours présente.
</para>
<anchor name="includegraphics-interpolate">includegraphics interpolate</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">interpolate</itemformat></item>
</tableterm><tableitem><para>Active ou désactive l&textrsquo;interpolation des images matricielles par la
visionneuse.  On peut régler l&textrsquo;option avec <code>interpolate=true</code> ou
juste comme ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics[...,interpolate,...]&lbrace;...&rbrace;
</pre></example>

<anchor name="includegraphics-quiet">includegraphics quiet</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">quiet</itemformat></item>
</tableterm><tableitem><para>N&textrsquo;écrit pas d&textrsquo;information dans le journal.  On peut régler l&textrsquo;option avec
<code>quiet=true</code> ou juste en la spécifiant avec
<code>\includegraphics[...,quiet,...]&lbrace;...&rbrace;</code>,
</para>
<anchor name="includegraphics-draft">includegraphics draft</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">draft</itemformat></item>
</tableterm><tableitem><para>Lorsqu&textrsquo;on règle l&textrsquo;option avec <code>draft=true</code> ou juste ainsi
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics[...,draft,...]&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>alors le graphique n&textrsquo;apparaît pas dans le document, ce qui permet
éventuellement d&textrsquo;économiser l&textrsquo;imprimante couleur.  À la place &latex;
place une boîte vide de la bonne taille avec le nom du fichier imprimé
dedans.
</para>
</tableitem></tableentry></table>

<para>Les options suivantes traitent de la boîte englobante pour les fichiers
graphique de type PostScript Encapsulé, leur taille est spécifié avec
une ligne <code>%%BoundingBox</code> qui apparaît dans le fichier.  Elle a
quatre valeurs donnant la coordonnée <math>x</math> inférieure, la coordonnée
<math>y</math> inférieure, la coordonnée <math>x</math> supérieure, et la coordonnée
<math>y</math> supérieure.  L&textrsquo;unité est le point PostScript, équivalent au big
point de &tex;, à savoir 1/72 de pouce.  Par exemple, si un fichier
<file>.eps</file> a la ligne <code>%%BoundingBox 10 20 40 80</code> alors sa taille
naturelle est 30/72 de pouce de large pour 60/72 de pouce de haut.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="includegraphics-bb">includegraphics bb</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">bb</itemformat></item>
</tableterm><tableitem><para>Spécifie la boîte englobante de la région affichée.  L&textrsquo;argument est
constitué de quatre dimensions séparées par des espaces, comme dans
<code>\includegraphics[.., bb= 0in 0in 1in 0.618in]&lbrace;...&rbrace;</code>.
D&textrsquo;ordinaire <code>\includegraphics</code> lit les ces nombre BoundingBox dans
le fichier EPS automatiquement, de sorte que cette option n&textrsquo;est utile que
si la définition de la boîte englobante est absente du fichier ou si
vous désirez la changer.
</para>
<anchor name="includegraphics-bbllx">includegraphics bbllx</anchor>
<anchor name="includegraphics-bblly">includegraphics bblly</anchor>
<anchor name="includegraphics-bburx">includegraphics bburx</anchor>
<anchor name="includegraphics-bbury">includegraphics bbury</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">bbllx, bblly, bburx, bbury</itemformat></item>
</tableterm><tableitem><para>Règle la boîte englobante.  Ces quatre options là sont obsolètes,
mais existent encore pour maintenir la rétrocompatibilité avec des
paquetages anciens.
</para>
<anchor name="includegraphics-natwidth">includegraphics natwidth</anchor>
<anchor name="includegraphics-natheight">includegraphics natheight</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">natwidth, natheight</itemformat></item>
</tableterm><tableitem><para>Une alternative à <code>bb</code>.  Régler
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics[...,natwidth=1in,natheight=0.618in,...]&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>revient au même que régler <code>bb=0 0 1in 0.618in</code>.
</para>
<anchor name="includegraphics-hiresbb">includegraphics hiresbb</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">hiresbb</itemformat></item>
</tableterm><tableitem><para>Si réglé à <code>true</code>, ou juste spécifié comme dans
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includegraphics[...,hiresbb,...]&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>alors &latex; recherche la ligne <code>%%HiResBoundingBox</code> plutôt que
la ligne <code>%%BoundingBox</code>.  (La ligne <code>BoundingBox</code> n&textrsquo;utilise
que des nombres entiers naturels alors que la ligne
<code>HiResBoundingBox</code> utilise des décimaux ; les deux utilisent une
unité équivalente au big point de &tex;, 1/72 de pouce). Pour
l&textrsquo;emporter sur un réglage précédent à <code>true</code>, on peut la régler à
<code>false</code>.
</para>
</tableitem></tableentry></table>

<para>Les options suivantes permettent à l&textrsquo;utilisateur de l&textrsquo;emporter sur la
méthode par laquelle &latex; choisit le type d&textrsquo;un graphique en fonction
de son extension de nom de fichier.  Par exemple avec
<code>\includegraphics[type=png,ext=.xxx,read=.xxx]&lbrace;lion&rbrace;</code> le fichier
<file>lion.xxx</file> est lu comme s&textrsquo;il s&textrsquo;agissait de <file>lion.png</file>. Pour
plus ample information, <pxref label="_005cDeclareGraphicsRule"><xrefnodename>\DeclareGraphicsRule</xrefnodename></pxref>.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="includegraphics-type">includegraphics type</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">type</itemformat></item>
</tableterm><tableitem><para>Spécifie le type de graphique.
</para>
<anchor name="includegraphics-ext">includegraphics ext</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">ext</itemformat></item>
</tableterm><tableitem><para>Spécifie l&textrsquo;extension du graphique. À n&textrsquo;utiliser qu&textrsquo;en conjonction avec
l&textrsquo;option <code>type</code>.
</para>
<anchor name="includegraphics-read">includegraphics read</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">read</itemformat></item>
</tableterm><tableitem><para>Spécifie l&textrsquo;extension du fichier lu. À n&textrsquo;utiliser qu&textrsquo;en conjonction avec
l&textrsquo;option <code>type</code>.
</para>
<anchor name="includegraphics-command">includegraphics command</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">command</itemformat></item>
</tableterm><tableitem><para>Spécifie une commande à appliquer à ce fichier. À n&textrsquo;utiliser qu&textrsquo;en
conjonction avec l&textrsquo;option <code>type</code>.  <xref label="Command-line-options"><xrefnodename>Command line options</xrefnodename></xref>,
pour une discussion sur l&textrsquo;activation de la fonctionnalité <code>\write18</code>
pour exécuter des commandes externes.
</para>
</tableitem></tableentry></table>


</subsection>
<node name="_005crotatebox" spaces=" "><nodename>\rotatebox</nodename><nodenext automatic="on">\scalebox</nodenext><nodeprev automatic="on">\includegraphics</nodeprev><nodeup automatic="on">Commands for graphics</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\rotatebox</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="683">rotation</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="684">rotation, appliquer à un graphique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="685">rotation, appliquer à du texte</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1190">\rotatebox</indexterm></findex>

<para>Synopsis si vous utilisez le paquetage <code>graphics</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\rotatebox&lbrace;<var>angle</var>&rbrace;&lbrace;<var>matière</var>&rbrace;
</pre></example>

<para>Synopsis si vous utilisez le paquetage <code>graphicx</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\rotatebox&lbrace;<var>angle</var>&rbrace;&lbrace;<var>matière</var>&rbrace;
\rotatebox[<var>liste-à-clefs-valeurs</var>]&lbrace;<var>angle</var>&rbrace;&lbrace;<var>matière</var>&rbrace;
</pre></example>

<para>Place <var>matière</var> dans une boîte et lui applique une rotation de
<var>angle</var> degrés dans le sens antihoraire.
</para>
<para>L&textrsquo;exemple suivant applique une rotation de quarante-cinq degrés aux
en-têtes de colonnes.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;tabular&rbrace;&lbrace;ll&rbrace;
  \rotatebox&lbrace;45&rbrace;&lbrace;Caractère&rbrace; &amp;\rotatebox&lbrace;45&rbrace;&lbrace;alphabet marin&rbrace;   \\
  A                         &amp;ALPHA  \\
  B                         &amp;BRAVO
\end&lbrace;tabular&rbrace;
</pre></example>

<para>Le <var>matière</var> peut être quoi que ce soit qui aille dans une boîte, y
compris un graphique.
</para>
<example endspaces=" ">
<pre xml:space="preserve">  \rotatebox[origin=c]&lbrace;45&rbrace;&lbrace;\includegraphics[width=2.5cm]&lbrace;lion&rbrace;&rbrace;
</pre></example>

<para>Pour placer la matière auquel on désire appliquer une rotation, la
première étape est que &latex; met <var>matière</var> dans une boîte, avec
un point de référence sur la ligne de base à gauche.  La deuxième étape
est la rotation, par défaut autour du point de référence.  La troisième
étape est que &latex; calcule une boîte englobante de matière après
rotation.  Quatrièmement, &latex; déplace cette boîte horizontalement
de sorte que son bord de gauche coïncide avec le bord de gauche de la
boîte de la première étape (il n&textrsquo;est pas nécessaire qu&textrsquo;elles coïncident
verticalement).  Cette nouvelle boîte englobante, dans sa nouvelle
position, est celle que &latex; utilisera au moment de composer cette
matière.
</para>
<para>Si vous utilisez le paquetage <code>graphics</code> alors la rotation est
autour du point de référence de la boîte.  Si vous utilisez le paquetage
<code>graphicx</code> alors voici les options qu&textrsquo;on peut mettre dans
<var>liste-à-clefs-valeurs</var>, mais notez qu&textrsquo;on peut obtenir le même effet
sans ce paquetage, excepté pour les options <code>x</code> et <code>y</code>.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">origin</itemformat></item>
</tableterm><tableitem><para>Le point de la boîte du <var>matière</var> autour duquel la rotation se
produit.  Les valeurs possibles sont toute chaîne contenant un ou deux
caractères pris parmi : <code>l</code> pour gauche (left), <code>r</code> droite
(right), <code>b</code> pour bas, <code>c</code> pour centre, <code>t</code>
pour haut (top), et <code>B</code> pour ligne de base (baseline).
Ainsi, la première ligne ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\rotatebox[origin=c]&lbrace;180&rbrace;&lbrace;LaLune&rbrace;
\rotatebox[origin=lB]&lbrace;180&rbrace;&lbrace;LeBateau&rbrace;
</pre></example>

<noindent></noindent>
<para>retourne l&textrsquo;image haut en bas autour de son centre, alors que la seconde
la retourne autour de l&textrsquo;extrémité gauche de sa ligne de base.  (Le
caractère <code>c</code> donne le centre horizontal dans <code>bc</code> ou
<code>tc</code> mais donne le centre vertical dans <code>lc</code> ou <code>rc</code>, et
donne les deux dans <code>c</code>).  Le réglage par défaut est <code>lB</code>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">x, y</itemformat></item>
</tableterm><tableitem><para>Spécifiez un point de rotation arbitraire avec
<code>\rotatebox[x=<var>dimension &tex;</var>,y=<var>dimension
&tex;</var>]&lbrace;...&rbrace;</code> (<pxref label="Units-of-length"><xrefnodename>Units of length</xrefnodename></pxref>).  Ces paramètres donnent le
décalage relatif au point de référence de la boîte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">units</itemformat></item>
</tableterm><tableitem><para>Cette clef vous permet d&textrsquo;utiliser une autre unité que celle par défaut,
à savoir les degrés antihoraires. Régler <code>units=-360</code> change la
direction en degrés horaires, et régler <code>units=6.283185</code> change
l&textrsquo;unité en radians antihoraires.
</para>
</tableitem></tableentry></table>


</subsection>
<node name="_005cscalebox" spaces=" "><nodename>\scalebox</nodename><nodenext automatic="on">\resizebox</nodenext><nodeprev automatic="on">\rotatebox</nodeprev><nodeup automatic="on">Commands for graphics</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\scalebox</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="686">graphiques, dilatation &amp; contraction</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="687">graphiques, changer d&textrsquo;échelle</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="688">dilater</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="689">contracter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="690">changer la taille</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="691">texte, dilater</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="692">texte, contracter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="693">texte, changer la taille</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1191">\scalebox</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1192">\reflectbox</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\scalebox&lbrace;<var>facteur horizontal</var>&rbrace;&lbrace;<var>matière</var>&rbrace;
\scalebox&lbrace;<var>facteur horizontal</var>&rbrace;[<var>facteur vertical</var>]&lbrace;<var>matière</var>&rbrace;
\reflectbox&lbrace;<var>matière</var>&rbrace;
</pre></example>

<para>Applique une homothétie au <var>matière</var>.
</para>
<para>Dans l&textrsquo;exemple suivant on divise la taille par deux, à la fois
horizontalement et verticalement, du premier texte, et on double la
taille du second :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\scalebox&lbrace;0.5&rbrace;&lbrace;BOIS MOI&rbrace; et \scalebox&lbrace;2.0&rbrace;&lbrace;Mange Moi&rbrace;
</pre></example>

<para>Si vous ne précisez pas le <var>facteur vertical</var> optionnel, alors par
défaut il prend la même valeur que le <var>facteur horizontal</var>.
</para>
<para>Vous pouvez utiliser cette commande pour changer la taille d&textrsquo;un
graphique, comme dans :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\scalebox&lbrace;0.5&rbrace;&lbrace;\includegraphics&lbrace;lion&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Si vous utilisez le paquetage <code>graphicx</code> alors vous pouvez
accomplir la même chose avec les arguments optionnels
d&textrsquo;<code>\includegraphics</code> (<pxref label="_005cincludegraphics"><xrefnodename>\includegraphics</xrefnodename></pxref>).
</para>
<para>La commande <code>\reflectbox</code> abrège
<code>\scalebox&lbrace;-1&rbrace;[1]&lbrace;<var>matière</var>&rbrace;</code>.  Ainsi, <code>orizabus
\reflectbox&lbrace;orizabus&rbrace;</code> affiche le mot <samp>orizabus</samp> immédiatement
suivi de son image par réflexion selon un axe vertical.
</para>

</subsection>
<node name="_005cresizebox" spaces=" "><nodename>\resizebox</nodename><nodeprev automatic="on">\scalebox</nodeprev><nodeup automatic="on">Commands for graphics</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\resizebox</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="694">graphiques, dilater</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="695">graphiques, contracter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="696">graphiques, homothétie</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="697">graphics, changer la taille</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="698">dilater</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="699">contracter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="700">homothétie</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="701">changer la taille</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="702">texte, dilater</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="703">texte, contracter</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="704">texte, homothétie sur du</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="705">texte, changer la taille</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1193">\resizebox</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\resizebox&lbrace;<var>longueur horizontale</var>&rbrace;&lbrace;<var>longueur verticale</var>&rbrace;&lbrace;<var>matière</var>&rbrace;
\resizebox*&lbrace;<var>longueur horizontale</var>&rbrace;&lbrace;<var>longueur verticale</var>&rbrace;&lbrace;<var>matière</var>&rbrace;
</pre></example>

<para>Étant donnée une taille, telle que <code>3cm</code>, transforme le
<var>matière</var> pour qu&textrsquo;il prenne cette taille. Si soit <var>longueur
horizontale</var> soit <var>longueur verticale</var> est un point
d&textrsquo;exclamation <code>!</code> alors l&textrsquo;autre argument est utilisé pour
déterminer un facteur d&textrsquo;échelle appliqué aux deux directions.
</para>
<para>Dans l&textrsquo;exemple suivant on rend le graphique 1,3<dmn>cm</dmn> de large et on
le dilate/contracte verticalement selon le même facteur pour ne pas
changer ses proportions.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\resizebox&lbrace;1.3cm&rbrace;&lbrace;!&rbrace;&lbrace;\includegraphics&lbrace;lion&rbrace;&rbrace;
</pre></example>

<para>La forme non étoilée <code>\resizebox</code> considère <var>longueur
verticale</var> comme la hauteur de la boîte alors que la forme étoilée
<code>\resizebox*</code> la considère comme la somme hauteur + profondeur.
Par exemple, rendez le texte d&textrsquo;une hauteur+profondeur de 6<dmn>mm</dmn> avec
<code>\resizebox*&lbrace;!&rbrace;&lbrace;6mm&rbrace;&lbrace;\parbox&lbrace;9cm&rbrace;&lbrace;Cette boîte a à la fois
de la hauteur et de la profondeur.&rbrace;&rbrace;</code>.
</para>
<para>Vous pouvez utiliser <code>\depth</code>, <code>\height</code>, <code>\totalheight</code>,
et <code>\width</code> pour vous référer aux dimensions originales de la
boîte. Ainsi, rendez le texte d&textrsquo;une largeur de 5<dmn>cm</dmn> tout en lui
conservant sa hauteur originale avec
<code>\resizebox&lbrace;5cm&rbrace;&lbrace;\height&rbrace;&lbrace;Cinq centimètres&rbrace;</code>.
</para>

</subsection>
</section>
</chapter>
<node name="Special-insertions" spaces=" "><nodename>Special insertions</nodename><nodenext automatic="on">Splitting the input</nodenext><nodeprev automatic="on">Graphics</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Insertions spéciales</sectiontitle>

<para>&latex; fournit des commandes pour insérer les caractères qui ont une
signification spéciale mais ne correspondent à aucun caractère simple
que vous pouvez taper.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Caractères réservés</menutitle><menunode separator=".     ">Reserved characters</menunode><menudescription><pre xml:space="preserve">Insérer <samp># $ % &amp; &lbrace; &rbrace; _ ~ ^ \</samp>
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Capitale et bas de casse</menutitle><menunode separator=". ">Upper and lower case</menunode><menudescription><pre xml:space="preserve">Changer la casse du texte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Symboles d&textrsquo;une police</menutitle><menunode separator=".    ">Symbols by font position</menunode><menudescription><pre xml:space="preserve">Insérer des symboles d&textrsquo;une police par leur numéro.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Symboles dans du texte</menutitle><menunode separator=".            ">Text symbols</menunode><menudescription><pre xml:space="preserve">Insérer d&textrsquo;autres symboles non-lettre dans le texte.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                 ">Accents</menunode><menudescription><pre xml:space="preserve">Insérer des accents.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Lettres latines supplémentaires</menutitle><menunode separator=".  ">Additional Latin letters</menunode><menudescription><pre xml:space="preserve">Insérer d&textrsquo;autres caractères non-Américain.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">inputenc&comma;, paquetage</menutitle><menunode separator=". ">inputenc package</menunode><menudescription><pre xml:space="preserve">Régler le codage de texte du fichier d&textrsquo;entrée.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                   ">\rule</menunode><menudescription><pre xml:space="preserve">Insérer des lignes et des  rectangles.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                  ">\today</menunode><menudescription><pre xml:space="preserve">Insérer la date du jour.
</pre></menudescription></menuentry></menu>


<node name="Reserved-characters" spaces=" "><nodename>Reserved characters</nodename><nodenext automatic="on">Upper and lower case</nodenext><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>Caractères réservés</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="706">caractères réservés</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="707">réservés, caractères</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="708">caractères spéciaux</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="709">spéciaux, caractères</indexterm></cindex>

<para>&latex; réserve les caractères suivant à un usage spécial (par exemple,
le signe pourcent <code>%</code> sert aux commentaires) c&textrsquo;est pourquoi on les
appelle <dfn>caractères réservés</dfn> ou <dfn>caractères spéciaux</dfn>. Ils sont
chacun l&textrsquo;objet d&textrsquo;une discussion ailleurs dans ce manuel.
</para>
<example endspaces=" ">
<pre xml:space="preserve"># $ % &amp; &lbrace; &rbrace; _ ~ ^ \
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1194">\#</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1195">\$</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1196">\%</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1197">\&amp;</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1198">\_</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1199">\&lbrace;</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1200">\&rbrace;</indexterm></findex>
<para>Si vous voulez qu&textrsquo;un caractère réservé soit imprimé comme lui-même, dans
la même police que le corps du texte, alors pour tous les caractères
hormis les trois derniers de cette liste il suffit de les faire précéder
d&textrsquo;une controblique <code>\</code>. Ainsi saisir <code>\$1.23</code>
produit <code>$1.23</code> en sortie.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1201">\~</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1202">\^</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1203">\textbackslash</indexterm></findex>
<para>Quant aux trois derniers caractères, pour faire un tilde dans la police
du corps du texte utilisez <code>\~&lbrace;&rbrace;</code> (sans les accolades cela
mettrait un accent tilde sur le caractère suivant). De même pour faire
un accent circonflexe dans la police du corps du texte utilisez
<code>\^&lbrace;&rbrace;</code>. Pour faire une controblique dans dans la police du corps
de texte, saisissez <code>\textbackslash&lbrace;&rbrace;</code>.
</para>
<para>Pour produire les caractères réservés dans la police tapuscrite utilisez
<code>\verb!!</code> comme ci-dessous (la double controblique <code>\\</code> n&textrsquo;est
là que pour aller à la ligne en sortie) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;center&rbrace;
  \# \$ \% \&amp; \&lbrace; \&rbrace; \_ \~&lbrace;&rbrace; \^&lbrace;&rbrace; \textbackslash \\
  \verb!# $ % &amp; &lbrace; &rbrace; _ ~ ^ \!
\end&lbrace;center&rbrace;
</pre></example>


</section>
<node name="Upper-and-lower-case" spaces=" "><nodename>Upper and lower case</nodename><nodenext automatic="on">Symbols by font position</nodenext><nodeprev automatic="on">Reserved characters</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>Capitales et bas de casse</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="710">Capitales</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="711">Bas de casse</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="712">Casse de caractères</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="713">Changer la casse de caractères</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\uppercase&lbrace;<var>texte</var>&rbrace;
\lowercase&lbrace;<var>texte</var>&rbrace;
\MakeUppercase&lbrace;<var>texte</var>&rbrace;
\MakeLowercase&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Change la casse des caractères.  Les commandes primitives de &tex;
<code>\uppercase</code> et <code>\lowercase</code> ne fonctionnent que pour les
26 lettres sans diacritiques a-z et A-Z. Les commandes &latex;
<code>\MakeUppercase</code> et <code>\MakeLowercase</code> changent aussi les
caractères accessibles par des commandes telles que <code>\ae</code> ou
<code>\aa</code>.  Ces commandes <code>\MakeUppercase</code> et
<code>\MakeLowercase</code> sont robustes, mais elles ont des arguments
mouvants (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Ces commandes ne changent pas la casse des lettres utilisées dans le nom
d&textrsquo;une commande au sein de <var>texte</var>. Mais par contre elles changent la
casse de tout autre lettre latine au sein de l&textrsquo;argument <var>texte</var>.
Ainsi, <code>\MakeUppercase&lbrace;Soit $y=f(x)$</code>&rbrace; produit <samp>SOIT
Y=F(X)</samp>.  Un autre exemple est que le nom de tout environnement est
changé, de sorte que <code>\MakeUppercase&lbrace;\begin&lbrace;tabular&rbrace;
... \end&lbrace;tabular&rbrace;&rbrace;</code> produit une erreur puisque la première moitié est
changée en <code>\begin&lbrace;TABULAR&rbrace;</code>.
</para>
<para>&latex; utilise la même table pour changer la casse tout au long du
document. La table utilisée est conçue pour le codage T1 ; ceci
fonctionne bien avec les polices standardes de &tex; pour tous les
alphabets latins, mais cause des problèmes avec d&textrsquo;autres alphabets.
</para>
<para>Pour changer la casse du texte qui résulte d&textrsquo;une macro au sein de
<var>texte</var> il est nécessaire de faire un développement.  Dans l&textrsquo;exemple
qui suit la macro <code>\Nomecole</code> produit <samp>UNIVERSITÉ DE MATHÉMATIQUES</samp>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\nomecole&rbrace;&lbrace;Universit\'e de math\'ematiques&rbrace;
\newcommand&lbrace;\Nomecole&rbrace;&lbrace;\expandafter\MakeUppercase\expandafter&lbrace;\nomecole&rbrace;&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1204"><r>paquetage</r> <code>textcase</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1205"><code>textcase</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>textcase</code> comble certaines des lacunes des commandes
standardes <code>\MakeUppercase</code> et <code>\MakeLowerCase</code> de &latex;.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1206"><r>paquetage</r> <code>mfirstuc</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1207"><code>mfirstuc</code>, <r>paquetage</r></indexterm></findex>

<para>Pour mettre en capitale seulement la première lettre d&textrsquo;un mot, on peut
utiliser le paquetage <code>mfirstuc</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1208"><r>paquetage</r> <code>expl3</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1209"><code>expl3</code>, <r>paquetage</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="714">Wright, Joseph</indexterm></cindex>

<para>Gérer toutes les règles concernant la casse spécifiée par Unicode, par
ex. pour les scripts non latins, est une tâche bien plus conséquente que
ce qui avait été considéré dans les &tex; et &latex; d&textrsquo;origine.  Cela
a été implémenté dans le paquetage <code>expl3</code> à compter de
2020. L&textrsquo;article « Case changing: From &tex; primitives to the Unicode
algorithm », (Joseph Wright, <cite>TUGboat</cite> 41:1,
<url><urefurl>https://tug.org/TUGboat/tb41-1/tb127wright-case.pdf</urefurl></url>), donne un bon
aperçu du sujet, passé et présent.
</para>
</section>
<node name="Symbols-by-font-position" spaces=" "><nodename>Symbols by font position</nodename><nodenext automatic="on">Text symbols</nodenext><nodeprev automatic="on">Upper and lower case</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>Symboles appelés par leur position dans une police</sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1210">\symbol</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="715">accéder à un caractère quelconque d&textrsquo;une police</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="716">symboles d&textrsquo;une police, par leur numéro</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="717">police, symboles par leur numéro</indexterm></cindex>

<para>Vous pouvez accéder à n&textrsquo;importe quel caractère de la police courante en
utilisant son numéro avec la commande <code>\symbol</code>. Par exemple, le
caractère espace visible utilisé dans la commande <code>\verb*</code> a le
code décimal 32 dans la police standarde tapuscrite Computer Modern,
ainsi on peut le taper avec <code>\symbol&lbrace;32&rbrace;</code>.
</para>
<para>Vous pouvez également spécifier le numéro en octal (base 8) en utilisant
un préfixe <code>'</code>, ou en hexadécimal (base 16) avec un préfixe
<code>&quot;</code>, ainsi l&textrsquo;espace visible de code 32 en décimal pourrait tout aussi bien être écrit
comme <code>\symbol&lbrace;'40&rbrace;</code> ou <code>\symbol&lbrace;&quot;20&rbrace;</code>.
</para>

</section>
<node name="Text-symbols" spaces=" "><nodename>Text symbols</nodename><nodenext automatic="on">Accents</nodenext><nodeprev automatic="on">Symbols by font position</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>Symboles en texte</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="718">texte, symboles</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="719">symboles texte</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1211"><r>paquetage</r> <code>textcomp</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1212"><code>textcomp</code>, <r>paquetage</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="720">TS1, codage</indexterm></cindex>
<para>&latex; fournit des commandes pour générer divers symboles qui ne sont
pas des lettres dans le cours du texte.  Certaines d&textrsquo;entre elles, en
particulier les plus obscures, ne sont pas disponibles en OT1. Depuis la
parution de février 2020 de &latex; tous ces symboles sont disponibles
par défaut ; avant cela, il était nécessaire d&textrsquo;utiliser le paquetage
<code>textcomp</code> pour certains d&textrsquo;entre eux (techniquement, ce qui sont
dans le codage de police <code>TS1</code>).
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1213">\copyright</indexterm>\copyright</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1214">\textcopyright</indexterm>\textcopyright</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="721">droit d&textrsquo;auteur, symbole</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="722">symbole droit d&textrsquo;auteur</indexterm></cindex>
<para>Le symbole « droit d&textrsquo;auteur », &copyright;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1215">\dag</indexterm>\dag</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="723">obèle, dans le texte</indexterm></cindex>
<para>Le symbole obèle (dans le texte).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1216">\ddag</indexterm>\ddag</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="724">double obèle, dans le texte</indexterm></cindex>
<para>Le symbole double obèle (dans le texte).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1217">\LaTeX</indexterm>\LaTeX</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="725">&latex;, logo</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="726">logo &latex;</indexterm></cindex>
<para>Le logo &latex;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1218">\LaTeXe</indexterm>\LaTeXe</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="727">&latex;2e logo</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="728">logo &latex;2e</indexterm></cindex>
<para>Le logo &latex;2e.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1219">\guillemotleft <r>(&laquo;)</r></indexterm>\guillemotleft <r>(&laquo;)</r></itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1220">\guillemotright <r>(&raquo;)</r></indexterm>\guillemotright <r>(&raquo;)</r></itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1221">\guilsinglleft <r>(&lsaquo;)</r></indexterm>\guilsinglleft <r>(&lsaquo;)</r></itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1222">\guilsinglright <r>(&rsaquo;)</r></indexterm>\guilsinglright <r>(&rsaquo;)</r></itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="729">guillemets double</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="730">guillemets simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="731">chevron gauche, guillemets</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="732">chevron droit, guillemets</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="733">chevron double, guillemets</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="734">chevron simple, guillemets</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="735">guillemets français</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="736">français, guillemets</indexterm></cindex>
<para>Guillemets à chevron double et simple, utilisés communément en français :
&laquo;, &raquo;, &lsaquo;, &rsaquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1223">\ldots</indexterm>\ldots</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1224">\dots</indexterm>\dots</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1225">\textellipsis</indexterm>\textellipsis</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="737">points de suspension</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="738">suspension, points de</indexterm></cindex>
<para>Des points de suspension (trois points sur la ligne de base) :
&textlsquo;&dots;&textrsquo;.  <code>\ldots</code> et <code>\dots</code> peuvent également être
utilisés en mode mathématique.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1226">\lq</indexterm>\lq</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="739">gauche, guillemet-apostrophe simple de</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="740">ouvrant, , guillemet-apostrophe simple</indexterm></cindex>
<para>guillemet-apostrophe simple de gauche (ouvrant) : &textlsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1227">\P</indexterm>\P</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1228">\textparagraph</indexterm>\textparagraph</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="741">paragraphe, symbole</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="742">Pied-de-mouche</indexterm></cindex>
<para>Signe paragraphe :  ¶ (pied-de-mouche).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1229">\pounds</indexterm>\pounds</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1230">\textsterling</indexterm>\textsterling</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="743">livre, symbole</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="744">sterling, symbole</indexterm></cindex>
<para>Livre sterling anglais : &pound;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1231">\quotedblbase <r>(&bdquo;)</r></indexterm>\quotedblbase <r>(&bdquo;)</r></itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1232">\quotesinglbase <r>(&sbquo;)</r></indexterm>\quotesinglbase <r>(&sbquo;)</r></itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="745">guillemet-virgule inférieur double</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="746">guillemet-virgule inférieur simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="747">inférieur, guillemet-virgule simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="748">inférieur, guillemet-virgule double</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="749">guillemet-virgule inférieur, simple et double</indexterm></cindex>
<para>Guillemet-virgule inférieur double et simple : &bdquo; et
&sbquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1233">\rq</indexterm>\rq</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="750">droite, guillemet-apostrophe simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="751">fermant, guillemet-apostrophe simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="752">droite, guillemet anglais simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="753">fermant, guillemet anglais simple</indexterm></cindex>
<para>Guillemet-apostrophe simple de droite (fermant) : &textrsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1234">\S</indexterm>\S</itemformat></item>
</tableterm><tableitem><para>\itemx \textsection
<cindex index="cp" spaces=" "><indexterm index="cp" number="754">section, symbole</indexterm></cindex>
Signe section : §.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1235">\TeX</indexterm>\TeX</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="755">logo &tex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="756">&tex;, logo</indexterm></cindex>
<para>Le logo &tex;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1236">\textasciicircum</indexterm>\textasciicircum</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="757">circonflexe ASCII, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="758">ASCII, circonflexe dans le texte</indexterm></cindex>
<para>circonflexe ASCII : ^.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1237">\textasciitilde</indexterm>\textasciitilde</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="759">tilde ASCII, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="760">ASCII, tilde dans le texte</indexterm></cindex>
<para>tilde ASCII : ~.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1238">\textasteriskcentered</indexterm>\textasteriskcentered</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="761">astérisque centré, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="762">centré, astérisque, dans le texte</indexterm></cindex>
<para>Astérisque centré : *.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1239">\textbackslash</indexterm>\textbackslash</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="763">controblique, dans le texte</indexterm></cindex>
<para>Controblique : \.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1240">\textbar</indexterm>\textbar</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="764">verticale, barre dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="765">barre verticale, dans le texte</indexterm></cindex>
<para>Barre verticale : |.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1241">\textbardbl</indexterm>\textbardbl</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="766">barre verticale double, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="767">barre, double verticale, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="768">double, barre verticale, dans le texte</indexterm></cindex>
<para>Barre verticale double.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1242">\textbigcircle</indexterm>\textbigcircle</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="769">Grand rond, symbole, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="770">rond, grand symbole, dans le texte</indexterm></cindex>
<para>Symbole grand rond.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1243">\textbraceleft</indexterm>\textbraceleft</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="771">accolade gauche, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="772">gauche, accolade, dans le texte</indexterm></cindex>
<para>Accolade gauche : &lbrace;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1244">\textbraceright</indexterm>\textbraceright</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="773">accolade droite, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="774">droite, accolade, dans le texte</indexterm></cindex>
<para>Accolade droite : &rbrace;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1245">\textbullet</indexterm>\textbullet</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="775">puce, dans le texte</indexterm></cindex>
<para>Puce : &bullet;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1246">\textcircled&lbrace;<var>lettre</var>&rbrace;</indexterm>\textcircled&lbrace;<var>lettre</var>&rbrace;</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="776">encerclée, lettre, dans le texte</indexterm></cindex>
<para><var>lettre</var> dans un cercle, comme dans &registered;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1247">\textcompwordmark</indexterm>\textcompwordmark</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1248">\textcapitalcompwordmark</indexterm>\textcapitalcompwordmark</itemformat></itemx>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1249">\textascendercompwordmark</indexterm>\textascendercompwordmark</itemformat></itemx>
</tableterm><tableitem><!-- c @cindex composite word mark, dans le texte -->
<!-- c @cindex cap height -->
<!-- c @cindex ascender height -->
<para>Marque de mot composé (invisible).  La forme <code>\textcapital...</code> à la
hauteur de capitale de la fonte, alors que la forme
<code>\textascender...</code> a la hauteur de hampe.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1250">\textdagger</indexterm>\textdagger</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="777">obèle, dans le texte</indexterm></cindex>
<para>Obèle : <math>\dag</math>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1251">\textdaggerdbl</indexterm>\textdaggerdbl</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="778">obèle  double, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="779">double, obèle, dans le texte</indexterm></cindex>
<para>Double-obèle : <math>\ddag</math>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1252">\textdollar <r>(ou <code>\$</code>)</r></indexterm>\textdollar <r>(ou <code>\$</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="780">dollar, signe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="781">monnaie, dollar</indexterm></cindex>
<para>Signe Dollar : $.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1253">\textemdash <r>(ou <code>---</code>)</r></indexterm>\textemdash <r>(ou <code>---</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="782">cadratin</indexterm></cindex>
<raggedright endspaces=" ">
<para>Cadratin : &textmdash;. Utilisé pour la ponctuation, d&textrsquo;ordinaire similaire à une virgules ou des parenthèses comme dans « <code>Les éliminatoires --- si vous assez de chance pour y arriver --- c'est comme si ça se passait d'un trait.</code> »
</para></raggedright>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1254">\textendash <r>(ou <code>--</code>)</r></indexterm>\textendash <r>(ou <code>--</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="783">cadratin, demi</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="784">demi-cadratin</indexterm></cindex>
<para>Demi cadratin : &textndash;. Utilisé pour les plages en anglais comme dans « <code>see pages 12--14</code> ».
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1255">\texteuro</indexterm>\texteuro</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="785">euro, symbole</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="786">monnaie, euro</indexterm></cindex>
<para>Le symbole monétaire Euro : &euro;.
<findex index="fn" spaces=" "><indexterm index="fn" number="1256"><r>paquetage</r> <code>eurosym</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1257"><code>eurosym</code>, <r>paquetage</r></indexterm></findex>
</para>
<para>Pour un dessin alternatif du glyphe, essayez le paquetage
<code>eurosym</code> ; de plus, la plupart des polices de nos jour sont
fournies avec leur propre symbole Euro (Unicode U+20AC).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1258">\textexclamdown <r>(ou <code>!`</code>)</r></indexterm>\textexclamdown <r>(ou <code>!`</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="787">point d&textrsquo;exclamation culbuté</indexterm></cindex>
<para>Point d&textrsquo;exclamation culbuté : &iexcl;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1259">\textfiguredash</indexterm>\textfiguredash</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="788">caractère tiret numérique</indexterm></cindex>
<para>Tiret utilisé entre les nombres, Unicode U+2012. Défini dans la parution
juin-2021 de &latex;. Quand utilisé avec pdf&tex;, approximé par un
demi-cadratin ; avec un moteur Unicode, soit le glyphe est composé s&textrsquo;il
est disponible dans la fonte courante, ou sinon l&textrsquo;avertissement habituel
« Missing character » est inscrit au journal de compilation.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1260">\textgreater</indexterm>\textgreater</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="789">supérieur à, symbole dans le texte</indexterm></cindex>
<para>Supérieur à : &gt;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1261">\texthorizontalbar</indexterm>\texthorizontalbar</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="790">barre horizontale, caractère</indexterm></cindex>
<para>Caractère barre horizontale, Unicode U+2015. Défini dans la parution
juin-2021 de &latex;. Comportement similaire à <code>\textfiguredash</code>
ci-dessus ; l&textrsquo;approximation de pdf&tex; est un cadratin.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1262">\textless</indexterm>\textless</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="791">inférieur à, symbole dans le texte</indexterm></cindex>
<para>Inférieur à : &lt;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1263">\textleftarrow</indexterm>\textleftarrow</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="792">flèche gauche, left, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="793">gauche, flèche, dans le texte</indexterm></cindex>
<para>Flèche gauche.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1264">\textnonbreakinghyphen</indexterm>\textnonbreakinghyphen</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="794">trait d&textrsquo;union insécable, caractère</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="795">insécable, caractère trait d&textrsquo;union</indexterm></cindex>
<para>Caractère trait d&textrsquo;union insécable, Unicode U+2011. Défini dans la
parution juin-2021 de &latex;. Comportement similaire à
<code>\textfiguredash</code> ci-dessus ; l&textrsquo;approximation de pdf&tex; est un
trait d&textrsquo;union ASCII ordinaire (avec saut de ligne non-autorisé juste
après).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1265">\textordfeminine</indexterm>\textordfeminine</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1266">\textordmasculine</indexterm>\textordmasculine</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="796">féminin, symbole ordinal</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="797">masculin, symbole ordinal</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="798">Ordinaux, féminin et masculin</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="799">Ordinaux espagnols, féminin et masculin</indexterm></cindex>
<para>Symboles ordinaux féminin et masculin : &ordf;, &ordm;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1267">\textperiodcentered</indexterm>\textperiodcentered</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="800">point centré, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="801">centré, point, dans le texte</indexterm></cindex>
<para>Point centré : ·.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1268">\textquestiondown <r>(ou <code>?`</code>)</r></indexterm>\textquestiondown <r>(ou <code>?`</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="802">point d&textrsquo;interrogation culbuté</indexterm></cindex>
<para>Point d&textrsquo;interrogation culbuté : &iquest;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1269">\textquotedblleft <r>(ou <code>``</code>)</r></indexterm>\textquotedblleft <r>(ou <code>``</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="803">guillemet-apostrophe double culbuté</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="804">double, guillemet-apostrophe culbuté</indexterm></cindex>
<para>Guillemet-apostrophe double culbuté : &textldquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1270">\textquotedblright <r>(ou <code>''</code>)</r></indexterm>\textquotedblright <r>(ou <code>''</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="805">guillemet-apostrophe de droite double</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="806">double, guillemet-apostrophe de droite</indexterm></cindex>
<para>Guillemet-apostrophe de droite double : &textrdquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1271">\textquoteleft <r>(ou <code>`</code>)</r></indexterm>\textquoteleft <r>(ou <code>`</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="807">guillemet-apostrophe simple culbuté</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="808">simple, guillemet-apostrophe culbuté</indexterm></cindex>
<para>Guillemet-apostrophe simple culbuté : &textlsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1272">\textquoteright <r>(ou <code>'</code>)</r></indexterm>\textquoteright <r>(ou <code>'</code>)</r></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="809">guillemet-apostrophe simple</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="810">simple, guillemet-apostrophe</indexterm></cindex>
<para>Guillemet-apostrophe simple : &textrsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1273">\textquotesingle</indexterm>\textquotesingle</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="811">guillemet-apostrophe simple droit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="812">simple droit, guillemet-apostrophe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="813">droit, guillemet-apostrophe simple</indexterm></cindex>
<para>Guillemet-apostrophe simple droit.  (Du codage TS1.)
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1274">\textquotestraightbase</indexterm>\textquotestraightbase</itemformat></item>
<itemx spaces=" "><itemformat command="code"><indexterm index="fn" number="1275">\textquotestraightdblbase</indexterm>\textquotestraightdblbase</itemformat></itemx>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="814">guillemet droit simple  sur la ligne de base</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="815">droit, guillemet simple sur la ligne de base</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="816">guillemet droit double  sur la ligne de base</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="817">droit, guillemet double sur la ligne de base</indexterm></cindex>
<para>Guillemets droit simple et double sur la ligne de base.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1276">\textregistered</indexterm>\textregistered</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="818">marque déposée, symbole</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="819">symbole marque déposée</indexterm></cindex>
<para>Symbole « marque déposée » : &registered;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1277">\textrightarrow</indexterm>\textrightarrow</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="820">flèche droite, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="821">droite, flèche, dans le texte</indexterm></cindex>
<para>Flèche droite.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1278">\textthreequartersemdash</indexterm>\textthreequartersemdash</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="822">trois-quarts, cadratin</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="823">cadratin, trois-quarts</indexterm></cindex>
<para>Cadratin « trois quarts ».
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1279">\texttrademark</indexterm>\texttrademark</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="824">marque de fabrique, symbole</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="825">symbole marque de fabrique</indexterm></cindex>
<para>Symbole marque de commerce : ™.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1280">\texttwelveudash</indexterm>\texttwelveudash</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="826">deux-tiers cadratin</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="827">cadratin, deux tiers</indexterm></cindex>
<para>Deux-tiers cadratin.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1281">\textunderscore</indexterm>\textunderscore</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="828">souligné, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="829">tiret bas, dans le texte</indexterm></cindex>
<para>Tiret bas : _.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1282">\textvisiblespace</indexterm>\textvisiblespace</itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="830">visible, symbole espace, dans le texte</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="831">espace visible, symbole, dans le texte</indexterm></cindex>
<para>Symbole espace visible.
</para>
</tableitem></tableentry></ftable>


</section>
<node name="Accents" spaces=" "><nodename>Accents</nodename><nodenext automatic="on">Additional Latin letters</nodenext><nodeprev automatic="on">Text symbols</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>Accents</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="832">accents</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="833">signes diacritiques</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="834">diacritiques, signes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="835">accentuées, lettres</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="836">accentués, caractères</indexterm></cindex>

<para>&latex; a une prise en charge très large de beaucoup des scripts et
langages du monde, à travers ce qu&textrsquo;offre le paquetage <code>babel</code>.
Cette section ne tente pas de couvrir la totalité de cette prise en
charge.  Elle liste simplement les commandes &latex; cœur pour
créer des caractères accentués, et plus généralement des caractères
portant un signe diacritique.
</para>
<para>Les commandes <code>\capital...</code>  produisent des formes alternatives
pouvant être utilisées avec les lettres capitales.  Elles ne sont pas
disponible avec l&textrsquo;OT1.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">\&quot;</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitaldieresis</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1283">\&quot; <r>(accent tréma)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1284">\capitaldieresis</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="837">accent tréma</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="838">diacritique tréma</indexterm></cindex>

<para>Produit une tréma, comme dans <accent type="uml">o</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\'</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalacute</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1285">\' <r>(accent aigu)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1286">\capitalacute</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="839">accent aigu</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="840">aigu, accent</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="841">diacritique accent aigu</indexterm></cindex>
<para>Produit un accent aigu, comme dans <accent type="acute">o</accent>.  Dans l&textrsquo;environnement
<code>tabbing</code>, pousse la colonne courante à droite de la colonne
précédente (<pxref label="tabbing"><xrefnodename>tabbing</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\.</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1287">\. <r>(dot-over accent)</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="842">accent point</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="843">accent point suscrit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="844">accent point en chef</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="845">diacritique point suscrit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="846">point en chef, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="847">point suscrit, diacritique</indexterm></cindex>
<para>Produit un point suscrit à la lettre qui suit, comme dans
<accent type="dotaccent">o</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\=</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalmacron</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1288">\= <r>(macron accent)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1289">\capitalmacron</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="848">macron, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="849">barre, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="850">barre  par-dessus, accent</indexterm></cindex>
<para>Produit un macron (une barre) suscrit à la lettre qui suit, comme
dans <accent type="macr">o</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\^</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalcircumflex</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1290">\^ <r>(accent circonflexe)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1291">\capitalcircumflex</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="851">accent circonflexe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="852">diacritique circonflexe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="853">circonflexe, accent</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="854">circonflexe, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="855">chapeau, accent</indexterm></cindex>
<para>Produit un accent circonflexe (un chapeau)  suscrit à la lettre qui suit, comme dans <accent type="circ">o</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\`</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalgrave</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1292">\` <r>(accent grave)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1293">\capitalgrave</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="856">grave accent</indexterm></cindex>
<para>Produit un accent grave suscrit à la lettre qui suit, comme dans
<accent type="grave">o</accent>.  Au sein de l&textrsquo;environnement <code>tabbing</code>, déplace le texte qui
suit à la marge de droite (<pxref label="tabbing"><xrefnodename>tabbing</xrefnodename></pxref>).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\~</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitaltilde</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1294">\~ <r>(accent tilde)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1295">\capitaltilde</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="857">diacritique tilde</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="858">tilde, diacritique</indexterm></cindex>
<para>Produit un diacritique tilde suscrit à la lettre qui suit, comme dans
<accent type="tilde">n</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\b</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1296">\b <r>(accent barre-souscrite)</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="859">diacritique barre-souscrite</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="860">diacritique macron-souscrit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="861">barre-souscrite, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="862">macron-souscrit, diacritique</indexterm></cindex>
<para>Produit un diacritique barre souscrite à la lettre qui suit, comme dans
<accent type="ubaraccent">o</accent>. Voir aussi <code>\underbar</code> ci-après.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\c</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalcedilla</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1297">\c <r>(cédille)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1298">\capitalcedilla</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="863">cédille, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="864">diacritique cédille</indexterm></cindex>
<para>Produit une cédille souscrite à la lettre qui suit, comme dans <accent type="cedil">c</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\d</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitaldotaccent</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1299">\d <r>(dot-under accent)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1300">\capitaldotaccent</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="865">diacritique point-souscrit</indexterm></cindex>
<para>Produit un point souscrit à la lettre qui suit, comme dans
<accent type="udotaccent">o</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\H</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalhungarumlaut</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1301">\H <r>(tréma hongrois)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1302">\capitalhungarumlaut</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="866">accent tréma hongrois</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="867">tréma hongrois, accent</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="868">diacritique tréma hongrois</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="869">tréma hongrois, diacritique</indexterm></cindex>
<para>Produit un long tréma hongrois suscrit à la lettre qui suit, comme dans <accent type="doubleacute">o</accent>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\i</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1303">\i <r>(i sans point)</r></indexterm></findex>
<cindex index="cp" spaces="  "><indexterm index="cp" number="870">i sans point</indexterm></cindex>
<para>Produit un i sans point, comme dans &textlsquo;<dotless>i</dotless>&textrsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\j</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1304">\j <r>(j sans point)</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="871">j sans point</indexterm></cindex>
<para>Produit un j sans point, comme dans &textlsquo;<dotless>j</dotless>&textrsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\k</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalogonek</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1305">\k <r>(ogonek)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1306">\capitalogonek</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="872">ogonek, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="873">diacritique ogonek</indexterm></cindex>
<para>Produit un ogonek, comme dans &textlsquo;<accent type="ogon">o</accent>&textrsquo;.  Non disponible dans le
codage OT1.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\r</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalring</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1307">\r <r>(ring accent)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1308">\capitalring</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="874">accent rond en chef</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="875">diacritique rond en chef</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="876">rond en chef, diacritique</indexterm></cindex>
<para>Produit un rond en chef, comme dans &textlsquo;<accent type="ring">o</accent>&textrsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\t</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitaltie</itemformat></itemx>
<itemx spaces=" "><itemformat command="code">\newtie</itemformat></itemx>
<itemx spaces=" "><itemformat command="code">\capitalnewtie</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1309">\t <r>(tie-after accent)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1310">\capitaltie</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1311">\newtie</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1312">\capitalnewtie</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="877">diacritique tirant suscrit</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="878">diacritique double-brève-renversée</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="879">accent double-brève-renversée</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="880">double-brève-renversée, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="881">tirant suscrit, diacritique</indexterm></cindex>
<para>Produit un tirant suscrit, ou double brève
renversée<inlinefmt><inlinefmtformat>tex</inlinefmtformat></inlinefmt>
(utilisé pour la translittération du Cyrillique dans la romanisation
ALA-LC). La commande <code>\t</code> attend que l&textrsquo;argument consiste en deux
caractères. La forme <code>\newtie</code> est centrée dans sa boîte.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\u</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalbreve</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1313">\u <r>(brève, accent)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1314">\capitalbreve</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="882">brève, accent</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="883">brève, diacritique</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="884">diacritique brève</indexterm></cindex>
<para>Produit un accent brève, comme dans &textlsquo;<accent type="breve">o</accent>&textrsquo;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\underbar</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1315">\underbar</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="885">barre souscrite</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="886">barre au-dessous</indexterm></cindex>
<para>Ce n&textrsquo;est pas vraiment un diacritique. Produit une barre au-dessous de
l&textrsquo;argument texte.  L&textrsquo;argument est toujours traité en mode horizontal.
La barre est toujours à une position fixée sous la ligne de base, de la
sorte elle traverse les descentes.  Voir aussi <code>\underline</code> dans
<ref label="Over_002d-and-Underlining"><xrefnodename>Over- and Underlining</xrefnodename></ref>. Voir aussi <code>\b</code> ci-avant.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\v</itemformat></item>
<itemx spaces=" "><itemformat command="code">\capitalcaron</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1316">\v <r>(brève, accent)</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1317">\capitalcaron</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="887">accent h<accent type="acute">a</accent><accent type="caron">c</accent>ek</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="888">diacritique h<accent type="acute">a</accent><accent type="caron">c</accent>ek</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="889">accent caron</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="890">diacritique caron</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="891">caron, diacritique</indexterm></cindex>
<para>Produit un  accent h<accent type="acute" bracketed="off">a</accent><accent type="caron">c</accent>ek (caron), comme dans &textlsquo;<accent type="caron">o</accent>&textrsquo;.
</para>
</tableitem></tableentry></table>


</section>
<node name="Additional-Latin-letters" spaces=" "><nodename>Additional Latin letters</nodename><nodenext automatic="on">inputenc package</nodenext><nodeprev automatic="on">Accents</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>Lettres latines supplémentaires</sectiontitle>
<anchor name="Non_002dEnglish-characters">Non-English characters</anchor>

<cindex index="cp" spaces=" "><indexterm index="cp" number="892">caractères spéciaux</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="893">spéciaux, caractères</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="894">caractères latins non diacrités</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="895">lettres latines non diacritées</indexterm></cindex>

<para>Voici les commandes de base de &latex; pour insérer des caractères
utilisés généralement utilisés dans des langages autres que l&textrsquo;anglais.
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">\aa</itemformat></item>
<itemx spaces=" "><itemformat command="code">\AA</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1318">\aa (&aring;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1319">\AA (&Aring;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="896">a rond-en-chef</indexterm></cindex>
<para>&aring; et &Aring;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ae</itemformat></item>
<itemx spaces=" "><itemformat command="code">\AE</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1320">\ae (&aelig;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1321">\AE (&AElig;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="897">a, e dans l&textrsquo;a</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="898">e dans l&textrsquo;a</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="899">a e liés</indexterm></cindex>
<para>&aelig; et &AElig;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\dh</itemformat></item>
<itemx spaces=" "><itemformat command="code">\DH</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1322">\dh (&eth;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1323">\DH (&ETH;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="900">eth islandais</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="901">eth, lettre islandaise</indexterm></cindex>
<para>Lettre islandaise eth : &eth; et &ETH;.  Non disponible dans le codage
<sc>OT1</sc>, il vous faut le paquetage <file>fontenc</file> pour sélectionner un
autre codage de police, tel que <sc>T1</sc>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\dj</itemformat></item>
<itemx spaces=" "><itemformat command="code">\DJ</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1324">\dj</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1325">\DJ</indexterm></findex>
<para>d et D barre, lettre d capitale et bas-de-casse avec une barre
traversant la hampe.  Non disponible dans le codage <sc>OT1</sc>, il vous
faut le paquetage <file>fontenc</file> pour sélectionner un autre codage de
police, tel que <sc>T1</sc>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ij</itemformat></item>
<itemx spaces=" "><itemformat command="code">\IJ</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1326">\ij (ij)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1327">\IJ (IJ)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="902">lettre ij, hollandais</indexterm></cindex>
<para>ij et IJ (à ceci près que les deux lettres apparaissent plus liées qu&textrsquo;ici).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\l</itemformat></item>
<itemx spaces=" "><itemformat command="code">\L</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1328">\l (&lslash;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1329">\L (&Lslash;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="903">l polonais</indexterm></cindex>
<para>&lslash; et &Lslash;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ng</itemformat></item>
<itemx spaces=" "><itemformat command="code">\NG</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1330">\ng</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1331">\NG</indexterm></findex>
<para>Lettre lapone eng, utilisée aussi en phonétique.  Non disponible dans le codage
<sc>OT1</sc>, il vous faut le paquetage <file>fontenc</file> pour sélectionner un
autre codage de police, tel que <sc>T1</sc>.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\o</itemformat></item>
<itemx spaces=" "><itemformat command="code">\O</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1332">\o (&oslash;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1333">\O (&Oslash;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="904">oslash</indexterm></cindex>
<para>&oslash; et &Oslash;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\oe</itemformat></item>
<itemx spaces=" "><itemformat command="code">\OE</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1334">\oe (&oelig;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1335">\OE (&OElig;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="905">o e liés</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="906">o, e dans l&textrsquo;o</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="907">e dans l&textrsquo;o</indexterm></cindex>
<para>&oelig; et &OElig;.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\ss</itemformat></item>
<itemx spaces=" "><itemformat command="code">\SS</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1336">\ss (&szlig;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1337">\SS (SS)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="908">eszett lettre allemande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="909">s long</indexterm></cindex>
<para>&szlig; et SS.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">\th</itemformat></item>
<itemx spaces=" "><itemformat command="code">\TH</itemformat></itemx>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1338">\th (&thorn;)</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1339">\TH (&THORN;)</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="910">islandaise, thorn, lettre</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="911">thorn, lettre islandaise</indexterm></cindex>
<para>Lettre islandaise thorn : &thorn; et &THORN;. Non disponible dans le codage
<sc>OT1</sc>, il vous faut le paquetage <file>fontenc</file> pour sélectionner un
autre codage de police, tel que <sc>T1</sc>.
</para>
</tableitem></tableentry></table>


</section>
<node name="inputenc-package" spaces=" "><nodename>inputenc package</nodename><nodenext automatic="on">\rule</nodenext><nodeprev automatic="on">Additional Latin letters</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle>paquetage <code>inputenc</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1340">inputenc</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[<var>nom-codage</var>]&lbrace;inputenc&rbrace;
</pre></example>

<para>Déclare que le codage du texte du fichier d&textrsquo;entrée est
<var>nom-codage</var>. Par défaut, quand ce paquetage n&textrsquo;est pas chargé, c&textrsquo;est
UTF-8.  Techniquement, la spécification du nom du codage est optionnelle,
mais en pratique il n&textrsquo;est pas utile de l&textrsquo;omettre.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="912">codage des fichiers d&textrsquo;entrée</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="913">caractère, codage de</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="914">Unicode</indexterm></cindex>
<para>Dans un fichier informatique, les caractères sont stockés selon un
schéma appelé le <dfn>codage</dfn>.  Il y a de nombreux différents
codages. Le plus simple est l&textrsquo;ASCII, il prend en charge 95 caractères
imprimables, soit trop peu pour la plupart des langages du monde. Par
exemple, pour composer un e tréma <samp>ë</samp> dans un fichier source
&latex; codé en ASCII, on utilise la séquence <code>\&quot;e</code>. Ceci
rendrait les fichiers source pour quoi que ce soit d&textrsquo;autre que
l&textrsquo;anglais difficiles à lire ; et même pour l&textrsquo;anglais il est commode
d&textrsquo;avoir un codage plus étendu.
</para>
<para>La norme moderne de codage, d&textrsquo;une certaine façon une réunion des autres,
est l&textrsquo;UTF-8, l&textrsquo;une des représentations de l&textrsquo;Unicode. C&textrsquo;est le codage par
défaut de &latex; depuis 2018.
</para>
<para>Le paquetage <code>inputenc</code> permet à &latex; de savoir quel codage est
utilisé. Par exemple, la commande suivante dit explicitement que le
fichier d&textrsquo;entrée est en UTF-8 (notez l&textrsquo;absence de tiret).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage[utf8]&lbrace;inputenc&rbrace;
</pre></example>

<para>Attention : n&textrsquo;utilisez <code>inputenc</code> qu&textrsquo;avec le moteur pdf&tex;
(<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).  (Les moteurs Xe&tex; et Lua&tex; supposent
que le fichier d&textrsquo;entrée est codé en UTF-8). Si vous invoquez &latex;
avec soit la commande <command>xelatex</command> soit la commande
<command>lualatex</command>, et essayez de déclarer un codage distinct d&textrsquo;UTF-8
avec <code>inputenc</code>, comme par ex.&noeos; <code>latin1</code>, alors vous
obtiendrez l&textrsquo;erreur <code>inputenc is not designed for xetex or luatex</code>.
</para>
<para>Une erreur du paquetage <code>inputenc</code> telle que <code>Invalid UTF-8
byte &quot;96</code> signifie que le fichier d&textrsquo;entrée contient de la matière qui ne
suit pas le schéma de codage. Souvent ces erreurs proviennent de la copie
de matière issue d&textrsquo;un document utilisant un codage différent de celui du
fichier d&textrsquo;entrée ; l&textrsquo;erreur donnée en exemple provient d&textrsquo;un guillemet
anglais simple copié d&textrsquo;une page web utilisant <code>latin1</code> vers un
fichier d&textrsquo;entrée &latex; utilisant UTF-8.  La solution la plus simple
consiste à remplacer tout caractère non-UTF-8 avec leur équivalent UTF-8,
ou d&textrsquo;utiliser une commande ou un caractère équivalent en &latex;.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1341">\inputencoding</indexterm></findex>
<anchor name="_005cinputencoding">\inputencoding</anchor>
<para>Dans certains documents, tel que des collections d&textrsquo;articles de revue
écrits pas différents auteurs, changer le codage en milieu de document
peut s&textrsquo;avérer nécessaire. Utiliser la commande
<code>\inputencoding&lbrace;<var>nom-codage</var>&rbrace;</code>.  Les valeurs les plus usuelles
pour <var>nom-codage</var> sont : <code>ascii</code>, <code>latin1</code>, <code>latin2</code>,
<code>latin3</code>, <code>latin4</code>, <code>latin5</code>, <code>latin9</code>,
<code>latin10</code>, et <code>utf8</code>.
</para>

</section>
<node name="_005crule" spaces=" "><nodename>\rule</nodename><nodenext automatic="on">\today</nodenext><nodeprev automatic="on">inputenc package</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle><code>\rule</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1342">\rule</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\rule[<var>élévation</var>]&lbrace;<var>largeur</var>&rbrace;&lbrace;<var>épaisseur</var>&rbrace;
</pre></example>

<para>la commande <code>\rule</code> produit un <dfn>filet</dfn>, c.-à-d.&noeos; une ligne ou
un rectangle.  Les arguments sont :
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">élévation</itemformat></item>
</tableterm><tableitem><para>De combien élever le filet (optionnel).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">largeur</itemformat></item>
</tableterm><tableitem><para>La longueur du filet (obligatoire).
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">épaisseur</itemformat></item>
</tableterm><tableitem><para>L&textrsquo;épaisseur du filet (obligatoire).
</para></tableitem></tableentry></table>


</section>
<node name="_005ctoday" spaces=" "><nodename>\today</nodename><nodeprev automatic="on">\rule</nodeprev><nodeup automatic="on">Special insertions</nodeup></node>
<section spaces=" "><sectiontitle><code>\today</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1343">\today</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="915">date d&textrsquo;aujourd&textrsquo;hui</indexterm></cindex>

<para>La commande <code>\today</code> produit la date d&textrsquo;aujourd&textrsquo;hui, par défaut dans
le format <samp><var>mois</var> <var>jj</var>, <var>aaaa</var></samp> ; par exemple, <samp>July 4,
1976</samp>.  Elle utilise les compteurs prédéfinis <code>\day</code>,
<code>\month</code>, et <code>\year</code> (<pxref label="_005cday-_0026-_005cmonth-_0026-_005cyear"><xrefnodename>\day &amp; \month &amp; \year</xrefnodename></pxref>) pour faire
cela.  Elle n&textrsquo;est pas mise à jour durant l&textrsquo;exécution de la compilation.
</para>
<para>Les extensions multilingues comme entre autres le paquetage <code>babel</code>
ou la classe <file>lettre</file> localisent <code>\today</code>. Par exemple le code
suivant produit <samp>4 juillet 1976</samp> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\year=1976 \month=7 \day=4
\documentclass&lbrace;minimal&rbrace;
\usepackage[french]&lbrace;babel&rbrace;
\begin&lbrace;document&rbrace;
\today
\end&lbrace;document&rbrace;
</pre></example>


<findex index="fn" spaces=" "><indexterm index="fn" number="1344"><r>paquetage</r> <code>datetime</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1345"><code>datetime</code>, <r>paquetage</r></indexterm></findex>

<para>Le paquetage <code>datetime</code>, entre autres, produit un large choix
d&textrsquo;autres formats de date.
</para>

</section>
</chapter>
<node name="Splitting-the-input" spaces=" "><nodename>Splitting the input</nodename><nodenext automatic="on">Front/back matter</nodenext><nodeprev automatic="on">Special insertions</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Partitionner le fichier d&textrsquo;entrée</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="916">partitionner le fichier d&textrsquo;entrée</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="917">fichier d&textrsquo;entrée</indexterm></cindex>

<para>&latex; vous permet de partitionner un document de grande taille en
plusieurs plus petits. Ceci peut simplifier son édition et permette à
plusieurs auteurs d&textrsquo;y travailler. Cela peut aussi accélérer le
traitement.
</para>
<para>Indépendamment du nombre de fichiers distincts que vous
utilisez, il y a toujours un seul
<cindex index="cp" spaces=" "><indexterm index="cp" number="918">racine, fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="919">fichier racine</indexterm></cindex>
<dfn>fichier racine</dfn> sur lequel la compilation &latex;
démarre. L&textrsquo;exemple ci-dessous illustre un tel fichier avec cinq fichiers
inclus.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\includeonly&lbrace;
  % mettre en commentaire les lignes ci-dessous pour ne pas compiler le fichier
  pref,
  chap1,
  chap2,
  append,
  bib
  &rbrace;
\begin&lbrace;document&rbrace;
\frontmatter
\include&lbrace;pref&rbrace;
\mainmatter
\include&lbrace;chap1&rbrace;
\include&lbrace;chap2&rbrace;
\appendix
\include&lbrace;append&rbrace;
\backmatter
\include&lbrace;bib&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>Dans cet exemple on prend la matière de <file>pref.tex</file>,
<file>chap1.tex</file>, <file>chap2.tex</file>, <file>append.tex</file>, et
<file>bib.tex</file>.  Si vous compilez ce fichier, et ensuite mettez en
commentaire toutes les lignes au sein de <code>\includeonly&lbrace;...&rbrace;</code>
hormis <code>chap1</code>, et compilez de nouveau, alors &latex; traite
seulement la matière du premier chapitre.  Ainsi, la sortie apparaît
plus rapidement et est plus courte à imprimer.  Cependant, l&textrsquo;avantage de
la commande <code>\includeonly</code> est que &latex; retient les numéros de
page et toute l&textrsquo;information de renvoi des autres parties du document de
sorte qu&textrsquo;elles apparaissent correctement en sortie.
</para>
<para><xref label="Larger-book-template"><xrefnodename>Larger book template</xrefnodename></xref>, pour un autre exemple de <code>\includeonly</code>.
</para>
<!-- c xxx Pourquoi avoir supprimer cette ref. -->
<!-- c @xref{filecontents}, pour un environnement qui permet de grouper un -->
<!-- c fichier externe à créer avec le document racine. -->

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::                 ">\endinput</menunode><menudescription><pre xml:space="preserve">Ne plus inclure la matière d&textrsquo;un fichier.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">\include &amp; \includeonly</menunode><menudescription><pre xml:space="preserve">Inclure conditionnellement des fichiers.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                    ">\input</menunode><menudescription><pre xml:space="preserve">Inclure inconditionnellement un fichier.
</pre></menudescription></menuentry></menu>


<node name="_005cendinput" spaces=" "><nodename>\endinput</nodename><nodenext automatic="on">\include &amp; \includeonly</nodenext><nodeup automatic="on">Splitting the input</nodeup></node>
<section spaces=" "><sectiontitle><code>\endinput</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1346">\endinput</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\endinput
</pre></example>

<para>Quand vous écrivez <code>\include&lbrace;nomfichier&rbrace;</code>, alors au sein de
<file>nomfichier.tex</file> la matière qui vient après <code>\endinput</code> n&textrsquo;est
pas incluse.  Cette commande est optionnelle ; si <file>nomfichier.tex</file>
ne comprend pas de <code>\endinput</code> alors &latex; lit tout le fichier.
</para>
<para>Par exemple, supposons que le fichier racine d&textrsquo;un document a un
<code>\input&lbrace;chap1&rbrace;</code> que ce le contenu de <file>chap1.tex</file> est ce qui
suit :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter&lbrace;One&rbrace; Cette matière apparaît dans le document.  \endinput Ceci
n'apparaît pas.
</pre></example>

<para>Ceci peut être utile pour placer de la documentation ou des commentaires
à la fin d&textrsquo;un fichier, ou pour éviter des caractères indésirables qui
pourraient s&textrsquo;ajouter si le fichier est transmis dans le corps d&textrsquo;un
courriel.  C&textrsquo;est également utile pour déboguer : une stratégie pour
localiser des erreurs est de placer un <code>\endinput</code> à mi-chemin en
cours des fichiers inclus et de voir si l&textrsquo;erreur disparaît. Ensuite,
sachant quelle moitié contient l&textrsquo;erreur, en déplaçant le
<code>\endinput</code> à mi-chemin de cette zone circonscrit de plus près
l&textrsquo;endroit où elle se trouve. Ainsi on trouve rapidement la ligne
fautive.
</para>
<para>Après avoir lu <code>\endinput</code>, &latex; continue à lire jusqu&textrsquo;à la fin
de la ligne, ainsi il est possible de faire suivre cette ligne par
quelque chose qui sera tout de même lu.  Ceci vous permet entre autre de
fermer un <code>\if...</code> par un <code>\fi</code>.
</para>
</section>
<node name="_005cinclude-_0026-_005cincludeonly" spaces=" "><nodename>\include &amp; \includeonly</nodename><nodenext automatic="on">\input</nodenext><nodeprev automatic="on">\endinput</nodeprev><nodeup automatic="on">Splitting the input</nodeup></node>
<section spaces=" "><sectiontitle><code>\include</code> &amp; <code>\includeonly</code></sectiontitle>

<anchor name="_005cinclude">\include</anchor>
<anchor name="_005cincludeonly">\includeonly</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1347">\include</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1348">\includeonly</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\includeonly&lbrace;  % dans le préambule du document
  ...
  <var>nomfichier</var>,
  ...
  &rbrace;
  ...
\include&lbrace;<var>nomfichier</var>&rbrace;  % dans le corps du document
</pre></example>

<para>Apporte de la matière d&textrsquo;un fichier externe <file><var>nomfichier</var>.tex</file>
dans un document &latex;.
</para>
<para>La commande <code>\include</code> fait trois choses : elle exécute
<code>\clearpage</code> (<pxref label="_005cclearpage-_0026-_005ccleardoublepage"><xrefnodename>\clearpage &amp; \cleardoublepage</xrefnodename></pxref>), puis elle
insère la matière à partir du fichier <file><var>nomfichier</var>.tex</file> dans
le document, ensuite fait encore un <code>\clearpage</code>. Cette commande ne
peut apparaître que dans le corps du document.
</para>
<para>La commande <code>\includeonly</code> contrôle quels fichiers seront lus par
&latex; lors des commandes <code>\include</code> suivantes. Sa liste de noms
de fichier est séparée par des virgules, et la commande ne peut
apparaître que dans le préambule, ou même plus tôt, par ex. dans la
ligne de commande : elle ne peut pas apparaître dans le corps du
document.
</para>
<para>Dans le document racine en exemple ci-dessous, <file>constitution.tex</file>, on
inclut trois fichiers, <file>preambule.tex</file>, <file>articles.tex</file>, et
<file>amendements.tex</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\includeonly&lbrace;
  preambule,
  articles,
  amendements
  &rbrace;
\begin&lbrace;document&rbrace;
\include&lbrace;preambule&rbrace;
\include&lbrace;articles&rbrace;
\include&lbrace;amendements&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>Le fichier <file>preambule.tex</file> ne contient aucun code spécial ; vous
avez juste extrait ce chapitre de <file>consitution.tex</file> pour le mettre
dans un fichier séparé pour rendre son édition plus commode.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter&lbrace;Préambule&rbrace;
Le peuple français proclame solennellement son attachement aux Droits de
l’Homme et aux principes de la souveraineté nationale tels qu’ils ont
été définis par la Déclaration de 1789, ...
</pre></example>

<noindent></noindent>
<para>Exécuter &latex; sur <file>constitution.tex</file> fait apparaître la
matière issue de ces trois fichiers dans le document mais génère
également les fichiers auxiliaires <file>preambule.aux</file>,
<file>articles.aux</file>, et <file>amendements.aux</file>. Ceux-ci contiennent de
l&textrsquo;information telle que les numéros de page et les renvois (<pxref label="Cross-references"><xrefnodename>Cross
references</xrefnodename></pxref>).  Si maintenant vous mettez en commentaire les lignes de
<code>\includeonly</code> contenant <code>preambule</code> et <code>amendements</code> et
exécutez &latex; de nouveau alors le document résultant ne contiendra
que la matière issue de <file>articles.tex</file>, mais pas celui de
<file>preamblue.tex</file> ni de <file>amendements.tex</file>.  Néanmoins, la
totalité de l&textrsquo;information auxiliaire issue des fichiers omis est
toujours là, y compris le numéro de la page où commence le chapitre.
</para>
<para>S&textrsquo;il n&textrsquo;y a pas de <code>\includeonly</code> dans le préambule du document,
alors &latex; inclut tous les fichiers demandés par des commandes
<code>\include</code>.
</para>
<para>La commande <code>\include</code> fabrique une nouvelle page.  Pour éviter
cela, voir <ref label="_005cinput"><xrefnodename>\input</xrefnodename></ref> (ce qui, cependant, ne retient pas l&textrsquo;information
auxiliaire).
</para>
<para><xref label="Larger-book-template"><xrefnodename>Larger book template</xrefnodename></xref>, pour un autre exemple utilisant
<code>\include</code> et <code>\includeonly</code>.  Cet exemple utilise également
<code>\input</code> pour certaine matière qui ne débute pas nécessairement sur
une nouvelle page.
</para>
<para>Les noms de fichiers peuvent impliquer un chemin.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\includeonly&lbrace;
  chapitres/chap1,
  &rbrace;
\begin&lbrace;document&rbrace;
\include&lbrace;chapitres/chap1&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<para>Pour rendre votre document portable vis à vis des diverses distributions
et plateformes vous devriez éviter les espaces dans les noms de
fichier. Traditionnellement on utilise des tirets de 6 ou de 8 à la
place.  Néanmoins, pour le nom <samp>amo amas amat</samp>, ce qui suit
fonctionne sous &tex; Live sur GNU/Linux:
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\includeonly&lbrace;
  &quot;amo\space amas\space amat&quot;
  &rbrace;
\begin&lbrace;document&rbrace;
\include&lbrace;&quot;amo\space amas\space amat&quot;&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<para>et ceci fonctionne sous MiK&tex; sur Windows:
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\includeonly&lbrace;
  &lbrace;&quot;amo amas amat&quot;&rbrace;
  &rbrace;
\begin&lbrace;document&rbrace;
\include&lbrace;&lbrace;&quot;amo amas amat&quot;&rbrace;&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="920"><code>\include</code> imbriqués non autorisés</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="921">imbrication de <code>\include</code> non autorisée</indexterm></cindex>
<para>Vous ne pouvez pas utiliser <code>\include</code> au sein d&textrsquo;un fichier qui
lui-même est inclus via <code>\include</code>, sans quoi vous obtenez l&textrsquo;erreur
<samp>LaTeX Error: \include cannot be nested</samp>.  La commande
<code>\include</code> ne peut pas apparaître dans le préambule ; sans quoi
vous obtenez l&textrsquo;erreur <samp>LaTeX Error: Missing \begin&lbrace;document&rbrace;</samp>.
</para>
<para>Si un fichier que vous incluez par <code>\include</code> n&textrsquo;existe pas, par
exemple si vous tapez la commande <code>\include&lbrace;athiesme&rbrace;</code> par erreur
à la place de <code>\include&lbrace;atheisme&rbrace;</code>, alors &latex; ne produit pas
une erreur mais un avertissement <samp>No file athiesme.tex.</samp>  (Il crée
également le fichier <file>athiesme.aux</file>).
</para>
<para>Si vous faites un <code>\include</code> du fichier racine dans lui-même alors
vous obtenez tout d&textrsquo;abord <samp>LaTeX Error: Can be used only in
preamble</samp>.  Les exécutions suivantes donnent <samp>TeX capacity
exceeded, sorry [text input levels=15]</samp>.  Pour réparer cela, vous devez
enlever l&textrsquo;inclusion <code>\include&lbrace;<var>racine</var>&rbrace;</code> mais aussi détruire
le fichier <file><var>racine</var>.aux</file> et exécuter de nouveau &latex;.
</para>

<!-- c xxx \includeonly omis = mettre plus haut dans le nœeud, pour la -->
<!-- c xxx progressivité de l'exposé. -->


</section>
<node name="_005cinput" spaces=" "><nodename>\input</nodename><nodeprev automatic="on">\include &amp; \includeonly</nodeprev><nodeup automatic="on">Splitting the input</nodeup></node>
<section spaces=" "><sectiontitle>\input</sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1349">\input</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\input&lbrace;<var>nomfichier</var>&rbrace;
</pre></example>

<para>La commande <code>\input</code> a pour effet que le <var>nomfichier</var> spécifié
soit lu et traité comme si son contenu était inséré dans le fichier
courant à cet endroit.
</para>
<para>Si <var>nomfichier</var> ne se termine pas en <samp>.tex</samp> (par ex.,
<samp>toto</samp> ou <samp>toto.tata</samp>), on essaie en premier en ajoutant cette
extension (<samp>toto.tex</samp> ou <samp>toto.tata.tex</samp>).  Si aucun fichier
n&textrsquo;est trouvé avec ce nom, alors on essaie le <var>nomfichier</var> original
(c.-à-d.&noeos; <samp>toto</samp> ou <samp>toto.tata</samp>).
</para>
</section>
</chapter>
<node name="Front_002fback-matter" spaces=" "><nodename>Front/back matter</nodename><nodenext automatic="on">Letters</nodenext><nodeprev automatic="on">Splitting the input</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Parties pré/postliminaires</sectiontitle>

<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">Table des matières etc.</menutitle><menunode separator=". ">Table of contents etc.</menunode><menudescription><pre xml:space="preserve">Table des matières, liste des figures, liste des tableaux.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Glossaires</menutitle><menunode separator=". ">Glossaries</menunode><menudescription><pre xml:space="preserve">Génère un glossaire.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=":">Index</menutitle><menunode separator=". ">Indexes</menunode><menudescription><pre xml:space="preserve">Génère un indexe.
</pre></menudescription></menuentry></menu>


<node name="Table-of-contents-etc_002e" spaces=" "><nodename>Table of contents etc.</nodename><nodenext automatic="on">Glossaries</nodenext><nodeup automatic="on">Front/back matter</nodeup></node>
<section spaces=" "><sectiontitle>Table des matières etc.</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="922">table des matières, création</indexterm></cindex>

<findex index="fn" spaces=" "><indexterm index="fn" number="1350">\tableofcontents</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1351">.toc, <r>fichier</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1352">\listoffigures</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1353">\listoftables</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1354">.lof <r>fichier</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1355">.lot <r>fichier</r></indexterm></findex>

<para>Synopsis, l&textrsquo;un parmi ceux qui suivent :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\tableofcontents
\listoffigures
\listoftables
</pre></example>

<para>Produit une table des matières, ou une liste des figures, ou une liste
des tableaux. Placez la commande à l&textrsquo;endroit même où vous voulez que la
table ou liste apparaisse. Vous n&textrsquo;avez pas à la renseigner ; par
exemple, typiquement les entrées de la table des matières sont
automatiquement générées à partir des commandes de rubricage
<code>\chapter</code>, etc.
</para>
<para>L&textrsquo;exemple ci-dessous illustre la première commande,
<code>\tableofcontents</code>.  &latex; produit une table des matières sur la
première page du livre.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
% \setcounter&lbrace;tocdepth&rbrace;&lbrace;1&rbrace;
\begin&lbrace;document&rbrace;
\tableofcontents\newpage
  ...
\chapter&lbrace;...&rbrace;
  ...
\section&lbrace;...&rbrace;
  ...
\subsection&lbrace;...&rbrace;
  ...
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>En décommentant la deuxième ligne on peut limiter la table à ne lister
que les rubriques issues de <code>\chapter</code> et <code>\section</code>, mais pas
celle issue de <code>\subsection</code>, parce que la commande <code>\section</code>
a pour niveau 1.  <xref label="Sectioning"><xrefnodename>Sectioning</xrefnodename></xref>, pour les numéros de niveaux des
rubriques.  Pour plus ample information sur <code>tocdepth</code>
<pxref label="Sectioning_002ftocdepth"><xrefnodename>Sectioning/tocdepth</xrefnodename></pxref>.
</para>
<para>Un autre exemple de l&textrsquo;utilisation de <code>\tableofcontents</code> est dans
<ref label="Larger-book-template"><xrefnodename>Larger book template</xrefnodename></ref>.
</para>
<para>Si vous désirez un saut de page après la table des matières, insérez une commande
<code>\newpage</code> après la commande <code>\tableofcontents</code>, comme ci-dessus.
</para>
<para>Pour fabriquer la table des matières, &latex; stocke l&textrsquo;information dans
un fichier auxiliaire nommé <file><var>fichier-racine</var>.toc</file>
(<pxref label="Splitting-the-input"><xrefnodename>Splitting the input</xrefnodename></pxref>).  Par exemple, le fichier
&latex; <file>test.tex</file> ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\begin&lbrace;document&rbrace;
\tableofcontents\newpage
\section&lbrace;Premièrement&rbrace;
\subsection&lbrace;Deuxièmement&rbrace;
  ...
</pre></example>

<noindent></noindent>
<para>écrit la ligne suivante dans <file>test.toc</file> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\contentsline &lbrace;section&rbrace;&lbrace;\numberline &lbrace;1&rbrace;Premièrement&rbrace;&lbrace;2&rbrace;
\contentsline &lbrace;subsection&rbrace;&lbrace;\numberline &lbrace;1.1&rbrace;Deuxièmement&rbrace;&lbrace;2&rbrace;
</pre></example>

<noindent></noindent>
<para>L&textrsquo;indication <code>section</code> ou <code>subsection</code> donne le type de
rubrique.  Le crochet <code>\numberline</code> vous permet de changer la façon
dont l&textrsquo;information apparaît au sein de la table des matières.  Son
unique argument, <code>1</code> ou <code>1.1</code>, est le numéro de la rubrique
alors que le reste du deuxième argument de <code>\contentsline</code>,
<code>Premièrement</code> ou <code>Deuxièmement</code>, est le titre.  Finalement,
le troisième argument, <code>2</code>, est le numéro de la page à laquelle les
rubriques débutent.
</para>
<para>Une conséquence de cette stratégie de stockage de fichier auxiliaire est
que pour obtenir correctement la page de table des matières vous devez
exécuter &latex; deux fois, une fois pour stocker l&textrsquo;information et une
fois pour l&textrsquo;obtenir.
<!-- c xxx Et avec les .lot et .lof c'est aussi 2 fois, mais parce que le -->
<!-- c .aux est relu avant le .lot/.lof -->
En particulier, la première fois que vous exécutez &latex; sur un
nouveau document, la page de table des matières est vide hormis le titre
<samp>Table des matières</samp>.  Il suffit de l&textrsquo;exécuter de nouveau.
</para>
<!-- c xxx ajouter que les fichiers .lot et .lof sont renseignés par la commande \caption -->
<para>Les commandes <code>\listoffigures</code> et <code>\listoftables</code> produisent
une liste des figures et une liste des tables.  Elles fonctionnent de la
même façon que les commandes pour la table des matières ; notamment
elles fonctionnent avec l&textrsquo;information stockée dans des fichiers
<file>.lof</file> et <file>.lot</file>.
</para>
<para>Pour modifier le titre de la page de table des matières, inspirez vous
la la première ligne de l&textrsquo;exemple suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand&lbrace;\contentsname&rbrace;&lbrace;Table des matières&rbrace;
\renewcommand&lbrace;\listfigurename&rbrace;&lbrace;Tracé de courbes&rbrace;
\renewcommand&lbrace;\listtablename&rbrace;&lbrace;Tableaux&rbrace;
</pre></example>

<noindent></noindent>
<para><findex index="fn" spaces=" "><indexterm index="fn" number="1356"><r>paquetage</r> <code>babel</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1357"><code>babel</code>, <r>paquetage</r></indexterm></findex>
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1358"><r>paquetage</r> <code>polyglossia</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1359"><code>polyglossia</code>, <r>paquetage</r></indexterm></findex>

<para>De même, les deux autres lignes s&textrsquo;occupent des deux autres. Des
paquetages d&textrsquo;internationalisation tels que <code>babel</code> ou
<code>polyglossia</code> modifient les titres en fonction de la langue de base
sélectionnée.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1360"><r>paquetage</r> <code>tocloft</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1361"><code>tocloft</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="1362"><r>paquetage</r> <code>tocbibbind</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1363"><code>tocbibbind</code>, <r>paquetage</r></indexterm></findex>

<para>Le CTAN a beaucoup de paquetages traitant de la table des matières et
des listes de figures et de tableaux.  L&textrsquo;un d&textrsquo;eux bien commode pour
ajuster certains aspects du traitement par défaut, tels que
l&textrsquo;espacement, est <code>tocloft</code>.  Et <code>tocbibbind</code> permet d&textrsquo;ajouter
automatiquement la bibliographie, les indexes, etc. à la table des
matières.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::    ">\&arobase;dottedtocline</menunode><menudescription><pre xml:space="preserve">Formate une entrée dans la table des matières etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::    ">\addcontentsline</menunode><menudescription><pre xml:space="preserve">Ajouter une entrée dans la table des matières etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::      ">\addtocontents</menunode><menudescription><pre xml:space="preserve">Ajouter du texte directement au fichier table des matières etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::       ">\contentsline</menunode><menudescription><pre xml:space="preserve">Règle une ligne de table des matières, etc.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">\nofiles</menunode><menudescription><pre xml:space="preserve">Empêche l&textrsquo;écriture dans les fichiers auxiliaires.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::         ">\numberline</menunode><menudescription><pre xml:space="preserve">Place le numéro en argument fer a gauche dans une boîte.
</pre></menudescription></menuentry></menu>


<node name="_005c_0040dottedtocline" spaces=" "><nodename>\&arobase;dottedtocline</nodename><nodenext automatic="on">\addcontentsline</nodenext><nodeup automatic="on">Table of contents etc.</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\&arobase;dottedtocline</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1364">\&arobase;dottedtocline</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="923">table des matières, crée une ligne pointillée</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\&arobase;dottedtocline&lbrace;<var>numnivrubrique</var>&rbrace;&lbrace;<var>renfoncement</var>&rbrace;&lbrace;<var>largeurnum</var>&rbrace;&lbrace;<var>texte</var>&rbrace;&lbrace;<var>numpage</var>&rbrace;
</pre></example>

<para>Utilisée en interne par &latex; pour formater une ligne d&textrsquo;article dans
la table des matières, table des figures ou table des tableaux. Les
auteurs ne saisissent pas directement des commandes
<code>\&arobase;dottedtocline</code>.
</para>
<para>Cette commande est typiquement utilisée par <code>\l&arobase;section</code>,
<code>\l&arobase;subsection</code>, etc., pour formater le contenu de ces tables.
Par exemple, le fichier <file>article.cls</file> contient ces définitions :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand*\l&arobase;section&lbrace;\&arobase;dottedtocline&lbrace;1&rbrace;&lbrace;1.5em&rbrace;&lbrace;2.3em&rbrace;&rbrace;
\newcommand*\l&arobase;subsection&lbrace;\&arobase;dottedtocline&lbrace;2&rbrace;&lbrace;3.8em&rbrace;&lbrace;3.2em&rbrace;&rbrace;
\newcommand*\l&arobase;subsubsection&lbrace;\&arobase;dottedtocline&lbrace;3&rbrace;&lbrace;7.0em&rbrace;&lbrace;4.1em&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>Dans cet exemple, on dirait <code>\&arobase;dottedcline</code> ne prend que trois
argument. Mais en remontant le code on s&textrsquo;aperçoit qu&textrsquo;elle prend
également les deux arguments finaux <var>texte</var> et <var>numéro-page</var> du
synopsis d&textrsquo;appel de <code>\contentsline</code> (<pxref label="_005ccontentsline"><xrefnodename>\contentsline</xrefnodename></pxref>).
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="924">points de suite, pointillés dans la table des matières</indexterm></cindex>
<para>Entre la boîte du texte de titre de rubrique et la marge de droite, ces
commandes <code>\&arobase;dottedtocline</code> insèrent des <dfn>points de suite</dfn>,
c.-à-d.&noeos; une ligne en pointillés uniformément espacés. L&textrsquo;espace
inter-point est donné par la commande <code>\&arobase;dotsep</code>.  Par défaut
c&textrsquo;est 4.5 (exprimé en unités de longueur mathématique, ou <code>mu</code>,
soit <code>1/18</code><dmn>em</dmn>.  On peut le modifier avec
<code>\renewcommand</code>, comme dans
<code>\renewcommand&lbrace;\&arobase;dotsep&rbrace;&lbrace;3.5&rbrace;</code>.
</para>
<para>Dans la classe standarde <file>book</file>, &latex; n&textrsquo;utilise pas de points
de suite pour articles de la table correspondant aux rubriques de niveau
<code>\part</code> ou <code>\chapter</code>, et dans la classe <file>article</file>, il
n&textrsquo;en utilise pas pour les articles de niveau <code>\section</code>.
</para>

</subsection>
<node name="_005caddcontentsline" spaces=" "><nodename>\addcontentsline</nodename><nodenext automatic="on">\addtocontents</nodenext><nodeprev automatic="on">\&arobase;dottedtocline</nodeprev><nodeup automatic="on">Table of contents etc.</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\addcontentsline</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1365">\addcontentsline&lbrace;<var>ext</var>&rbrace;&lbrace;<var>unit</var>&rbrace;&lbrace;<var>texte</var>&rbrace;</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="925">table des matières, ajouter manuellement un article</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addcontentsline&lbrace;<var>ext</var>&rbrace;&lbrace;<var>unit</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1366">\contentsline</indexterm></findex>
<para>Ajoute un article dans le fichier auxiliaire dont l&textrsquo;extension de nom est
<var>ext</var>.
</para>
<para>L&textrsquo;exemple suivant a pour effet d&textrsquo;ajouter une ligne <samp>Appendices</samp> à
la table des matières :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addcontentsline&lbrace;toc&rbrace;&lbrace;section&rbrace;&lbrace;\protect\textbf&lbrace;Appendices&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>elle apparaîtra au même niveau de renfoncement que les rubriques, sera en
caractères gras, et recevra le numéro de page correspondant au point où
la commande apparaît dans le fichier d&textrsquo;entrée.
</para>
<para>La commande <code>\addcontentsline</code> écrit de l&textrsquo;information dans le
fichier <file><var>nom-racine</var>.<var>ext</var></file>, où <var>nom-racine</var> est le
nom du fichier racine (<pxref label="Splitting-the-input"><xrefnodename>Splitting the input</xrefnodename></pxref>). Il écrit cette
information comme le texte de la commande
<code>\contentsline&lbrace;<var>unit</var>&rbrace;&lbrace;<var>texte</var>&rbrace;&lbrace;<var>numéro</var>&rbrace;</code>, où
<code><var>numéro</var></code> est la valeur courante du compteur <code><var>unit</var></code>
(<pxref label="_005ccontentsline"><xrefnodename>\contentsline</xrefnodename></pxref>). Le cas le plus fréquent est la table des
matières et dans ce cas <var>numéro</var> est la valeur du compteur
<var>unit</var> dans la première page produite où la commande
<code>\addcontentsline</code> correspondante fut utilisée.
</para>
<para>Cette commande est invoquées par les commandes de rubricage
<code>\chapter</code>, etc. (<pxref label="Sectioning"><xrefnodename>Sectioning</xrefnodename></pxref>), et aussi par <code>\caption</code>
au sein d&textrsquo;un environnement flottant (<pxref label="Floats"><xrefnodename>Floats</xrefnodename></pxref>). Mais elle est
aussi directement utilisées par des auteurs. Par exemple, un auteur
écrivant un livre dont le style est d&textrsquo;avoir une préface non numérotée
pourrait utiliser <code>\chapter*</code>. Mais cette commande ne produit pas
d&textrsquo;article dans la table des matières, on peut alors l&textrsquo;entrer manuellement
ainsi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\chapter*&lbrace;Preface&rbrace;
\addcontentsline&lbrace;toc&rbrace;&lbrace;chapter&rbrace;&lbrace;\protect\numberline&lbrace;&rbrace;Préface&rbrace;
</pre></example>

<noindent></noindent>
<para>Dans le fichier <file><var>nom-racine</var>.toc</file> &latex; insère alors la
ligne <code>\contentsline &lbrace;chapter&rbrace;&lbrace;\numberline &lbrace;&rbrace;Préface&rbrace;&lbrace;3&rbrace;</code> ;
notez que le numéro de page <samp>3</samp> est généré automatiquement par le
système, et non saisi manuellement.
</para>
<para>Tous les arguments de <code>\addcontentsline</code> sont obligatoires.
</para>

<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">ext</itemformat></item>
</tableterm><tableitem><para>Typiquement c&textrsquo;est l&textrsquo;une des trois chaînes suivantes : <code>toc</code> pour la
table des matières (« table of contents » en langue anglaise), <code>lof</code>
pour la liste des figures (« list of figures »), ou <code>lot</code> pour la
liste des tableaux (« list of tables »).  L&textrsquo;extension de nom de fichier
du fichier dans lequel l&textrsquo;information doit être écrite.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">unit</itemformat></item>
</tableterm><tableitem><para>Une chaîne dépendant de la valeur de l&textrsquo;argument <var>ext</var>, typiquement
l&textrsquo;une des suivantes :
</para>
<table commandarg="code" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="code">toc</itemformat></item>
</tableterm><tableitem><para>Pour la table des matières, c&textrsquo;est le nom d&textrsquo;une unité sectionnelle : <code>part</code>, <code>chapter</code>,
<code>section</code>, <code>subsection</code>, <code>subsubsection</code>, etc.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">lof</itemformat></item>
</tableterm><tableitem><para>Pour la liste des figures : <code>figure</code>.
</para></tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">lot</itemformat></item>
</tableterm><tableitem><para>Pour la liste des tableaux : <code>table</code>.
</para></tableitem></tableentry></table>

</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">texte</itemformat></item>
</tableterm><tableitem><para>Le texte de l&textrsquo;entrée. On doit précéder de <code>\protect</code> toute commande
fragile (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>) y figurant.
</para></tableitem></tableentry></table>

<para>La commande <code>\addcontentsline</code> a une interaction avec
<code>\include</code> (<pxref label="_005cinclude-_0026-_005cincludeonly"><xrefnodename>\include &amp; \includeonly</xrefnodename></pxref>). Si vous les utilisez
au même niveau comme dans
<code>\addcontentsline&lbrace;...&rbrace;&lbrace;...&rbrace;&lbrace;...&rbrace;\include&lbrace;...&rbrace;</code>, alors les
lignes dans la table des matières risquent de sortir dans un ordre
erroné. La solution est de déplacer <code>\addcontentsline</code> dans le
fichier qu&textrsquo;on inclut.
</para>
<para>Si vous utiliser une <var>unit</var> que &latex; ne reconnaît pas, comme
la coquille dans l&textrsquo;exemple suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addcontentsline&lbrace;toc&rbrace;&lbrace;setcion&rbrace;&lbrace;\protect\textbf&lbrace;Appendices&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>alors vous n&textrsquo;obtiendrez pas une erreur mais le formatage de la table des
matières sera incohérent.
</para>

</subsection>
<node name="_005caddtocontents" spaces=" "><nodename>\addtocontents</nodename><nodenext automatic="on">\contentsline</nodenext><nodeprev automatic="on">\addcontentsline</nodeprev><nodeup automatic="on">Table of contents etc.</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\addtocontents</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1367">\addtocontents&lbrace;<var>ext</var>&rbrace;&lbrace;<var>texte</var>&rbrace;</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addtocontents&lbrace;<var>ext</var>&rbrace;&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Ajoute <var>texte</var>, qui peut être du texte ou des commandes de formatage,
directement au fichier auxiliaire dont le nom a l&textrsquo;extension
<file>.<var>ext</var></file>. Cela est utilisé d&textrsquo;ordinaire pour la table des
matières, mais aussi pour la liste des figures ou celle des tableaux.
</para>
<para>L&textrsquo;exemple suivant place un peu d&textrsquo;espace vertical dans la table des
matières après l&textrsquo;en-tête <samp>Table des matières</samp> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\tableofcontents\newpage
\addtocontents&lbrace;toc&rbrace;&lbrace;\protect\vspace*&lbrace;3ex&rbrace;&rbrace;
</pre></example>

<noindent></noindent>
<para>L&textrsquo;exemple suivant place le mot <samp>page</samp>, en caractères gras, au
dessus de la colonne des numéros de page après l&textrsquo;en-tête.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\tableofcontents
\addtocontents&lbrace;toc&rbrace;&lbrace;~\hfill\textbf&lbrace;page&rbrace;\par&rbrace;
\chapter&lbrace;...&rbrace;
</pre></example>

<noindent></noindent>
<para>L&textrsquo;exemple ci-dessous ajoute une ligne annonçant l&textrsquo;œuvre d&textrsquo;un nouvel
auteur :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\addtocontents&lbrace;toc&rbrace;&lbrace;%
  \protect\vspace&lbrace;2ex&rbrace;
  \textbf&lbrace;Chapitres de N. Autre Auteur&rbrace;\par&rbrace;
</pre></example>

<para>La différence entre <code>\addtocontents</code> et <code>\addcontentsline</code> est
que cette dernière commande est strictement réservée aux lignes, comme
le cas d&textrsquo;une ligne donnant le numéro de page pour le début d&textrsquo;un nouveau
sous-ensemble des chapitres.  Comme les exemples ci-dessus le démontrent,
<code>\addtocontents</code> permet de la matière telle que de l&textrsquo;espacement.
</para>
<para>La commande <code>\addtocontents</code> a deux arguments, tous deux
obligatoires.
</para>
<table commandarg="var" spaces=" " endspaces=" ">
<tableentry><tableterm><item spaces=" "><itemformat command="var">ext</itemformat></item>
</tableterm><tableitem><para>Typiquement l&textrsquo;un parmi : <file>toc</file> pour la table des matières,
<file>lof</file> por la liste des figures, ou <file>lot</file> pour la liste des
tableaux. L&textrsquo;extension de nom de fichier du fichier dans lequel
l&textrsquo;information est à écrire.
</para>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="var">texte</itemformat></item>
</tableterm><tableitem><para>Le texte, et possiblement les commandes, à écrire.
</para></tableitem></tableentry></table>

<para>Les commandes de rubricage telles que <code>\chapter</code> utilisent la
commande <code>\addcontentsline</code> pour stocker l&textrsquo;information.  Cette
commande crée des lignes dans le fichier auxiliaire en <file>.toc</file> qui
contient les commandes <code>\contentsline</code> (<pxref label="_005caddcontentsline"><xrefnodename>\addcontentsline</xrefnodename></pxref>).
Contrairement à elle, la commande <code>\addtocontents</code> place
directement la matière dans ce fichier.
</para>
<para>La commande <code>\addtocontents</code> interagit avec <code>\include</code>
(<pxref label="_005cinclude-_0026-_005cincludeonly"><xrefnodename>\include &amp; \includeonly</xrefnodename></pxref>). Si vous les utilisez au même niveau,
comme dans <code>\addtocontents&lbrace;...&rbrace;&lbrace;...&rbrace;\include&lbrace;...&rbrace;</code> alors les
lignes de la table des matières risquent de sortir dans le mauvais
ordre.  La solution est de déplacer <code>\addtocontents</code> pour la mettre
dans le fichier à inclure.
</para>

</subsection>
<node name="_005ccontentsline" spaces=" "><nodename>\contentsline</nodename><nodenext automatic="on">\nofiles</nodenext><nodeprev automatic="on">\addtocontents</nodeprev><nodeup automatic="on">Table of contents etc.</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\contentsline</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="926">table des matières</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1368">\contentsline</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1369">\tableofcontents</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1370">.toc, <r>fichier</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1371">\listoffigures</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1372">\listoftables</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1373">.lof, <r>fichier</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1374">.lot, <r>fichier</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1375">\l&arobase;chapter</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1376">\l&arobase;section</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1377">\l&arobase;subsection</indexterm></findex>

<para>Synopsis :
</para>
<!-- c attention référence au synoposis dans nœud \@dottedtocline -->
<example endspaces=" ">
<pre xml:space="preserve">\contentsline&lbrace;<var>unit</var>&rbrace;&lbrace;<var>texte</var>&rbrace;&lbrace;<var>numéro-page</var>&rbrace;
</pre></example>

<para>Utilisé en interne par &latex; pour composer un article dans une table
des matières, table des figures, ou table des tableaux (<pxref label="Table-of-contents-etc_002e"><xrefnodename>Table of
contents etc.</xrefnodename></pxref>). Les auteurs ne saisissent pas directement les commandes
<code>\contentsline</code>.
</para>
<para>En général l&textrsquo;ajout de matière à ces tables est fait automatiquement par
les commandes <code>\chapter</code>, <code>\section</code>, etc. pour la table des
matières, ou par la commande <code>\caption</code> au sein d&textrsquo;un environnement
<code>\figure</code> ou <code>\table</code> (<pxref label="figure"><xrefnodename>figure</xrefnodename></pxref> et <pxref label="table"><xrefnodename>table</xrefnodename></pxref>).
Ainsi, en supposant que le fichier racine est <file>these.tex</file>, et
qu&textrsquo;il contient la déclaration <code>\tableofcontents</code>, la commande
<code>\chapter&lbrace;Chapitre premier&rbrace;</code> produit quelque chose de ce genre
dans le fichier <file>these.toc</file> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\contentsline &lbrace;chapter&rbrace;&lbrace;\numberline &lbrace;1&rbrace;Chapitre premier&rbrace;&lbrace;3&rbrace;
</pre></example>

<para>Si le fichier contient la déclaration <code>\listoffigures</code> alors un
environnement figure comprenant <code>\caption&lbrace;Essai&rbrace;</code> produira quelque chose de ce genre dans <file>these.lof</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\contentsline &lbrace;figure&rbrace;&lbrace;\numberline &lbrace;1.1&rbrace;&lbrace;\ignorespaces Essai&rbrace;&rbrace;&lbrace;6&rbrace;
</pre></example>
<para>x
Pour ajouter manuellement de la matière, utilisez
<code>\addcontentsline&lbrace;<var>typefic</var>&rbrace;&lbrace;<var>unit</var>&rbrace;&lbrace;\<var>texte</var>&rbrace;</code>,
où <var>typefic</var> est <code>toc</code>, <code>lof</code>, ou <code>lot</code>
(<pxref label="_005caddcontentsline"><xrefnodename>\addcontentsline</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1378"><r>paquetage</r> <code>tocloft</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1379"><code>tocloft</code>, <r>paquetage</r></indexterm></findex>

<para>Pour manipuler la façon dont la matière de la commande
<code>\contentline</code> est composé, voir le paquetage <code>tocloft</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1380"><r>paquetage</r> <code>hyperref</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1381"><code>hyperref</code>, <r>paquetage</r></indexterm></findex>


<para>Notez que le paquetage <code>hyperref</code> change la définition de
<code>\contentsline</code> (et de <code>\addcontentsline</code>) pour ajouter plus
d&textrsquo;arguments, fabriquer des hyperliens.  C&textrsquo;est la source de l&textrsquo;erreur
<code>Argument of \contentsline has an extra &rbrace;</code> quand on
ajoute/supprime l&textrsquo;utilisation d&textrsquo;<code>hyperref</code> et qu&textrsquo;une compilation a
déjà été faite.  Pour réparer cette erreur, détruisez les fichiers
<file>.toc</file>, <file>.lof</file> ou <file>.lot</file>, et exécutez de nouveau
&latex;.
</para>

</subsection>
<node name="_005cnofiles" spaces=" "><nodename>\nofiles</nodename><nodenext automatic="on">\numberline</nodenext><nodeprev automatic="on">\contentsline</nodeprev><nodeup automatic="on">Table of contents etc.</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\nofiles</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1382">\nofiles</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\nofiles
</pre></example>

<para>Empêche &latex; d&textrsquo;écrire quelque fichier auxiliaire que ce soit.  Les
seules sorties seront les fichiers <file>.log</file> et <file>.pdf</file> (ou
<file>.dvi</file>).  Cette commande ne peut être placée que dans le préambule.
</para>
<para>À cause de la commande <code>\nofiles</code> dans cet exemple aucun fichier
<file>.toc</file> n&textrsquo;est produit.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\nofiles
\begin&lbrace;document&rbrace;
\tableofcontents\newpage
\chapter&lbrace;...&rbrace;
  ...
</pre></example>

<noindent></noindent>
<para>&latex; n&textrsquo;efface pas les fichiers auxiliaires existants, de sorte que
si vous insérer la commande <code>\nofiles</code> après avoir compilé le
fichier et obtenu un fichier <file>.toc</file> alors la page de table des
matières contiendra l&textrsquo;ancienne information.
</para>

</subsection>
<node name="_005cnumberline" spaces=" "><nodename>\numberline</nodename><nodeprev automatic="on">\nofiles</nodeprev><nodeup automatic="on">Table of contents etc.</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\numberline</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1383">\numberline</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\numberline&lbrace;\<var>numéro</var>&rbrace;
</pre></example>

<para>Compose son argument fer à gauche dans une boîte. Cela est utilisé au
sein d&textrsquo;une commande <code>\contentsline</code> pour composer les numéros de
rubrique (<pxref label="_005ccontentsline"><xrefnodename>\contentsline</xrefnodename></pxref>).
</para>
<para>Par exemple, cette ligne dans un fichier <file>.toc</file> a pour effet que le
<code>1.1</code> est composé fer à gauche :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\contentsline &lbrace;subsection&rbrace;&lbrace;\numberline &lbrace;1.1&rbrace;Motivation&rbrace;&lbrace;2&rbrace;
</pre></example>

<para>Par défaut, &latex; compose tout numéro de rubrique au sein d&textrsquo;une boîte
de longueur <code>\&arobase;tempdima</code>.  Cette longueur est réglée par les
commandes <code>\l&arobase;section</code>, <code>\l&arobase;subsection</code>, etc.  Pour Mettre
les numéros de rubrique dans des boîtes de longueur naturelle utiliser le
code <code>\renewcommand&lbrace;\numberline&rbrace;[1]&lbrace;#1~&rbrace;</code> avant
<code>\tableofcontents</code>.
</para>
<para>Cette commande est fragile, aussi vous pourriez avoir besoin de la
précéder d&textrsquo;un <code>\protect</code> (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).  Un exemple
est l&textrsquo;utilisation de <code>\protect</code> dans la commande suivante :
</para>
<example endspaces=" ">
<pre xml:space="preserve"><code>\addcontentsline&lbrace;toc&rbrace;&lbrace;section&rbrace;&lbrace;\protect\numberline &lbrace;&rbrace;Sommaire&rbrace;</code>
</pre></example>

<noindent></noindent>
<para>de sorte à obtenir le <code>\numberline</code> dans la commande
<code>\contentsline</code> dans le fichier <file>.toc</file> ainsi :
<code>\contentsline &lbrace;section&rbrace;&lbrace;\numberline &lbrace;&rbrace;Sommaire&rbrace;&lbrace;6&rbrace;</code> (le
numéro de page <samp>6</samp> est ajouté automatiquement par &latex; ;
<pxref label="_005caddcontentsline"><xrefnodename>\addcontentsline</xrefnodename></pxref>).
</para>

</subsection>
</section>
<node name="Glossaries" spaces=" "><nodename>Glossaries</nodename><nodenext automatic="on">Indexes</nodenext><nodeprev automatic="on">Table of contents etc.</nodeprev><nodeup automatic="on">Front/back matter</nodeup></node>
<section spaces=" "><sectiontitle>Glossaires</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="927">glossaires</indexterm></cindex>

<findex index="fn" spaces=" "><indexterm index="fn" number="1384">\makeglossary</indexterm></findex>
<para>La commande <code>\makeglossary</code> active la création des glossaires.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1385">\glossary</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="928"><file>.glo</file>, fichier</indexterm></cindex>
<para>La commande <code>\glossary&lbrace;<var>texte</var>&rbrace;</code> écrit un article de
glossaire pour <var>texte</var> dans un fichier auxiliaire nommé avec
l&textrsquo;extension <file>.glo</file>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1386">\glossaryentry</indexterm></findex>
<para>Plus précisément, ce qui est écrit est la commande
<code>\glossaryentry&lbrace;<var>texte</var>&rbrace;&lbrace;<var>numpage</var>&rbrace;</code>, où <var>numpage</var>
est la valeur courante de <code>\thepage</code>.
</para>
<para>Le paquetage <code>glossary</code> disponible sur le CTAN fournit une prise en
charge de glossaires plus élaborée.
</para>

</section>
<node name="Indexes" spaces=" "><nodename>Indexes</nodename><nodeprev automatic="on">Glossaries</nodeprev><nodeup automatic="on">Front/back matter</nodeup></node>
<!-- c Revoir la trad. -->
<section spaces=" "><sectiontitle>Index</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="929">index</indexterm></cindex>

<findex index="fn" spaces=" "><indexterm index="fn" number="1387">\makeindex</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1388">\index</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="930"><file>.idx</file>, fichier</indexterm></cindex>

<para>Si vous dites à &latex; les termes que vous voulez voir apparaître dans
un index, alors il peut produire cet index, classé alphabétiquement et
en maintenant automatiquement les numéros de page.  Ce qui suit illustre
les bases.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;article&rbrace;
\usepackage&lbrace;makeidx&rbrace;    % Fournit les commandes d'indexation
  \makeindex
% \usepackage&lbrace;showidx&rbrace;  % Affiche les notes en marge des articles
                        % de l'index
  ...
\begin&lbrace;document&rbrace;
  ...
Le théorème de Wilson\index&lbrace;Théorème de Wilson&rbrace; dit qu'un nombre $n&gt;1$
est premier si et seulement si la factorielle de $n-1$ est congurente à
$-1$ modulo~$n$.\index&lbrace;congruence!et théorème de Wilson&rbrace;
  ...
\printindex
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>Comme illustré ci-dessus, on déclare des articles d&textrsquo;index avec la
commande <code>\index</code> (<pxref label="_005cindex"><xrefnodename>\index</xrefnodename></pxref>). Quand vous exécutez &latex;,
le <code>\index</code> inscrit son information, telle que <samp>Théorème de
Wilson</samp>, et le numéro de page, dans un fichier auxiliaire dont le nom
finit en <file>.idx</file>. Ensuite, pour classer par ordre alphabétique, et
pour d&textrsquo;autre manipulations, on exécute un program externe, typiquement
<command>makeindex</command> (<pxref label="makeindex"><xrefnodename>makeindex</xrefnodename></pxref>), ce qui écrit un fichier dont le
nom finit en <file>.ind</file>.  Finalement, <code>\printindex</code> ramène cette
information manipulée dans la sortie (<pxref label="_005cprintindex"><xrefnodename>\printindex</xrefnodename></pxref>).
</para>
<para>Ainsi, si le code de l&textrsquo;exemple plus haut est dans le fichier
<file>numth.tex</file> alors exécuter <samp>pdflatex numth</samp> sauvegarde
l&textrsquo;information de l&textrsquo;article d&textrsquo;index et son numéro de page dans
<file>numth.idx</file>. Et ensuite exécuter <samp>makeindex numth</samp> classe par
ordre alphabétique et sauvegarde les résultats dans
<file>numth.ind</file>. Finalement, exécuter de nouveau <samp>pdflatex numth</samp>
affiche l&textrsquo;index désiré, à l&textrsquo;endroit où la commande <code>\printindex</code>
est dans le code source.
</para>
<para>Il, y a beaucoup d&textrsquo;options pour contrôler la sortie.  Un exemple est que
le point d&textrsquo;exclamation dans <code>\index&lbrace;congruence!et théorème de
Wilson&rbrace;</code> produit un article principal pour <samp>congruence</samp> avec un
sous-article pour <samp>et théorème de Wilson</samp>.  Pour plus
d&textrsquo;information, <pxref label="makeindex"><xrefnodename>makeindex</xrefnodename></pxref>.
</para>
<para>Les commandes <code>\makeindex</code> et <code>\printindex</code> sont
indépendantes.  Ne pas mettre le <code>\makeindex</code> arrête que &latex;
sauvegarde les articles d&textrsquo;index dans le fichier auxiliaire. Ne pas
mettre le <code>\printindex</code> a pour effet que &latex; n&textrsquo;affiche pas
l&textrsquo;index dans la sortie.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1389"><r>paquetage</r> <code>showidx</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1390"><code>showidx</code>, <r>paquetage</r></indexterm></findex>

<findex index="fn" spaces=" "><indexterm index="fn" number="1391"><r>paquetage</r> <code>multind</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1392"><code>multind</code>, <r>paquetage</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="931">indexes multiples</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="932">multiples, indexes</indexterm></cindex>
<para>Nombre de paquetages existent concernant l&textrsquo;indexation. Le paquetage
<code>showidx</code> a pour effet que chaque article d&textrsquo;index est affiché dans
la marge sur la page où le <code>\index</code> apparaît. Ceci peut être utile
pour préparer l&textrsquo;index.  Le paquetage <code>multind</code>, avec d&textrsquo;autres,
prend en charge les indexes multiples. Voir aussi l&textrsquo;article de la FAQ
&tex; sur ce sujet,
<url><urefurl>https://www.texfaq.org/FAQ-multind</urefurl></url>, et le sujet CTAN,
<url><urefurl>https://ctan.org/topic/index-multi</urefurl></url>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::   ">Produce the index manually</menunode><menudescription><pre xml:space="preserve">Classez les articles vous-même.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::        ">\index</menunode><menudescription><pre xml:space="preserve">Déclare un article d&textrsquo;index.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::     ">makeindex</menunode><menudescription><pre xml:space="preserve">Classe les articles d&textrsquo;index automatiquement.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">\printindex</menunode><menudescription><pre xml:space="preserve">Met l&textrsquo;index à cet endroit.
</pre></menudescription></menuentry></menu>


<node name="Produce-the-index-manually" spaces=" "><nodename>Produce the index manually</nodename><nodenext automatic="on">\index</nodenext><nodeup automatic="on">Indexes</nodeup></node>
<subsection spaces=" "><sectiontitle>Produire l&textrsquo;index manuellement</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="933">index, production manuelle</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1393">theindex</indexterm></findex>

<para>Les documents qui sont brefs et statiques peuvent avoir un index produit
manuellement. L&textrsquo;exemple ci-dessous produit une page séparée intitulée
<samp>Index</samp>, en format à deux-colonnes.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1394"><r>environnement</r> <code>theindex</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1395"><code>theindex</code>, <r>environnement</r></indexterm></findex>

<example endspaces=" ">
<pre xml:space="preserve">\begin&lbrace;theindex&rbrace;
\item acorn squash, 1
\subitem maple baked, 2
\indexspace
\item bacon, 3
\subitem maple baked, 4
\end&lbrace;theindex&rbrace;
</pre></example>

<para>Notez que l&textrsquo;auteur doit saisir les numéros de page, ce qui est rébarbatif
et résulte en des numéros inexacts si le document change. C&textrsquo;est pourquoi
dans la plupart des cas des méthodes automatisées telles que
<command>makeindex</command> sont préférables.  <xref label="Indexes"><xrefnodename>Indexes</xrefnodename></xref>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1396">\item</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1397">\subitem</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1398">\subsubitem</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1399">\indexspace</indexterm></findex>
<para>Toutefois nous couvrons ces commandes pour être exhaustif, et parce que
les méthodes automatisées sont basées sur elles. Comme l&textrsquo;exemple
l&textrsquo;illustre, un article principal utilise <code>\item</code>, un sous-article
<code>\subitem</code>, et le niveau le plus bas utilise <code>\subsubitem</code>.
Les lignes à blanc entre les articles sont sans effet. L&textrsquo;exemple
ci-dessus inclut <code>\indexspace</code> pour produire un espace vertical dans
la sortie que certains styles utilisent avant le premier article
commençant avec une nouvelle lettre.
</para>

</subsection>
<node name="_005cindex" spaces=" "><nodename>\index</nodename><nodenext automatic="on">makeindex</nodenext><nodeprev automatic="on">Produce the index manually</nodeprev><nodeup automatic="on">Indexes</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\index</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1400">\index</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="934"><file>.idx</file>, fichier</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\index&lbrace;<var>chaîne-article-index</var>&rbrace;
</pre></example>

<para>Déclare un article dans l&textrsquo;index.  Cette commande est fragile
(<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).
</para>
<para>Par exemple, comme décrit dans <ref label="Indexes"><xrefnodename>Indexes</xrefnodename></ref>, une façon d&textrsquo;obtenir un
index du code ci-dessous est de compiler le document avec <code>pdflatex
test</code>, puis de traiter les articles de l&textrsquo;index avec <code>makeindex
test</code>, et ensuite de compiler de nouveau avec <code>pdflatex test</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">% fichier test.tex
  ...
W~Ackermann (1896--1962).\index&lbrace;Ackermann&rbrace;
  ...
fonction d'Ackermann\index&lbrace;Ackermann!fonction&rbrace;
  ...
taux de croissance\index&lbrace;Ackermann!fonction!taux de croissance&rbrace;
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="935">index, articles, sous-articles</indexterm></cindex>
<noindent></noindent>
<para>Les trois articles obtiendront un numéro de page, comme dans
<samp>Ackermann, 22</samp>.  &latex; formate le deuxième comme un
sous-article du premier, sur la ligne du dessous et renfoncé, et le
troisième comme un sous-article du deuxième. On ne peut pas imbriquer
les articles au delà du troisième niveau de sous-articles.  (Si vous
ajoutez <code>\index&lbrace;Ackermann!fonction!taux de
croissance!comparaison&rbrace;</code> alors <command>makeindex</command> dit <samp>Scanning
input file test.idx....done (4 entries accepted, 1 rejected)</samp> et le
quatrième niveau est silencieusement absent de l&textrsquo;index).
</para>
<para>Si vous saisissez un deuxième <code>\index</code> avec la même
<var>chaîne-article-index</var> alors vous obtiendrez un unique article
d&textrsquo;index avec deux numéros de page (à moins qu&textrsquo;il se trouve que les deux
soient sur la même page). Ainsi, ajouter <code>comme pour
Ackermann.\index&lbrace;Ackermann&rbrace;</code> plus loin dans le même document que
ci-dessus donnera un article d&textrsquo;index du genre de <samp>Ackermann, 22,
151</samp>.  Notez aussi que vous pouvez saisir les articles d&textrsquo;index dans un
ordre quelconque, ainsi par exemple <code>\index&lbrace;Ackermann!fonction&rbrace;</code>
peut arriver avant <code>\index&lbrace;Ackermann&rbrace;</code>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="936">index, plage de pages</indexterm></cindex>
<para>Obtenez une plage de page en sortie, du genre de <samp>Hilbert, 23--27</samp>,
comme avec le code ci-dessous :
</para>
<example endspaces=" ">
<pre xml:space="preserve">W~Ackermann (1896--1962).\index&lbrace;Ackermann&rbrace;
  ...
D~Hilbert (1862--1943)\index&lbrace;Ackermann!Hilbert|(&rbrace;
  ...
désapprouvait son mariage.\index&lbrace;Ackermann!Hilbert|)&rbrace;
</pre></example>

<noindent></noindent>
<para>Si le début et la fin de la plage de pages sont égaux alors le système
ne donne qu&textrsquo;un seul numéro de page, et non une plage.
</para>
<para>Si vous indexez des sous-articles mais sans article principal, comme
dans <code>\index&lbrace;Jones!programme&rbrace;</code> et
<code>\index&lbrace;Jones!résultats&rbrace;</code>, alors la sortie est l&textrsquo;article
<samp>Jones</samp> sans virgule ni numéro de page, suivi de deux
sous-articles, du genre de <samp>programme, 50</samp> et <samp>résultats, 51</samp>.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="937">voir et voir aussi, articles d&textrsquo;index</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="938">index, articles, « voir » et « voir aussi »</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1401">\seename</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1402">\alsoname</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1403"><r>paquetage</r> <code>babel</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1404"><code>babel</code>, <r>paquetage</r></indexterm></findex>
 <findex index="fn" spaces=" "><indexterm index="fn" number="1405"><r>paquetage</r> <code>polyglossia</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1406"><code>polyglossia</code>, <r>paquetage</r></indexterm></findex>


<para>On génère un article d&textrsquo;index qui dit <samp>Voir</samp> en utilisant un
caractère barre verticale :
<code>\index&lbrace;Ackermann!function|see&lbrace;fonction de P\'eter&rbrace;&rbrace;</code>.  On peut
également obtenir <samp>voir aussi</samp> avec <code>seealso</code>.  (Le texte
<samp>voir</samp> est défini par <code>\seename</code>, et <samp>voir ausi</samp> par
<code>\alsoname</code> lorsqu&textrsquo;on charge un paquetage d&textrsquo;internationalisation
tel que <code>babel</code> or <code>polyglossia</code>, et que la langue
sélectionnée est le français, sinon par défaut c&textrsquo;est <samp>see</samp> et
<samp>see also</samp>, on peut aussi les redéfinir directement avec
quelque chose du genre de <code>\renewcommand&lbrace;\seename&rbrace;&lbrace;cf.&rbrace;
\renewcommand&lbrace;\alsoname&rbrace;&lbrace;ibid.&rbrace;</code>).
</para>
<para>La production du mot <samp>voir</samp> fait partie d&textrsquo;une fonctionnalité plus
générale. Après la barre verticale vous pouvez mettre le nom <var>cmd</var>
d&textrsquo;une commande <code>\<var>cmd</var></code> à un argument, comme dans
<code>\index&lbrace;group|textit&rbrace;</code> (notez l&textrsquo;absence de controblique sur la
commande <code>\textit</code>) et le système appliquera cette commande au
numéro de page dans l&textrsquo;article d&textrsquo;index, donnant ici quelque chose du
genre de <code>\textit&lbrace;7&rbrace;</code>.  Vous pouvez aussi définir vos propres
commandes comme dans
<code>\newcommand&lbrace;\pagecours&rbrace;[1]&lbrace;&lbrace;\color&lbrace;blue&rbrace;#1&rbrace;&rbrace;</code> et ensuite
<code>\index&lbrace;Ackermann!function|pagecours&rbrace;</code> donnera un numéro de page
en bleu (<pxref label="Color"><xrefnodename>Color</xrefnodename></pxref>).  Voici in autre exemple, moins pratique :
</para>
<!-- c credit Ian Thompson https://tex.stackexchange.com/a/272572/121234 -->
<example endspaces=" ">
<pre xml:space="preserve">\newcommand\pageindex[1]&lbrace;#1, \thepage&rbrace;
  ... Epimenides.\index&lbrace;self-reference|pageindex&rbrace;
</pre></example>

<noindent></noindent>
<para>qui crée une article citant le numéro de page dans le listing de l&textrsquo;index.
</para>
<para>Les deux fonctions décrites plus haut peuvent être combinées, comme dans :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\index&lbrace;Ackermann!fonction|(pagecours&rbrace;
  ...
\index&lbrace;Ackermann!fonction|)&rbrace;
</pre></example>

<noindent></noindent>
<para>ce qui en sortie produit un article d&textrsquo;index du genre de <samp>fonction,
23--27</samp> où la plage de numéros de page est en bleu.
</para>
<para>Considérez un article d&textrsquo;index tel que <samp>β-testeur</samp>. Le
saisir telle que <code>$\beta$-testeur</code> aura pour effet qu&textrsquo;il sera
classé selon le signe dollar. Vous pouvez le saisir en utilisant une
arobe, comme dans <code>\index&lbrace;bêta-testeur&arobase;$\beta$-testeur&rbrace;</code>.
Lorsque vous spécifiez un article avec une arobe qui sépare deux chaînes,
<code><var>pos</var>&arobase;<var>texte</var></code>, alors <var>pos</var> donne la position
alphabétique de l&textrsquo;article alors que <var>texte</var> produit le texte de
l&textrsquo;article. Un autre exemple est que <code>\index&lbrace;Saint Michael's
College&arobase;SMC&rbrace;</code> produit un article d&textrsquo;index <samp>SMC</samp> classé dans un
autre endroit que son épellation donnerait naturellement.
</para>
<para>Pour mettre le caractère <code>!</code>, <code>&arobase;</code>, <code>|</code> ou <code>&quot;</code> dans
un article d&textrsquo;index, échappez le en le précédant d&textrsquo;un guillemet anglais
double, <code>&quot;</code>.  (Le guillemet double est ignoré pour le classement
alphabétique).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1407"><r>paquetage</r> <code>index</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1408"><code>index</code>, <r>paquetage</r></indexterm></findex>

<para>Nombre de paquetages sur le CTAN apportent des fonctionnalités
supplémentaires allant au-delà de celles fournies par <code>makeidx</code>.
L&textrsquo;un deux est <code>index</code> qui permet d&textrsquo;avoir des index multiples et
contient une commande <code>\index*&lbrace;<var>index-entry-string</var>&rbrace;</code> qui
imprime la <var>chaîne-article-index</var> en plus de l&textrsquo;indexer.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1409">\indexentry</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="939">idx, fichier</indexterm></cindex>
<para>La commande <code>\index</code> écrit l&textrsquo;information d&textrsquo;indexation dans le
fichier <file><var>nom-racine</var>.idx</file>.  Plus spécifiquement, elle écrit le
texte de la commande
<code>\indexentry&lbrace;<var>chaîne-article-index</var>&rbrace;&lbrace;<var>num-page</var>&rbrace;</code>, où
<var>num-page</var> est la valeur du compteur <code>\thepage</code>.  Il peut
arriver, lorsque la commande <code>\printindex</code> perd les pédales, que
vous ayez à détruire ce fichier pour repartir de bases saines.
</para>
<para>Si vous oubliez l&textrsquo;accolade fermante sur une commande <code>\index</code> alors
vous obtiendrez un message du genre de :
</para>
<example endspaces=" ">
<pre xml:space="preserve">Runaway argument?  &lbrace;Ackermann!function
!  Paragraph ended before \&arobase;wrindex was complete.
</pre></example>


</subsection>
<node name="makeindex" spaces=" "><nodename>makeindex</nodename><nodenext automatic="on">\printindex</nodenext><nodeprev automatic="on">\index</nodeprev><nodeup automatic="on">Indexes</nodeup></node>
<subsection spaces=" "><sectiontitle><command>makeindex</command></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1410">index, traitement</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="940">makeindex, <r>programme</r></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="941"><file>.ind</file>, fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="942"><file>.idx</file>, fichier</indexterm></cindex>

<para>Synopsis, l&textrsquo;un parmi :
</para>
<example endspaces=" ">
<pre xml:space="preserve">makeindex <var>nomfic</var>
makeindex -s <var>fichier-style</var> <var>nomfic</var>
makeindex <var>options</var> <var>nomfic0</var> ...
</pre></example>

<para>Trie l&textrsquo;information d&textrsquo;index dans le fichier auxiliaire, et fait d&textrsquo;autres
traitements dessus. C&textrsquo;est un programme en ligne de commande. Il prend en
entrée un ou plusieurs fichiers bruts d&textrsquo;index, les fichiers
<file><var>nomfic</var>.idx</file>, et produit en sortie le ficher d&textrsquo;index fini, le
fichier <file><var>nomfic</var>.ind</file> qui est l&textrsquo;entrée de <code>\printindex</code>
(<pxref label="_005cprintindex"><xrefnodename>\printindex</xrefnodename></pxref>).
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="943"><file>.isty</file>, fichier</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1411">index, fichier de style</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1412">makeindex, fichier de style</indexterm></findex>
<para>La première forme de la commande suffit pour beaucoup d&textrsquo;usages. La
deuxième permet de formater l&textrsquo;index en utilisant un <dfn>fichier de
style d&textrsquo;index</dfn>, un fichier <file>.isty</file>.  La troisième forme est la plus
générale ; voir la documentation complète sur le CTAN.
</para>
<para>Ci-dessous on donne un exemple d&textrsquo;un fichier <file>.isty</file> simple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">% book.isty 
%   $ makeindex -s book.isty -p odd book.idx
% creates the index as book.ind, starting on an odd page. 
preamble
&quot;\\pagestyle&lbrace;empty&rbrace;
\\small
\\begin&lbrace;theindex&rbrace;
\\thispagestyle&lbrace;empty&rbrace;&quot;

postamble
&quot;\n
\\end&lbrace;theindex&rbrace;&quot;
</pre></example>

<para>La présente description ne couvre que certaines des possibilités du
<var>fichier-style</var>. Pour une liste complète voir la documentation sur
le CTAN.
</para>
<para>Un fichier de style consiste en une liste de couples :
<var>spécificateur</var> et <var>attribut</var>. Ils peuvent apparaître dans le
fichier dans un ordre quelconque. Tous les <var>attribut</var>s sont des
chaînes, sauf mention du contraire. Les chaînes sont entourées de
guillemets anglais doubles, <code>&quot;</code>, et la longueur maximale d&textrsquo;une
chaîne est de 144 caractères.  Le <code>\n</code> représente un saut de ligne
et le <code>\t</code> une tabulation. Les controbliques sont échappées avec
une autre controblique, comme cela : <code>\\</code>.  Si une ligne commence
avec un signe pourcent, <code>%</code>, alors c&textrsquo;est un commentaire.
</para>
<ftable commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><anchor name="makeindex-preamble">makeindex preamble</anchor>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1413">preamble</indexterm>preamble</itemformat></item>
</tableterm><tableitem><para>Préambule du fichier d&textrsquo;index de sortie. Définit le contexte dans lequel
l&textrsquo;index est formaté. Vaut par défaut : <code>&quot;\\begin&lbrace;theindex&rbrace;\n&quot;</code>.
</para>
<anchor name="makeindex-postamble">makeindex postamble</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1414">postamble</indexterm>postamble</itemformat></item>
</tableterm><tableitem><para>Postambule du fichier d&textrsquo;index de sortie. Vaut par défaut :
<code>&quot;\n\n\\end&lbrace;theindex&rbrace;\n&quot;</code>.
</para>
<anchor name="makeindex-group-skip">makeindex group skip</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1415">group_skip</indexterm>group_skip</itemformat></item>
</tableterm><tableitem><findex index="fn" spaces=" "><indexterm index="fn" number="1416">\indexspace</indexterm></findex>
<para>Traditionnellement les articles d&textrsquo;index sont répartis en groupes,
typiquement un groupe pour les articles commençant pas la lettre
<samp>a</samp>, etc.  Ce spécificateur donne ce qui est inséré quand un
nouveau groupe commence.  Vaut par défaut : <code>&quot;\n\n \\indexspace\n&quot;</code>
(<code>\indexspace</code> est une commande qui insère une longueur élastique,
par défaut <code>10pt plus5pt minus3pt</code>).
</para>
<anchor name="makeindex-letheadflag">makeindex letheadflag</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1417">lethead_flag</indexterm>lethead_flag</itemformat></item>
</tableterm><tableitem><para>Un entier. Il commande ce qui est inséré pour un nouveau groupe ou une
nouvelle lettre. Lorsqu&textrsquo;il vaut 0 (ce qui est le réglage par défaut)
alors rien d&textrsquo;autre que <code>group_skip</code> n&textrsquo;est inséré avant le
groupe. S&textrsquo;il est positif, alors pour une nouvelle lettre les attributs
<code>lethead_prefix</code> et <code>lethead_suffix</code> sont insérés, avec cette
lettre en capitale entre eux. S&textrsquo;il est négatif, alors ce qui est inséré
est la lettre en bas de casse. Vaut par défaut 0.
</para>
<anchor name="makeindex-lethead-prefix">makeindex lethead prefix</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1418">lethead_prefix</indexterm>lethead_prefix</itemformat></item>
</tableterm><tableitem><para>Si un nouveau groupe commence avec une lettre différente alors c&textrsquo;est le
préfixe inséré devant l&textrsquo;en-tête présentant la nouvelle lettre. Vaut par
défaut : <code>&quot;&quot;</code>
</para>
<anchor name="makeindex-lethead-suffix">makeindex lethead suffix</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1419">lethead_suffix</indexterm>lethead_suffix</itemformat></item>
</tableterm><tableitem><para>Si un nouveau groupe commence avec une lettre différente alors c&textrsquo;est le
suffixe inséré après l&textrsquo;en-tête présentant la nouvelle lettre. Vaut par
défaut : <code>&quot;&quot;</code>
</para>
<anchor name="makeindex-item-0">makeindex item 0</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1420">item_0</indexterm>item_0 </itemformat></item>
</tableterm><tableitem><para>C&textrsquo;est ce qui est mis entre deux articles de niveau 0. Vaut par défaut :
<code>&quot;\n \\item &quot;</code>.
</para>
<anchor name="makeindex-item-1">makeindex item 1</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1421">item_1</indexterm>item_1</itemformat></item>
</tableterm><tableitem><para>Mis entre deux articles de niveau 1. Vaut par défaut : <code>&quot;\n
\\subitem &quot;</code>.
</para>
<anchor name="makeindex-item-2">makeindex item 2</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1422">item_2</indexterm>item_2</itemformat></item>
</tableterm><tableitem><para>Mis entre deux articles de niveau 2. Vaut par défaut : <code>&quot;\n
\\subsubitem &quot;</code>.
</para>
<anchor name="makeindex-item-01">makeindex item 01</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1423">item_01</indexterm>item_01</itemformat></item>
</tableterm><tableitem><para>C&textrsquo;est ce qui est mis entre un article de niveau 0 et un article de
niveau 1. Vaut par défaut : <code>&quot;\n \\subitem &quot;</code>.
</para>
<anchor name="makeindex-item-x1">makeindex item x1</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1424">item_x1</indexterm>item_x1</itemformat></item>
</tableterm><tableitem><para>C&textrsquo;est ce qui est mis entre un article de niveau 0 et un article de
niveau 1 dans le cas où l&textrsquo;article de niveau 0 n&textrsquo;a pas de numéro de page
(comme dans <code>\index&lbrace;aaa|see&lbrace;bbb&rbrace;&rbrace;</code>). Vaut par défaut :
<code>&quot;\n \\subitem &quot;</code>.
</para>
<anchor name="makeindex-item-12">makeindex item 12</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1425">item_12</indexterm>item_12</itemformat></item>
</tableterm><tableitem><para>C&textrsquo;est ce qui est mis entre un article de niveau 1 et un article de
niveau 2.  Vaut par défaut : <code>&quot;\n \\subsubitem &quot;</code>.
</para>
<anchor name="makeindex-item-x2">makeindex item x2</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1426">item_x2</indexterm>item_x2</itemformat></item>
</tableterm><tableitem><para>C&textrsquo;est ce qui est mis entre un article de niveau 1 et un article de
niveau 2 si l&textrsquo;article de niveau 1 n&textrsquo;a pas de numéro de page. Vaut par
défaut : <code>&quot;\n \\subsubitem &quot;</code>.
</para>
<anchor name="makeindex-delim-0">makeindex delim 0</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1427">delim_0</indexterm>delim_0</itemformat></item>
</tableterm><tableitem><para>Délimiteur mis entre une clef de niveau 0 et son premier numéro de
page. Vaut par défaut : une virgule suivie d&textrsquo;un blanc, <code>&quot;, &quot;</code>.
</para>
<anchor name="makeindex-delim-1">makeindex delim 1</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1428">delim_1</indexterm>delim_1</itemformat></item>
</tableterm><tableitem><para>Délimiteur mis entre une clef de niveau 1 et son premier numéro de
page.  Vaut par défaut : une virgule suivie d&textrsquo;un blanc, <code>&quot;, &quot;</code>.
</para>
<anchor name="makeindex-delim-2">makeindex delim 2</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1429">delim_2</indexterm>delim_2</itemformat></item>
</tableterm><tableitem><para>Délimiteur mis entre une clef de niveau 2 et son premier numéro de
page.  Vaut par défaut : une virgule suivie d&textrsquo;un blanc, <code>&quot;, &quot;</code>.
</para>
<anchor name="makeindex-delim-n">makeindex delim n</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1430">delim_n</indexterm>delim_n</itemformat></item>
</tableterm><tableitem><para>Délimiteur mis entre deux numéros de page de la même clef (quel que soit
le niveau) .  Vaut par défaut : une virgule suivie d&textrsquo;un blanc, <code>&quot;,
&quot;</code>.
</para>
<anchor name="makeindex-delim-r">makeindex delim r</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1431">delim_r</indexterm>delim_r</itemformat></item>
</tableterm><tableitem><para>Délimiteur mis entre le numéro de début et le numéro de fin d&textrsquo;une plage
de numéros de page deux numéros de page. Vaut par défaut : <code>&quot;--&quot;</code>.
</para>
<anchor name="makeindex-line-max">makeindex line max</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1432">line_max</indexterm>line_max</itemformat></item>
</tableterm><tableitem><para>Un entier. Longueur maximale d&textrsquo;une ligne d&textrsquo;article d&textrsquo;index dans la
sortie au delà de quoi la ligne est repliée. Vaut par défaut :
<code>72</code>.
</para>
<anchor name="makeindex-indent-space">makeindex indent space</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1433">indent_space</indexterm>indent_space</itemformat></item>
</tableterm><tableitem><para>Ce qui est inséré au début d&textrsquo;une ligne repliée. Vaut par défaut :
<code>&quot;\t\t&quot;</code>.
</para>
<anchor name="makeindex-indent-length">makeindex indent length</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1434">indent_length</indexterm>indent_length</itemformat></item>
</tableterm><tableitem><para>Un nombre. La longueur d&textrsquo;un renfoncement de ligne repliée. La valeur par
défaut d&textrsquo;<code>indent_space</code> est de deux tabulations, et chaque
tabulation compte pour huit espaces de sorte que la valeur par défaut
est <code>16</code>.
</para>
<anchor name="makeindex-page-precedence">makeindex page precedence</anchor>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code"><indexterm index="fn" number="1435">page_precedence</indexterm>page_precedence</itemformat></item>
</tableterm><tableitem><para>Un document peut avoir différents types de numérotations des pages. Par
exemple, un livre peut avoir des matières préliminaires dont les pages
sont numérotées en chiffres romains bas de casse alors que les pages de
la matière principale sont en chiffres arabes. Cette chaîne spécifie
l&textrsquo;ordre dans lequel ils apparaissent dans l&textrsquo;index. La commande
<command>makeindex</command> prend en charge cinq types différents de
numérotation : romain bas de casse <code>r</code>, numérique ou arabe
<code>n</code>, alphabétique bas de casse <code>a</code>, romain capital <code>R</code>,
et alphabétique capital <code>A</code>.  Vaut par défaut : <code>&quot;rnaRA&quot;</code>.
</para>
</tableitem></tableentry></ftable>

<cindex index="cp" spaces=" "><indexterm index="cp" number="944">xindy, <r>programme</r></indexterm></cindex>
<para>Il y a plusieurs autres programmes faisant le même travail que
<command>makeindex</command>. L&textrsquo;un d&textrsquo;eux est <command>xindy</command>
(<uref><urefurl>https://ctan.org/pkg/xindy</urefurl></uref>), qui fait de l&textrsquo;internationalisation
et peut traiter des documents balisés en utilisant &latex; et plusieurs
autres langages. Il est écrit en Lisp, hautement configurable, à la fois
en termes de balise et en termes d&textrsquo;ordre d&textrsquo;assemblage du texte, comme
décrit dans sa documentation.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1436">xindex, <r>programme</r></indexterm></findex>
<para>Un programme d&textrsquo;indexation plus récent prenant en charge l&textrsquo;Unicode est
<code>xindex</code>, écrit en Lua (<url><urefurl>https://ctan.org/pkg/xindex</urefurl></url>).
</para>
</subsection>
<node name="_005cprintindex" spaces=" "><nodename>\printindex</nodename><nodeprev automatic="on">makeindex</nodeprev><nodeup automatic="on">Indexes</nodeup></node>
<subsection spaces=" "><sectiontitle><command>\printindex</command></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="945">index, impression</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1437">\printindex</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\printindex
</pre></example>

<para>Place l&textrsquo;index dans la sortie.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1438"><r>paquetage</r> <code>makeidx</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1439"><code>makeidx</code>, <r>paquetage</r></indexterm></findex>

<para>Pour obtenir un index vous devez en premier inclure
<code>\usepackage&lbrace;makeidx&rbrace;</code> dans le préambule du document et compiler
le document, et ensuite exécuter la commande système
<command>makeindex</command>, puis de nouveau compiler le
document. <xref label="Indexes"><xrefnodename>Indexes</xrefnodename></xref>, pour plus de détails et un exemple d&textrsquo;usage de
<code>\printindex</code>.
</para>
</subsection>
</section>
</chapter>
<node name="Letters" spaces=" "><nodename>Letters</nodename><nodenext automatic="on">Terminal input/output</nodenext><nodeprev automatic="on">Front/back matter</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Des lettres</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="946">lettres, écrire des</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="947">écrire des lettres</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;letter&rbrace;
\address&lbrace;<var>adresse expéditeur</var>&rbrace;
\signature&lbrace;<var>nom de l'expéditeur</var>&rbrace;
\begin&lbrace;document&rbrace;
\begin&lbrace;letter&rbrace;&lbrace;<var>adresse destinataire</var>&rbrace;
\opening&lbrace;<var>apostrophe</var>&rbrace;
  <var>corps-de-la-lettre</var>
\closing&lbrace;<var>texte de salutation</var>&rbrace;
\end&lbrace;letter&rbrace;
  ...  encore des lettres ...
\end&lbrace;document&rbrace;
</pre></example>

<para>Produit une ou plusieurs lettres.
</para>
<para>Chaque lettre est dans un environnement séparé <code>letter</code>, dont
l&textrsquo;argument <var>adresse desinataire</var> contient souvent plusieurs lignes
séparées par une double controblique (<code>\\</code>).  Par exemple, vous
pourriez avoir :
</para>
<example endspaces=" ">
<pre xml:space="preserve"> \begin&lbrace;letter&rbrace;&lbrace;Ninon de l'Enclos \\
      l'hôtel Sagonne&rbrace;
   ...
 \end&lbrace;letter&rbrace;
</pre></example>

<para>Le début de l&textrsquo;environnement <code>letter</code> réinitialise le numéro de page
à 1, et le numéro de note en bas de page à 1 aussi.
</para>
<para>Les <var>adresse expéditeur</var> et <var>nom de l&textrsquo;expéditeur</var> sont
communs à toutes les lettres, qu&textrsquo;il y en ait une ou plus, ainsi il est
préférable de mettre ces déclarations dans le préambule. Comme avec
l&textrsquo;adresse du destinataire, souvent <var>adresse expéditeur</var> contient plusieurs
lignes séparées par une double controblique <code>\\</code>. &latex; place
le <var>nom de l&textrsquo;expéditeur</var> sous la salutation, après un espace
vertical pour la signature manuscrite traditionnelle ; il peut aussi
contenir plusieurs lignes.
</para>
<para>Le corps de chaque environnement <code>letter</code> commence par une commande
<code>\opening</code> obligatoire telle que <code>\opening&lbrace;Madame,
Monsieur,&rbrace;</code>. Le texte <var>corps-de-la-lettre</var> est du code &latex;
ordinaire et peut donc tout contenir de la liste énumérée à des formules
mathématique en hors texte, à ceci près que la commandes de rubricage
telles que <code>\chapter</code> qui n&textrsquo;ont pas lieu d&textrsquo;être au sein d&textrsquo;une
lettre sont indisponibles. Chaque environnement <code>letter</code> se termine
typiquement par une commande <code>\closing</code> telle que dans
<code>\closing&lbrace;Je vous prie, Madame, Monsieur, d'agréer l'expression de
mes sentiments les meilleurs.&rbrace;</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1440">\\ <r>(pour les lettres)</r></indexterm></findex>
<para>de la matière supplémentaire peut venir après le <code>\closing</code>. Vous
pouvez préciser qui est en copie de la lettre avec une commande comme
<code>\cc&lbrace;Le Patron\\Le Patron du Patron&rbrace;</code>. Il y a une commande
<code>\encl</code>  similaire pour spécifier une liste de pièces jointes. Et,
vous pouvez ajouter un postscriptum avec <code>\ps</code>.
</para>
<para>Par défaut &latex; renfonce la signature et la salutation
<code>\closing</code> la précédant d&textrsquo;une longueur valant
<code>\longindentation</code>. Celle-ci vaut par défaut
<code>0.5\textwidth</code>. Pour les aligner à gauche, il suffit de spécifier
<code>\setlength&lbrace;\longindentation&rbrace;&lbrace;0em&rbrace;</code> dans votre préambule.
</para>
<para>Pour fixer la date utilisez quelque chose comme
<code>\renewcommand&lbrace;\today&rbrace;&lbrace;2015-10-12&rbrace;</code>. En plaçant ce code dans
votre préambule, il s&textrsquo;appliquera à toutes les lettres du document.
</para>
<para>Cet exemple est avec un seul environnement <code>letter</code>.  Les trois
lignes marquées en commentaire comme optionnelles sont typiquement
omises.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;letter&rbrace;
\usepackage[T1]&lbrace;fontenc&rbrace;
\usepackage&lbrace;french&rbrace;
\address&lbrace;Rue de l'expéditeur \\ Ville de l'expéditeur&rbrace;
\signature&lbrace;Nom de l'expéditeur\\ Titre de l'expéditeur&rbrace;
% optionnel : \location&lbrace;Boîte Postale 13&rbrace;
% optionnel : \telephone&lbrace;(102) 555-0101&rbrace;
\begin&lbrace;document&rbrace;
\begin&lbrace;letter&rbrace;&lbrace;Nom du destinataire \\ Adresse du destinataire&rbrace;
\opening&lbrace;Monsieur,&rbrace;
% optionnel : \thispagestyle&lbrace;firstpage&rbrace;
I ne suis pas intéressé à faire affaire avec vous.
\closing&lbrace;Je vous prie, Monsieur, de recevoir mes salutations distinguées.&rbrace;
\end&lbrace;letter&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<para>Ces commandes sont utilisées avec la classe <code>letter</code>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::            ">\address</menunode><menudescription><pre xml:space="preserve">Adresse de l&textrsquo;expéditeur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                 ">\cc</menunode><menudescription><pre xml:space="preserve">Liste des personnes en copie.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">\closing</menunode><menudescription><pre xml:space="preserve">Dire au revoir.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::               ">\encl</menunode><menudescription><pre xml:space="preserve">Liste des pièces jointes.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::           ">\location</menunode><menudescription><pre xml:space="preserve">L&textrsquo;adresse de votre organisation.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::         ">\makelabels</menunode><menudescription><pre xml:space="preserve">Fabriquer des étiquettes d&textrsquo;adresse.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::               ">\name</menunode><menudescription><pre xml:space="preserve">Votre nom, pour l&textrsquo;adresse de l&textrsquo;expéditeur.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">\opening</menunode><menudescription><pre xml:space="preserve">Dire bonjour.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::                 ">\ps</menunode><menudescription><pre xml:space="preserve">Ajouter un postscriptum.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::          ">\signature</menunode><menudescription><pre xml:space="preserve">Votre signature.
<!-- c * \startbreaks::        Autorisez les sauts de page. -->
<!-- c * \stopbreaks::         Interdire les sauts de page. -->
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::          ">\telephone</menunode><menudescription><pre xml:space="preserve">Votre numéro de téléphone.
</pre></menudescription></menuentry></menu>


<node name="_005caddress" spaces=" "><nodename>\address</nodename><nodenext automatic="on">\cc</nodenext><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\address</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1441">\address</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\address&lbrace;<var>adresse-expéditeurs</var>&rbrace;
</pre></example>

<para>Spécifie l&textrsquo;adresse de retour telle qu&textrsquo;elle apparaît sur la lettre et sur
l&textrsquo;enveloppe. Séparez des lignes multiples au sein de
<var>adresse-expéditeurs</var> avec une double controblique <code>\\</code>.
</para>
<para>Parce qu&textrsquo;elle peut s&textrsquo;appliquer à des lettres multiples cette déclaration
est souvent placée dans le préambule. Toutefois elle peut être faite
n&textrsquo;importe où, y compris au sein d&textrsquo;un environnement <code>letter</code>
individuel.
</para>
<para>Cette commande est optionnelle : sans la déclaration <code>\address</code> la
lettre est formatée avec un espace à blanc en haut de sorte à pouvoir
être imprimée sur du papier à en-tête pré-imprimé. (<xref label="Overview"><xrefnodename>Overview</xrefnodename></xref>,
pour les détails concernant votre implémentation locale). Avec la
déclaration <code>\address</code>, elle est formatée comme une lettre
personnelle.
</para>
<para>En voici un exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\address&lbrace;Stephen Maturin \\
         The Grapes of the Savoy&rbrace;
</pre></example>

</section>
<node name="_005ccc" spaces=" "><nodename>\cc</nodename><nodenext automatic="on">\closing</nodenext><nodeprev automatic="on">\address</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\cc</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1442">\cc</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="948">copie, liste des personnes en, dans une lettre</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="949">liste des personnes en copie, dans une lettre</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\cc&lbrace;<var>premier nom</var>\\...&rbrace;
</pre></example>

<para>Produit une liste de noms de personnes mis en copie de la lettre. Cette
commande est optionnelle. Si elle est présente, alors elle vient
typiquement après le <code>\closing</code>. En cas de ligne multiple, séparez
les avec une double controblique <code>\\</code>, comme dans :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\cc&lbrace;Président \\
    Vice-président&rbrace;
</pre></example>


</section>
<node name="_005cclosing" spaces=" "><nodename>\closing</nodename><nodenext automatic="on">\encl</nodenext><nodeprev automatic="on">\cc</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\closing</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1443">\closing</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="950">lettres, salutation</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="951">fin d&textrsquo;une lettre</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\closing&lbrace;<var>texte</var>&rbrace;
</pre></example>

<!-- c XXXX TODO en français la signature est au dessus du nom, pas en -->
<!-- c dessous! -->

<para>D&textrsquo;ordinaire à la fin d&textrsquo;une lettre, au dessus de la signature manuscrite,
il y a un <code>\closing</code> (bien que cette commande soit
optionnelle). Par exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\closing&lbrace;Je vous prie, Madame, Monsieur, d'agréer l'expression de ma
   confiance.&rbrace;
</pre></example>


</section>
<node name="_005cencl" spaces=" "><nodename>\encl</nodename><nodenext automatic="on">\location</nodenext><nodeprev automatic="on">\closing</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\encl</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1444">\encl</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="952">pièces jointes, liste</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\encl&lbrace;<var>ligne1</var>\\<var>ligne2</var>&rbrace;
</pre></example>

<para>Déclare une liste d&textrsquo;une ou plus de pièces jointes.
</para>

</section>
<node name="_005clocation" spaces=" "><nodename>\location</nodename><nodenext automatic="on">\makelabels</nodenext><nodeprev automatic="on">\encl</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\location</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1445">\location</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\location&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Le <var>texte</var> apparaît centré au bas de chaque page. Il apparaît
seulement si le style de la page est <code>firstpage</code>.
</para>

</section>
<node name="_005cmakelabels" spaces=" "><nodename>\makelabels</nodename><nodenext automatic="on">\name</nodenext><nodeprev automatic="on">\location</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\makelabels</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1446">\makelabels</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\makelabels
</pre></example>

<para>Crée une feuille d&textrsquo;étiquettes d&textrsquo;adresses à partir des adresses des
destinataires, une pour chaque lettre. Cette feuille sera sortie avant
les lettres, avec dans l&textrsquo;idée de la copier sur une feuille vierge de
vignettes autocollantes. Cette commande est à mettre dans le préambule.
</para>
<para>Vous pouvez personnaliser les étiquettes en redéfinissant les trois
commandes <code>\startlabels</code>, <code>\mlabel</code> et <code>\returnaddress</code>
dans le préambule.  Ces commandes ne sont pas à appeler directement par
l&textrsquo;utilisateur, c&textrsquo;est la classe <code>letter</code> qui les appelle.  La
commande <code>\startlabels</code> compose la page sur laquelle les étiquettes
sont imprimées en termes de largeur, de hauteur, et de nombre de
colonnes, etc.  La commande <code>\mlabel&lbrace;<var>adresse
expéditeur</var>&rbrace;&lbrace;<var>adresse destinataire</var>&rbrace;</code> est appelée pour chaque
lettre du document avec deux arguments :
</para>
<itemize commandarg="bullet" endspaces=" "><itemprepend>&bullet;</itemprepend>
<listitem><prepend>&bullet;</prepend>
<para>Le premier, <var>adresse expéditeur</var>, est le contenu courant de la macro
<code>\returnaddress</code>
</para></listitem><listitem><prepend>&bullet;</prepend>
<para>Le second, <var>adresse destinataire</var>, est l&textrsquo;adresse du destinataire
telle que passée en argument à l&textrsquo;environnement <code>letter</code>.
</para></listitem></itemize>

<para>La définition par défaut de <code>\mlabel</code> ignore le premier argument,
c&textrsquo;est à dire que si vous placez seulement un <code>\makelabels</code> dans le
préambule, la feuille d&textrsquo;étiquettes ne contiendra des étiquettes que pour
les destinataires.
</para>
<para>Si vous désirez imprimer une étiquette d&textrsquo;adresse expéditeur et d&textrsquo;adresse
destinataire pour chaque lettre, vous devez faire deux choses :
</para><enumerate first="1" endspaces=" ">
<listitem>
<para>La première est de redéfinir <code>\mlabel</code> pour fabriquer deux
étiquettes au lieu d&textrsquo;une, vous pouvez pour cela mettre ce qui suit dans le préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand*\originalMlabel&lbrace;&rbrace;
\let\originalMlabel\mlabel
\def\mlabel#1#2&lbrace;\originalMlabel&lbrace;&rbrace;&lbrace;#1&rbrace;\originalMlabel&lbrace;&rbrace;&lbrace;#2&rbrace;&rbrace;
</pre></example>

<para>Ceci ne suffit toutefois pas, parce que la première des deux étiquettes
est vide, vu que la définition par défaut de <code>\returnaddress</code> l&textrsquo;est.
</para></listitem><listitem>
<para>La seconde est de redéfinir <code>\returnaddress</code> pour contenir
l&textrsquo;adresse de l&textrsquo;expéditeur, vous pouvez faire cela en plaçant dans le
préambule :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\renewcommand*\returnaddress&lbrace;\protect\fromname\\\protect\fromaddress&rbrace;
</pre></example>

</listitem></enumerate>

</section>
<node name="_005cname" spaces=" "><nodename>\name</nodename><nodenext automatic="on">\opening</nodenext><nodeprev automatic="on">\makelabels</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\name</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1447">\name</indexterm></findex>

<para><code>\name&lbrace;June Davenport&rbrace;</code>
</para>
<para>Le nom de l&textrsquo;expéditeur, à imprimer sur l&textrsquo;enveloppe avec l&textrsquo;adresse de
retour.
</para>

</section>
<node name="_005copening" spaces=" "><nodename>\opening</nodename><nodenext automatic="on">\ps</nodenext><nodeprev automatic="on">\name</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\opening&lbrace;<var>texte</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1448">\opening</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="953">lettres, commencer</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\opening&lbrace;<var>texte</var>&rbrace;
</pre></example>

<para>Cette commande est obligatoire. Elle commence la lettre, en suivant le
<code>\begin&lbrace;letter&rbrace;&lbrace;...&rbrace;</code>. L&textrsquo;argument obligatoire <var>texte</var> est le
<cindex index="cp" spaces=" "><indexterm index="cp" number="954">appel</indexterm></cindex>
texte d&textrsquo;<dfn>appel</dfn> de votre lettre. Par exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\opening&lbrace;Dear John,&rbrace;
</pre></example>


</section>
<node name="_005cps" spaces=" "><nodename>\ps</nodename><nodenext automatic="on">\signature</nodenext><nodeprev automatic="on">\opening</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\ps</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1449">\ps</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="955">postscriptum, dans une lettre</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ps&lbrace;<var>texte</var>&rbrace;
</pre></example>


<para>Utilisez la commande <code>\ps</code> pour commencer un postscriptum dans une lettre, après
<code>\closing</code>.
</para>

</section>
<node name="_005csignature" spaces=" "><nodename>\signature</nodename><nodenext automatic="on">\telephone</nodenext><nodeprev automatic="on">\ps</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\signature&lbrace;<var>texte</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1450">\signature</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\signature&lbrace;<var>première ligne</var> \\
            ... &rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1451">\signature</indexterm></findex>

<para>Le nom de l&textrsquo;expéditeur. Cette commande est optionnelle, quoique son
inclusion soit habituelle.
</para>
<para>Le texte de l&textrsquo;argument apparaît à la fin de la lettre, après la clôture
et après une espace verticale pour la signature manuscrite
traditionnelle. Séparez des lignes multiples avec une double
controblique <code>\\</code>.  Par exemple :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\signature&lbrace;J Fred Muggs \\
           White House&rbrace;
</pre></example>

<para>La valeur par défaut de &latex; pour l&textrsquo;espace verticale space du texte
de <code>\closing</code> au texte de <code>\signature</code> est
<code>6\medskipamount</code>, ce qui vaut six fois 0,7<dmn>em</dmn>.
</para>
<para>Cette commande est d&textrsquo;ordinaire dans le préambule, de sorte à s&textrsquo;appliquer
à toutes les lettres du document.  Pour qu&textrsquo;elle ne s&textrsquo;applique qu&textrsquo;à une
seule lettre, placez la au sein d&textrsquo;un environnement <code>letter</code> et
avant le <code>\closing</code>.
</para>
<para>Vous pouvez inclure un graphique dans la signature, par exemple avec
<code>\signature&lbrace;\vspace&lbrace;-6\medskipamount&rbrace;\includegraphics&lbrace;sig.png&rbrace;\\
My name&rbrace;</code> (ceci nécessite d&textrsquo;écrire <code>\usepackage&lbrace;graphicx&rbrace;</code> dans
le préambule).
</para>
<!-- c Jim a écrit: I think this is not a user-level command; it is used to keep from breaking -->
<!-- c the page between the closing and the signature -->
<!-- c @node \startbreaks -->
<!-- c @section @code{\startbreaks} -->
<!-- c @findex \startbreaks -->
<!-- c -->
<!-- c @code{\startbreaks} -->
<!-- c -->
<!-- c Used after une commande @code{\stopbreaks} to allow page breaks again. -->
<!-- c -->
<!-- c -->
<!-- c -->
<!-- c @node \stopbreaks -->
<!-- c @section @code{\stopbreaks} -->
<!-- c @findex \stopbreaks -->
<!-- c -->
<!-- c @code{\stopbreaks} -->
<!-- c -->
<!-- c Inhibit page breaks until une commande @code{\startbreaks} occurs. -->
<!-- c -->


</section>
<node name="_005ctelephone" spaces=" "><nodename>\telephone</nodename><nodeprev automatic="on">\signature</nodeprev><nodeup automatic="on">Letters</nodeup></node>
<section spaces=" "><sectiontitle><code>\telephone</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1452">\telephone</indexterm></findex>

<para>Synopsis :
</para>
<para><code>\telephone&lbrace;<var>numéro</var>&rbrace;</code>
</para>
<para>C&textrsquo;est le numéro de téléphone de l&textrsquo;expéditeur. Déclaré typiquement dans
le préambule, où il s&textrsquo;applique à toutes les lettres. Ceci apparaît
seulement si le style de
<!-- c vincentb1: vérifier ce que pagestyle veut dire. -->
page (<code>pagestyle</code>) <code>firstpage</code> est sélectionné. Dans ce cas,
il apparaît en bas à droite de la page.
</para>

</section>
</chapter>
<node name="Terminal-input_002foutput" spaces=" "><nodename>Terminal input/output</nodename><nodenext automatic="on">Command line interface</nodenext><nodeprev automatic="on">Letters</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Entrée/sortie console</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="956">entrée/sortie console</indexterm></cindex>

<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::  ">\openin &amp; \openout</menunode><menudescription><pre xml:space="preserve">Ouvrir un fichier.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::               ">\read</menunode><menudescription><pre xml:space="preserve">Lire du texte à partir d&textrsquo;un fichier.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">\typein</menunode><menudescription><pre xml:space="preserve">Lire du texte à partir de la console.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::            ">\typeout</menunode><menudescription><pre xml:space="preserve">Écrire du texte vers la console.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::              ">\write</menunode><menudescription><pre xml:space="preserve">Écrire du texte dans un fichier ou le terminal.
</pre></menudescription></menuentry></menu>

<node name="_005copenin-_0026-_005copenout" spaces=" "><nodename>\openin &amp; \openout</nodename><nodenext automatic="on">\read</nodenext><nodeup automatic="on">Terminal input/output</nodeup></node>
<section spaces=" "><sectiontitle><code>\openin</code> &amp; <code>\openout</code></sectiontitle>

<anchor name="_005copenin">\openin</anchor>
<anchor name="_005copenout">\openout</anchor>
<anchor name="_005cclosein">\closein</anchor>
<anchor name="_005ccloseout">\closeout</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1453">\openin</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1454">\openout</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1455">\closein</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1456">\closeout</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="957">fichier, ouverture</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="958">fichier, fermeture</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="959">ouvrir un fichier</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\openin <var>numéro</var>=<var>nomfichier</var>
</pre></example>

<para>ou :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\openout <var>numéro</var>=<var>nomfichier</var>
</pre></example>

<para>Ouvre un fichier pour y lire, ou pour y écrire.  Pour la plupart des
moteurs, le <var>numéro</var> doit être entre 0 et 15, comme dans
<code>\openin3</code>, dans Lua&latex; <var>numéro</var> peut être entre 0 et
127.
</para>
<para>Ici &tex; ouvre le fichier le fichier <file>presidents.tex</file> en lecture.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newread\fichierpresidents
\openin\fichierpresidents=presidents
\typeout&lbrace;fichierpresidents vaut \the\fichierpresidents&rbrace;
\read\fichierpresidents to\presidentligne
\typeout&lbrace;\presidentligne&rbrace;
</pre></example>

<noindent></noindent>
<para>La commande <code>\newread</code> alloue des numéros de flux d&textrsquo;entrée de 0
à 15 (il y a aussi une commande <code>\newwrite</code>).  La variable
<code>\fichierpresidents</code> est plus facile à mémoriser mais sous le capot
ce n&textrsquo;est rien de plus qu&textrsquo;un numéro ; le premier <code>\typeout</code> donne
quelque chose du genre de <samp>fichierpresidents vaut 1</samp>.  De plus,
<code>\newread</code> garde la trace de l&textrsquo;allocation de sorte que si vous en
utilisez trop alors vous obtiendrez une erreur du genre de <samp>! No
room for a new \read</samp>.  Le second <code>\typeout</code> produit la première
ligne du fichier, quelque chose du genre de <samp>1 Bonaparte,
Louis-Napoléon</samp>.
</para>
<para>D&textrsquo;ordinaire &tex; n&textrsquo;essaie pas d&textrsquo;ouvrir le fichier jusqu&textrsquo;à la prochaine
éjection de page. Pour changer cela, utilisez
<code>\immediate\openin <var>numéro</var>=<var>nomfichier</var></code> ou
<code>\immediate\openout <var>numéro</var>=<var>nomfichier</var></code>.
</para>
<para>Fermez les fichiers avec <code>\closein <var>numéro</var></code> et
<code>\closeout <var>numéro</var></code>.
</para>
<para>La façon dont &latex; manipule les noms de fichiers varie selon les
distributions, et peut même varier d&textrsquo;une version à l&textrsquo;autre d&textrsquo;une même
distribution.  Si le nom de fichier n&textrsquo;a pas d&textrsquo;extension alors &tex; y
ajoute un <file>.tex</file>. L&textrsquo;exemple suivant crée <file>presidents.tex</file>, y
écrit une ligne, et le ferme.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newwrite\fichierpresidents
\openout\fichierpresidents=presidents
\write\fichierpresidents&lbrace;1 Bonaparte, Louis-Napoléon&rbrace;
\closeout\fichierpresidents
</pre></example>

<noindent></noindent>
<para>Mais les noms de fichier avec un point peuvent causer des problèmes : si
&tex; tombe sur un <var>nomfichier</var> comme <file>presidents.dat</file> il se
peut qu&textrsquo;il cherche d&textrsquo;abord <file>presidents.dat.tex</file> et ensuite
<file>presidents.dat</file>, ou bien le contraire.  La documentation de votre
distribution devrait en dire plus, et si cela fonctionne pour vous tant
mieux, mais pour assurer une portabilité complète le mieux et d&textrsquo;utiliser
des noms de fichier ne contenant que les vingt-six lettres ASCII
(insensible à la casse) et les dix chiffres, ainsi que
les tirets de 8 <samp>_</samp> et de 6 <samp>-</samp>, et en particulier sans point
ni espace.
</para>
<para>Pour <code>\openin</code>, si &tex; ne peut pas trouver le fichier alors il
ne produit pas une erreur.  Il ne fait que considérer que ce flux n&textrsquo;est
pas ouvert (ce qu&textrsquo;on peut vérifier avec <code>\ifeof</code> ; on peut
également recourir à la commande <code>\InputIfFileExists</code>, <pxref label="Class-and-package-commands"><xrefnodename>Class
and package commands</xrefnodename></pxref>).  Si vous essayer d&textrsquo;utiliser le même numéro deux
fois, &latex; ne produit pas d&textrsquo;erreur.  Si vous essayer d&textrsquo;utiliser un
mauvais numéro, alors vous obtiendrez un message d&textrsquo;erreur du genre de
<samp>!  Bad number (16).  &lt;to be read again&gt; = l.30 \openin16=test.jh</samp>.
</para>
</section>
<node name="_005cread" spaces=" "><nodename>\read</nodename><nodenext automatic="on">\typein</nodenext><nodeprev automatic="on">\openin &amp; \openout</nodeprev><nodeup automatic="on">Terminal input/output</nodeup></node>
<section spaces=" "><sectiontitle><code>\read</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1457">\read</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="960">fichier, lecture d&textrsquo;un</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="961">lire un fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="962">lecture d&textrsquo;un fichier</indexterm></cindex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\read <var>numéro</var> to<var>macro</var>
</pre></example>

<para>Fait que la commande <var>macro</var> contienne la ligne suivante d&textrsquo;entrée du
flux de texte <var>numéro</var>, comme dans <code>\read5 to\data</code>.
</para>
<para>L&textrsquo;exemple suivant ouvre le fichier <file>mel.tex</file> en lecture, me le
contenu de la première ligne dans la commande <code>\courriel</code>, et
ensuite ferme le fichier.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newread\fichierreception
\openin\fichierreception=mel
\read\fichierreception to\courriel
\typeout&lbrace;Adresse mél : \courriel&rbrace;
\closein\fichierreception
</pre></example>

<para>Si <var>numéro</var> est hors de l&textrsquo;intervalle de 0 à 15 ou si aucun fichier
avec ce numéro n&textrsquo;est ouvert, ou si le fichier est à sa fin, alors
<code>\read</code> prend son entrée à partir du terminal.  Notez, cependant,
que la méthode naturelle en &latex; de prendre en entrée à partir du
terminal est <code>\typein</code> (<pxref label="_005ctypein"><xrefnodename>\typein</xrefnodename></pxref>).
</para>
<para>Pour lire un fichier entier en une fois utilisez <code>\input</code>
(<pxref label="_005cinput"><xrefnodename>\input</xrefnodename></pxref>) ou <code>\include</code> (<pxref label="_005cinclude-_0026-_005cincludeonly"><xrefnodename>\include &amp; \includeonly</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1458"><r>paquetage</r> <code>datatool</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1459"><code>datatool</code>, <r>paquetage</r></indexterm></findex>


<para>Une raison usuelle de vouloir lire d&textrsquo;un fichier de données est de faire
du publipostage.  CTAN a plusieurs paquetage pour cela ; parmi lesquels
<code>datatool</code>.
</para>
</section>
<node name="_005ctypein" spaces=" "><nodename>\typein</nodename><nodenext automatic="on">\typeout</nodenext><nodeprev automatic="on">\read</nodeprev><nodeup automatic="on">Terminal input/output</nodeup></node>
<section spaces=" "><sectiontitle><code>\typein[<var>cmd</var>]&lbrace;<var>msg</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1460">\typein</indexterm></findex>

<!-- c xxx Realigner sur l'anglais -->
<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\typein[<var>\cmd</var>]&lbrace;<var>msg</var>&rbrace;
</pre></example>

<para><code>\typein</code> tape <var>msg</var> sur la console et fait que &latex;
s&textrsquo;arrête et attend que vous saisissiez une ligne d&textrsquo;entrée, en la
terminant par un retour chariot.  Si l&textrsquo;argument optionnel <var>\cmd</var> est
omis, l&textrsquo;entrée tapée est traitée comme si elle avec été incluse dans le
fichier d&textrsquo;entrée à la place de la commande <code>\typein</code>.  Si
l&textrsquo;argument <var>\cmd</var> est présent, cela doit être un nom de commande.
Ce nom de commande est alors défini, ou redéfini, pour se développer en
le texte en entrée qui a été tapé.
</para>

</section>
<node name="_005ctypeout" spaces=" "><nodename>\typeout</nodename><nodenext automatic="on">\write</nodenext><nodeprev automatic="on">\typein</nodeprev><nodeup automatic="on">Terminal input/output</nodeup></node>
<section spaces=" "><sectiontitle><code>\typeout&lbrace;<var>msg</var>&rbrace;</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1461">\typeout</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\typeout&lbrace;<var>msg</var>&rbrace;
</pre></example>

<para>Tape <code>msg</code> sur le terminal et dans le journal (fichier
<code>log</code>). Les commandes dans <code>msg</code> qui sont définies avec
<code>\newcommand</code> ou <code>\renewcommand</code> (entre autres) sont
remplacées par leurs définitions avant d&textrsquo;être tapées.
</para>
<para>Les règles usuelles de &latex; pour le traitement de plusieurs espaces
comme un seul espace et pour ignorer les espaces après un nom de
commande s&textrsquo;appliquent à <code>msg</code>. Une commande <code>\space</code> dans
<code>msg</code> provoque un unique espace tapé, indépendant des espaces qui
l&textrsquo;entourent. Un <code>^^J</code> dans <code>msg</code> tape un saut à la ligne.
</para>
</section>
<node name="_005cwrite" spaces=" "><nodename>\write</nodename><nodeprev automatic="on">\typeout</nodeprev><nodeup automatic="on">Terminal input/output</nodeup></node>
<section spaces=" "><sectiontitle><code>\write</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1462">\write</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\write <var>numéro</var>&lbrace;<var>chaîne</var>&rbrace;
</pre></example>

<para>Écrit <var>chaîne</var> vers le fichier journal (<file>.log</file>), vers le
terminal, ou vers un fichier ouvert par <code>\openout</code>.  Par exemple,
<code>\write6</code> écrit vers le flux textuel numéro 6
</para>
<para>Si le code suivant apparaît dans le fichier <file><var>fichierbase</var>.tex</file>
alors cela ouvre le fichier <file><var>fichierbase</var>.jh</file>, y écrit
<samp>Bonjour tout le monde !</samp> et un saut le ligne, et ferme ce fichier.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newwrite\monfichier
\immediate\openout\monfichier=\jobname.jh % \jobname est le nom
                                       % de base du fichier racine
...
\immediate\write\monfichier&lbrace;Bonjour tout le monde !&rbrace;
  ...
\immediate\closeout\monfichier
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1463">\newwrite</indexterm></findex>
<noindent></noindent>
<para>Le <code>\newwrite</code> alloue un numéro de flux, en lui donnant un nom
symbolique pour se faciliter la vie, de sorte que <code>flux
\newwrite\monfichier\the\monfichier</code> produit quelque chose du genre de
<samp>flux 3</samp>.  Ensuite <code>\openout</code> associe le numéro de flux avec
le nom de fichier fourni.  Et puis à la fin &tex; exécute
<code>\write3</code> ce qui place la chaîne dans le fichier.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="963">journal, écrire vers le fichier</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="964">terminal, écrire vers le</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="965"><math>-1</math>, écrire dans le flux numéro</indexterm></cindex>
<para>Typiquement <var>numéro</var> est compris entre 0 et 15, parce que typiquement
les auteurs &latex; suivent l&textrsquo;exemple précédent et le numéro est alloué
par le système.  Si <var>numéro</var> est hors de l&textrsquo;intervalle de 0 à 15 ou
si il n&textrsquo;est pas associé à un fichier ouvert alors &latex; écrit
<var>chaîne</var> vers le fichier journal.  Si <var>numéro</var> est positif alors
en plus &latex; écrit <var>chaîne</var> vers le terminal. Ainsi, <code>test
\write-1&lbrace;Bonjour tout le monde !&rbrace;</code> place <samp>Bonjour tout le
monde !</samp> suivi d&textrsquo;un saut de ligne dans le fichier journal (c&textrsquo;est ce que
la commande <code>\wlog</code> fait ; <pxref label="_005cwlog"><xrefnodename>\wlog</xrefnodename></pxref>).  Et
<code>\write100&lbrace;Bonjour tout le monde !&rbrace;</code> met la même chose dans le
fichier journal mais aussi met <samp>Bonjour tout le monde !</samp> suivi d&textrsquo;un
saut de ligne dans la sortie terminal.  (Mais 16, 17, et 18 sont des
valeurs spéciales de <var>numéro</var> ; voir ci-dessous.)
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="966">Lua&tex;, 256 flux de sortie dans</indexterm></cindex>
<para>Dans Lua&tex;, au lieu de 16 flux de sortie il y en a 256
(<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1464">\&arobase;auxout</indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1465">\&arobase;mainaux</indexterm></findex>
<para>Utilisez <code>\write\&arobase;auxout&lbrace;<var>chaîne</var>&rbrace;</code> pour écrire vers le
fichier <file>.aux</file> courant qui est associé soit au fichier racine soit
au fichier inclus courant ; et utilisez
<code>\write\&arobase;mainaux&lbrace;<var>chaîne</var>&rbrace;</code> pour écrire le fichier
<file>.aux</file> principal. Ces noms symboliques sont définis par &latex;.
</para>
<!-- c credit: David Carlisle https://tex.stackexchange.com/a/115933/121234 -->
<para>Par défaut &latex; n&textrsquo;écrit pas <var>chaîne</var> vers le fichier
immédiatement.  C&textrsquo;est ainsi parce que, par exemple, vous pourriez avoir
besoin de <code>\write</code> pour sauvegarder le numéro de page courant, mais
au moment où &tex; rencontre une commande <code>\write</code> typiquement il
ne connaît pas quel est le numéro de page, puisque il n&textrsquo;a pas encore
découpé la sortie en pages.  Ainsi, vous utilisez <code>\write</code> dans
l&textrsquo;un des trois contextes suivants :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\immediate\write\&arobase;auxout&lbrace;<var>chaîne</var>&rbrace;     %1
\write\&arobase;auxout&lbrace;<var>chaîne</var>&rbrace;              %2
\protected&arobase;write\&arobase;auxout&lbrace;&rbrace;&lbrace;<var>chaîne</var>&rbrace;   %3
</pre></example>

<enumerate first="1" endspaces=" ">
<listitem>
<cindex index="cp" spaces=" "><indexterm index="cp" number="967"><code>\write</code> immédiat</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1466">\immediate\write</indexterm></findex>
<para>Avec le premier, &latex; écrit <var>chaîne</var> vers le fichier
immédiatement.  Toutes les macros dans <var>chaîne</var> sont développées à
fond (exactement comme dans <code>\edef</code> de sorte que pour empêcher le
développement vous devez utiliser <code>\noexpand</code>, un <code>toks</code>, etc.
mais avec la différence que vous devez utiliser <code>#</code> au lieu de
<code>##</code>).
</para>
</listitem><listitem>
<cindex index="cp" spaces=" "><indexterm index="cp" number="968"><code>\write</code> retardé</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="969">élément extraordinaire</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1467">\shipout <r>et développement</r></indexterm></findex>
<para>Avec le deuxième, <var>chaîne</var> est stockée dans la liste courante des
choses (comme un élément « extraordinaire » de &tex;) et conservé
jusqu&textrsquo;à ce que la page soit éjectée et de la même manière les macros ne
sont pas développées jusqu&textrsquo;à l&textrsquo;éjection (<code>\shipout</code>). Au moment du
<code>\shipout</code>, <var>chaîne</var> est développée à fond.
</para>
</listitem><listitem>
<findex index="fn" spaces=" "><indexterm index="fn" number="1468">\protected&arobase;write</indexterm></findex>
<para>Le troisième, <code>\protected&arobase;write</code>, est semblable au deuxième sauf
que vous pouvez utiliser <code>\protect</code> pour éviter le
développement. Le premier argument qui est en plus vous permet d&textrsquo;insérer
localement des définitions supplémentaires pour que plus de macros
soient protégées ou pour avoir d&textrsquo;autres définitions spéciales pendant
l&textrsquo;écriture.
</para></listitem></enumerate>


<para>Voici un exemple simple de développement avec <code>\write</code> dans lequel
<var>chaîne</var> contient une séquence de contrôle <code>\triplex</code> que l&textrsquo;on
a définie comme le texte <samp>XYZ</samp> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newwrite\fichierjh
\openout\fichierjh=test.jh
\newcommand&lbrace;\triplex&rbrace;&lbrace;XYZ&rbrace;
\write\fichierjh&lbrace;test \triplex test&rbrace;
</pre></example>

<noindent></noindent>
<para>Ceci résulte en ce que le fichier <file>test.jh</file> contienne le texte
<samp>test XYZtest</samp> suivi d&textrsquo;un saut de ligne.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="970"><code>\write</code>, flux 16, 17, 18</indexterm></cindex>
<para>Les cas où <var>numéro</var> vaut 16, 17, ou 18 sont spéciaux.  À cause du
comportement de <code>\write</code> quand <var>numéro</var> est hors de
l&textrsquo;intervalle de 0 à 15 qu&textrsquo;on a déjà décrit plus haut, dans Plain &tex;
<code>\write16</code> et <code>\write17</code> étaient parfois utilisés pour écrire
dans le fichier journal et le terminal ; toutefois, dans &latex;, la
façon naturelle de faire ceci est d&textrsquo;utiliser <code>\typeout</code>
(<pxref label="_005ctypeout"><xrefnodename>\typeout</xrefnodename></pxref>).  La commande <code>\write18</code> est encore plus
spéciale ; les systèmes &tex; modernes l&textrsquo;utilisent pour passer des
commandes au système d&textrsquo;exploitation (<pxref label="_005cwrite18"><xrefnodename>\write18</xrefnodename></pxref>).
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="971">saut de ligne, dans <code>\write</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="972"><code>^^J</code>, dans <code>\write</code></indexterm></cindex>
<para>D&textrsquo;ordinaire <code>\write</code> produit en sortie une unique ligne. On peut y
insérer un saut de ligne avec <code>^^J</code>.  Ainsi, l&textrsquo;exemple suivant
produit deux lignes dans le fichier journal :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\wlog&lbrace;Les lignes parallèles ont beaucoup en commun.^^JMais elles ne se
rencontrent jamais.&rbrace;
</pre></example>

<findex index="fn" spaces=" "><indexterm index="fn" number="1469"><r>paquetage</r> <code>answers</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1470"><code>answers</code>, <r>paquetage</r></indexterm></findex>

<para>Un cas usuel dans lequel des auteurs tentent d&textrsquo;écrire dans leur propre
fichier est pour les réponses à des exercices, ou dans quelque autre
situation où vous désirez écrire en sortie verbatim, sans développer les
macros.  CTAN a plusieurs paquetages pour cela ; parmi lesquels
<code>answers</code>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">\write et la sécurité</menutitle><menunode separator=". ">\write and security</menunode><menudescription><pre xml:space="preserve">Sécurité.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::          ">\message</menunode><menudescription><pre xml:space="preserve">Écrit du texte vers le fichier journal et le terminal.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::             ">\wlog</menunode><menudescription><pre xml:space="preserve">Écrit du texte vers le fichier journal.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::          ">\write18</menunode><menudescription><pre xml:space="preserve">Exécute une commande du système d&textrsquo;exploitation.
</pre></menudescription></menuentry></menu>

<node name="_005cwrite-and-security" spaces=" "><nodename>\write and security</nodename><nodenext automatic="on">\message</nodenext><nodeup automatic="on">\write</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\write</code> et la sécurité</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="973">sécurité et <code>\write</code></indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="974"><code>\write</code> et sécurité</indexterm></cindex>

<para>La possibilité d&textrsquo;écrire dans des fichiers soulève des problèmes de
sécurité. Si vous compilez un fichier &latex; téléchargé et qu&textrsquo;il
écrase votre fichier de mots de passe alors vous serez à juste titre
embêté.
</para>
<para>Ainsi par défaut les systèmes &tex; ne vous autorisent à ouvrir en
écriture que les fichiers qui sont dans le répertoire courant ou dans un
sous-répertoire. L&textrsquo;exemple suivant
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newwrite\fichierjh
\openout\fichierjh=../test.jh
</pre></example>

<noindent></noindent>
<para>produit une erreur du genre de :
</para><example endspaces=" ">
<pre xml:space="preserve">Not writing to ../test.jh (openout_any = p).
! I can't write on file `../test.jh'
</pre></example>

<cindex index="cp" spaces=" "><indexterm index="cp" number="975">répertoires parents, impossible d&textrsquo;écrire vers</indexterm></cindex>
<para>Il est possible d&textrsquo;avoir une telle erreur lorsqu&textrsquo;on essaie d&textrsquo;utiliser une
commande telle que <code>\include&lbrace;../nomfichier&rbrace;</code> puisque &latex; va
essayer d&textrsquo;ouvrir <file>../nomfichier.aux</file>.  La solution la plus simple est
de placer les fichiers inclus dans le même répertoire que le fichier
racine, ou dans des sous-répertoires.
</para>
</subsection>
<node name="_005cmessage" spaces=" "><nodename>\message</nodename><nodenext automatic="on">\wlog</nodenext><nodeprev automatic="on">\write and security</nodeprev><nodeup automatic="on">\write</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\message</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1471">\message</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\message&lbrace;<var>chaîne</var>&rbrace;
</pre></example>

<para>Écrit <var>chaîne</var> vers le fichier journal en <file>.log</file> et le
terminal.
</para>
<para>Typiquement, les auteurs &latex; utilisent <code>\typeout</code>
(<pxref label="_005ctypeout"><xrefnodename>\typeout</xrefnodename></pxref>) qui permet d&textrsquo;utiliser <code>\protect</code> sur toute
commande fragile au sein de <var>chaîne</var> (<pxref label="_005cprotect"><xrefnodename>\protect</xrefnodename></pxref>).  Mais la
commande <code>\typeout</code> insère un saut de ligne à la fin de
<var>chaîne</var> contrairement à <code>\message</code>, aussi cette dernière peut
être utile.
</para>
<para>Dans l&textrsquo;exemple ci-dessous dans le corps du document
</para>
<example endspaces=" ">
<pre xml:space="preserve">avant\message&lbrace;Un Deux&rbrace;\message&lbrace;Trois&rbrace;\message&lbrace;Quatre^^JLes&rbrace;
\message&lbrace;pouces vont se battre.&rbrace;Après
</pre></example>

<noindent></noindent>
<para>dans certaines circonstances (voir ci-dessous) &latex; écrit ce qui suit
à la fois vers le terminal et le fichier journal.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Un Deux Trois Quatre
Les pouces vont se battre.
</pre></example>

<noindent></noindent>
<para>Un <code>^^J</code> produit un saut de ligne.  Aussi, dans le document
en sortie, on a entre <samp>avant</samp> et <samp>Après</samp> un seul espace (issu
de la fin de ligne suivant <samp>Les&rbrace;</samp>).
</para>
<para>Alors que <code>\message</code> vous permet de mieux contrôler le formatage,
un truc à piger c&textrsquo;est que &latex; peut très bien bousiller ce formatage
là en insérant des sauts de ligne selon ce qu&textrsquo;il a déjà sorti. Comparez
ce corps de document, où le <samp>Deux</samp> a été déplacé, à celui donné en
exemple plus haut.
</para>
<example endspaces=" ">
<pre xml:space="preserve">avant\message&lbrace;Un&rbrace;\message&lbrace;Deux Trois&rbrace;\message&lbrace;Quatre^^JLes&rbrace;
\message&lbrace;pouces vont se battre.&rbrace;Après
</pre></example>

<para>La chose suivante peut se produire : lorsque &latex; produit les
messages en sortie vers le terminal, le message avec <samp>Un</samp> désormais
plus court tient à la fin de la ligne de terminal, et du coup &latex;
saute de ligne juste après lui et avant le <samp>Deux Trois</samp>.  Ce saut
de ligne apparaît également dans le fichier journal.  Cette insertion de
saut de ligne peut déprendre de, par exemple, la longueur des noms
complet des fichiers inclus. C&textrsquo;est pourquoi il est difficile de produire
des lignes formatées précisément et d&textrsquo;une façon qui soit portable, et de
même de demander que votre message commence au début d&textrsquo;une ligne.
</para>

</subsection>
<node name="_005cwlog" spaces=" "><nodename>\wlog</nodename><nodenext automatic="on">\write18</nodenext><nodeprev automatic="on">\message</nodeprev><nodeup automatic="on">\write</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\wlog</code></sectiontitle>

<findex index="fn" spaces=" "><indexterm index="fn" number="1472">\wlog</indexterm></findex>

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\wlog&lbrace;<var>chaîne</var>&rbrace;
</pre></example>

<para>Écrit <var>chaîne</var> vers le fichier journal <file>.log</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\wlog&lbrace;Pour tout n différent de 0, et tout x, (sin x)/n vaut six.&rbrace;
\wlog&lbrace;Ben oui, il suffit de simplifier par n.&rbrace;
</pre></example>

<para>D&textrsquo;ordinaire <var>chaîne</var> apparaît sur une seule ligne séparée.  Utilisez
<code>^^J</code> pour insérer un saut de ligne.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\wlog&lbrace;C'est Helvetica qui téléphone à Times Roman :&rbrace;
\wlog&lbrace;Change de ligne !^^JJe t'entends très mal.&rbrace;
</pre></example>


</subsection>
<node name="_005cwrite18" spaces=" "><nodename>\write18</nodename><nodeprev automatic="on">\wlog</nodeprev><nodeup automatic="on">\write</nodeup></node>
<subsection spaces=" "><sectiontitle><code>\write18</code></sectiontitle>
<findex index="fn" spaces=" "><indexterm index="fn" number="1473">\write18</indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="976">externes, commandes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="977">commandes exécutées depuis &latex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="978">système, commandes exécutées depuis &latex;</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="979">interpréteur de commandes du système d&textrsquo;exploitation, accès à</indexterm></cindex>
<!-- c Derived from: Joseph Wright: https://tex.stackexchange.com/a/20446/121234 -->

<para>Synopsis :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\write18&lbrace;<var>commande_shell</var>&rbrace;
</pre></example>

<para>Émet une commande vers l&textrsquo;interpréteur du système d&textrsquo;exploitation. Le
système d&textrsquo;exploitation exécute la commande et l&textrsquo;exécution de &latex;
est bloquée jusqu&textrsquo;à ce que cela soit fini.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1474"><r>paquetage</r> <code>Asymptote</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1475"><code>Asymptote</code>, <r>paquetage</r></indexterm></findex>

<para>La séquence suivante (sur Unix)
</para>
<example endspaces=" ">
<pre xml:space="preserve">\usepackage&lbrace;graphicx&rbrace;  % dans le préambule
  ...
\newcommand&lbrace;\numerofig&rbrace;&lbrace;1&rbrace;
\immediate\write18&lbrace;cd pix &amp;&amp; asy figure\numerofig&rbrace;
\includegraphics&lbrace;pix/figure\numerofig.pdf&rbrace;
</pre></example>

<noindent></noindent>
<para>exécute Asymptote (le programme <code>asy</code>) sur le fichier
<file>pix/figure1.asy</file>, de sorte que le document peut par la suite lire
le graphique en résultant (<pxref label="_005cincludegraphics"><xrefnodename>\includegraphics</xrefnodename></pxref>).  Comme pour tout
<code>\write</code>, ici &latex; développe les macros contenues dans
<var>commande_shell</var> de sorte que <code>\numerofig</code> est remplacé par
<samp>1</samp>.
</para>
<para>Un autre exemple est que vous pouvez exécuter automatiquement Bib&tex;
au début de chaque exécution de &latex; (<pxref label="Using-BibTeX"><xrefnodename>Using BibTeX</xrefnodename></pxref>) en
incluant <code>\immediate\write18&lbrace;bibtex8 \jobname&rbrace;</code> comme première
ligne du fichier.  Notez que <code>\jobname</code> se développe par défaut en
le nom de base du fichier racine, ou bien l&textrsquo;argument de l&textrsquo;option
<code>--jobname</code> si celle-ci est passée sur la ligne de commande.
</para>
<para>Il peut arriver que vous ayez besoin de plusieurs étapes pour obtenir
l&textrsquo;information désirée.  L&textrsquo;exemple suivant insère en entrée une liste de
tous les fichiers PDF du répertoire courant (voir aussi
<code>texosquery</code> plus bas) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\immediate\write18&lbrace;ls *.pdf &gt; tmp.dat&rbrace;
\input&lbrace;tmp.dat&rbrace;
</pre></example>

<para>Le comportement standard de tout <code>\write</code> est d&textrsquo;attendre jusqu&textrsquo;à la
prochaine éjection de page avant de développer les macros ou d&textrsquo;écrire
dans le flux (<pxref label="_005cwrite"><xrefnodename>\write</xrefnodename></pxref>). Mais il se peut que vous désiriez que
cela soit immédiat.  Pour cela, utilisez
<code>\immediate\write18&lbrace;<var>commande_shell</var>&rbrace;</code>.
</para>
<para>Autoriser l&textrsquo;usage de commandes système au sein d&textrsquo;un fichier &latex;
pose des problèmes de sécurité évidents.  Si vous télécharger un fichier
depuis la Toile et qu&textrsquo;il contient des commandes pour détruire tous vos
fichiers, cela vous rendrait bien malheureux. Le réglage standard dans
les distributions modernes est d&textrsquo;interdire l&textrsquo;accès complet à
l&textrsquo;interpréteur de commande du système d&textrsquo;exploitation. Vous pouvez
l&textrsquo;autoriser, si vous êtes sûr qu&textrsquo;il n&textrsquo;y a pas de danger, en compilant
avec <code>latex --enable-write18 <var>nomfichier</var></code> (<pxref label="Command-line-options"><xrefnodename>Command line
options</xrefnodename></pxref>).  (L&textrsquo;option <code>--shell-escape</code> est un synonyme dans &tex;
Live.)
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="980">restreint, accès shell</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="981">restreint, accès interpréteur de commande du système d&textrsquo;exploitation</indexterm></cindex>
<para>Au lieu de l&textrsquo;accès complet, les distributions modernes par défaut
utilisent une version restreinte qui permet à certaines commandes de
fonctionner, telles que celles qui font tourner Metafont pour générer
les polices manquantes, même si vous n&textrsquo;utilisez pas l&textrsquo;option
<code>enable-write18</code>. Par défaut cette liste de commandes autorisées
est courte et ne fait figurer que les commandes qui sont sous contrôle
des mainteneurs de la distribution (<pxref label="Command-line-options"><xrefnodename>Command line options</xrefnodename></pxref>).
</para>
<para>Certains paquetages ont besoin d&textrsquo;exécuter des commandes système
externes. Par exemple <file>sagetex</file> vous permet de faire faire des
calculs ou tracer des graphiques au logiciel de mathématiques <i>Sage</i>,
puis d&textrsquo;incorporer ces sorties dans votre document. Pour cela vous devez
exécuter &latex; avec la fonction <code>\write18</code> pleinement débridée.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1476">/bin/sh<r>, utilisé par <code>\write18</code></r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1477">sh<r>, utilisé par <code>\write18</code></r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1478">cmd.exe<r>, utilisé par <code>\write18</code></r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1479">SHELL<r>, environnement, variables de</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1480">SHELL<r>, variables d&textrsquo;environnement</r></indexterm></findex>
<para>Le texte <var>commande_shell</var> est toujours passé à <file>/bin/sh</file> sur
les systèmes d&textrsquo;exploitation unixiens, et à l&textrsquo;interpréteur de commande DOS
<file>cmd.exe</file> sur Windows. &latex; ignore tout réglage d&textrsquo;un autre
interpréteur de commande par l&textrsquo;utilisateur, ainsi que la variable
d&textrsquo;environnement <code>SHELL</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1481"><r>paquetage</r> <code>texosquery</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1482"><code>texosquery</code>, <r>paquetage</r></indexterm></findex>

<cindex index="cp" spaces=" "><indexterm index="cp" number="982">système, information</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="983">exploitation, information système de</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="984">locale, information, du système</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="985">répertoire, listage, du système</indexterm></cindex>
<para>Si votre besoin c&textrsquo;est d&textrsquo;avoir de l&textrsquo;information sur le système, comme le
nom du système d&textrsquo;exploitation, celui de la locale, ou le contenu d&textrsquo;un
répertoire, alors jeter un coup d&textrsquo;œil au paquetage <code>texosquery</code> qui
fournit une interface commode et sûre pour cela, contrairement aux
exemples donnés plus haut utilisant <code>\write18</code> à l&textrsquo;état brut :
<url><urefurl>https://ctan.org/pkg/texosquery</urefurl></url>.
</para>
</subsection>
</section>
</chapter>
<node name="Command-line-interface" spaces=" "><nodename>Command line interface</nodename><nodenext automatic="on">Document templates</nodenext><nodeprev automatic="on">Terminal input/output</nodeprev><nodeup automatic="on">Top</nodeup></node>
<chapter spaces=" "><sectiontitle>Interface ligne de commande</sectiontitle>
<anchor name="Command-line">Command line</anchor><!-- c ancien nom -->
<cindex index="cp" spaces=" "><indexterm index="cp" number="986">ligne de commande, interface</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="987">interface ligne de commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="988">CLI</indexterm></cindex>

<para>Synopsis (depuis la ligne de commande d&textrsquo;un terminal) :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex <var>options</var> <var>argument</var>
</pre></example>

<para>Exécute &latex; sur <var>argument</var>. À la place de <command>pdflatex</command>
vous pouvez aussi utiliser (pour une sortie PDF) <command>xelatex</command>, ou
<command>lualatex</command>, ou (pour une sortie DVI) <command>latex</command> ou
<code>dvilualatex</code>, entre autres (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).
</para>
<para>L&textrsquo;exemple suivant exécute &latex; sur le fichier <file>these.tex</file>
produisant en sortie <file>these.pdf</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex these
</pre></example>

<noindent></noindent>
<para><findex index="fn" spaces=" "><indexterm index="fn" number="1483">.tex, <r>extension par défaut</r></indexterm></findex>
Notez que <file>.tex</file> est l&textrsquo;extension par défaut des noms de fichier.
</para>
<para>pdf&tex; est une évolution du programme original &tex;, comme le sont
Xe&tex; et Lua&tex; (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).  Ils sont complètement
rétrocompatibles. Mais le programme original avait son propre format de
sortie, DVI, alors que les plus récents peuvent produire directement un
PDF en sortie.  Ceci leur permet de profiter des fonctions
supplémentaires des PDF tels que les hyperliens, la prise en charge de
formats modernes d&textrsquo;images tels que JPG et PNG, et les programmes de
visionnage que l&textrsquo;on trouve de partout.  En bref, si vous exécutez
<command>pdflatex</command> ou <command>xelatex</command> ou <command>lualatex</command> alors par
défaut vous obtenez un PDF et avez accès à toutes ses fonctions
modernes.  Si vous exécutez <command>latex</command>, ou <command>dvilualatex</command>,
alors vous obtenez un DVI.  La description faite ici suppose
<command>pdflatex</command>.
</para>
<para><xref label="Command-line-options"><xrefnodename>Command line options</xrefnodename></xref>, pour une sélection des options de ligne de
commande les plus utiles. Quant à <var>argument</var>, le cas habituel est
qu&textrsquo;il ne commence pas par une controblique, dans ce cas le système le
prend pour un nom de fichier, et compile ce fichier. Si <var>argument</var>
commence avec une controblique, alors le système l&textrsquo;interprète comme une
ligne d&textrsquo;entrée à &latex;, ce qui peut être utilisé pour obtenir
certains effets spéciaux (<pxref label="Command-line-input"><xrefnodename>Command line input</xrefnodename></pxref>).
</para>
<para>Si vous ne donnez aucun arguments ni options alors <command>pdflatex</command>
invite à saisir à partir du terminal. Vous pouvez vous échapper de cela
en entrant <kbd>CTRL-D</kbd>.
</para>
<para>Si &latex; trouve une erreur dans votre document alors par défaut il
s&textrsquo;arrête et vous interroge à ce propos.  <xref label="Recovering-from-errors"><xrefnodename>Recovering from errors</xrefnodename></xref>,
pour un aperçu de quoi faire.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menunode separator="::     ">Command line options</menunode><menudescription><pre xml:space="preserve">Options usuelles de ligne de commande.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::       ">Command line input</menunode><menudescription><pre xml:space="preserve">Spécifier du code LaTeX sur la ligne de commande.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">Nom d&textrsquo;ouvrage</menutitle><menunode separator=".     ">Jobname</menunode><menudescription><pre xml:space="preserve">Comment &tex; définit le nom de l&textrsquo;ouvrage courant.
</pre></menudescription></menuentry><menuentry leadingtext="* "><menunode separator="::   ">Recovering from errors</menunode><menudescription><pre xml:space="preserve">Quand quelque chose se passe mal.
</pre></menudescription></menuentry></menu>


<node name="Command-line-options" spaces=" "><nodename>Command line options</nodename><nodenext automatic="on">Command line input</nodenext><nodeup automatic="on">Command line interface</nodeup></node>
<section spaces=" "><sectiontitle>Options passées à la ligne de commande</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="989">options passée à la ligne de commande</indexterm></cindex>

<para>On décrit ici les options de ligne de commande qui sont pertinentes pour
rédaction ordinaire de documents. Pour une liste complète, essayez
d&textrsquo;exécuter <samp>latex --help</samp> depuis la ligne de commande.
</para>
<para>Avec nombre d&textrsquo;implémentations on peut spécifier les options de ligne de
commande avec un préfixe <samp>-</samp> ou <samp>--</samp>.  C&textrsquo;est le cas à la fois
pour &tex; Live (y compris Mac&tex;) et MiK&tex;. Ici on utilise les
deux conventions indistinctement. Si une option prend une valeur,
celle-ci peut être spécifiée soit comme un argument séparé
(<samp>--truc bidule</samp>), ou comme un argument unique avec un signe
<code>=</code> (<samp>--truc=bidule</samp>), à condition qu&textrsquo;il n&textrsquo;y ait aucun espace
autour du <code>=</code>. On utilisera en général la syntaxe en <code>=</code>.
</para>


<table commandarg="code" spaces=" " endspaces=" ">
<beforefirstitem><findex index="fn" spaces=" "><indexterm index="fn" number="1484">--version <r>ligne de commande, option</r></indexterm></findex>
</beforefirstitem><tableentry><tableterm><item spaces=" "><itemformat command="code">-version</itemformat></item>
</tableterm><tableitem><para>Affiche la version courante, comme <samp>pdfTeX 3.14159265-2.6-1.40.16
(&tex; Live 2015/Debian)</samp> ainsi qu&textrsquo;une petite quantité d&textrsquo;information
supplémentaire, et se termine.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1485">--help <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-help</itemformat></item>
</tableterm><tableitem><para>Produit un message bref d&textrsquo;utilisation servant d&textrsquo;aide-mémoire et se
termine.
</para>
<anchor name="interaction-modes">interaction modes</anchor>
<findex index="fn" spaces=" "><indexterm index="fn" number="1486">--interaction <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-interaction=<var>mode</var></itemformat></item>
</tableterm><tableitem><cindex index="cp" spaces=" "><indexterm index="cp" number="990">batchmode</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="991">scrollmode</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="992">errorstopmode</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="993">nonstopmode</indexterm></cindex>
<para>z&tex; compile un document en l&textrsquo;un parmi quatre modes possibles
d&textrsquo;interaction : <code>batchmode</code>, <code>nonstopmode</code>, <code>scrollmode</code>,
<code>errorstopmode</code>. Dans le mode <dfn>errorstopmode</dfn> (le
mode par défaut), &tex; s&textrsquo;arrête à chaque erreur et demande une
intervention de l&textrsquo;utilisateur. Dans le mode <dfn>batchmode</dfn>
il n&textrsquo;imprime rien sur le terminal, on défile sur les erreurs comme si
l&textrsquo;utilisateur appuyait <kbd>RETURN</kbd> à chaque erreur, et les fichiers
manquants entraînent la terminaison de la tâche. Dans le mode
<dfn>nonstopmode</dfn>, les messages de diagnostic apparaissent
sur le terminal mais comme dans le mode <code>batchmode</code> il n&textrsquo;y a pas
d&textrsquo;interaction avec l&textrsquo;utilisateur. Dans le mode
<dfn>scrollmode</dfn>, &tex; s&textrsquo;arrête en cas de fichiers
manquants ou d&textrsquo;entrée clavier, mais pour nulle autre raison.
</para>
<para>Par exemple, en démarrant &latex; avec cette ligne de commande :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex -interaction=batchmode <var>nomfichier</var>
</pre></example>

<noindent></noindent>
<para>on élimine la plupart des sorties terminal.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="994">jobname</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="995">nom de fichier de la tâche courante</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1487">--jobname <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-jobname=<var>chaîne</var></itemformat></item>
</tableterm><tableitem><para>Règle la valeur du <dfn>nom d&textrsquo;ouvrage</dfn> de &tex; à la chaîne de
caractères <var>chaîne</var>.  Le fichier journal et le fichier de sortie
s&textrsquo;appelleront <file><var>chaîne</var>.log</file> et
<file><var>chaîne</var>.pdf</file>. <pxref label="Jobname"><xrefnodename>Jobname</xrefnodename></pxref>.
</para>
<anchor name="output-directory">output directory</anchor>
<cindex index="cp" spaces=" "><indexterm index="cp" number="996">répertoire de sortie pour tous les fichiers externes</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="997">sortie, pour tous les fichiers externes, répertoire de</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1488">--output-directory <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-output-directory=<var>répertoire</var></itemformat></item>
</tableterm><tableitem><para>Écrit les fichiers dans le répertoire <var>répertoire</var>.  Il doit déjà
exister.  Ceci s&textrsquo;applique à tous les fichiers externes créés par &tex;
ou &latex;, tels que le fichier <file>.log</file> de l&textrsquo;exécution, les
fichiers <file>.aux</file>, <file>.toc</file>, etc., créés par &latex;, de même que
le fichier de sortie principal <file>.pdf</file> ou <file>.dvi</file> lui-même.
</para>
<para>Lorsqu&textrsquo;il est spécifié, le répertoire de sortie <var>répertoire</var> est
aussi vérifié en premier automatiquement pour tout fichier lu en entrée,
de sorte que les fichiers externes peuvent être relus en entrée, si
désiré. Le vrai répertoire courant (dans lequel &latex; été lancé)
demeure inchangé, et est également vérifié pour trouver les fichiers en
entrée.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="998">shell escape</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="999"><code>\write18</code>, activation</indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1489">--enable-write18 <r>ligne de commande, option</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1490">--disable-write18 <r>ligne de commande, option</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1491">--shell-escape <r>ligne de commande, option</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1492">--no-shell-escape <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">--enable-write18</itemformat></item>
<itemx spaces=" "><itemformat command="code">--disable-write18</itemformat></itemx>
<itemx spaces=" "><itemformat command="code">--shell-escape</itemformat></itemx>
<itemx spaces=" "><itemformat command="code">--no-shell-escape</itemformat></itemx>
</tableterm><tableitem><para>Activation et désactivation <code>\write18&lbrace;<var>commande_shell</var>&rbrace;</code>
(<pxref label="_005cwrite18"><xrefnodename>\write18</xrefnodename></pxref>).  Les deux premières options sont prises en charge à
la fois par &tex; Live et MiK&tex;, alors que les deux suivantes sont
des synonymes pris en charge par &tex; Live.
</para>
<para>Activer cette fonction a des implications lourdes de sécurité, puisque
cela permet à un fichier &latex; d&textrsquo;exécuter n&textrsquo;importe quelle commande.
Ainsi, par défaut, le <code>\write18</code> non restreint n&textrsquo;est pas autorisé.
(Le réglage par défaut de &tex; Live, Mac&tex;, et MiK&tex;
est d&textrsquo;autoriser l&textrsquo;exécution d&textrsquo;un nombre limité de programmes en relation
avec &tex;, et qu&textrsquo;elles distribuent).
</para>
<para>Pa exemple, si vous invoquez &latex; avec l&textrsquo;option
<code>no-shell-escape</code>, et que dans votre document vous appelez
<code>\write18&lbrace;ls -l&rbrace;</code>, alors vous n&textrsquo;obtenez pas d&textrsquo;erreur mais votre
fichier journal dit <samp>runsystem(ls -l)...disabled</samp>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1493">--halt-on-error <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-halt-on-error</itemformat></item>
</tableterm><tableitem><para>Arrête le traitement sur la première erreur.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1494">--file-line-error <r>ligne de commande, option</r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1495">--no-file-line-error <r>ligne de commande, option</r></indexterm></findex>
</tableitem></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-file-line-error</itemformat></item>
</tableterm></tableentry><tableentry><tableterm><item spaces=" "><itemformat command="code">-no-file-line-error</itemformat></item>
</tableterm><tableitem><para>Active ou désactive le style
<code><var>nomfichier</var>:<var>numéroligne</var>:<var>erreur</var></code> des messages
d&textrsquo;erreur.  Ces options ne sont disponibles qu&textrsquo;avec &tex; Live ou
Mac&tex;.
</para></tableitem></tableentry></table>


</section>
<node name="Command-line-input" spaces=" "><nodename>Command line input</nodename><nodenext automatic="on">Jobname</nodenext><nodeprev automatic="on">Command line options</nodeprev><nodeup automatic="on">Command line interface</nodeup></node>
<section spaces=" "><sectiontitle>Spécifier du code LaTeX sur la ligne de commande</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="1000">code entré sur la ligne de commande</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1001">entré, code sur la ligne de commande</indexterm></cindex>

<para>Au sein de l&textrsquo;invocation de ligne de commande
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex <var>options</var> <var>argument</var>
</pre></example>

<noindent></noindent>
<para>vous pouvez spécifier du code &latex; arbitraire en entrée en
commençant <var>argument</var> par une controblique (ce qui est pris en
charge par tous les moteurs). Ceci permet de faire certains effets
spéciaux.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1496"><r>paquetage</r> <code>hyperref</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1497"><code>hyperref</code>, <r>paquetage</r></indexterm></findex>

<!-- c -->
<para>Par exemple, ce fichier (qui utilise le paquetage <code>hyperref</code> pour
les hyperliens) peut produire deux types de sortie, l&textrsquo;un pour une
consultation sur document papier et l&textrsquo;autre pour une consultation sur
écran.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\ifdefined\paperversion        % dans le préambule
\newcommand&lbrace;\urlcolor&rbrace;&lbrace;black&rbrace;
\else
\newcommand&lbrace;\urlcolor&rbrace;&lbrace;blue&rbrace;
\fi
\usepackage[colorlinks=true,urlcolor=\urlcolor]&lbrace;hyperref&rbrace;
  ...
\href&lbrace;https://www.ctan.org&rbrace;&lbrace;CTAN&rbrace;  % dans le corps
  ...
</pre></example>

<noindent></noindent>
<para>Lorsqu&textrsquo;on compile ce document <file>book.tex</file> avec la ligne de commande
<code>pdflatex book</code> le lien <samp>CTAN</samp> sera en bleu.  Mais si on le
compile avec
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex &quot;\def\paperversion&lbrace;&rbrace;\input book.tex&quot;
</pre></example>

<noindent></noindent>
<para>alors le lien sera en noir.  On utilise des guillemets anglais double
pour empêcher l&textrsquo;interprétation des symboles par l&textrsquo;interpréteur de ligne
de commande (désigné également par <dfn>shell</dfn>). (Ceci fonctionne
généralement à la fois sur les systèmes Unix et Windows, mais il y a
nombre de particularités dans l&textrsquo;usage des guillemets par les shells,
lisez donc la documentation de votre système si besoin est).
</para>
<para>De même, à partir d&textrsquo;un seul fichier <file>principal.tex</file> vous pouvez
compiler deux versions distinctes.
</para>
<!-- c credit Paul Gaborit: https://tex.stackexchange.com/a/220101/121234 -->
<example endspaces=" ">
<pre xml:space="preserve">pdflatex -jobname=etudiants &quot;\def\etudiants&lbrace;&rbrace;\input&lbrace;principal&rbrace;&quot;
pdflatex -jobname=professeurs &quot;\def\profs&lbrace;&rbrace;\input&lbrace;principal&rbrace;&quot;
</pre></example>

<noindent></noindent>
<para>L&textrsquo;option <code>jobname</code> est là parce que sinon les deux fichiers en
sortie s&textrsquo;appelleraient <file>principal.pdf</file> et le second écraserait le
premier. (<pxref label="Jobname"><xrefnodename>Jobname</xrefnodename></pxref>).
</para>
<para>Dans cet exemple on passe l&textrsquo;option <code>draft</code> au paquetage
<code>graphicx</code> :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex &quot;\PassOptionsToPackage&lbrace;draft&rbrace;&lbrace;graphicx&rbrace;\input&lbrace;aa.tex&rbrace;&quot;
</pre></example>

<noindent></noindent>
<para>de sorte que les fichiers graphiques ne sont lus que pour l&textrsquo;information
de dimension de boîte englobante, mais remplacés dans le PDF par une
boîte de même taille ne contenant que le nom de fichier, ce qui accélère
le temps de compilation, et économise l&textrsquo;encre d&textrsquo;imprimante.
</para>
<para>Un autre exemple classique est de cribler certains chapitres à la
compilation en les passant à <code>\includeonly</code> dans la ligne de
commande. Ainsi, supposons qu&textrsquo;on a un fichier racine <file>livre.tex</file>
ainsi formé :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\begin&lbrace;document&rbrace;
\frontmatter
\include&lbrace;pref&rbrace;
\mainmatter
\include&lbrace;chap1&rbrace;
\include&lbrace;chap2&rbrace;
\appendix
\include&lbrace;append&rbrace;
\backmatter
\include&lbrace;bib&rbrace;
\end&lbrace;document&rbrace;
</pre></example>

<para>En compilant <file>livre.tex</file> avec la ligne de commande suivante :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\includeonly&lbrace;chap1&rbrace;\input&lbrace;livre&rbrace;
</pre></example>

<noindent></noindent>
<para>seul le chapitre contenu dans <file>chap1.tex</file> sera produit en
sortie. <xref label="Splitting-the-input"><xrefnodename>Splitting the input</xrefnodename></xref>.
</para>
<para>Dans ce dernier exemple, on force la date au 14 juillet 1789 :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\day=14 \month=7 \year=1789 \input revolution'
</pre></example>

<para>Ainsi, si le fichier <file>revolution.tex</file> contient ceci :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[french]&lbrace;minimal&rbrace;
\usepackage&lbrace;babel&rbrace;
\begin&lbrace;document&rbrace;
\today\ c'est la révolution !
\end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>alors vous aurez en sortie un truc du genre :
</para>
<example endspaces=" ">
<pre xml:space="preserve">14 juillet 1789 c’est la révolution !
</pre></example>

</section>
<node name="Jobname" spaces=" "><nodename>Jobname</nodename><nodenext automatic="on">Recovering from errors</nodenext><nodeprev automatic="on">Command line input</nodeprev><nodeup automatic="on">Command line interface</nodeup></node>
<section spaces=" "><sectiontitle>Nom d&textrsquo;ouvrage de &tex;</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1002">nom d&textrsquo;ouvrage (jobname)</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1003">jobname, nom d&textrsquo;ouvrage</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1004">document, nom racine</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1005">racine du nom du document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1006">fichier racine</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1007">racine, fichier</indexterm></cindex>
<!-- c xx TODO TikZ externalize not working with -jobname option -->

<para>Exécuter &latex; crée plusieurs fichiers, dont la sortie principale en
PDF (ou DVI) et bien d&textrsquo;autres. Ces fichiers sont nommés selon ce qu&textrsquo;on
appelle le <dfn>nom d&textrsquo;ouvrage</dfn>. Le cas le plus fréquent est aussi le
plus simple : la commande <code>pdflatex these</code> crée <code>these.pdf</code> et
aussi <code>these.log</code> et <code>these.aux</code>. Ici le nom d&textrsquo;ouvrage est
<code>these</code>.
</para>
<para>En général, &latex; est invoqué comme <code><var>moteur-latex</var>
<var>options</var> <var>arguments</var></code>, où <var>moteur-latex</var> est
<code>pdflatex</code>, <code>lualatex</code>, etc.&noeos; (<pxref label="TeX-engines"><xrefnodename>&tex; engines</xrefnodename></pxref>).  Si
<var>arguments</var> ne commence pas par une controblique, comme c&textrsquo;est le
cas ci-dessus avec <code>these</code>, alors &tex; insère un argument
<code>\input</code> en tête de la liste d&textrsquo;arguments <var>arguments</var> et
considère le texte formé en joignant les éléments de cette liste séparés
par des blancs comme un code source pris en entrée. Ainsi la ligne de
commande <code>pdflatex these</code> conduit &latex; à compiler le code
source suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\input these
</pre></example>

<noindent></noindent>
<para>Ceci permet de faire une indirection vers le fichier <file>these.tex</file>
qui est censé contenir l&textrsquo;entièreté du code source à compiler, et qu&textrsquo;on
appelle à ce titre <dfn>fichier racine</dfn> (<pxref label="Splitting-the-input"><xrefnodename>Splitting the input</xrefnodename></pxref>).
</para>
<para>On appelle <dfn>nom racine</dfn> le nom du fichier racine, sans l&textrsquo;extension
<file>.tex</file> s&textrsquo;il en a une. <xref label="_005cinput"><xrefnodename>\input</xrefnodename></xref>, pour la gestion de l&textrsquo;extension
<file>.tex</file>.
</para>
<para>Notez bien, que si on a toujours un nom d&textrsquo;ouvrage, on n&textrsquo;a pas
systématiquement de nom racine. En effet, dès lors qu&textrsquo;on a du code
&latex; passé sur la ligne de commande (<pxref label="Command-line-input"><xrefnodename>Command line input</xrefnodename></pxref>),
l&textrsquo;entièreté du code compilé n&textrsquo;est pas issu d&textrsquo;un seul fichier. En
supposant ici et ci-après que le shell est <file>bash</file>, et donc que les
guillemets anglais simples ou doubles sont interprétés par le shell (voir
<uref><urefurl>https://www.gnu.org/software/bash/manual/html_node/Quoting.html#Quoting</urefurl><urefdesc spaces="\n"></urefdesc><urefreplacement>(info &quot;(bash) Quoting&quot;)</urefreplacement></uref>), considérez par exemple ligne de commande
suivante :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\documentclass&lbrace;article&rbrace;\input' corps
</pre></example>

<noindent></noindent>
<para>Dans l&textrsquo;exemple précédent, on ne peut pas considérer <file>corps.tex</file>
comme un fichier racine, puisqu&textrsquo;il ne peut pas être compilé de façon
autonome vu qu&textrsquo;il ne contient pas la commande <code>\documentclass</code>. Par
abus de langage on continue toutefois de parler de fichier racine si le
code &latex; passé en ligne de commande ne sert qu&textrsquo;à configurer la
façon dont le fichier est compilé, comme dans :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\PassOptionsToClass&lbrace;printout&rbrace;&lbrace;beamer&rbrace;\input' mapresentation
</pre></example>

<noindent></noindent>
<para>où <file>mapresenation.tex</file> contient une présentation <code>beamer</code>, et
on veut juste la compiler de façon adéquate pour une impression plutôt
que pour une projection.
</para>
<para>Voici par contre un exemple extrême où on n&textrsquo;a pas de fichier racine,
considérez la ligne de commande :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex fic &quot;Bonjour tout le monde~!&quot; '\end&lbrace;document&rbrace;'
</pre></example>

<noindent></noindent>
<para>ce qui conduit <file>pdflatex</file> à compiler le code source suivant :
</para>
<example endspaces=" ">
<pre xml:space="preserve">\input fic Bonjour tout le monde~! \end&lbrace;document&rbrace;
</pre></example>

<noindent></noindent>
<para>À supposer que <file>fic.tex</file> soit un fichier contenant
<code>\documentclass&lbrace;minimal&rbrace;\begin&lbrace;document&rbrace;</code> le résultat sera un
document PDF nommé <file>fic.pdf</file> et contenant le texte <samp>Bonjour
tout le monde !</samp>.
</para>
<para>Dans la mesure où on n&textrsquo;a pas systématiquement de fichier racine, la
règle que &tex; utilise pour déterminer implicitement le nom d&textrsquo;ouvrage,
c.-à-d.&noeos; lorsqu&textrsquo;il n&textrsquo;est pas spécifié explicitement par l&textrsquo;option
<code>-jobname</code> (<pxref label="Command-line-options"><xrefnodename>Command line options</xrefnodename></pxref>), est que le nom d&textrsquo;ouvrage
soit le nom du fichier correspondant à l&textrsquo;argument passé au premier
<code>\input</code> rencontré durant la compilation, débarrassé de l&textrsquo;extension
<file>.tex</file> s&textrsquo;il en a une. Dans l&textrsquo;exemple précédent, le nom d&textrsquo;ouvrage
est donc bien <file>fic</file>. Voir aussi plus bas la primitive
<code>\jobname</code> pour une dérogation à cette règle.
</para>
<para>Ce qui précède vaut également si &tex; est en mode interactif, la seule
différence est alors que <var>arguments</var> n&textrsquo;est pas passé entièrement sur
la ligne de commande, mais saisi interactivement par l&textrsquo;utilisateur. Par
exemple si dans le shell vous tapez la ligne de commande
<code>pdflatex</code>, puis qu&textrsquo;à l&textrsquo;invite de &tex; vous tapez <code>these</code>,
vous aurez le même résultat que dans le premier exemple donné, à savoir
si vous aviez tapé directement <code>pdflatex these</code> depuis le shell.
</para>
<para>Dans la même veine, la seule différence si <var>arguments</var> commence avec
une controblique est que le <code>\input</code> n&textrsquo;est pas inséré, et donc
<code>pdflatex &quot;\input&quot; these</code> est sensiblement équivalent à
<code>pdflatex these</code>.
</para>
<para>Il y a deux autres possibilités pour le nom d&textrsquo;ouvrage. Pour ce qui est de
la première, il peut être directement spécifié avec l&textrsquo;option
<code>-jobname</code>, comme dans <code>pdflatex -jobname=monnom</code>
(<pxref label="Command-line-input"><xrefnodename>Command line input</xrefnodename></pxref> pour un véritable exemple).
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1498">texput<r>, nom d&textrsquo;ouvrage par défaut</r></indexterm></findex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1008">repli, nom d&textrsquo;ouvrage</indexterm></cindex>
<para>La seconde possibilité est <file>texput</file>, c&textrsquo;est la valeur par défaut de
repli si aucun autre nom n&textrsquo;est disponible pour &tex;. Par exemple si
aucune option <code>-jobname</code> n&textrsquo;a été spécifiée et que la compilation
s&textrsquo;arrête avant qu&textrsquo;une commande <code>\input</code> ne soit trouvée, alors le
fichier journal s&textrsquo;appelle <file>texput.log</file>.
</para>

<findex index="fn" spaces=" "><indexterm index="fn" number="1499">\jobname</indexterm></findex>
<para>Au sein du document, la primitive <code>\jobname</code> se comporte comme une
macro qui se développe en le nom d&textrsquo;ouvrage. Quand le nom d&textrsquo;ouvrage
contient au moins un blanc, un guillemet anglais est ajouté et début et
fin de la chaîne renvoyée par <code>\jobname</code> et tout blanc est remplacé
par un espace, c.-à-d.&noeos; qu&textrsquo;un caractère tabulation est remplacé par un
espace. De plus, au cours du développement, tous les caractères sont de
catcode 12 (other), y compris les lettres qui normalement sont de
catcode 11, mais à l&textrsquo;exception des espaces auquel un catcode 10 est
attribué.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1500">\IfBeginWith*<r> macro from <code>xstring</code></r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1501"><r>paquetage</r> <code>xstring</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1502"><code>xstring</code>, <r>paquetage</r></indexterm></findex>


<para>À cause de cette situation des catcodes, utiliser le nom d&textrsquo;ouvrage dans
une expression conditionnelle peut devenir compliqué. Une solution est
d&textrsquo;utiliser la macro <code>\IfBeginWith</code> du paquetage <file>xtring</file> dans
sa forme étoilée pour être insensible au catcode. Dans le texte suivant
par exemple, la note en bas de page « dont la Respublica
Bananensis Francorum. » n&textrsquo;est présente que si le nom d&textrsquo;ouvrage commence
par <file>moi-meme</file>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">Si une démocratie est juste un régime où les citoyens votent alors
toutes les républiques bananières\IfBeginWith*&lbrace;\jobname&rbrace;&lbrace;moi-meme&rbrace;%
&lbrace;\footnote&lbrace;dont la Respublica Bananensis Francorum.&rbrace;&rbrace;&lbrace;&rbrace; sont des
démocraties.
</pre></example>

<para>Redéfinir <code>\jobname</code> dans le code source avec un
<code>\renewcommand</code> peut s&textrsquo;avérer vain et risqué. Tout d&textrsquo;abord, si
c&textrsquo;était ce qui vous cherchiez, cela ne changera pas le nom d&textrsquo;ouvrage au
sens où les fichiers créés directement par le moteur continuent à
utiliser le nom d&textrsquo;ouvrage original : il s&textrsquo;agit notamment du fichier de
sortie principale <file>.pdf</file> ou <file>.dvi</file>, du journal de compilation
<file>.log</file> et du fichier de liste fichiers <file>.fls</file> si l&textrsquo;option
<code>-recorder</code> a été utilisée. Par contre les fichiers auxiliaires
<file>.aux</file>, <file>.bib</file>, etc.&noeos; pourront être renommés car leur nom est
produit par le noyau &latex; en développant <code>\jobname</code> et non
directement par le moteur, mais à condition bien sûr que la redéfinition
soit faite avant l&textrsquo;ouverture des fichiers en question. Le paquetage
<file>multibib</file> utilise ce truc pour gérer plusieurs fichiers de
référence bibliographique.
</para>
<para>La séquence de contrôle <code>\jobname</code> se comporte comme une macro, au
sens où on peut faire dessus toutes les opérations qu&textrsquo;on ferait sur une
macro, et notamment la développer, mais ce n&textrsquo;est pas une macro, c&textrsquo;est
une primitive &tex;. Ainsi, une seconde règle de détermination du nom
d&textrsquo;ouvrage est que le premier développement de <code>\jobname</code> fige le
nom d&textrsquo;ouvrage. Dans l&textrsquo;exemple suivant de ligne de commande :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\typeout&lbrace;\jobname&rbrace;\input' these
</pre></example>

<noindent></noindent>
<para>le nom d&textrsquo;ouvrage sera la valeur par défaut <file>texput</file>, et non
<file>these</file>. En effet le code &latex; <code>\typeout&lbrace;\jobname&rbrace;</code> a
pour effet que <code>\jobname</code> est développé avant que le premier
<code>\input</code> ne soit rencontré, et donc on déroge à la première règle
énoncée plus haut, c.-à-d.&noeos; que dans ce cas le nom d&textrsquo;ouvrage n&textrsquo;est pas
donné par le premier <code>\input</code>.
</para>
<findex index="fn" spaces=" "><indexterm index="fn" number="1503">\documentclass<r>, et nom d&textrsquo;ouvrage <code>texput</code></r></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1504">\RequirePackage<r>, et nom d&textrsquo;ouvrage <code>texput</code></r></indexterm></findex>
<para>Cette seconde règle a pour autre conséquence que dans l&textrsquo;exemple suivant
de ligne de commande :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\documentclass&lbrace;article&rbrace;\input' corps
</pre></example>

<noindent></noindent>
<para>le nom d&textrsquo;ouvrage sera également <file>texput</file>, en effet en sous-main les
commandes <code>\documentclass</code> et <code>\RequirePackage</code> développent
<code>\jobname</code>, et donc la seconde règle déroge à la première règle,
celle du premier <code>\input</code> rencontré.
</para>
<para>Il est à noter que ce qui précède n&textrsquo;était pas vrai avec de vieilles
versions de &latex; (approximativement) antérieures à 2020. Avec ces
vieilles versions <code>\documentclass</code> et <code>\RequirePackage</code>
faisaient un <code>\input</code> sans développement préalable de
<code>\jobname</code> et donc dans l&textrsquo;exemple précédent le nom d&textrsquo;ouvrage aurait
été <file>article</file>, ce qui était déroutant.
</para>
<para>Par ailleurs, l&textrsquo;équivalence entre <code>pdflatex &quot;\input&quot; these</code> et
<code>pdflatex these</code> peut être mise en défaut lorsque le nom du fichier
comprend un blanc. Comparer par exemple les deux lignes de commande
suivantes :
</para>
<example endspaces=" ">
<pre xml:space="preserve">pdflatex '\input' 'to\space\space to'
pdflatex 'to\space\space to'
</pre></example>

<noindent></noindent>
<para>En remplaçant les espaces par des espaces visibles
<code>␣</code> pour la clarté de l&textrsquo;exposé, la première ligne de
commande qui a un <code>\input</code> explicite cherche un fichier
<file>to.tex</file>, ou à défaut <file>to</file>, et ajoute à la suite de
l&textrsquo;<code>\input</code> de ce fichier, le code source
<code>\space␣to</code>, en effet le premier des deux
<code>\space</code> est consommé par l&textrsquo;<code>\input</code>. Elle aura donc pour nom
d&textrsquo;ouvrage <file>to</file>. La seconde, qui a un <code>\input</code> implicite, a par
contre un comportement qui dépend de la distribution. Avec MiK&tex; elle
est équivalente à la première. Mais avec &tex; Live, elle cherche un
fichier <file>to␣␣to.tex</file>, ou à défaut
<file>to␣␣to</file>, et n&textrsquo;ajoute rien à la suite
de l&textrsquo;<code>\input</code> de ce fichier. Elle aura donc pour nom d&textrsquo;ouvrage
<file>&quot;to␣␣to&quot;</file>.
</para>

</section>
<node name="Recovering-from-errors" spaces=" "><nodename>Recovering from errors</nodename><nodeprev automatic="on">Jobname</nodeprev><nodeup automatic="on">Command line interface</nodeup></node>
<section spaces=" "><sectiontitle>Quand quelque chose se passe mal</sectiontitle>

<para>Si &latex; trouve une erreur dans votre document alors il vous produit
un message d&textrsquo;erreur et vous invite à la saisie par un point
d&textrsquo;interrogation, <code>?</code>.  Par exemple, exécuter &latex; sur ce fichier
</para>
<example endspaces=" ">
<pre xml:space="preserve">\newcommand&lbrace;\NP&rbrace;&lbrace;\ensuremath&lbrace;\textbf&lbrace;NP&rbrace;&rbrace;&rbrace;
Le problème \PN&lbrace;&rbrace; est mis à prix à un million de dollars.
</pre></example>

<noindent></noindent>
<para>a pour effet qu&textrsquo;il affiche ceci, et attende une saisie :
</para>
<example endspaces=" ">
<pre xml:space="preserve">! Undefined control sequence.
l.5 Le problème \PN
           &lbrace;&rbrace; est mis à prix à un million de dollars.
?
</pre></example>

<noindent></noindent>
<para>Le plus simple est de saisir <kbd>x</kbd> et <kbd>RETURN</kbd> et de corriger la
coquille.  Alternativement vous pourriez saisir <kbd>?</kbd> et <kbd>RETURN</kbd>
pour voir les autres options.
</para>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1009"><samp>*</samp>, invite</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1010">invite <samp>*</samp></indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1505">\stop</indexterm></findex>
<para>Il y a deux autres scénarios.  Le premier est que vous ayez omis le
<code>\end&lbrace;document&rbrace;</code> ou fait une faute de frappe dessus.  Dans ce cas
&latex; produit en invite <samp>*</samp>.  Vous pouvez revenir à la ligne de
commande en tapant <kbd>\stop</kbd> et <kbd>RETURN</kbd>.
</para>
<para>Le dernier scénario est que vous ayez fait une faute de frappe sur le
nom de fichier.  Par exemple, au lieu de <code>pdflatex test</code> vous
auriez tapé <code>pdflatex tste</code>.
</para>
<example endspaces=" ">
<pre xml:space="preserve">! I can't find file `tste'.
&lt;*&gt; tste

(Press Enter to retry, or Control-D to exit)
Please type another input file name:
</pre></example>

<noindent></noindent>
<para>Le plus simple est de saisir <kbd>CTRL D</kbd> (en appuyant sur les touches
Contrôle et d simultanément), et d&textrsquo;ensuite retaper la ligne de commande
correcte.
</para>

</section>
</chapter>
<node name="Document-templates" spaces=" "><nodename>Document templates</nodename><nodenext automatic="on">License translation</nodenext><nodeprev automatic="on">Command line interface</nodeprev><nodeup automatic="on">Top</nodeup></node>
<appendix spaces=" "><sectiontitle>Patrons de documents</sectiontitle>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1011">patron de document</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1012">modèle de document</indexterm></cindex>

<para>Bien qu&textrsquo;ils soient illustratifs, ces patrons de document vous seront
peut-être utiles.  Davantage de ressources de patrons sont listées à
<url><urefurl>https://tug.org/interest.html#latextemplates</urefurl></url>.
</para>
<menu endspaces=" ">
<menuentry leadingtext="* "><menutitle separator=": ">patron <code>beamer</code></menutitle><menunode separator=".">beamer template</menunode><menudescription><pre xml:space="preserve">
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">patron <code>article</code></menutitle><menunode separator=".">article template</menunode><menudescription><pre xml:space="preserve">
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">patron <code>book</code></menutitle><menunode separator=".">book template</menunode><menudescription><pre xml:space="preserve">
</pre></menudescription></menuentry><menuentry leadingtext="* "><menutitle separator=": ">patron <code>book</code> plus élaboré</menutitle><menunode separator=".">Larger book template</menunode><menudescription><pre xml:space="preserve">
</pre></menudescription></menuentry></menu>


<node name="beamer-template" spaces=" "><nodename>beamer template</nodename><nodenext automatic="on">article template</nodenext><nodeup automatic="on">Document templates</nodeup></node>
<section spaces=" "><sectiontitle>Un patron <code>beamer</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="1013"><code>beamer</code> patron et classe</indexterm></cindex>
<cindex index="cp" spaces=" "><indexterm index="cp" number="1014">patron, <code>beamer</code></indexterm></cindex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1506"><r>paquetage</r> <code>beamer</code></indexterm></findex>
<findex index="fn" spaces=" "><indexterm index="fn" number="1507"><code>beamer</code>, <r>paquetage</r></indexterm></findex>


<para>La classe <code>beamer</code> crée des présentations en diapositives. Elle a
de très nombreuses possibilités, mais voici un patron de base :
</para>
<verbatim xml:space="preserve">
\documentclass{beamer}
\usepackage[latin1]{inputenc}

\title{Patron pour la classe Beamer}
\author{Alex L'Auteur}
\date{31 juillet 2020}

\begin{document}

\maketitle

% sans [fragile], n'importe quel code {verbatim} se prend des erreurs mystérieuses.
\begin{frame}[fragile]
 \frametitle{Première diapositive}

\begin{verbatim}
  C'est \verbatim!
\end{verbatim}

\end{frame}

\end{document}
</verbatim>

<para>Le paquetage Beamer sur le CTAN :
<url><urefurl>https://ctan.org/pkg/beamer</urefurl></url>.
</para>
</section>
<node name="article-template" spaces=" "><nodename>article template</nodename><nodenext automatic="on">book template</nodenext><nodeprev automatic="on">beamer template</nodeprev><nodeup automatic="on">Document templates</nodeup></node>
<section spaces=" "><sectiontitle>Patron <code>article</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="1015">patron (simple), <code>article</code></indexterm></cindex>

<para>Un patron simple pour un article.
</para>
<verbatim xml:space="preserve">
\documentclass{article}
\title{Patron de la classe article}
\author{Alex Author}

\begin{document}
\maketitle

\section{Première section}
Du texte.

\subsection{Première section, première sous-section}
Encore du texte.

\section{Deuxième section}
Et du texte.

\end{document}
</verbatim>

</section>
<node name="book-template" spaces=" "><nodename>book template</nodename><nodenext automatic="on">Larger book template</nodenext><nodeprev automatic="on">article template</nodeprev><nodeup automatic="on">Document templates</nodeup></node>
<section spaces=" "><sectiontitle>Un patron <code>book</code></sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="1016">patron, <code>book</code></indexterm></cindex>

<para>Voici un patron simple pour un livre. <xref label="Larger-book-template"><xrefnodename>Larger book template</xrefnodename></xref>, pour
un patron plus élaboré.
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass&lbrace;book&rbrace;
\title&lbrace;Le Patron de la classe book&rbrace;
\author&lbrace;Alex L'Auteur&rbrace;

\begin&lbrace;document&rbrace;
\maketitle

\chapter&lbrace;Premier&rbrace;
Du texte.

\chapter&lbrace;Second&rbrace;
Et du texte.

\section&lbrace;Un sujet secondaire&rbrace;
La fin.

\end&lbrace;document&rbrace;
</pre></example>


</section>
<node name="Larger-book-template" spaces=" "><nodename>Larger book template</nodename><nodeprev automatic="on">book template</nodeprev><nodeup automatic="on">Document templates</nodeup></node>
<section spaces=" "><sectiontitle>Un patron <code>book</code> plus élaboré</sectiontitle>

<cindex index="cp" spaces=" "><indexterm index="cp" number="1017">patron <code>book</code></indexterm></cindex>

<para>Voici un patron quelque peu élaboré pour un livre. <xref label="book-template"><xrefnodename>book template</xrefnodename></xref>,
pour un patron plus simple.
</para>
<para>Ce patron utilise un <code>\frontmatter</code>, <code>\mainmatter</code>, et
<code>\backmatter</code> pour contrôler la typographie des trois zones
principales d&textrsquo;un livre (<pxref label="_005cfrontmatter-_0026-_005cmainmatter-_0026-_005cbackmatter"><xrefnodename>\frontmatter &amp; \mainmatter &amp;
\backmatter</xrefnodename></pxref>).  Le livre a une bibliographie et un index.
</para>
<para>Il est également à noter qu&textrsquo;il utilise <code>\include</code> et
<code>\includeonly</code> (<pxref label="Splitting-the-input"><xrefnodename>Splitting the input</xrefnodename></pxref>).  Lorsque vous
travaillez sur un chapitre vous pouvez ne pas compiler tous les autres
chapitres en mettant en commentaire les entrées correspondantes dans les
arguments de <code>\includeonly</code>.  Ceci accélère la compilation sans
perdre aucune information telle que les renvois.  (La matière qu&textrsquo;il
n&textrsquo;est pas nécessaire de mettre sur une nouvelle page est inclus avec
<code>\input</code> au lieu de <code>\include</code> ; mais ceci au dépens du
bénéfice de maintenir les valeurs de renvois).
</para>
<example endspaces=" ">
<pre xml:space="preserve">\documentclass[titlepage]&lbrace;book&rbrace;
\usepackage&lbrace;makeidx&rbrace;\makeindex

\title&lbrace;Book Class Template&rbrace;
\author&lbrace;Alex Author&rbrace;

\includeonly&lbrace;%
%  frontcover,
  preface,
  chap1,
% appenA,
  &rbrace;

\begin&lbrace;document&rbrace;
\frontmatter
\include&lbrace;frontcover&rbrace;
  % maybe comment out while drafting:
\maketitle \input&lbrace;dedication&rbrace; \input&lbrace;copyright&rbrace;
\tableofcontents
\include&lbrace;preface&rbrace;

\mainmatter
\include&lbrace;chap1&rbrace;
...
\appendix
\include&lbrace;appenA&rbrace;
...

\backmatter
\bibliographystyle&lbrace;apalike&rbrace;
\addcontentsline&lbrace;toc&rbrace;&lbrace;chapter&rbrace;&lbrace;Bibliography&rbrace;
\bibliography
\addcontentsline&lbrace;toc&rbrace;&lbrace;chapter&rbrace;&lbrace;Index&rbrace;
\printindex
\include&lbrace;backcover&rbrace;
\end&lbrace;document&rbrace;
</pre></example>


</section>
</appendix>
<node name="License-translation" spaces=" "><nodename>License translation</nodename><nodenext spaces=" ">Concept Index</nodenext><nodeprev spaces=" ">Document templates</nodeprev><nodeup spaces=" ">Top</nodeup></node>
<!-- comment  node-name,  next,  previous,  up -->
<appendix spaces=" "><sectiontitle>Traduction de la licence</sectiontitle>

<para>La traduction qui suit est donnée uniquement à titre informatif, et ne
remplace pas le texte en anglais donné au début de ce document.
</para>
<para>Permission vous est donnée de distribuer des copies conformes de ce
manuel à condition que les mentions du droit d&textrsquo;auteur et de permission
soient préservées sur toutes les copies.
</para>
<ignore>
Il est permis de traiter ce fichier par @TeX{} et d'imprimer le
résultat, à condition que le document imprimé porte une mention de
permission de copier identique à celle-ci à l'exception de la
suppression de ce paragraphe (ce paragraphe n'étant pas pertinent pour
le manuel imprimé).
</ignore>

<para>Permission vous est donnée de copier et distribuer des versions
modifiées de ce manuel dans les conditions d&textrsquo;une copie conforme, à
condition que l&textrsquo;ensemble de l&textrsquo;ouvrage dérivé résultant soit distribué
sous les termes d&textrsquo;une mention de permission identique à celle-ci.
</para>
<para>Permission vous est donnée de copier et distribuer des traductions de ce
manuel dans une autre langue, dans les conditions ci-dessus pour les
versions modifiées.
</para>
</appendix>
<node name="Concept-Index" spaces=" "><nodename>Concept Index</nodename><nodenext automatic="on">Command Index</nodenext><nodeprev automatic="on">License translation</nodeprev><nodeup automatic="on">Top</nodeup></node>
<unnumbered spaces=" "><sectiontitle>Index des concepts</sectiontitle>

<printindex value="cp" line="cp"></printindex>


<!-- c The name of the `Commande Index' node must NOT be altered for ltx-help.el. -->
</unnumbered>
<node name="Command-Index" spaces=" "><nodename>Command Index</nodename><nodeprev automatic="on">Concept Index</nodeprev><nodeup automatic="on">Top</nodeup></node>
<unnumbered spaces=" "><sectiontitle>Index des commandes</sectiontitle>

<printindex value="fn" line="fn"></printindex>

</unnumbered>
<bye></bye>
</texinfo>
