Sophie

Sophie

distrib > Mandriva > current > i586 > media > main-updates > by-pkgid > ef94ce641418407205f56847b8006626 > files > 221

kde-l10n-fr-4.4.5-3.1mdv2010.2.noarch.rpm

<chapter id="advanced-editing-tools">
<chapterinfo>
<authorgroup>
<author
>&Anders.Lund; &Anders.Lund.mail;</author>
<author
>&Dominik.Haumann; &Dominik.Haumann.mail;</author>
&traducteurEquipeKDE; 
</authorgroup>
</chapterinfo>
<title
>Outils d'édition avancée</title>

<sect1 id="advanced-editing-tools-comment">

<title
>Commenter / Décommenter</title>

<para
>Les commandes Commenter et Décommenter, disponibles dans le menu <guimenu
>Outils</guimenu
>, permettent d'ajouter ou de supprimer des indicateurs de commentaires à la sélection ou à la ligne actuelle, s'il n'y a pas de texte sélectionné et si le format du texte qu'on modifie prend en charge les commentaires.</para>

<para
>Les règles qui régissent la façon de créer des commentaires étant établies dans les définitions de syntaxe, l'ajout/la suppression de commentaires n'est pas possible si la coloration syntaxique n'est pas activée. </para>

<para
>Certains formats définissent des indicateurs de commentaire sur une seule ligne, d'autres sur plusieurs lignes et d'autres encore, les deux. Si les indicateurs sur plusieurs lignes ne sont pas disponibles, il n'est pas possible de commenter une sélection qui ne contient pas la totalité de sa dernière ligne.</para>

<para
>Si un indicateur de commentaire sur une seule ligne est disponible, le commentaire ligne par ligne aura la préférence là où il est applicable, car ce comportement contribue à éviter des problèmes avec les commentaires imbriqués.</para>

<para
>Lorsqu'on supprime des indicateurs de commentaire, il ne faut pas sélectionner de texte non commenté. Lorsqu'on supprime des indicateurs de commentaire sur plusieurs lignes d'une sélection, tout espace en dehors des indicateurs de commentaire est ignoré.</para>

<para
><indexterm
><primary
>commenter</primary
></indexterm
> Pour placer des indicateurs de commentaire, cliquez sur la ligne de menu <menuchoice
><guimenu
>Outils</guimenu
> <guimenuitem
>Commenter</guimenuitem
></menuchoice
> ou le raccourci clavier correspondant, par défaut <keycombo action="simul"
>&Ctrl;<keycap
>#</keycap
></keycombo
>.</para>

<para
><indexterm
><primary
>décommenter</primary
></indexterm
> Pour supprimer des indicateurs de commentaire, cliquez sur la ligne de menu <menuchoice
><guimenu
>Outils</guimenu
> <guimenuitem
>Décommenter</guimenuitem
></menuchoice
> ou le raccourci clavier correspondant, par défaut <keycombo action="simul"
>&Ctrl;&Maj;<keycap
>#</keycap
></keycombo
>.</para>

</sect1>

<sect1 id="advanced-editing-tools-commandline">
<title
>La ligne de commande du composant éditeur</title>

<para
>Le composant éditeur de &kate; offre une ligne de commande interne permettant d'effectuer diverses actions à partir d'une interface graphique minimale. La ligne de commande est un élément de texte situé au bas de la zone d'édition. Pour la voir, cliquez sur <menuchoice
><guimenu
>Affichage</guimenu
><guimenuitem
>Afficher la ligne de commande</guimenuitem
></menuchoice
> ou utilisez le raccourci clavier (par défaut, <keycombo action="simul"
><keycap
>F7</keycap
></keycombo
>). L'éditeur fournit un ensemble de commandes comme décrit ci-dessous. Des commandes additionnelles peuvent être fournies par des modules externes.</para>

<para
>Pour exécuter une commande, saisissez cette dernière, puis appuyez sur la touche Entrée. La ligne de commande indique si elle a abouti et affiche éventuellement un message. Si vous avez saisi la ligne de commande en appuyant sur <keycap
>F7</keycap
>, elle disparaît automatiquement au bout de quelques secondes. Pour effacer le message et saisir une nouvelle commande, appuyez sur <keycap
>F7</keycap
> à nouveau.</para>

<para
>La ligne de commande est dotée d'un système d'aide intégré : exécutez la commande <command
>help</command
> pour démarrer. Pour afficher une liste de toutes les commandes disponibles, saisissez <command
>help list</command
>. Pour afficher l'aide concernant une commande donnée, saisissez <command
>help <replaceable
>commande</replaceable
></command
>.</para>

<para
>Comme la ligne de commande comporte un historique intégré, vous pouvez réutiliser les commandes déjà saisies. Pour parcourir l'historique, utilisez les touches <keycap
>Haut</keycap
> et <keycap
>Bas</keycap
>. Lorsque vous affichez l'historique des commandes, la partie argument de la commande est sélectionnée, ce qui permet d'écraser aisément les arguments.</para>

<sect2 id="advanced-editing-tools-commandline-commands">
<title
>Commandes standard de la ligne de commande</title>

<sect3 id="advanced-editing-tools-commandline-commands-configure">
<title
>Commandes pour configurer l'éditeur</title>

<para
>Ces commandes sont fournies par le composant éditeur et permettent de configurer le document actif et son affichage uniquement. Ce comportement est pratique si vous voulez employer un autre paramètre que ceux par défaut, par exemple pour l'indentation. </para>

<variablelist>
<title
>Types d'arguments</title>

<varlistentry>
<term
>BOOLÉEN</term>
<listitem
><para
>On emploie cet argument avec les commandes qui servent à (dés)activer tel ou tel élément. Les valeurs admises sont <userinput
>on</userinput
>, <userinput
>off</userinput
>, <userinput
>true</userinput
>, <userinput
>false</userinput
>, <userinput
>1</userinput
> ou <userinput
>0</userinput
></para
></listitem>
</varlistentry>

<varlistentry>
<term
>ENTIER</term>
<listitem
><para
>Un nombre entier</para
></listitem>
</varlistentry>

<varlistentry>
<term
>CHAÎNE</term>
<listitem
><para
>Une chaîne de caractères</para
></listitem>
</varlistentry>

</variablelist>

<variablelist>

<varlistentry>
<term
><cmdsynopsis
><command
>set-tab-width</command
><arg
>ENTIER largeur</arg
></cmdsynopsis
></term>
<listitem
><para
>Associe la largeur de tabulation au nombre <userinput
>largeur</userinput
></para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-indent-width</command
><arg
>ENTIER largeur</arg
></cmdsynopsis
></term>
<listitem
><para
>Associe la largeur d'indentation au nombre <userinput
>largeur</userinput
>. Utilisé seulement si vous indentez avec des espaces.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-word-wrap-column</command
><arg
>ENTIER largeur</arg
></cmdsynopsis
></term>
<listitem
><para
>Associe la largeur de ligne pour le retour à la ligne forcé à <userinput
>largeur</userinput
>. Utilisé si vous avez choisi le retour à la ligne automatique pour votre texte.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-icon-border</command
><arg
>BOOLÉEN activer</arg
> </cmdsynopsis
></term>
<listitem
><para
>Définit la visibilité de la bordure d'icônes.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-folding-markers</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Définit la visibilité de la bordure des indicateurs de pliage.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-line-numbers</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Définit la visibilité du panneau des numéros de ligne.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-replace-tabs</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Si cette option est cochée, les tabulations sont remplacées par des espaces au fur et à mesure que vous saisissez au clavier. </para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-remove-trailing-space</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Si cette option est cochée, les espaces de fin sont supprimés chaque fois que le curseur change de ligne.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-show-tabs</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Si cette option est cochée, les caractères de tabulation et l'espace de fin de ligne seront représentés par un petit point.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-indent-spaces</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Si cette option est cochée, l'éditeur indente avec des espaces <option
>indentation-largeur</option
> pour chaque niveau d'indentation plutôt qu'avec un caractère de tabulation.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-mixed-indent</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Si cette option est cochée, &kate; utilise un mélange de tabulations et d'espaces pour l'indentation. Chaque niveau d'indentation aura une largeur <option
>indentation-largeur</option
> et d'autres niveaux d'indentation seront optimisés pour pouvoir utiliser autant de caractères de tabulation que possible.</para>
<para
>Lorsqu'elle est exécutée, cette commande définit en outre l'indentation avec des espaces activée et, si la largeur d'indentation n'est pas spécifiée, elle est définie à la moitié de la <option
>tab-width</option
> du document au moment de l'exécution.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-word-wrap</command
><arg
>BOOLÉEN largeur</arg
></cmdsynopsis
></term>
<listitem
><para
>Active le retour à la ligne dynamique en fonction de <userinput
>activer</userinput
></para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-replace-tabs-save</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Si cette option est cochée, les tabulations sont remplacées par un blanc à chaque fois que le document est enregistré.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-remove-trailing-space-save</command
><arg
>BOOLÉEN activer</arg
></cmdsynopsis
></term>
<listitem
><para
>Lorsque cette option est cochée, l'espace de fin est supprimé de chaque ligne à chaque fois que le document est enregistré.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-indent-mode</command
><arg
>nom</arg
></cmdsynopsis
></term>
<listitem
><para
>Définit le mode d'indentation automatique à <userinput
>nom</userinput
>. Si <userinput
>nom</userinput
> n'est pas connu, le mode est associé à « none ». Les modes autorisés sont « cstyle », « csands », « xml », « python », « varindent » et « none ».</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>set-highlight</command
><arg
>coloration syntaxique</arg
></cmdsynopsis
></term>
<listitem
><para
>Définit le système de coloration syntaxique pour le document. L'argument doit être un nom de coloration syntaxique autorisé, comme on le voit dans le menu <menuchoice
><guimenu
>Outils</guimenu
><guisubmenu
>Coloration syntaxique</guisubmenu
></menuchoice
>. Cette commande fournit une liste de complétement automatique pour son argument.</para
></listitem>
</varlistentry>

</variablelist>

</sect3>

<sect3 id="advanced-editing-tools-commandline-commands-edit">
<title
>Commandes d'édition</title>

<para
>Ces commandes modifient le document actuel.</para>

<variablelist>
<varlistentry>
<term
><cmdsynopsis
><command
>indent</command
></cmdsynopsis
></term>
<listitem
><para
>Indente les lignes sélectionnées ou la ligne actuelle.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>unindent</command
></cmdsynopsis
></term>
<listitem
><para
>Désindente les lignes sélectionnées ou la ligne actuelle.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>cleanindent</command
></cmdsynopsis
></term>
<listitem
><para
>Nettoie l'indentation des lignes sélectionnées ou de la ligne actuelle en fonction des paramètres d'indentation du document. </para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>comment</command
></cmdsynopsis
></term>
<listitem
><para
>Insère des indicateurs de commentaire pour créer sur la sélection, les lignes sélectionnées ou la ligne actuelle, un commentaire en fonction du format du texte, comme défini par la coloration syntaxique concernant le document.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>uncomment</command
></cmdsynopsis
></term>
<listitem
><para
>Supprime les indicateurs de commentaires de la sélection, des lignes sélectionnées ou de la ligne actuelle en fonction du format du texte, comme défini par la définition de la coloration syntaxique concernant le document.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>kill-line</command
></cmdsynopsis
></term>
<listitem
><para
>Supprime la ligne actuelle.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>replace</command
><arg
>motif</arg
><arg
>remplacement</arg
></cmdsynopsis
></term>
<listitem
><para
>Remplace le texte correspondant au <userinput
>motif</userinput
> par <userinput
>remplacement</userinput
>. Si vous voulez ajouter un blanc dans le <userinput
>motif</userinput
>, vous devez entourer d'apostrophes ou de guillemets à la fois le <userinput
>motif</userinput
> et le <userinput
>remplacement</userinput
>. Si les arguments n'ont pas de guillemets, le premier mot sert de <userinput
>motif</userinput
> et le reste de <userinput
>remplacement</userinput
>. Si <userinput
>remplacement</userinput
> est vide, chaque occurrence de <userinput
>motif</userinput
> est supprimée.</para>
<para
>Vous pouvez définir des drapeaux pour configurer la recherche, en ajoutant un caractère « : » (deux points), suivi d'une ou plusieurs lettres représentant une configuration, ce qui donne la forme <userinput
>replace:options motif remplacement</userinput
>. Les options disponibles sont les suivantes : <variablelist>

<varlistentry>
<term
><userinput
>b</userinput
></term>
<listitem
><para
>Recherche arrière.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>c</userinput
></term>
<listitem
><para
>Recherche à partir de la position du curseur.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>e</userinput
></term>
<listitem
><para
>Recherche dans la sélection uniquement.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>r</userinput
></term>
<listitem
><para
>Recherche sur des expressions rationnelles. Si défini, vous pouvez utiliser <userinput
>\N</userinput
>, où N est un nombre représentant des captures dans la chaîne de remplacement.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>s</userinput
></term>
<listitem
><para
>Recherche sensible à la casse.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>p</userinput
></term>
<listitem
><para
>Invite de permission pour remplacer la prochaine occurrence.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>w</userinput
></term>
<listitem
><para
>Correspondance de mots entiers uniquement.</para
></listitem>
</varlistentry>

</variablelist>

</para>
</listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>date</command
><arg
>format</arg
></cmdsynopsis
></term>
<listitem
><para
>Insère une chaîne date/heure comme défini par le format spécifié <userinput
>format</userinput
> ou le format « aaaa-MM-jj hh:mm:ss », si aucun n'est indiqué. Les traductions suivantes sont effectuées lors de l'interprétation de <userinput
>format</userinput
> : <informaltable
> <tgroup cols="2"
> <tbody>
<row
><entry
><literal
>d</literal
></entry
><entry
>Le jour sous la forme d'un nombre sans zéro de début (1-31).</entry
></row>
<row
><entry
><literal
>dd</literal
></entry
><entry
>Le jour sous la forme d'un nombre avec un zéro de début (01-31).</entry
></row>
<row
><entry
><literal
>ddd</literal
></entry
><entry
>Le nom abrégé du jour localisé (par exemple 'Lun'..'Dim').</entry
></row>
<row
><entry
><literal
>dddd</literal
></entry
><entry
>Le nom entier du jour localisé (par exemple 'Lundi'..'Dimanche').</entry
></row>
<row
><entry
><literal
>M</literal
></entry
><entry
>Le mois sous la forme d'un nombre sans zéro de début (1-12).</entry
></row>
<row
><entry
><literal
>MM</literal
></entry
><entry
>Le mois sous la forme d'un nombre avec un zéro de début (01-12).</entry
></row>
<row
><entry
><literal
>MMM</literal
></entry
><entry
>Le nom abrégé du mois localisé (par exemple 'Jan'..'Déc').</entry
></row>
<row
><entry
><literal
>aa</literal
></entry
><entry
>L'année sous la forme d'un nombre à deux chiffres (00-99).</entry
></row>
<row
><entry
><literal
>aaaa</literal
></entry
><entry
>L'année sous la forme d'un nombre à quatre chiffres (1752-8000).</entry
></row>
<row
><entry
><literal
>h</literal
></entry
><entry
>L'heure sans zéro de début (0..23 ou 1..12 en cas d'affichage AM/PM).</entry
></row>
<row
><entry
><literal
>hh</literal
></entry
><entry
>L'heure avec un zéro de début (00..23 ou 01..12 en cas d'affichage AM/PM).</entry
></row>
<row
><entry
><literal
>m</literal
></entry
><entry
>La minute sans zéro de début (0..59).</entry
></row>
<row
><entry
><literal
>mm</literal
></entry
><entry
>La minute avec un zéro de début (00..59).</entry
></row>
<row
><entry
><literal
>s</literal
></entry
><entry
>La seconde sans zéro de début (0..59).</entry
></row>
<row
><entry
><literal
>ss</literal
></entry
><entry
>La seconde avec un zéro de début (00..59).</entry
></row>
<row
><entry
><literal
>z</literal
></entry
><entry
>Les millisecondes sans zéro de début (0..999).</entry
></row>
<row
><entry
><literal
>zzz</literal
></entry
><entry
>Les millisecondes avec des zéros de début (000..999).</entry
></row>
<row
><entry
><literal
>AP</literal
></entry
><entry
>Utiliser l'affichage AM/PM. AP sera remplacé soit par « AM », soit par « PM ».</entry
></row>
<row
><entry
><literal
>ap</literal
></entry
><entry
>Utiliser l'affichage. ap sera remplacé soit par « am », soit par « pm ».</entry
></row>

</tbody>
</tgroup>
</informaltable>

</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>char</command
><arg
>identifiant</arg
></cmdsynopsis
></term>
<listitem>
<para
>Cette commande permet d'insérer des caractères spéciaux par leur identifiant numérique, sous forme décimale, octale ou hexadécimale. Pour l'utiliser, ouvrez la boîte de dialogue Commandes d'édition, et saisissez <userinput
>char: [numéro]</userinput
> dans la zone de saisie, puis cliquez sur <guibutton
>Ok</guibutton
>.</para>

<example>
<title
>Exemples avec <command
>char</command
></title>

<para
>Entrée : <userinput
>char:234</userinput
></para>
<para
>Sortie : <computeroutput
>&#234;</computeroutput
></para>
<para
>Entrée : <userinput
>char:0x1234</userinput
></para>
<para
>Sortie : <computeroutput
>&#x1234;</computeroutput
></para>
</example>

</listitem>
</varlistentry>

<varlistentry>
<term>
<indexterm
><primary
>remplacer, dans le style de sed</primary>
<secondary
>chercher, dans le style de sed</secondary
></indexterm>
<command
>s///[ig]</command
> <command
>%s///[ig]</command
></term>

<listitem>
<para
>Cette commande effectue une opération de recherche / remplacement comme sed dans la ligne actuelle, ou dans tout le fichier (<command
>%s///</command
>).</para>

<para
>En bref, on recherche dans le texte une expression qui correspond au <emphasis
>texte recherché</emphasis
>, l'expression rationnelle entre la première et la deuxième barre oblique. Lorsqu'une correspondance est trouvée, la partie de texte correspondant est remplacée par l'expression située entre la partie du milieu et la dernière partie de la chaîne. Les parenthèses dans le motif de recherche créent des <emphasis
>références arrière</emphasis
>, c'est-à-dire que la commande se souvient quelle partie du motif correspondait dans les parenthèses ; ces chaînes peuvent être réutilisées dans le motif de remplacement, référencées par <userinput
>\1</userinput
> pour la première paire de parenthèses, <userinput
>\2</userinput
> pour la deuxième, etc.</para>

<para
>Pour rechercher une <literal
>(</literal
> ou une <literal
>)</literal
>, vous devez la faire  précéder d'une barre oblique inverse, qui joue le rôle de <emphasis
>caractère d'échappement</emphasis
> : <userinput
>\(\)</userinput
></para>

<para
>Si vous placez un <userinput
>i</userinput
> à la fin de l'expression, l'expression correspondante sera insensible à la casse. Si vous placez un <userinput
>g</userinput
> à la fin, toutes les occurrences du motif seront remplacées, sinon seule la première occurrence est remplacée.</para>

<example>

<title
>Remplacer du texte dans la ligne actuelle</title>

<para
>Votre compilateur préféré vient de s'arrêter en vous indiquant que la classe <classname
>maClasse</classname
> mentionnée à la ligne 3902 de votre fichier source n'est pas définie.</para>

<para
>Il s'agit évidemment de <classname
>MaClasse</classname
> ! Allez à la ligne 3902 et, au lieu d'essayer de trouver le mot dans le texte, ouvrez la boîte de dialogue Commande d'édition, saisissez <userinput
>s/maClasse/MaClasse/i</userinput
>, cliquez sur le bouton <guibutton
>Ok</guibutton
>, enregistrez le fichier et compilez &ndash; avec succès, sans l'erreur.</para>

</example>

<example>
<title
>Remplacer du texte dans le fichier entier</title>

<para
>Imaginez que vous avez un fichier dans lequel vous mentionnez plusieurs fois « Mlle Dupont » lorsque quelqu'un vient vous informer qu'elle vient de se marier avec « M. Martin ». Vous voulez, bien évidemment, remplacer chaque occurrence de « Mlle Dupont » par « Mme Martin ».</para>

<para
>Sur la ligne de commande, saisissez <userinput
>%s/Melle Dupont/Mme Martin/</userinput
> et appuyez sur Entrée. Vous avez terminé.</para>

</example>

<example>
<title
>Un exemple plus avancé</title>

<para
>Cet exemple utilise les <emphasis
>références arrière</emphasis
> ainsi qu'une <emphasis
>classe de caractères</emphasis
> (si vous ne savez pas de quoi il s'agit, consultez la documentation relative à ce sujet mentionnée ci-dessous).</para>

<para
>Supposons que vous ayez la ligne suivante : <programlisting
>void MyClass::DoStringOps( String      &amp;foo, String &amp;bar String *p, int  &amp;a, int &amp;b )</programlisting>
</para>
<para
>Maintenant, vous vous rendez compte que ces lignes ne donnent pas du code élégant et que vous voulez utiliser le mot clé <constant
>const</constant
> pour tous les arguments « adresse de », ceux caractérisés par l'opérateur &amp; avant le nom d'argument. Vous voulez aussi simplifier les espaces,pour qu'il n'y ait qu'un caractère d'espacement entre les mots.</para>

<para
>Ouvrez la boîte de dialogue « Commande d'édition » et saisissez : <userinput
>s/\s+(\w+)\s+(&amp;)/ const \1 \2/g</userinput
>, puis cliquez sur le bouton <guibutton
>Ok</guibutton
>. Le <userinput
>g</userinput
> à la fin de l'expression fait recompiler l'expression rationnelle pour chaque occurrence, pour enregistrer les <emphasis
>références arrière</emphasis
>.</para>

<para
>Sortie : <computeroutput
>void MyClass::DoStringOps( const String &amp;foo, const String &amp;bar String *p, const int &amp;a, const int &amp;b )</computeroutput
></para>

<para
>Mission réussie ! Mais que s'est-il passé ? Nous avons recherché des blancs (<literal
>\s+</literal
>), suivis d'un ou plusieurs caractères alphabétiques (<literal
>\w+</literal
>), eux-mêmes suivis d'un autre blanc (<literal
>\s+</literal
>) suivi d'une esperluette. Le processus a enregistré le fragment alphanumérique et l'esperluette pour le réutiliser lors de l'opération de remplacement. Puis, nous avons remplacé la partie correspondante de la ligne par un blanc suivi de « const », suivi d'un blanc, suivi de notre fragment alphanumérique enregistré (<literal
>\1</literal
>), lui-même suivi d'un blanc et de notre esperluette enregistrée (<literal
>\2</literal
>)</para>

<para
>Maintenant, comme dans certains cas, le fragment alphanumérique était « String » et dans d'autres « int », l'utilisation de la classe de caractères <literal
>//w</literal
> et du quantificateur <literal
>+</literal
> a été un grand avantage.</para>

</example>

</listitem>

</varlistentry>

</variablelist>

</sect3>

<sect3 id="advanced-editing-tools-commandline-commands-navigation">
<title
>Commandes de navigation</title>

<variablelist>

<varlistentry>
<term
><cmdsynopsis
><command
>goto</command
><arg
>ENTIER ligne</arg
></cmdsynopsis
></term>
<listitem
><para
>Cette commande permet d'aller jusqu'à la ligne spécifiée.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>find</command
><arg
>motif</arg
></cmdsynopsis
></term>
<listitem
><para
>Cette commande permet d'aller à la première occurrence de <userinput
>motif</userinput
>, en fonction de la configuration. Vous pouvez trouver les occurrences suivantes à l'aide de <menuchoice
><guimenu
>Édition</guimenu
><guimenuitem
>Poursuivre la recherche</guimenuitem
></menuchoice
> (le raccourci par défaut est <keycap
>F3</keycap
>).</para>
<para
>Il est possible de configurer la commande Chercher en ajoutant à la fin un caractère « : », suivi d'une ou plusieurs options. La forme est <userinput
>find:options motif</userinput
>. Les options suivantes sont prises en charge : <variablelist>

<varlistentry>
<term
><userinput
>b</userinput
></term>
<listitem
><para
>Recherche arrière.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>c</userinput
></term>
<listitem
><para
>Recherche à partir de la position du curseur.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>e</userinput
></term>
<listitem
><para
>Recherche dans la sélection uniquement.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>r</userinput
></term>
<listitem
><para
>Recherche sur des expressions rationnelles. Si défini, vous pouvez utiliser <userinput
>\N</userinput
>, où N est un nombre représentant des captures dans la chaîne de remplacement.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>s</userinput
></term>
<listitem
><para
>Recherche sensible à la casse.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>w</userinput
></term>
<listitem
><para
>Correspondance de mots entiers uniquement.</para
></listitem>
</varlistentry>

</variablelist>

</para>

</listitem>

</varlistentry>

<varlistentry>
<term
><cmdsynopsis
><command
>ifind</command
><arg
>motif</arg
></cmdsynopsis
></term>
<listitem
><para
>Cette commande fournit une recherche au fur et à mesure de la saisie (« as-you-type »). On peut configurer le comportement ou la recherche en ajoutant à la fin un caractère « : », suivi d'une ou plusieurs options, comme suit : <userinput
>ifind:options motif</userinput
>. Les options autorisées sont <variablelist>
<varlistentry>
<term
><userinput
>b</userinput
></term>
<listitem
><para
>Recherche arrière.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>r</userinput
></term>
<listitem
><para
>Effectue une recherche sur des expressions rationnelles.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>s</userinput
></term>
<listitem
><para
>Recherche sensible à la casse.</para
></listitem>
</varlistentry>

<varlistentry>
<term
><userinput
>c</userinput
></term>
<listitem
><para
>Recherche à partir de la position du curseur.</para
></listitem>
</varlistentry>

</variablelist>
</para
></listitem>
</varlistentry>

</variablelist>

</sect3>

</sect2>

</sect1>

<sect1 id="advanced-editing-tools-code-folding">
<title
>Utiliser le pliage du code</title>

<para
>Le pliage du code permet de cacher des parties d'un document dans l'éditeur, ce qui facilite l'affichage de la vue d'ensemble de documents volumineux. Dans &kate;, les régions pliables sont calculées à l'aide de règles définies dans les définitions de coloration syntaxique, et le pliage du code n'est donc disponible que dans certains formats - en général le code source du programme, le marquage XML et similaires. La plupart des définitions de coloration syntaxique prenant en charge le pliage du code permet également de définir manuellement des régions pliables, en général à l'aide des mots clés <userinput
>DÉBUT</userinput
> et <userinput
>FIN</userinput
>.</para>

<para
>Pour utiliser la fonctionnalité de pliage du code, activez les marqueurs suivants à l'aide de l'élément de menu <menuchoice
><guimenu
>Affichage</guimenu
><guimenuitem
>Afficher les indicateurs de pliage</guimenuitem
></menuchoice
> s'ils ne sont pas déjà visibles. Le panneau des indicateurs de pliage du côté gauche de l'écran affiche une vue graphique des régions pliables, avec des signes +/- pour indiquer l'opération possible sur une région donnée : un - signifie que la région est dépliée. Un clic sur - replie la région et sur + sera affiché à la place.</para>

<para
>Quatre commandes sont prévues pour manipuler l'état des régions de pliage. Consultez la <link linkend="view-code-folding"
>documentation du menu</link
>. </para>

<para
>Si vous ne voulez pas employer la fonctionnalité de pliage du code, vous pouvez désactiver l'option <guilabel
>Afficher les indicateurs de pliage (si disponible)</guilabel
> dans la page <link linkend="appearance"
>Apparence</link
> de la configuration de l'éditeur.</para>

</sect1>

<sect1 id="advanced-editing-tools-scripting">
<title
>Étendre &kate; avec des scripts</title>

<para
>Depuis la version 3.4 de &kate; présente dans KDE 4.4, on peut facilement étendre le composant éditeur de &kate; en écrivant des scripts. Le langage de scriptage utilisé est ECMAScript (bien connu sous le nom de JavaScript). &kate; prend en charge deux sortes de scripts : les scripts d'indentation et les scripts de ligne de commande. </para>

<sect2 id="advanced-editing-tools-scripting-indentation">
<title
>Scripts d'indentation</title>

<para
>Scripts d'indentation - également appelés indenteurs - indentent automatiquement le code source au fil de la saisie du texte. À titre d'exemple, après avoir appuyé sur la touche Entrée, le niveau d'indentation augmente en principe. </para>

<para
>Les sections suivantes décrivent étape par étape comment créer le squelette d'un indenteur simple. Premièrement, créez un nouveau fichier <filename
>*.js</filename
> appelé par exemple <filename
>javascript.js</filename
> dans votre dossier personnel local <filename
>$KDEHOME/share/apps/katepart/script</filename
>. </para>

<sect3 id="advanced-editing-tools-scripting-indentation-header">
<title
>L'en-tête du script d'indentation</title>
<para
>L'en-tête du fichier <filename
>javascript.js</filename
> est intégré dans un commentaire et se présente sous la forme suivante <programlisting>
/* kate-script
 * name: JavaScript
 * author: Exemple de nom &lt;exemple.nom@une.adresse.org&gt;
 * license: BSD
 * revision: 1
 * kate-version: 3.4
 * type: indentation
 * required-syntax-style: javascript
 * indent-languages: javascript
 * priority: 0
 *
 * Une ligne sans « : » arrête l'analyse syntaxique de l'en-tête. On peut donc ajouter ici
 * du texte facultativement, comme une licence détaillée.
 */
</programlisting
> Chaque ligne est expliquée en détail ci-après : <itemizedlist>
<listitem
><para
><literal
>kate-script</literal
> [requis] : la chaîne de texte doit apparaître dans la première ligne du fichier <filename
>*.js</filename
>, sinon &kate; ignore le script. </para
></listitem>
<listitem
><para
><literal
>name</literal
> [requis] : le nom de l'indenteur qui apparaît dans le menu <menuchoice
><guimenu
>Outils</guimenu
><guimenuitem
>Indentation</guimenuitem
></menuchoice
> et dans la boîte de dialogue de configuration. </para
></listitem>
<listitem
><para
><literal
>author</literal
> [optionnel] : le nom de l'auteur et les informations de contact. </para
></listitem>
<listitem
><para
><literal
>license</literal
> [optionnel] : la forme abrégée de la licence, comme BSD ou LGPLv3. </para
></listitem>
<listitem
><para
><literal
>revision</literal
> [requis] : la révision du script. Ce nombre devra être augmenté à chaque fois que le script est modifié. </para
></listitem>
<listitem
><para
><literal
>kate-version</literal
> [requis] : version de &kate; minimale nécessaire. </para
></listitem>
<listitem
><para
><literal
>type</literal
> [requis] : le type doit être <quote
><literal
>indentation</literal
></quote
>, sinon &kate; ignore ce script. </para
></listitem>
<listitem
><para
><literal
>required-syntax-style</literal
> [optionnel] : liste séparée par une virgule des styles de coloration syntaxique requis. Ce paramètre est important pour les indenteurs qui s'appuient sur des informations de coloration syntaxique spécifique dans le document. Si un style de syntaxe requis est spécifié, l'indenteur est disponible uniquement quand l'outil de coloration syntaxique est actif. On empêche ainsi un <quote
>comportement indéfini</quote
> causé par l'emploi de l'indenteur sans le schéma de coloration syntaxique attendu. Par exemple, l'indenteur de Ruby l'utilise dans les fichiers <filename
>ruby.js</filename
> et <filename
>ruby.xml</filename
>. </para
></listitem>
<listitem
><para
><literal
>indent-languages</literal
> [optionnel] : liste séparée par une virgule de styles de coloration syntaxique que l'indenteur peut indenter correctement, ex. : c++, java. </para
></listitem>
<listitem
><para
><literal
>priority</literal
> [optionnel] : si plusieurs indenteurs sont adaptés pour un certain fichier mis en surbrillance, la priorité décide de l'indenteur choisi comme indenteur par défaut. </para
></listitem>
</itemizedlist>
</para>

<para
>&kate; lit toutes les paires de la forme <quote
><replaceable
>clé</replaceable
>:<replaceable
>valeur</replaceable
></quote
> jusqu'à ce qu'il ne puisse plus trouver de « : ». Cette fonction implique que l'en-tête puisse contenir du texte arbitraire tel qu'une licence comme le montre l'exemple. </para>

</sect3>

<sect3 id="advanced-editing-tools-scripting-indentation-body">
<title
>Le code source de l'indenteur</title>
<para
>Après avoir spécifié l'en-tête, cette section explique comment fonctionne le scriptage d'indentation lui-même. Voici à quoi ressemble le squelette de base du corps : <programlisting>
triggerCharacters = "{}/:;";
function indent(line, indentWidth, ch)
{
    // appelé pour chaque nouvelle ligne (ch == '\n') et tous les caractères spécifiés dans
    // la variable globale triggerCharacters. Lorsqu'on appelle <menuchoice
><guimenu
>Outils</guimenu
><guimenuitem
>Aligner</guimenuitem
></menuchoice
>,
    // la variable ch est vide, c'est-à-dire ch == ''.
    //
    // voir également : API de scriptage
    return -2;
}
</programlisting
>La fonction <function
>indent()</function
> comporte trois paramètres : <itemizedlist
> <listitem
><para
><literal
>line</literal
> : la ligne à indenter</para
></listitem
> <listitem
><para
><literal
>indentWidth</literal
> : la largeur d'indentation dans la quantité d'espaces</para
></listitem
> <listitem
><para
><literal
>ch</literal
> : soit un caractère de saut de ligne (<literal
>ch == '\n'</literal
>), le caractère déclencheur spécifié dans <literal
>triggerCharacters</literal
> ou vide si l'utilisateur a exécuté l'action <menuchoice
><guimenu
>Outils</guimenu
><guimenuitem
>Aligner</guimenuitem
></menuchoice
>.</para
></listitem
> </itemizedlist
> La valeur de retour de la fonction <function
>indent()</function
> spécifie de combien la ligne sera indentée. Si la valeur de retour est un nombre entier simple, il est interprété comme suit : <itemizedlist
> <listitem
><para
>valeur de retour <literal
>-2</literal
> : ne rien faire</para
></listitem
> <listitem
><para
>valeur de retour <literal
>-1</literal
> : conserver l'indentation (chercher s'il existe une ligne précédente non vide)</para
></listitem
> <listitem
><para
>valeur de retour <literal
> 0</literal
> : les nombres &gt;= 0 spécifient la profondeur d'indentation en espaces</para
></listitem
> </itemizedlist
> Autrement, un tableau de deux éléments peut être retourné : <itemizedlist
> <listitem
><para
><literal
>return [ indent, align ];</literal
></para
></listitem
> </itemizedlist
> Dans ce cas, le premier élément est la profondeur d'indentation comme ci-dessus, avec la même signification des valeurs spéciales. Cependant, le second élément est une valeur absolue représentant une colonne pour <quote
>alignement</quote
>. Si la valeur est supérieure à la valeur d'indentation, la différence représente un nombre d'espaces à ajouter après l'indentation du premier paramètre. Sinon, le second nombre est ignoré. L'utilisation de tabulations et d'espaces pour l'indentation est souvent dénommée <quote
>mode mixte</quote
>. </para>

<para
>Voyons l'exemple suivant : supposons qu'on utilise des tabulations pour indenter et que la largeur des tabulations soit définie à 4. Ici, &lt;tab&gt; représente une  tabulation et « . » un espace : <programlisting>
1: &lt;tab&gt;&lt;tab&gt;exemple("bonjour",
2: &lt;tab&gt;&lt;tab&gt;......."monde");
</programlisting
> Lorsqu'on indente la ligne 2, la fonction <function
>indent()</function
> retourne [8, 15]. Par conséquent, deux tabulations sont insérées pour indenter dans la colonne 8, et 7 espaces sont ajoutés pour aligner le second paramètre sous le premier, pour qu'il reste aligné si le fichier est visualisé avec une largeur de tabulation différente. </para>

<para
>Une installation KDE par défaut fournit &kate; avec plusieurs indenteurs. Le code source JavaScript correspondant se trouve dans <filename
>$KDRDIR/share/apps/katepart/script</filename
>. </para>

<para
>Le développement d'un indenteur nécessite de recharger les scripts pour vérifier si les changements se comportent convenablement. Au lieu de redémarrer l'application, passez simplement sur la ligne de commande et exécutez la commande <command
>reload-scripts</command
>. </para>

<para
>Si vous développez des scripts utiles, vous pourriez envisager de contribuer au Projet &kate; en <ulink url="mailto:kwrite-devel@kde.org"
>contactant la liste de diffusion</ulink
>. </para>

</sect3>
</sect2>

<sect2 id="advanced-editing-tools-scripting-command-line">
<title
>Scripts de ligne de commande</title>

<para
>Comme il est difficile de satisfaire les besoins de chacun, &kate; prend en charge de petits outils d'aide permettant une manipulation rapide du texte par le biais de la <link linkend="advanced-editing-tools-commandline"
>ligne de commande intégrée</link
>. Par exemple, la commande <command
>sort</command
> est implémentée comme script. Cette section explique comment créer des fichiers <filename
>*.js</filename
> pour étendre &kate; avec des scripts d'aide arbitraires. </para>

<para
>Les scripts de ligne de commande se trouvent dans le même dossier que les scripts d'indentation. Ainsi, la première étape consiste à créer un nouveau fichier <filename
>*.js</filename
> appelé <filename
>myutils.js</filename
> dans le dossier personnel local <filename
>$KDEHOME/share/apps/katepart/script</filename
>. </para>

<sect3 id="advanced-editing-tools-scripting-command-line-header">
<title
>L'en-tête du script de ligne de commande</title>
<para
>L'en-tête de chaque script de ligne de commande est intégré dans un commentaire et se présente sous la forme suivante <programlisting>
/* kate-script
 * author: Exemple de nom &lt;exemple.nom@une.adresse.org&gt;
 * license: BSD
 * revision: 1
 * kate-version: 3.4
 * type: commands
 * functions: sort, format-paragraph
 *
 * Une ligne sans « : » arrête l'analyse syntaxique de l'en-tête. On peut donc ajouter ici
 * du texte facultativement, comme une licence détaillée.
 */
</programlisting
>  Chaque ligne est expliquée en détail ci-après : <itemizedlist>
<listitem
><para
><literal
>kate-script</literal
> [requis] : la chaîne de texte doit apparaître dans la première ligne du fichier <filename
>*.js</filename
>, sinon &kate; ignore le script.</para
></listitem>
<listitem
><para
><literal
>author</literal
> [optionnel] : le nom de l'auteur et les informations de contact.</para
></listitem>
<listitem
><para
><literal
>license</literal
> [optionnel] : la forme abrégée de la licence, comme BSD ou LGPLv3.</para
></listitem>
<listitem
><para
><literal
>revision</literal
> [requis] : la révision du script. Ce nombre devra être augmenté à chaque fois que le script est modifié.</para
></listitem>
<listitem
><para
><literal
>kate-version</literal
> [requis] : version de &kate; minimale nécessaire.</para
></listitem>
<listitem
><para
><literal
>type</literal
> [requis] : le type doit être <quote
><literal
>commands</literal
></quote
>, sinon &kate; ignore ce script.</para
></listitem>
<listitem
><para
><literal
>functions</literal
> [requis] : liste séparée par une virgule de commandes dans le  script.</para
></listitem>
</itemizedlist>
</para>

<para
>&kate; lit toutes les paires de la forme <quote
><replaceable
>clé</replaceable
>:<replaceable
>valeur</replaceable
></quote
> jusqu'à ce qu'il ne puisse plus trouver de « : ». Cette fonction implique que l'en-tête puisse contenir du texte arbitraire tel qu'une licence comme le montre l'exemple. La valeur des fonctions clés est une liste séparée par une virgule de commandes en ligne de commande. Cela signifie qu'un seul script contient une quantité arbitraire de commandes en ligne de commande. Chaque fonction est disponible par le biais de la <link linkend="advanced-editing-tools-commandline"
>ligne de commande intégrée</link
> de &kate;. </para>
</sect3>

<sect3 id="advanced-editing-tools-scripting-command-line-body">
<title
>Le code source du script</title>

<para
>Toutes les fonctions spécifiées dans l'en-tête doivent être implémentées dans le script. Par exemple, le fichier de script tiré de l'exemple ci-dessus doit implémenter les deux fonctions <command
>sort</command
> et <command
>format-paragraph</command
>. Toutes les fonctions ont la syntaxe suivante : <programlisting
>function &lt;name&gt;(arg1, arg2, ...)
{
    // ... implémentation, voir également : API de scriptage
}
</programlisting>
</para>

<para
>Les arguments dans la ligne de commande sont passés à la fonction sous la forme <parameter
>arg1</parameter
>, <parameter
>arg2</parameter
>, etc. Pour pouvoir fournir de la documentation pour chaque commande, implémentez simplement la fonction « <function
>help</function
> » comme suit : <programlisting>
function help(cmd)
{
    if (cmd == "sort") {
        return "Trier le texte sélectionné.";
    } else if (cmd == "...") {
        // ...
    }
}
</programlisting
> Exécuter <command
>help sort</command
> dans la ligne de commande appelle alors cette fonction d'aide avec l'argument <parameter
>cmd</parameter
> associé à la commande indiquée, c'est-à-dire <parameter
>cmd == "sort"</parameter
>. &kate; présente ensuite le texte obtenu sous forme de documentation à l'utilisateur. </para>

<para
>Le développement d'un script de ligne de commande nécessite de recharger les scripts pour vérifier si les changements se comportent convenablement. Au lieu de redémarrer l'application passez simplement dans la ligne de commande et exécutez la commande <command
>reload-scripts</command
>. </para>

<para
>Si vous développez des scripts utiles, vous pourriez envisager de contribuer au Projet &kate; en <ulink url="mailto:kwrite-devel@kde.org"
>contactant la liste de diffusion</ulink
>. </para>
</sect3>
</sect2>

<sect2 id="advanced-editing-tools-scripting-api">
<title
>API de scriptage</title>

<para
>L'API de scriptage présentée ici est disponible dans tous les scripts, c'est-à-dire l'indentation de scripts et les commandes en ligne de commande. Avant de charger le contenu d'un script, &kate; ajoute d'abord plusieurs prototypes et fonctions au contexte de scriptage. Cette API de commodité contient des prototypes comme les curseurs de texte ainsi que des plages de texte, et se trouve dans le dossier <filename
>$KDEDIR/share/apps/katepart/api</filename
>. Là, les noms des fichiers de chaque fichier JavaScript se conforme au schéma natif de nommage : <programlisting>
&lt;nombre&gt;_&lt;nom&gt;.js
</programlisting
> Le nombre comprend deux chiffres, et le nom est un nom arbitraire tel que <quote
><filename
>mesoutils</filename
></quote
>. Grâce à ce nombre, &kate; contrôle l'ordre d'exécution de l'API. Autrement dit, le fichier appelé <filename
>05_cursor.js</filename
> est appelé avant le fichier <filename
>10_range.js</filename
> (ce comportement est similaire à l'ordre de démarrage du système de niveau d'exécution/d'initialisation sous Linux). </para>

<para
>Pour étendre l'API de scriptage standard avec ses propres fonctions et prototypes, il suffit de créer un nouveau fichier dans le dossier de configuration local de KDE <filename
>$KDEHOME/share/apps/katepart/api</filename
> et de vérifier qu'il possède un nombre supérieur (ordre d'exécution) aux autres fichiers <filename
>*.js</filename
> dans le dossier global <filename
>$KDEDIR/share/apps/katepart/api</filename
>. &kate; cherche automatiquement les fichiers <filename
>*.js</filename
> dans les deux dossiers et les exécute dans l'ordre correct. </para>

<para
>Pour étendre les prototypes existants comme <classname
>Cursor</classname
> ou <classname
>Range</classname
>, la méthode recommandée consiste à ne <emphasis
>pas</emphasis
> modifier les fichiers <filename
>*.js</filename
> globaux. À la place, créez un fichier <filename
>*.js</filename
> dans le dossier local, qui est exécuté plus tard que le <filename
>05_cursor.js</filename
> puis changez le prototype <classname
>Cursor</classname
> en JavaScript. </para>

<sect3 id="advanced-editing-tools-scripting-api-global">
<title
>Curseurs et intervalles</title>

<para
>Comme &kate; est un éditeur de texte, toute l'API de scriptage repose sur des curseurs et des intervalles dans la mesure du possible. Un curseur est un tuple <literal
>(line, column)</literal
> simple représentant une position du texte dans le document. Un intervalle étend du texte à partir de la position du curseur de début vers une position de curseur de fin. L'API est expliquée en détail dans les sections suivantes. </para>

<sect4 id="advanced-editing-tools-scripting-api-cursors">
<title
>Le prototype de curseur</title>

<variablelist
><varlistentry>
<term
><synopsis
>Cursor();
</synopsis
></term>
<listitem
><para
>Constructeur. Retourne un curseur à la position <literal
>(0, 0)</literal
>.</para>
<para
>Exemple : <function
>var cursor = new Cursor();</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Curseur(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Constructeur. Retourne un curseur à la position (ligne, colonne). </para>
<para
>Exemple : <function
>var cursor = new Cursor(3, 42);</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Cursor(<parameter
>Cursor <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Constructeur de copie. Retourne une copie du curseur <replaceable
>autre</replaceable
>. </para>
<para
>Exemple : <function
>var copy = new Cursor(autre);</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Cursor Cursor.clone();
</synopsis
></term>
<listitem
><para
>Retourne un clone du curseur.</para>
<para
>Exemple : <function
>var clone = cursor.clone();</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Cursor.isValid();
</synopsis
></term>
<listitem
><para
>Vérifiez si le curseur est valable ou non. Le curseur n'est pas valable si la ligne et/ou la colonne sont associées à <literal
>-1</literal
>. </para>
<para
>Exemple : <function
>var valid = cursor.isValid();</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Cursor Cursor.invalid();
</synopsis
></term>
<listitem
><para
>Retourne un nouveau curseur non valable situé à <literal
>(-1, -1)</literal
>. </para>
<para
>Exemple : <function
>var invalidCursor = cursor.invalid();</function
> </para
></listitem>
</varlistentry
></variablelist>

<variablelist
><varlistentry>
<term
><synopsis
>int Cursor.compareTo(<parameter
>Cursor <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Compare ce curseur au curseur <replaceable
>autre</replaceable
>. Retourne <itemizedlist>
<listitem
><para
><literal
>-1</literal
>, si le curseur se trouve avant le curseur <replaceable
>autre</replaceable
>,</para
></listitem>
<listitem
><para
><literal
>0</literal
>, si les deux curseurs sont égaux et</para
></listitem>
<listitem
><para
><literal
>+1</literal
>, si ce curseur se trouve après le curseur <replaceable
>autre</replaceable
>.</para
></listitem>
</itemizedlist>
</para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Cursor.equals(<parameter
>Cursor <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le curseur et le curseur <replaceable
>autre</replaceable
> sont égaux, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String Cursor.toString();
</synopsis
></term>
<listitem
><para
>Retourne le curseur ou une chaîne de la forme <quote
><literal
>Cursor(line, column)</literal
></quote
>. </para
></listitem>
</varlistentry
></variablelist>

</sect4>


<sect4 id="advanced-editing-tools-scripting-api-ranges">
<title
>Le prototype d'intervalle</title>

<variablelist
><varlistentry>
<term
><synopsis
>Range();
</synopsis
></term>
<listitem
><para
>Constructeur. Appeler <literal
>new Range()</literal
> retourne un intervalle à (0, 0) - (0, 0). </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Range(<parameter
>Cursor <replaceable
>début</replaceable
></parameter
>, <parameter
>Cursor <replaceable
>fin</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Constructeur. Appeler <literal
>new Range(<replaceable
>début</replaceable
>, <replaceable
>fin</replaceable
>)</literal
> retourne l'intervalle (<replaceable
>début</replaceable
>, <replaceable
>fin</replaceable
>). </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Range(<parameter
>int <replaceable
>ligneDébut</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneDébut</replaceable
></parameter
>, <parameter
>int <replaceable
>ligneFin</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneFin</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Constructeur. Appeler <literal
>new Range(<replaceable
>ligneDébut</replaceable
>, <replaceable
>colonneDébut</replaceable
>, <replaceable
>ligneFin</replaceable
>, <replaceable
>colonneFin</replaceable
>)</literal
> Retourne l'intervalle de (<replaceable
>ligneDébut</replaceable
>, <replaceable
>colonneDébut</replaceable
>) à (<replaceable
>ligneFin</replaceable
>, <replaceable
>colonneFin</replaceable
>). </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Range(<parameter
>Range <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Constructeur de copie. Retourne une copie de l'intervalle Range <replaceable
>autre</replaceable
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Range Range.clone();
</synopsis
></term>
<listitem
><para
>Retourne un clone de l'intervalle. </para>
<para
>Exemple : <function
>var clone = range.clone();</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.isValid();
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si les curseurs de début et de fin sont valables, sinon <literal
>false</literal
>. </para>
<para
>Exemple : <function
>var valid = range.isValid();</function
> </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.invalid();
</synopsis
></term>
<listitem
><para
>Retourne l'intervalle Range de (-1, -1) à (-1, -1). </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.contains(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si cet intervalle contient la position du curseur, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.contains(<parameter
>Range <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'intervalle contient l'intervalle Range contient <replaceable
>autre</replaceable
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.containsColumn(<parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si <replaceable
>colonne</replaceable
> est dans l'intervalle semi-ouvert <literal
>[start.column, end.column)</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.containsLine(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si <replaceable
>ligne</replaceable
> est dans l'intervalle semi-ouvert <literal
>[start.line, end.line)</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.overlaps(<parameter
>Range <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'intervalle et l'intervalle <replaceable
>autre</replaceable
> partagent une région commune, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.overlapsLine(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si <replaceable
>ligne</replaceable
> est dans l'intervalle <literal
>[start.line, end.line]</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.overlapsColumn(<parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si <replaceable
>colonne</replaceable
> est dans l'intervalle <literal
>[start.column, end.column]</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool Range.equals(<parameter
>Range <replaceable
>autre</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si cet intervalle et l'intervalle Range <replaceable
>autre</replaceable
> sont égaux, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String Range.toString();
</synopsis
></term>
<listitem
><para
>Retourne l'intervalle en tant que chaîne de la forme <quote
><literal
>Range(Cursor(line, column), Cursor(line, column))</literal
></quote
>. </para
></listitem>
</varlistentry
></variablelist>

</sect4>
</sect3>

<sect3 id="advanced-editing-tools-scripting-api-debug">
<title
>Fonctions globales</title>

<variablelist
><varlistentry>
<term
><synopsis
>void debug(<parameter
>String <replaceable
>texte</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Affiche <replaceable
>texte</replaceable
> dans <literal
>stdout</literal
> dans la console lançant l'application. </para
></listitem>
</varlistentry
></variablelist>


</sect3>

<sect3 id="advanced-editing-tools-scripting-api-view">
<title
>L'API d'affichage</title>
<para
>Dès l'instant où un script est exécuté, il existe une variable globale <quote
><literal
>view</literal
></quote
> représentant la vue de l'éditeur actif actuel. Voici une liste de toutes les fonctions View disponibles. <variablelist
><varlistentry>
<term
><synopsis
><function
>Cursor view.cursorPosition()</function
>
</synopsis
></term>
<listitem
><para
>Retourne la position actuelle du curseur dans la vue.</para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
><function
>void view.setCursorPosition(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>)</function>
<function
>void view.setCursorPosition(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>)</function
>
</synopsis
></term>
<listitem
><para
>Retourne la position actuelle du curseur dans la vue.</para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void view.setCursorPosition(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
void view.setCursorPosition(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Associe la position actuelle du curseur soit à (ligne, colonne), soit au curseur donné. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Cursor view.virtualCursorPosition();
</synopsis
></term>
<listitem
><para
>Retourne la position virtuelle du curseur avec chaque tabulation comptant la quantité correspondante d'espaces en fonction de la largeur de tabulation actuelle. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void view.setVirtualCursorPosition(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
void view.setVirtualCursorPosition(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Associe la position actuelle du curseur virtuel soit à (ligne, colonne), soit au curseur donné. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String view.selectedText();
</synopsis
></term>
<listitem
><para
>Retourne le texte sélectionné. S'il n'y a pas de texte sélectionné, la chaîne retournée est vide. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool view.hasSelection();
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si la vue a sélectionné du texte, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Range view.selection();
</synopsis
></term>
<listitem
><para
>Retourne l'intervalle de texte sélectionné. L'intervalle retourné n'est pas valable s'il n'y a pas de texte sélectionné. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void view.setSelection(<parameter
>Range <replaceable
>intervalle</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Associe le texte sélectionné à l'intervalle donné. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void view.removeSelectedText();
</synopsis
></term>
<listitem
><para
>Supprime le texte sélectionné. Si la vue ne contient pas de texte sélectionné, ce paramètre ne fait rien. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void view.selectAll();
</synopsis
></term>
<listitem
><para
>Sélectionne le texte entier dans le document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void view.clearSelection();
</synopsis
></term>
<listitem
><para
>Efface la sélection de texte sans supprimer le texte. </para
></listitem>
</varlistentry
></variablelist>
</para>
</sect3>

<sect3 id="advanced-editing-tools-scripting-api-document">
<title
>L'API du document</title>
<para
>Dès l'instant où un script est exécuté, il existe une variable globale <quote
><literal
>document</literal
></quote
> représentant le dossier actif actuel. Voici une liste des fonctions Document disponibles. <variablelist
><varlistentry>
<term
><synopsis
>String document.fileName();
</synopsis
></term>
<listitem
><para
>Retourne le nom de fichier du document ou une chaîne vide pour les tampons de texte non enregistrés. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.url();
</synopsis
></term>
<listitem
><para
>Retourne l'URL complet du document ou une chaîne vide pour les tampons de texte non enregistrés. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.mimeType();
</synopsis
></term>
<listitem
><para
>Retourne le type MIME du document ou le type MIME <literal
>application/octet-stream</literal
> s'il est impossible de trouver un type MIME approprié. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.encoding();
</synopsis
></term>
<listitem
><para
>Retourne l'encodage actuellement utilisé pour enregistrer le fichier. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isModified();
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le document contient des changements non enregistrés (modifiés), sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.text();
</synopsis
></term>
<listitem
><para
>Retourne le contenu entier du document en une seule chaîne de texte. Les nouvelles lignes sont marquées avec le caractère de saut de ligne <quote
><literal
>\n</literal
></quote
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.text(<parameter
>int <replaceable
>ligneDébut</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneDepuis</replaceable
></parameter
>, <parameter
>int <replaceable
>ligneVers</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneVers</replaceable
></parameter
>);
String document.text(<parameter
>Cursor <replaceable
>depuis</replaceable
></parameter
>, <parameter
>Cursor <replaceable
>vers</replaceable
></parameter
>);
String document.text(<parameter
>Range <replaceable
>intervalle</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le texte dans l'intervalle donné. Il est recommandé d'utiliser la version correspondant au curseur et à l'intervalle pour avoir une meilleure lisibilité du code source. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.line(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la ligne de texte donnée sous la forme d'une chaîne. La chaîne est vide si la ligne demandée est en dehors de l'intervalle. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.wordAt(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
String document.wordAt(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le mot à la position donnée du curseur. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.charAt(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
String document.charAt(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le caractère la position donnée du curseur. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.firstChar(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le premier caractère dans la <replaceable
>ligne</replaceable
> donnée, qui n'est pas un caractère d'espacement. Le premier caractère se trouve à la colonne 0. Si la ligne est vide ou ne contient que des caractères d'espacement, la chaîne retournée est vide. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.lastChar(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le dernier caractère dans la <replaceable
>ligne</replaceable
> donnée, qui n'est pas un caractère d'espacement. Si la ligne est vide ou ne contient que des caractères d'espacement, la chaîne retournée est vide. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isSpace(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isSpace(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le caractère à la position donnée du curseur est un caractère d'espacement, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.matchesAt(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>, <parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>);
bool document.matchesAt(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le <replaceable
>texte</replaceable
> donné concorde avec la position correspondante du curseur, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.startsWith(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>, <parameter
>bool <replaceable
>ignorerEspaces</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si la ligne commence par <replaceable
>texte</replaceable
>, sinon <literal
>false</literal
>. L'argument <replaceable
>ignorerEspaces</replaceable
> contrôle si les caractères d'espacement de début sont ou non ignorés. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.endsWith(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>, <parameter
>bool <replaceable
>ignorerEspaces</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si la ligne se termine par <replaceable
>texte</replaceable
>, sinon <literal
>false</literal
>. L' argument <replaceable
>ignorerEspaces</replaceable
> contrôle si les caractères d'espacement sont ou non ignorés. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.setText(<parameter
>String <replaceable
>texte</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Définit le texte entier du document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.clear();
</synopsis
></term>
<listitem
><para
>Supprime le texte entier dans le document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.truncate(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.truncate(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Tronque la ligne donnée à la colonne ou la position de curseur donnée. Retourne <literal
>true</literal
> en cas de succès ou <literal
>false</literal
>, si la ligne donnée ne fait pas partie de l'intervalle de document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.insertText(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>, <parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>);
bool document.insertText(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Insère le <replaceable
>texte</replaceable
> à la position donnée du curseur. Retourne <literal
>true</literal
> en cas de succès ou <literal
>false</literal
>, si le document est en mode lecture seule. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.removeText(<parameter
>int <replaceable
>ligneDepuis</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneDepuis</replaceable
></parameter
>, <parameter
>int <replaceable
>ligneVers</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneVers</replaceable
></parameter
>);
bool document.removeText(<parameter
>Cursor <replaceable
>depuis</replaceable
></parameter
>, <parameter
>Cursor <replaceable
>vers</replaceable
></parameter
>);
bool document.removeText(<parameter
>Range <replaceable
>intervalle</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Supprime le texte dans l'intervalle donné. Retourne <literal
>true</literal
> en cas de succès ou <literal
>false</literal
>, si le document est en mode lecture seule. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.insertLine(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Insère du texte dans la ligne donnée. Retourne <literal
>true</literal
> en cas de succès ou <literal
>false</literal
>, si le document est en mode lecture seule ou si la ligne n'est pas dans l'intervalle du document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.removeLine(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Supprime la ligne de texte donnée. Retourne <literal
>true</literal
> en cas de succès ou <literal
>false</literal
>, si le document est en mode lecture seule ou si la ligne n'est pas dans l'intervalle du document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void document.joinLines(<parameter
>int <replaceable
>ligneDébut</replaceable
></parameter
>, <parameter
>int <replaceable
>ligneFin</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Joint les lignes de <replaceable
>ligneDébut</replaceable
> à <replaceable
>ligneFin</replaceable
>. Deux lignes de texte consécutives sont toujours séparées par un seul espace. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.lines();
</synopsis
></term>
<listitem
><para
>Retourne le nombre de lignes dans le document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.length();
</synopsis
></term>
<listitem
><para
>Retourne le nombre de caractères dans le document. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.lineLength(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourna la longueur de la <replaceable
>ligne</replaceable
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void document.editBegin();
</synopsis
></term>
<listitem
><para
>Démarre un groupe d'édition pour regrouper les opérations Annuler/Refaire. Veillez à toujours appeler <function
>editEnd()</function
> aussi souvent que vous appelez <function
>editBegin()</function
>. L'appel de <function
>editBegin()</function
> en interne utilise un compteur de référence, c'est-à-dire que cet appel peut être imbriqué. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>void document.editEnd();
</synopsis
></term>
<listitem
><para
>Termine un groupe d'édition. Le dernier appel de <function
>editEnd()</function
> (c'est-à-dire celui qui fait le pendant avec le premier appel de <function
>editBegin()</function
>) met fin à l'étape d'édition. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.firstColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la première colonne, contenant des caractères autres que des caractères d'espacement, dans la <replaceable
>ligne</replaceable
> donnée. S'il n'y a que des caractères d'espacement dans la ligne, la valeur de retour est <literal
>-1</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.lastColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la dernière colonne, contenant des caractères autres que des caractères d'espacement, dans la <replaceable
>ligne</replaceable
> donnée. S'il n'y a que des caractères d'espacement dans la ligne, la valeur de retour est <literal
>-1</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.prevNonSpaceColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
int document.prevNonSpaceColumn(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la colonne, contenant des caractères autres que des caractères d'espacement, en commençant à la position donnée du curseur et en effectuant une recherche arrière. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.nextNonSpaceColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
int document.nextNonSpaceColumn(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la colonne, contenant des caractères autres que des caractères d'espacement, en commençant à la position actuelle du curseur et en effectuant une recherche avant. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.prevNonEmptyLine(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la prochaine ligne non vide, contenant des caractères autres que des caractères d'espacement, en effectuant une recherche arrière. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.nextNonEmptyLine(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la prochaine ligne non vide, contenant des caractères autres que des caractères d'espacement, en effectuant une recherche avant. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isInWord(<parameter
>String <replaceable
>caractère</replaceable
></parameter
>, <parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le <replaceable
>caractère</replaceable
> donné contenant l'<replaceable
>attribut</replaceable
> donné peuvent faire partie d'un mot, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.canBreakAt(<parameter
>String <replaceable
>caractère</replaceable
></parameter
>, <parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le <replaceable
>caractère</replaceable
> donné contenant l'<replaceable
>attribut</replaceable
> donné est approprié pour encapsuler une ligne, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.canComment(<parameter
>int <replaceable
>attributDébut</replaceable
></parameter
>, <parameter
>int <replaceable
>attributFin</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si un intervalle commençant et se terminant par les attributs données est approprié pour être mis en commentaire, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.commentMarker(<parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne l'indicateur de commentaires pour les commentaires à une seule ligne pour un <replaceable
>attribut</replaceable
> donné. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.commentStart(<parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne l'indicateur de commentaires pour le début des commentaires multilignes pour un <replaceable
>attribut</replaceable
> donné. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.commentEnd(<parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne l'indicateur de commentaires pour la fin des commentaires multilignes pour un <replaceable
>attribut</replaceable
> donné. </para
></listitem>
</varlistentry
></variablelist>



<variablelist
><varlistentry>
<term
><synopsis
>int document.attribute(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
int document.attribute(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne l'attribut à la position donnée du curseur. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isAttribute(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>, <parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
bool document.isAttribute(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>, <parameter
>int <replaceable
>attribut</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut à la position donnée du curseur est égal à <replaceable
>attribut</replaceable
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.attributeName(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
String document.attributeName(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le nom de l'attribut sous la forme de texte lisible par l'utilisateur. Il est égal au nom <literal
>itemData</literal
> dans la fichier de coloration syntaxique. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isAttributeName(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>, <parameter
>String <replaceable
>nom</replaceable
></parameter
>);
bool document.isAttributeName(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>, <parameter
>String <replaceable
>nom</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si le nom de l'attribut à une certaines position du curseur correspond au <replaceable
>nom</replaceable
> donné, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>String document.variable(<parameter
>String <replaceable
>clé</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la valeur de la variable de document demandée <replaceable
>clé</replaceable
>. Si la variable de document n'existe pas, la valeur de retour est une chaîne vide. </para
></listitem>
</varlistentry
></variablelist>



<variablelist
><varlistentry>
<term
><synopsis
>int document.firstVirtualColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la colonne virtuelle du premier caractère autre qu'un caractère d'espacement dans la ligne donnée ou <literal
>-1</literal
>, si la ligne est vide ou ne contient que des caractères d'espacement. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.lastVirtualColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne la colonne virtuelle du dernier caractère autre qu'un caractère d'espacement dans la ligne donnée ou <literal
>-1</literal
>, si la ligne est vide ou ne contient que des caractères d'espacement. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.toVirtualColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
int document.toVirtualColumn(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Convertit la position de curseur <quote
>réel</quote
> donné à une position virtuelle de curseur. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.fromVirtualColumn(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonneVirtuelle</replaceable
></parameter
>);
int document.fromVirtualColumn(<parameter
>Cursor <replaceable
>curseurVirtuel</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Convertit la position de curseur virtuel donnée à une position de curseur <quote
>réel</quote
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Cursor document.anchor(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>, <parameter
>Char <replaceable
>caractère</replaceable
></parameter
>);
Cursor document.anchor(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>, <parameter
>Char <replaceable
>caractère</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Cherche en arrière le caractère donné en commençant depuis le curseur donné. Par exemple, si « ( » est passée comme caractère, cette fonction retournera la position de la « ( » ouvrante. Ce compte de référence, c'est-à-dire les autres « (...) » est ignoré. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>Cursor document.rfind(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>, <parameter
>int <replaceable
>attribut</replaceable
> = -1</parameter
>);
Cursor document.rfind(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>, <parameter
>String <replaceable
>texte</replaceable
></parameter
>, <parameter
>int <replaceable
>attribut</replaceable
> = -1</parameter
>);
</synopsis
></term>
<listitem
><para
>Cherche en arrière le texte donné avec l'<replaceable
>attribut</replaceable
> approprié. L'argument <replaceable
>attribut</replaceable
> est ignoré s'il est associé à <literal
>-1</literal
>. Le curseur retourné n'est pas valable, s'il est impossible de trouver le texte. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>int document.defStyleNum(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
int document.defStyleNum(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne le style par défaut utilisé à la position donnée du curseur. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isCode(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isCode(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut à la position donnée du curseur n'est pas égale à tous les styles suivants : <literal
>dsComment</literal
>, <literal
>dsString</literal
>, <literal
>dsRegionMarker</literal
>, <literal
>dsChar</literal
>, <literal
>dsOthers</literal
>. </para
></listitem>
</varlistentry
></variablelist>



<variablelist
><varlistentry>
<term
><synopsis
>bool document.isComment(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isComment(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut du caractère à la position du curseur est <literal
>dsComment</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isString(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isString(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut du caractère à la position du curseur est <literal
>dsString</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isRegionMarker(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isRegionMarker(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut du caractère à la position du curseur est <literal
>dsRegionMarker</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isChar(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isChar(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut du caractère à la position du curseur est <literal
>dsChar</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>


<variablelist
><varlistentry>
<term
><synopsis
>bool document.isOthers(<parameter
>int <replaceable
>ligne</replaceable
></parameter
>, <parameter
>int <replaceable
>colonne</replaceable
></parameter
>);
bool document.isOthers(<parameter
>Cursor <replaceable
>curseur</replaceable
></parameter
>);
</synopsis
></term>
<listitem
><para
>Retourne <literal
>true</literal
>, si l'attribut du caractère à la position du curseur est <literal
>dsOthers</literal
>, sinon <literal
>false</literal
>. </para
></listitem>
</varlistentry
></variablelist>
</para>

</sect3>
</sect2>
</sect1>
</chapter>