hgbook

changeset 982:a9c3a727f253

ch01-intro.xml : some errors corrected and translated the last few part untranslated
author Frédéric Bouquet <youshe.jaalon@gmail.com>
date Tue Sep 08 18:20:00 2009 +0200 (2009-09-08)
parents 64393e8da2ff
children 5e1e70fcdfdb
files fr/ch01-intro.xml
line diff
     1.1 --- a/fr/ch01-intro.xml	Tue Sep 08 15:30:26 2009 +0200
     1.2 +++ b/fr/ch01-intro.xml	Tue Sep 08 18:20:00 2009 +0200
     1.3 @@ -14,7 +14,7 @@
     1.4  à chaque fois plus grand que celui de la version précédente.</para>
     1.5  
     1.6      <para id="x_6e">Ce genre de gestion de version manuelle est cependant facilement sujette
     1.7 -à des erreurs, ainsi, depuis longtemps, des logiciels existent pour
     1.8 +aux erreurs, ainsi, depuis longtemps, des logiciels existent pour
     1.9  résoudre cette problématique. Les premiers outils de gestion de sources
    1.10  étaient destinés à aider un seul utilisateur, à automatiser la gestion
    1.11  des versions d'un seul fichier. Dans les dernières décades, cette cible
    1.12 @@ -26,15 +26,15 @@
    1.13  
    1.14      <para id="x_6f">L'arrivée de la gestion de révision distribuée est
    1.15      relativement récente, et, pour le moment, ce nouveau domaine a grandi
    1.16 -    grâce à la volonté des gens d'explorer ces territoires encores inconnues.
    1.17 +    grâce à la volonté des gens d'explorer ces territoires encore inconnus.
    1.18      </para>
    1.19  
    1.20      <para id="x_70">J'écris un livre sur la gestion de révision distribuée
    1.21      parce que je pense qu'il s'agit d'un sujet important qui mérite un guide
    1.22      du terrain. J'ai choisi d'écrire un livre sur Mercurial car il est
    1.23      l'outil le plus facile pour découvrir ce nouveau domaine, tout en étant
    1.24 -    un outil efficase qui répond aux demandes d'environement réel et
    1.25 -    difficile, là où d'autres outils de révisions s'effondre.</para>
    1.26 +    un outil efficace qui répond aux demandes d'environnements réels et
    1.27 +    difficiles, là où d'autres outils de gestions de versions s'effondrent.</para>
    1.28  
    1.29      <sect2>
    1.30        <title>Pourquoi utiliser un gestionnaire de source ?</title>
    1.31 @@ -44,10 +44,10 @@
    1.32  
    1.33        <itemizedlist>
    1.34  	<listitem><para id="x_72">L'outil se chargera de suivre l'évolution de votre projet, sans
    1.35 -que vous n'ayez à le faire. Pour chaque modification, vous aurez à votre
    1.36 +que vous ayez à le faire. Pour chaque modification, vous aurez à votre
    1.37  disposition un journal indiquant <emphasis>qui</emphasis> a fait quoi, <emphasis>pourquoi</emphasis>
    1.38 -ils l'ont fait, <emphasis>quand</emphasis> ils l'ont fait, et <emphasis>ce</emphasis> qu'ils ont
    1.39 -modifiés.</para>
    1.40 +il l'a fait, <emphasis>quand</emphasis> il l'a fait, et
    1.41 +<emphasis>ce</emphasis> qu'il a modifié.</para>
    1.42  </listitem>
    1.43  <listitem><para id="x_73">Quand vous travaillez avec d'autres personnes, les logiciels de
    1.44  gestion de source facilitent le travail collaboratif. Par exemple, quand
    1.45 @@ -62,42 +62,48 @@
    1.46  de détails).</para>
    1.47  </listitem>
    1.48  <listitem><para id="x_75">L'outil vous permettra aussi de travailler sur plusieurs versions différentes
    1.49 -de votre projet et à gérer l'écart entre chacune.</para>
    1.50 +de votre projet et de gérer l'écart entre chacune.</para>
    1.51  </listitem></itemizedlist>
    1.52 -<para id="x_76">La plupart de ces raisons ont autant d'importances &emdash;du moins en théorie&emdash; que
    1.53 -vous travailliez sur un projet pour vous, ou avec une centaine d'autres
    1.54 -personnes.
    1.55 +<para id="x_76">La plupart de ces raisons ont autant d'importances &emdash;du
    1.56 +  moins en théorie&emdash; que vous travailliez sur un projet pour vous, ou
    1.57 +  avec une centaine d'autres personnes.
    1.58  </para>
    1.59  
    1.60 -<para id="x_77">Une question fondamentale à propos des outils de gestion de source, qu'il s'agisse
    1.61 -du projet d'une personne ou d'une grande équipe, est quels sont ses
    1.62 -<emphasis>avantages</emphasis> par rapport à ses <emphasis>coûts</emphasis>. Un outil qui est difficile à
    1.63 -utiliser ou à comprendre exigera un lourd effort d'adaptation.
    1.64 +<para id="x_77">Une question fondamentale à propos des outils de gestion de
    1.65 +  source, qu'il s'agisse du projet d'une personne ou d'une grande équipe, est
    1.66 +  quels sont ses <emphasis>avantages</emphasis> par rapport à ses
    1.67 +  <emphasis>coûts</emphasis>. Un outil qui est difficile à utiliser ou à
    1.68 +  comprendre exigera un lourd effort d'adaptation.
    1.69  </para>
    1.70  
    1.71 -<para id="x_78">)Un projet de cinq milles personnes s'effondrera très certainement de lui même
    1.72 -sans aucun processus et outil de gestion de source. Dans ce cas, le coût
    1.73 -d'utilisation d'un logiciel de gestion de source est dérisoire puisque
    1.74 -<emphasis>sans</emphasis>, l'échec est presque garanti.
    1.75 +<para id="x_78">)Un projet de cinq milles personnes s'effondrera très
    1.76 +  certainement de lui même sans aucun processus et outil de gestion de
    1.77 +  source. Dans ce cas, le coût d'utilisation d'un logiciel de gestion de
    1.78 +  source est dérisoire puisque <emphasis>sans</emphasis>, l'échec est presque
    1.79 +  garanti.
    1.80  </para>
    1.81  
    1.82 -<para id="x_79">D'un autre coté, un <quote>rapide hack</quote> d'une personne peut sembler un contexte
    1.83 -bien pauvre pour utiliser un outil de gestion de source, car, bien évidement
    1.84 -le coût d'utilisation dépasse le coût total du projet. N'est ce pas ?
    1.85 +<para id="x_79">D'un autre coté, un <quote>rapide hack</quote> d'une personne
    1.86 +  peut sembler un contexte bien pauvre pour utiliser un outil de gestion de
    1.87 +  source, car, bien évidement le coût d'utilisation dépasse le coût total du
    1.88 +  projet. N'est ce pas ?
    1.89  </para>
    1.90  
    1.91 -      <para id="x_7a">Mercurial supporte ces <emphasis>deux</emphasis> échelles de travail. Vous pouvez apprendre
    1.92 -les bases en quelques minutes seulement, et, grâce à sa performance, vous pouvez
    1.93 -l'utiliser avec facilité sur le plus petit des projets. Cette simplicité
    1.94 -signifie que vous n'avez pas de concept obscurs ou de séquence de commandes
    1.95 -défiant l'imagination, sans aucune corrélation avec <emphasis>ce que vous
    1.96 -êtes entrain de faire</emphasis>. En même temps, ces mêmes performances et sa
    1.97 -nature <quote>peer-to-peer</quote> vous permettent d'augmenter, sans difficulté, son
    1.98 -utilisation à de très grands projets.
    1.99 +      <para id="x_7a">Mercurial supporte ces <emphasis>deux</emphasis>
   1.100 +        échelles de travail. Vous pouvez apprendre les bases en quelques
   1.101 +        minutes seulement, et, grâce à sa performance, vous pouvez l'utiliser
   1.102 +        avec facilité sur le plus petit des projets. Cette simplicité
   1.103 +        signifie que vous n'avez pas de concept obscurs ou de séquence de
   1.104 +        commandes défiant l'imagination, sans aucune corrélation avec
   1.105 +        <emphasis>ce que vous êtes entrain de faire</emphasis>. En même
   1.106 +        temps, ces mêmes performances et sa nature
   1.107 +        <quote>peer-to-peer</quote> vous permettent d'adapter, sans
   1.108 +        difficulté, son utilisation à de très grands projets.
   1.109  </para>
   1.110  
   1.111 -      <para id="x_7b">Aucun outil de gestion de source ne peut sauver un projet mal mené, mais un
   1.112 -bon outil peut rendre beaucoup plus fluide votre travail.
   1.113 +      <para id="x_7b">Aucun outil de gestion de source ne peut sauver un
   1.114 +        projet mal mené, mais un bon outil peut rendre beaucoup plus fluide
   1.115 +        votre travail.
   1.116  </para>
   1.117  
   1.118      </sect2>
   1.119 @@ -105,19 +111,21 @@
   1.120      <sect2>
   1.121        <title>Les multiples noms de la gestion de source</title>
   1.122  
   1.123 -      <para id="x_7c">La gestion de source<!--
   1.124 -      TODO:<footnote><J'ai utilisé systématiquement le terme
   1.125 -<quote>gestion de source</quote> à travers tout l'ouvrage. Ce n'est pas forcement la
   1.126 -meilleure traduction, et ceci peut rendre la lecture un peu lourde, mais je
   1.127 -pense que le document y gagne en clarté et en précision. --> est un domaine
   1.128 -divers, tellement qu'il n'existe pas une seul nom ou acronyme pour le désigner.
   1.129 -Voilà quelqu'uns des noms ou
   1.130 -acronymes que vous rencontrerez le plus souvent <!-- TODO:<footnote> J'ai conservé la
   1.131 -liste des noms en anglais pour des raisons de commodité (ils sont plus
   1.132 -<quote>googelable</quote>). En outre, j'ai opté  pour conserver l'ensemble des opérations de
   1.133 -Mercurial (\textit{commit},\textit{push}, \textit{pull},...) en anglais, là
   1.134 -aussi pour faciliter la lecture d'autres documents en anglais, ainsi que
   1.135 -l'utilisation de Mercurial. -->
   1.136 +      <para id="x_7c">La gestion de source
   1.137 +        <!-- TODO:<footnote><J'ai utilisé systématiquement le terme
   1.138 +            <quote>gestion de source</quote> à travers tout l'ouvrage. Ce
   1.139 +            n'est pas forcement la meilleure traduction, et ceci peut rendre
   1.140 +            la lecture un peu lourde, mais je pense que le document y gagne
   1.141 +            en clarté et en précision. -->
   1.142 +        est un domaine tellement large qu'il n'existe pas qu'un seul nom ou
   1.143 +        acronyme pour le désigner. Voici quelques noms ou acronymes que vous
   1.144 +        rencontrerez le plus souvent.
   1.145 +        <!-- TODO:<footnote> J'ai conservé la liste des noms en anglais pour
   1.146 +          des raisons de commodité (ils sont plus <quote>googelable</quote>).
   1.147 +          En outre, j'ai opté  pour conserver l'ensemble des opérations de
   1.148 +          Mercurial (\textit{commit},\textit{push}, \textit{pull},...) en
   1.149 +          anglais, là aussi pour faciliter la lecture d'autres documents en
   1.150 +          anglais, ainsi que l'utilisation de Mercurial. -->
   1.151  </para>
   1.152  
   1.153  <para>:
   1.154 @@ -125,58 +133,60 @@
   1.155  
   1.156        <itemizedlist>
   1.157  	<listitem><para id="x_7d">Revision control (RCS)</para></listitem>
   1.158 -	<listitem><para id="x_7e">Software configuration management (SCM), or
   1.159 +	<listitem><para id="x_7e">Software configuration management (SCM), ou
   1.160  	    configuration management</para></listitem>
   1.161  	<listitem><para id="x_7f">Source code management</para></listitem>
   1.162 -	<listitem><para id="x_80">Source code control, or source
   1.163 -	    control</para></listitem>
   1.164 -	<listitem><para id="x_81">Version control
   1.165 -	    (VCS)</para></listitem></itemizedlist>
   1.166 -
   1.167 - <para id="x_82">Certaines personnes prétendent que ces termes ont en fait des sens
   1.168 -différents mais en pratique ils se recouvrent tellement qu'il n'y a pas
   1.169 -réellement de manière pertinente de les distinguer.
   1.170 -</para>
   1.171 +	<listitem><para id="x_80">Source code control, ou source control</para></listitem>
   1.172 +	<listitem><para id="x_81">Version control (VCS)</para></listitem></itemizedlist>
   1.173 +
   1.174 + <para id="x_82">Certaines personnes prétendent que ces termes ont en fait
   1.175 +   des sens différents mais en pratique ils se recouvrent tellement qu'il n'y
   1.176 +   a pas réellement de manière pertinente de les distinguer. </para>
   1.177  
   1.178      </sect2>
   1.179    </sect1>
   1.180  
   1.181    <sect1>
   1.182  
   1.183 -<title>About the examples in this book</title>
   1.184 -
   1.185 -    <para id="x_84">This book takes an unusual approach to code samples.  Every
   1.186 -      example is <quote>live</quote>&emdash;each one is actually the result
   1.187 -      of a shell script that executes the Mercurial commands you see.
   1.188 -      Every time an image of the book is built from its sources, all
   1.189 -      the example scripts are automatically run, and their current
   1.190 -      results compared against their expected results.</para>
   1.191 -
   1.192 -    <para id="x_85">The advantage of this approach is that the examples are
   1.193 -      always accurate; they describe <emphasis>exactly</emphasis> the
   1.194 -      behavior of the version of Mercurial that's mentioned at the
   1.195 -      front of the book.  If I update the version of Mercurial that
   1.196 -      I'm documenting, and the output of some command changes, the
   1.197 -      build fails.</para>
   1.198 -
   1.199 -    <para id="x_86">There is a small disadvantage to this approach, which is
   1.200 -      that the dates and times you'll see in examples tend to be
   1.201 -      <quote>squashed</quote> together in a way that they wouldn't be
   1.202 -      if the same commands were being typed by a human.  Where a human
   1.203 -      can issue no more than one command every few seconds, with any
   1.204 -      resulting timestamps correspondingly spread out, my automated
   1.205 -      example scripts run many commands in one second.</para>
   1.206 -
   1.207 -    <para id="x_87">As an instance of this, several consecutive commits in an
   1.208 -      example can show up as having occurred during the same second.
   1.209 -      You can see this occur in the <literal
   1.210 -	role="hg-ext">bisect</literal> example in <xref
   1.211 -	linkend="sec:undo:bisect"/>, for instance.</para>
   1.212 -
   1.213 -    <para id="x_88">So when you're reading examples, don't place too much weight
   1.214 -      on the dates or times you see in the output of commands.  But
   1.215 -      <emphasis>do</emphasis> be confident that the behavior you're
   1.216 -      seeing is consistent and reproducible.</para>
   1.217 +<title>A propos des exemples dans ce livre</title>
   1.218 +
   1.219 +    <para id="x_84">Ce livre prend une approche non usuel pour les exemples
   1.220 +      de code. Tous les exemples sont en <quote>live</quote> &emdash; Chacun
   1.221 +      est actuellement le résultat d'un script shell qui exécute les
   1.222 +      commandes Mercurial que vous voyez. A chaque fois qu'une image du livre
   1.223 +      est construite à partir des sources, tous les scripts d'exemple sont
   1.224 +      lancés automatiquement, et leurs résultats effectifs sont comparés aux
   1.225 +      résultats attendus.</para>
   1.226 +
   1.227 +    <para id="x_85">L'avantage de dette approche est que les exemples sont
   1.228 +      toujours précis ; ils décrivent <emphasis>exactement</emphasis> la
   1.229 +      conduite de la version de Mercurial qui est mentionnée en entête du
   1.230 +      livre. Si je met à jour la version de Mercurial que je suis en train de
   1.231 +      documenter, et que la sortie de certaines commandes change, la
   1.232 +      construction du livre échoue.</para>
   1.233 +
   1.234 +    <para id="x_86">
   1.235 +      Il existe un petit désavantage à cette approche qui est que les dates et
   1.236 +      heures que vous verrez dans les exemples tendent à être
   1.237 +      <quote>écrasés</quote> ensemble, dans le sens où elles ne sont pas
   1.238 +      celles qu'elles auraient été si un humain avait tapé les commandes. En
   1.239 +      effet, humain ne peut pas taper plus d'une commande toutes les quelques
   1.240 +      secondes, avec le temps qui s'écoule, mes scripts d'exemples exécutent
   1.241 +      plusieurs commandes en une seconde.
   1.242 +    </para>
   1.243 +
   1.244 +    <para id="x_87">Une circonstance de ceci est que plusieurs commits
   1.245 +      consécutifs dans un exemple peuvent apparaître comme ayant eu lieu
   1.246 +      durant la même seconde.
   1.247 +      Vous pouvez observer le phénomène dans l'exemple <literal
   1.248 +        role="hg-ext">bisect</literal> dans <xref linkend="sec:undo:bisect"/>
   1.249 +    </para>
   1.250 +
   1.251 +    <para id="x_88">Donc, lorsque vous lisez ces exemples, ne prêtez pas trop
   1.252 +      d'importance aux dates et heures que vous voyez dans la sortie des
   1.253 +      commandes. Cependant, <emphasis>soyez</emphasis> confiants que le
   1.254 +      comportement que vous voyez est consistent et reproductible 
   1.255 +    </para>
   1.256  
   1.257    </sect1>
   1.258  
   1.259 @@ -185,604 +195,657 @@
   1.260    <sect1>
   1.261      <title>Tendances de la gestion de source</title>
   1.262  
   1.263 -    <para id="x_89">Il y a eu une tendance évidente dans le développement et l'utilisation d'outils
   1.264 -de gestion de source depuis les quatre dernières décades, au fur et à mesure
   1.265 -que les utilisateurs se sont habitués à leur outils et se sont sentis contraints
   1.266 -par leurs limitations.
   1.267 -</para>
   1.268 -
   1.269 -    <para id="x_8a">La première génération commença simplement par gérer un fichier unique sur un
   1.270 -ordinateur individuel. Cependant, même si ces outils présentaient une grande
   1.271 -avancée par rapport à la gestion manuelle des versions, leur modèle de
   1.272 -verrouillage et leur utilisation limitée à un seul ordinateur rendaient leur
   1.273 -utilisation possible uniquement dans une très petite équipe.
   1.274 -</para>
   1.275 -
   1.276 -    <para id="x_8b">La seconde génération a assoupli ces contraintes en adoptant une architecture
   1.277 -réseau et centralisée, permettant de gérer plusieurs projets entiers en même
   1.278 -temps. Alors que les projets grandirent en taille, ils rencontrèrent de nouveaux
   1.279 -problèmes. Avec les clients discutant régulièrement avec le serveurs, la montée
   1.280 -en charge devint un réel problème sur les gros projets. Une connexion réseau
   1.281 -peu fiable pouvait complètement empêcher les utilisateurs distants de dialoguer
   1.282 -avec le serveur. Alors que les projets <emphasis remap="it">Open Source</emphasis> commencèrent à
   1.283 -mettre en place des accès en lecture seule disponible anonymement, les
   1.284 -utilisateurs sans les privilèges de <quote>commit</quote> réalisèrent qu'ils ne pouvaient
   1.285 -pas utiliser les outils pour collaborer naturellement avec le projet, comme ils
   1.286 -ne pouvaient pas non plus enregistrer leurs modifications.
   1.287 -</para>
   1.288 -
   1.289 -    <para id="x_8c">La génération actuelle des outils de gestion de source est <quote>peer-to-peer</quote> par
   1.290 -nature. Tout ces systèmes ont abandonné la dépendance à un serveur central, et
   1.291 -ont permis à leur utilisateur de distribuer les données de leur gestion de
   1.292 -source à qui en a besoin. La collaboration à travers Internet a transformé la
   1.293 -contrainte technologique en une simple question de choix et de consencus. Les
   1.294 -outils modernes peuvent maintenant fonctionner en mode déconnecté sans limite et
   1.295 -de manière autonome, la connexion au réseau n'étant nécessaire que pour
   1.296 -synchroniser les modifications avec les autres dépôts.
   1.297 -</para>
   1.298 -
   1.299 +    <para id="x_89">Il y a eu une tendance évidente dans le développement et
   1.300 +      l'utilisation d'outils de gestion de source depuis les quatre dernières
   1.301 +      décades, au fur et à mesure que les utilisateurs se sont habitués à
   1.302 +      leur outils et se sont sentis contraints par leurs limitations.
   1.303 +    </para>
   1.304 +
   1.305 +    <para id="x_8a">La première génération commença simplement par gérer un
   1.306 +      fichier unique sur un ordinateur individuel. Cependant, même si ces
   1.307 +      outils présentaient une grande avancée par rapport à la gestion
   1.308 +      manuelle des versions, leur modèle de verrouillage et leur utilisation
   1.309 +      limitée à un seul ordinateur rendaient leur utilisation possible
   1.310 +      uniquement dans une très petite équipe.
   1.311 +    </para>
   1.312 +
   1.313 +    <para id="x_8b">La seconde génération a assoupli ces contraintes en
   1.314 +      adoptant une architecture réseau et centralisée, permettant de gérer
   1.315 +      plusieurs projets entiers en même temps. Alors que les projets
   1.316 +      grandirent en taille, ils rencontrèrent de nouveaux problèmes. Avec les
   1.317 +      clients discutant régulièrement avec le serveurs, la montée en charge
   1.318 +      devint un réel problème sur les gros projets. Une connexion réseau peu
   1.319 +      fiable pouvait complètement empêcher les utilisateurs distants de
   1.320 +      dialoguer avec le serveur. Alors que les projets <emphasis
   1.321 +        remap="it">Open Source</emphasis> commencèrent à mettre en place des
   1.322 +      accès en lecture seule disponible anonymement, les utilisateurs sans
   1.323 +      les privilèges de <quote>commit</quote> réalisèrent qu'ils ne pouvaient
   1.324 +      pas utiliser les outils pour collaborer naturellement avec le projet,
   1.325 +      comme ils ne pouvaient pas non plus enregistrer leurs modifications.
   1.326 +    </para>
   1.327 +
   1.328 +    <para id="x_8c">La génération actuelle des outils de gestion de source
   1.329 +      est <quote>peer-to-peer</quote> par nature. Tous ces systèmes ont
   1.330 +      abandonné la dépendance à un serveur central, et ont permis à leur
   1.331 +      utilisateur de distribuer les données de leur gestion de source à qui
   1.332 +      en a besoin. La collaboration à travers Internet a transformé la
   1.333 +      contrainte technologique en une simple question de choix et de
   1.334 +      consensus. Les outils modernes peuvent maintenant fonctionner en mode
   1.335 +      déconnecté sans limite et de manière autonome, la connexion au réseau
   1.336 +      n'étant nécessaire que pour synchroniser les modifications avec les
   1.337 +      autres dépôts.
   1.338 +    </para>
   1.339    </sect1>
   1.340 +    
   1.341    <sect1>
   1.342      <title>Quelques avantages des gestionnaires de source distribués</title>
   1.343 -
   1.344 -<para id="x_8d">Même si les gestionnaire de source distribués sont depuis plusieurs années
   1.345 -assez robustes et aussi utilisables que leurs prédécesseurs, les utilisateurs
   1.346 -d'autres outils n'y ont pas encore été sensibilisés. Les gestionnaires
   1.347 -de source distribués se distinguent particulièrement de leurs équivalents
   1.348 -centralisés de nombreuses manières.
   1.349 -</para>
   1.350 -
   1.351 -    <para id="x_8e">Pour un développeur individuel, ils restent beaucoup plus rapides que les
   1.352 -outils centralisés. Cela pour une raison simple : un outil centralisé doit
   1.353 -toujours dialoguer à travers le réseau pour la plupart des opérations, car
   1.354 -presque toutes les métadonnées sont stockées sur la seule copie du serveur
   1.355 -central. Un outil distribué stocke toute ses métadonnées localement. À tâche
   1.356 -égale, effectuer un échange avec le réseau ajoute un délai aux outils
   1.357 -centralisés. Ne sous-estimez pas la valeur d'un outil rapide : vous allez
   1.358 -passer beaucoup de temps à interagir avec un logiciel de gestion de source.
   1.359 -</para>
   1.360 -
   1.361 -    <para id="x_8f">Les outils distribués sont complètement indépendants des aléas de votre serveur,
   1.362 -d'autant plus qu'ils répliquent les métadonnées à beaucoup d'endroits. Si
   1.363 -votre serveur central prend feu, vous avez intérêt à ce que les médias de
   1.364 -sauvegardes soient fiables, et que votre dernier <quote>backup</quote> soit récent et
   1.365 -fonctionne sans problème. Avec un outil distribué, vous avez autant de
   1.366 -<quote>backup</quote> que de contributeurs.
   1.367 -</para>
   1.368 -
   1.369 -    <para id="x_90">En outre, la fiabilité de votre réseau affectera beaucoup moins les
   1.370 -outils distribués. Vous ne pouvez même pas utiliser un outil centralisé
   1.371 -sans connexion réseau, à l'exception de quelques commandes, très limitées.
   1.372 -Avec un outil distribué, si votre connexion réseau tombe pendant que vous
   1.373 -travaillez, vous pouvez ne même pas vous en rendre compte. La seule chose
   1.374 -que vous ne serez pas capable de faire sera de communiquer avec des dépôts
   1.375 -distants, opération somme toute assez rare en comparaison aux opérations
   1.376 -locales. Si vous avez une équipe de collaborateurs très dispersée ceci peut
   1.377 -être significatif.
   1.378 -</para>
   1.379 -
   1.380 +      
   1.381 +    <para id="x_8d">Même si les gestionnaire de source distribués sont depuis
   1.382 +      plusieurs années assez robustes et aussi utilisables que leurs
   1.383 +      prédécesseurs, les utilisateurs d'autres outils n'y ont pas encore été
   1.384 +      sensibilisés. Les gestionnaires de source distribués se distinguent
   1.385 +      particulièrement de leurs équivalents centralisés de nombreuses
   1.386 +      manières.
   1.387 +    </para>
   1.388 +
   1.389 +    <para id="x_8e">Pour un développeur individuel, ils restent beaucoup plus
   1.390 +      rapides que les outils centralisés. Cela pour une raison simple : un
   1.391 +      outil centralisé doit toujours dialoguer à travers le réseau pour la
   1.392 +      plupart des opérations, car presque toutes les métadonnées sont
   1.393 +      stockées sur la seule copie du serveur central. Un outil distribué
   1.394 +      stocke toute ses métadonnées localement. À tâche égale, effectuer un
   1.395 +      échange avec le réseau ajoute un délai aux outils centralisés. Ne
   1.396 +      sous-estimez pas la valeur d'un outil rapide : vous allez passer
   1.397 +      beaucoup de temps à interagir avec un logiciel de gestion de source.
   1.398 +    </para>
   1.399 +
   1.400 +    <para id="x_8f">Les outils distribués sont complètement indépendants des
   1.401 +      aléas de votre serveur, d'autant plus qu'ils répliquent les métadonnées
   1.402 +      à beaucoup d'endroits. Si votre serveur central prend feu, vous avez
   1.403 +      intérêt à ce que les médias de sauvegardes soient fiables, et que votre
   1.404 +      dernier <quote>backup</quote> soit récent et fonctionne sans problème.
   1.405 +      Avec un outil distribué, vous avez autant de <quote>backup</quote> que
   1.406 +      de contributeurs.
   1.407 +    </para>
   1.408 +
   1.409 +    <para id="x_90">En outre, la fiabilité de votre réseau affectera beaucoup
   1.410 +      moins les outils distribués. Vous ne pouvez même pas utiliser un outil
   1.411 +      centralisé sans connexion réseau, à l'exception de quelques commandes,
   1.412 +      très limitées. Avec un outil distribué, si votre connexion réseau tombe
   1.413 +      pendant que vous travaillez, vous pouvez ne même pas vous en rendre
   1.414 +      compte. La seule chose que vous ne serez pas capable de faire sera de
   1.415 +      communiquer avec des dépôts distants, opération somme toute assez rare
   1.416 +      en comparaison aux opérations locales. Si vous avez une équipe de
   1.417 +      collaborateurs très dispersée ceci peut être significatif.
   1.418 +    </para>
   1.419  
   1.420      <sect2>
   1.421        <title>Avantages pour les projets Open Source</title>
   1.422  
   1.423 -      <para id="x_91">Si vous prenez goût à un projet <emphasis remap="it">Open Source</emphasis> et que vous
   1.424 -décidez de commencer à toucher à son code, et que le projet utilise
   1.425 -un gestionnaire de source distribué, vous êtes immédiatement un "pair"
   1.426 -avec les personnes formant le <quote>cœur</quote> du projet. Si ils publient
   1.427 -leurs dépôts, vous pouvez immédiatement copier leurs historiques de
   1.428 -projet, faire des modifications, enregistrer votre travail en utilisant
   1.429 -les même outils qu'eux. Par comparaison, avec un outil centralisé, vous
   1.430 -devez utiliser un logiciel en mode <quote>lecture seule</quote> à moins que
   1.431 -quelqu'un ne vous donne les privilèges de <quote>commit</quote> sur le serveur
   1.432 -central. Avant ça, vous ne serez pas capable d'enregistrer vos
   1.433 -modifications, et vos propres modifications risqueront de se
   1.434 -corrompre chaque fois que vous essayerez de mettre à jour à votre
   1.435 -espace de travail avec le serveur central.
   1.436 -</para>
   1.437 -
   1.438 -      <sect3>
   1.439 -	<title>Le non-problème du "fork"</title>
   1.440 -
   1.441 -	<para id="x_92">Il a été souvent suggéré que les gestionnaires de source distribués
   1.442 -posent un risque pour les projets <emphasis remap="it">Open Source</emphasis> car ils
   1.443 -facilitent grandement la création de <quote>fork</quote>.<!-- footnote{NdT:Création
   1.444 -d'une
   1.445 -<ulink url="version alternative du logiciel">version alternative du
   1.446 -logiciel</ulink>{http://fr.wikipedia.org/wiki/Fork#Embranchement_d.27un_projet_informatique}
   1.447 --->
   1.448 -Un <quote>fork</quote> apparait quand il y des divergences d'opinion ou d'attitude
   1.449 -au sein d'un groupe de développeurs qui aboutissent à la décision de ne
   1.450 -plus travailler ensemble. Chaque parti s'empare d'une copie plus ou moins
   1.451 -complète du code source du projet et continue dans sa propre direction.
   1.452 -</para>
   1.453 -
   1.454 -	<para id="x_93">Parfois ces différents partis décident de se réconcilier. Avec un
   1.455 -serveur central, l'aspect <emphasis>technique</emphasis> de cette réconciliation
   1.456 -est un processus douloureux, et essentiellement manuel. Vous devez
   1.457 -décider quelle modification est <quote>la gagnante</quote>, et replacer, par un
   1.458 -moyen ou un autre, les modifications de l'autre équipe dans l'arborescence
   1.459 -du projet. Ceci implique généralement la perte d'une partie de l'historique
   1.460 -d'un des partis, ou même des deux.
   1.461 -</para>
   1.462 -
   1.463 -	<para id="x_94">Ce que les outils distribués permettent à ce sujet est probablement
   1.464 -la <emphasis>meilleure</emphasis> façon de développer un projet. Chaque modification
   1.465 -que vous effectuez est potentiellement un <quote>fork</quote>. La grande force de
   1.466 -cette approche est que les gestionnaires de source distribués doivent être
   1.467 -vraiment très efficaces pour <emphasis>fusionner</emphasis><!-- TODO footnote{NdT:j'ai choisi de
   1.468 -traduire ici <emphasis remap="it">merging</emphasis> par <quote>fusionner</quote> pour des raisons 
   1.469 -de clarté} --> des <quote>forks</quote>, car les <quote>forks</quote>, dans ce contexte, arrivent 
   1.470 -tout le temps.</para>
   1.471 -
   1.472 -	<para id="x_95">Si chaque altération que n'importe qui effectue, à tout moment, est vue
   1.473 -comme un <quote>fork</quote> à fusionner, alors ce que le monde de
   1.474 -l'<emphasis remap="it">Open Source</emphasis>
   1.475 -Source} voit comme un <quote>fork</quote> devient <emphasis>uniquement</emphasis> une problématique
   1.476 -sociale. En fait, les outils de gestions de source distribués <emphasis>réduisent</emphasis>
   1.477 -les chances de <quote>fork</quote>:
   1.478 -</para>
   1.479 -<itemizedlist>
   1.480 -    <listitem>
   1.481 -        <para>Ils éliminent la distinction sociale qu'imposent les outils centralisés
   1.482 -        entre les membres du projets (ceux qui ont accès au <quote>commit</quote>) et ceux de
   1.483 -        l'extérieur (ce qui ne l'ont pas).</para>
   1.484 -        <para>rendent plus facile la réconciliation après un <quote>fork</quote> social, car tout ce 
   1.485 -         qu'elle implique est une simple fusion.</para>
   1.486 -    </listitem>
   1.487 -</itemizedlist>
   1.488 -
   1.489 -	<para id="x_98">Certaines personnes font de la résistance envers les gestionnaires de source
   1.490 -distribués parce qu'ils veulent garder un contrôle ferme sur leur projet, et
   1.491 -ils pensent que les outils centralisés leur fournissent ce contrôle. Néanmoins,
   1.492 -si c'est votre cas, sachez que si vous publiez votre dépôt CVS ou Subversion
   1.493 -de manière publique, il existe une quantité d'outils disponibles pour récupérer
   1.494 -entièrement votre projet et son historique (quoique lentement) et le récréer
   1.495 -ailleurs, sans votre contrôle. En fait, votre contrôle sur votre projet est
   1.496 -illusoire, vous ne faites qu'interdire à vos collaborateurs de travailler
   1.497 -de manière fluide, en disposant d'un miroir ou d'un <quote>fork</quote> de votre
   1.498 -historique.
   1.499 -%%%TODO: Fussy, those last sentences are not really well translated:
   1.500 -%%%no problem for me (wilk)
   1.501 -%However, if you're of this belief, and you publish your CVS or Subversion
   1.502 -%repositories publically, there are plenty of tools available that can pull
   1.503 -%out your entire project's history (albeit slowly) and recreate it somewhere
   1.504 -%that you don't control.  So while your control in this case is illusory, you are
   1.505 -%forgoing the ability to fluidly collaborate with whatever people feel
   1.506 -%compelled to mirror and fork your history.
   1.507 -</para>
   1.508 -
   1.509 -      </sect3>
   1.510 +      <para id="x_91">Si vous prenez goût à un projet <emphasis
   1.511 +          remap="it">Open Source</emphasis> et que vous décidez de commencer
   1.512 +        à toucher à son code, et que le projet utilise un gestionnaire de
   1.513 +        source distribué, vous êtes immédiatement un "pair" avec les
   1.514 +        personnes formant le <quote>cœur</quote> du projet. S'ils publient
   1.515 +        leurs dépôts, vous pouvez immédiatement copier leurs historiques de
   1.516 +        projet, faire des modifications, enregistrer votre travail en
   1.517 +        utilisant les mêmes outils qu'eux. Par comparaison avec un outil
   1.518 +        centralisé, vous devez utiliser un logiciel en mode <quote>lecture
   1.519 +          seule</quote> à moins que quelqu'un ne vous donne les privilèges de
   1.520 +        <quote>commit</quote> sur le serveur central. Avant ça, vous ne serez
   1.521 +        pas capable d'enregistrer vos modifications, et vos propres
   1.522 +        modifications risqueront de se corrompre chaque fois que vous
   1.523 +        essayerez de mettre à jour à votre espace de travail avec le serveur
   1.524 +        central.
   1.525 +      </para>
   1.526 +
   1.527 +    <sect3>
   1.528 +      <title>Le non-problème du "fork"</title>
   1.529 +      
   1.530 +      <para id="x_92">Il a été souvent suggéré que les gestionnaires de
   1.531 +        source distribués posent un risque pour les projets <emphasis
   1.532 +          remap="it">Open Source</emphasis> car ils facilitent grandement la
   1.533 +        création de <quote>fork</quote>.
   1.534 +        <!--footnote{NdT:Création d'une <ulink url="version alternative du
   1.535 +          logiciel">version alternative du
   1.536 +          logiciel</ulink>{http://fr.wikipedia.org/wiki/Fork#Embranchement_d.27un_projet_informatique}
   1.537 +        -->
   1.538 +        Un <quote>fork</quote> apparait quand il y des divergences d'opinion
   1.539 +        ou d'attitude au sein d'un groupe de développeurs qui aboutissent à
   1.540 +        la décision de ne plus travailler ensemble. Chaque parti s'empare
   1.541 +        d'une copie plus ou moins complète du code source du projet et
   1.542 +        continue dans sa propre direction.
   1.543 +      </para>
   1.544 +
   1.545 +
   1.546 +      <para id="x_93">Parfois ces différents partis décident de se
   1.547 +        réconcilier. Avec un serveur central, l'aspect
   1.548 +        <emphasis>technique</emphasis> de cette réconciliation est un
   1.549 +        processus douloureux, et essentiellement manuel. Vous devez décider
   1.550 +        quelle modification est <quote>la gagnante</quote>, et replacer, par
   1.551 +        un moyen ou un autre, les modifications de l'autre équipe dans
   1.552 +        l'arborescence du projet. Ceci implique généralement la perte d'une
   1.553 +        partie de l'historique d'un des partis, ou même des deux.
   1.554 +      </para>
   1.555 +    
   1.556 +      <para id="x_94">Ce que les outils distribués permettent à ce sujet est
   1.557 +        probablement la <emphasis>meilleure</emphasis> façon de développer un
   1.558 +        projet. Chaque modification que vous effectuez est potentiellement un
   1.559 +        <quote>fork</quote>. La grande force de cette approche est que les
   1.560 +        gestionnaires de source distribués doivent être vraiment très
   1.561 +        efficaces pour <emphasis>fusionner (merge)</emphasis>
   1.562 +        <!-- TODO footnote{NdT:j'ai choisi de traduire ici <emphasis
   1.563 +          remap="it">merging</emphasis> par <quote>fusionner</quote> pour des
   1.564 +        raisons de clarté} -->
   1.565 +        des <quote>forks</quote>, car les <quote>forks</quote>, dans ce
   1.566 +        contexte, arrivent tout le temps.
   1.567 +      </para>
   1.568 +      
   1.569 +      <para id="x_95">Si chaque altération que n'importe qui effectue, à tout
   1.570 +        moment, est vue comme un <quote>fork</quote> à fusionner, alors ce
   1.571 +        que le monde de l'<emphasis remap="it">Open Source</emphasis> voit
   1.572 +        comme un <quote>fork</quote> devient <emphasis>uniquement</emphasis>
   1.573 +        une problématique sociale. En fait, les outils de gestions de source
   1.574 +        distribués <emphasis>réduisent</emphasis> les chances de
   1.575 +        <quote>fork</quote> :
   1.576 +      </para>
   1.577 +        
   1.578 +      <itemizedlist>
   1.579 +        <listitem>
   1.580 +        <para>Ils éliminent la distinction sociale qu'imposent les outils
   1.581 +          centralisés entre les membres du projets (ceux qui ont accès au
   1.582 +          <quote>commit</quote>) et ceux de l'extérieur (ce qui ne l'ont
   1.583 +          pas).
   1.584 +        </para>
   1.585 +        <para>Ils rendent plus facile la réconciliation après un
   1.586 +          <quote>fork</quote> social, car tout ce qu'elle implique est une
   1.587 +          simple fusion.
   1.588 +        </para>
   1.589 +        </listitem>
   1.590 +      </itemizedlist>
   1.591 +
   1.592 +      <para id="x_98">Certaines personnes font de la résistance envers les
   1.593 +        gestionnaires de source distribués parce qu'ils veulent garder un
   1.594 +        contrôle ferme sur leur projet, et ils pensent que les outils
   1.595 +        centralisés leur fournissent ce contrôle. Néanmoins, si c'est votre
   1.596 +        cas, sachez que si vous publiez votre dépôt CVS ou Subversion de
   1.597 +        manière publique, il existe une quantité d'outils disponibles pour
   1.598 +        récupérer entièrement votre projet et son historique (quoique
   1.599 +        lentement) et le récréer ailleurs, sans votre contrôle. En fait,
   1.600 +        votre contrôle sur votre projet est illusoire, vous ne faites
   1.601 +        qu'interdire à vos collaborateurs de travailler de manière fluide, en
   1.602 +        disposant d'un miroir ou d'un <quote>fork</quote> de votre
   1.603 +        historique.
   1.604 +      </para>
   1.605 +
   1.606 +    </sect3>
   1.607      </sect2>
   1.608      <sect2>
   1.609        <title>Avantages pour les projets commerciaux</title>
   1.610  
   1.611 -      <para id="x_99">Beaucoup de projets commerciaux sont réalisés par des équipes éparpillées
   1.612 -à travers le globe. Les contributeurs qui sont loin du serveur central
   1.613 -devront subir des commandes lentes et même parfois peu fiables. Les
   1.614 -solutions propriétaires de gestion de source tentent de palier ce problème
   1.615 -avec des réplications de sites distants qui sont à la fois coûteuses à mettre
   1.616 -en place et lourdes à administrer. Un système distribué ne souffre pas
   1.617 -de ce genre de problèmes. En outre, il est très aisé de mettre en place
   1.618 -plusieurs serveurs de références, disons un par site, de manière à ce qu'il
   1.619 -n'y ait pas de communication redondante entre les dépôts, sur une connexion
   1.620 -longue distance souvent onéreuse.
   1.621 -</para>
   1.622 -
   1.623 -      <para id="x_9a">Les systèmes de gestion de source supportent généralement assez mal la
   1.624 -montée en charge. Ce n'est pas rare pour un gestionnaire de source centralisé
   1.625 -pourtant onéreux de s'effondrer sous la charge combinée d'une douzaine
   1.626 -d'utilisateurs concurrents seulement. Une fois encore, la réponse à cette problématique
   1.627 -est généralement encore la mise en place d'un ensemble complexe de serveurs
   1.628 -synchronisés par un mécanisme de réplication. Dans le cas d'un gestionnaire
   1.629 -de source distribué, la charge du serveur central &emdash; si vous avez un&emdash; est
   1.630 -plusieurs fois inférieure (car toutes les données sont déjà répliquées ailleurs),
   1.631 -un simple serveur, pas très cher, peut gérer les besoins d'une plus grande
   1.632 -équipe, et la réplication pour balancer la charge devient le
   1.633 -travail d'un simple script.
   1.634 -</para>
   1.635 -
   1.636 -      <para id="x_9b">Si vous avez des employés sur le terrain, en train de chercher à résoudre un souci sur
   1.637 -le site d'un client, ils bénéficieront aussi d'un gestionnaire de source
   1.638 -distribué. Cet outil leur permettra de générer des versions personnalisées,
   1.639 -d'essayer différentes solutions, en les isolant aisément les unes des autres,
   1.640 -et de rechercher efficacement à travers l'historique des sources, la cause
   1.641 -des bugs ou des régressions, tout ceci sans avoir besoin de la moindre
   1.642 -connexion au réseau de votre compagnie.
   1.643 -</para>
   1.644 +      <para id="x_99">Beaucoup de projets commerciaux sont réalisés par des
   1.645 +        équipes éparpillées à travers le globe. Les contributeurs qui sont
   1.646 +        loin du serveur central devront subir des commandes lentes et même
   1.647 +        parfois peu fiables. Les solutions propriétaires de gestion de source
   1.648 +        tentent de palier ce problème avec des réplications de sites distants
   1.649 +        qui sont à la fois coûteuses à mettre en place et lourdes à
   1.650 +        administrer. Un système distribué ne souffre pas de ce genre de
   1.651 +        problèmes. En outre, il est très aisé de mettre en place plusieurs
   1.652 +        serveurs de références, disons un par site, de manière à ce qu'il n'y
   1.653 +        ait pas de communication redondante entre les dépôts, sur une
   1.654 +        connexion longue distance souvent onéreuse.
   1.655 +      </para>
   1.656 +
   1.657 +      <para id="x_9a">Les systèmes de gestion de source supportent
   1.658 +        généralement assez mal la monté en charge. Il n'est pas rare pour un
   1.659 +        gestionnaire de source centralisé pourtant onéreux de s'effondrer
   1.660 +        sous la charge combinée d'une douzaine d'utilisateurs concurrents
   1.661 +        seulement. Une fois encore, la réponse à cette problématique est
   1.662 +        généralement encore la mise en place d'un ensemble complexe de
   1.663 +        serveurs synchronisés par un mécanisme de réplication. Dans le cas
   1.664 +        d'un gestionnaire de source distribué, la charge du serveur central
   1.665 +        &emdash; si vous avez un&emdash; est plusieurs fois inférieure (car
   1.666 +        toutes les données sont déjà répliquées ailleurs), un simple serveur,
   1.667 +        pas très cher, peut gérer les besoins d'une plus grande équipe, et la
   1.668 +        réplication pour balancer la charge devient le travail d'un simple
   1.669 +        script.
   1.670 +      </para>
   1.671 +
   1.672 +      <para id="x_9b">Si vous avez des employés sur le terrain, en train de
   1.673 +        chercher à résoudre un souci sur le site d'un client, ils
   1.674 +        bénéficieront aussi d'un gestionnaire de source distribué. Cet outil
   1.675 +        leur permettra de générer des versions personnalisées, d'essayer
   1.676 +        différentes solutions, en les isolant aisément les unes des autres,
   1.677 +        et de rechercher efficacement à travers l'historique des sources, la
   1.678 +        cause des bugs ou des régressions, tout ceci sans avoir besoin de la
   1.679 +        moindre connexion au réseau de votre compagnie.
   1.680 +      </para>
   1.681  
   1.682      </sect2>
   1.683 -  </sect1>
   1.684 -  <sect1>
   1.685 -    <title>Pourquoi choisir Mercurial?</title>
   1.686 -
   1.687 -    <para id="x_9c">Mercurial a plusieurs caractéristiques qui en font un choix particulièrement
   1.688 -pertinent pour la gestion de source:
   1.689 -</para>
   1.690 +    </sect1>
   1.691 +    <sect1>
   1.692 +      <title>Pourquoi choisir Mercurial?</title>
   1.693 +
   1.694 +      <para id="x_9c">Mercurial a plusieurs caractéristiques qui en font un
   1.695 +        choix particulièrement pertinent pour la gestion de source :
   1.696 +      </para>
   1.697      <itemizedlist>
   1.698 -      <listitem><para id="x_9d">It is easy to learn and use.</para></listitem>
   1.699 -      <listitem><para id="x_9e">It is lightweight.</para></listitem>
   1.700 -      <listitem><para id="x_9f">It scales excellently.</para></listitem>
   1.701 -      <listitem><para id="x_a0">It is easy to
   1.702 -	  customise.</para></listitem></itemizedlist>
   1.703 -
   1.704 -    <para id="x_a1">Si vous êtes déjà familier d'un outil de gestion de source, vous serez
   1.705 -capable de l'utiliser en moins de 5 minutes. Sinon, ça ne sera pas beaucoup
   1.706 -plus long.
   1.707 -Les commandes utilisées par Mercurial, comme ses fonctionnalités, sont
   1.708 -généralement uniformes et cohérentes, et vous pouvez donc ainsi garder en tête
   1.709 -simplement quelques règles générales, plutôt qu'un lot complexe d'exceptions.
   1.710 -</para>
   1.711 -
   1.712 -    <para id="x_a2">Sur un petit projet, vous pouvez commencer à travailler avec Mercurial en
   1.713 -quelques instants. Ajouter des modifications ou des branches, transférer
   1.714 -ces modifications (localement ou via le réseau), et les opérations
   1.715 -d'historique ou de statut sont aussi très rapides. Mercurial reste hors de
   1.716 -votre chemin grâce à sa simplicité d'utilisation et sa rapidité d'exécution.
   1.717 -</para>
   1.718 -
   1.719 -    <para id="x_a3">L'utilité de Mercurial ne se limite pas à de petits projets: il est
   1.720 -aussi utilisé par des projets ayant des centaines ou même des milliers
   1.721 -de contributeurs, avec plusieurs dizaines de milliers de fichiers, et des
   1.722 -centaines de méga de code source.
   1.723 -</para>
   1.724 -
   1.725 -    <para id="x_a4">Si les fonctionnalités cœur de Mercurial ne sont pas suffisantes pour vous,
   1.726 -il est très aisé d'en construire d'autres. Mercurial est adapté à l'utilisation
   1.727 -de scripts, et son implémentation interne en Python, propre et claire,
   1.728 -rend encore plus facile l'ajout de fonctionnalités sous forme d'extensions. Il
   1.729 -en existe déjà un certain nombre de très populaires et très utiles,
   1.730 -dont le périmètre va de la recherche de bugs à l'amélioration des performances.
   1.731 -</para>
   1.732 +      <listitem><para id="x_9d">Il est simple à apprendre et à utiliser.</para></listitem>
   1.733 +      <listitem><para id="x_9e">Il est léger.</para></listitem>
   1.734 +      <listitem><para id="x_9f">Il s'adapte très bien à la charge.</para></listitem>
   1.735 +      <listitem><para id="x_a0">Il se personnalise facilement.</para></listitem>
   1.736 +    </itemizedlist>
   1.737 +
   1.738 +    <para id="x_a1">Si vous êtes déjà familier d'un outil de gestion de
   1.739 +      source, vous serez capable de l'utiliser en moins de 5 minutes. Sinon,
   1.740 +      ça ne sera pas beaucoup plus long. Les commandes utilisées par
   1.741 +      Mercurial, comme ses fonctionnalités, sont généralement uniformes et
   1.742 +      cohérentes, et vous pouvez ainsi garder en tête simplement quelques
   1.743 +      règles générales, plutôt qu'un lot complexe d'exceptions.
   1.744 +    </para>
   1.745 +
   1.746 +    <para id="x_a2">Sur un petit projet, vous pouvez commencer à travailler
   1.747 +      avec Mercurial en quelques instants. Ajouter des modifications ou des
   1.748 +      branches, transférer ces modifications (localement ou via le réseau),
   1.749 +      et les opérations d'historique ou de statut sont aussi très rapides.
   1.750 +      Mercurial reste hors de votre chemin grâce à sa simplicité
   1.751 +      d'utilisation et sa rapidité d'exécution.
   1.752 +    </para>
   1.753 +
   1.754 +    <para id="x_a3">L'utilité de Mercurial ne se limite pas à de petits
   1.755 +      projets: il est aussi utilisé par des projets ayant des centaines ou
   1.756 +      même des milliers de contributeurs, avec plusieurs dizaines de milliers
   1.757 +      de fichiers, et des centaines de méga octets de code source.
   1.758 +    </para>
   1.759 +
   1.760 +    <para id="x_a4">Si les fonctionnalités au cœur de Mercurial ne sont pas
   1.761 +      suffisantes pour vous, il est très aisé d'en construire d'autres.
   1.762 +      Mercurial est adapté à l'utilisation de scripts, et son implémentation
   1.763 +      interne en Python, propre et claire, rend encore plus facile l'ajout de
   1.764 +      fonctionnalités sous forme d'extensions. Il en existe déjà un certain
   1.765 +      nombre de très populaires et très utiles, dont le périmètre va de la
   1.766 +      recherche de bugs à l'amélioration des performances.
   1.767 +    </para>
   1.768  
   1.769    </sect1>
   1.770    <sect1>
   1.771      <title>Mercurial comparé aux autres outils</title>
   1.772  
   1.773 -    <para id="x_a5">Avant que vous n'alliez plus loin, comprenez bien que cette section
   1.774 -reflète mes propres expériences, et elle est donc (j'ose le dire)
   1.775 -peu objective. Néanmoins, j'ai utilisé les outils de gestion de source
   1.776 -listés ci dessous, dans la plupart des cas, pendant plusieurs années.
   1.777 -%% TODO: Fussy translation.
   1.778 -</para>
   1.779 -
   1.780 +    <para id="x_a5">Avant que vous n'alliez plus loin, comprenez bien que
   1.781 +      cette section reflète mes propres expériences, et elle est donc (j'ose
   1.782 +      le dire) peu objective. Néanmoins, j'ai utilisé les outils de gestion
   1.783 +      de source listés ci dessous, dans la plupart des cas, pendant plusieurs
   1.784 +      années.
   1.785 +    </para>
   1.786  
   1.787      <sect2>
   1.788        <title>Subversion</title>
   1.789  
   1.790 -      <para id="x_a6">Subversion est un des outils de gestion de source les plus populaire, il fût
   1.791 -développé pour remplacer CVS. Il a une architecture client/server centralisée.
   1.792 -</para>
   1.793 -
   1.794 -    <para id="x_a7">Subversion et Mercurial ont des noms de commandes très similaires pour
   1.795 -les mêmes opérations, ainsi si vous êtes familier avec l'un, c'est facile
   1.796 -d'apprendre l'autre. Ces deux outils sont portables sur les systèmes
   1.797 -d'exploitation les plus populaires
   1.798 -</para>
   1.799 -
   1.800 -      <para id="x_a8">Avant la version 1.5, Subversion n'offrait aucune forme de support pour les fusions. Lors
   1.801 -de l'écriture de ce livre, ses capacités de fusion étaient nouvelles, et réputées pour être
   1.802 -<ulink url="http://svnbook.red-bean.com/nightly/en/svn.branchmerge.advanced.html#svn.branchmerge.advanced.finalword">
   1.803 -complexes et boguées</ulink>.
   1.804 -</para>
   1.805 -
   1.806 -      <para id="x_a9">Mercurial dispose d'un avantage substantiel en terme de performance par rapport à
   1.807 -Subversion sur la plupart des opérations que j'ai pu tester. J'ai mesuré
   1.808 -une différence de performance allant de deux à six fois plus rapide avec
   1.809 -le système de stockage de fichier local de Subversion 1.4.3
   1.810 -(<emphasis>ra_local</emphasis>), qui est la méthode d'accès la plus rapide disponible. Dans
   1.811 -un déploiement plus réaliste, impliquant un stockage réseau, Subversion
   1.812 -serait encore plus désavantagé. Parce que la plupart des commandes Subversion
   1.813 -doivent communiquer avec le serveur et que Subversion n'a pas de mécanisme
   1.814 -de réplication, la capacité du serveur et la bande passante sont devenues des
   1.815 -goulots d'étranglement pour les projets de taille moyenne ou grande.
   1.816 -</para>
   1.817 -
   1.818 -      <para id="x_aa">En outre, Subversion implique une surcharge substantielle dans le stockage local
   1.819 -de certaines données, pour éviter des transactions avec le serveur, pour
   1.820 -certaines opérations communes, telles que la recherche des fichiers modifiés
   1.821 -(<literal>status</literal>) et l'affichage des modifications par rapport à la révision
   1.822 -courante (<literal>diff</literal>). En conséquence, un répertoire de travail Subversion
   1.823 -a souvent la même taille, ou est plus grand, qu'un dépôt Mercurial et son
   1.824 -espace de travail, et ceci bien que le dépôt Mercurial contienne l'intégralité
   1.825 -de l'historique.
   1.826 -</para>
   1.827 -
   1.828 -      <para id="x_ab">Subversion est largement supporté par les outils tierces. Mercurial est
   1.829 -actuellement encore en retrait de ce point de vue. L'écart se réduit, néanmoins,
   1.830 -et en effet certains des outils graphiques sont maintenant supérieurs à leurs
   1.831 -équivalents Subversion. Comme Mercurial, Subversion dispose d'un excellent
   1.832 -manuel utilisateur.
   1.833 -</para>
   1.834 -
   1.835 -      <para id="x_ac">Parce que Subversion ne stocke pas l'historique chez ses clients, il est
   1.836 -parfaitement adapté à la gestion de projets qui doivent suivre un ensemble
   1.837 -de larges fichiers binaires et opaques. Si vous suivez une cinquantaine de
   1.838 -versions d'un fichier incompressible de 10MB, l'occupation disque coté client
   1.839 -d'un projet sous Subversion restera à peu près constante. A l'inverse,
   1.840 -l'occupation disque du même projet sous n'importe lequel des gestionnaires
   1.841 -de source distribués grandira rapidement, proportionnellement aux nombres
   1.842 -de versions, car les différences entre chaque révisions seront très grandes.
   1.843 -</para>
   1.844 -
   1.845 -      <para id="x_ad">En outre, c'est souvent difficile ou, généralement, impossible de fusionner
   1.846 -des différences dans un fichier binaire. La capacité de Subversion de
   1.847 -verrouiller des fichiers, pour permettre à l'utilisateur d'être le seul
   1.848 -à le mettre à jour (<quote>commit</quote>) temporairement, est un avantage significatif
   1.849 -dans un projet doté de beaucoup de fichiers binaires.
   1.850 -</para>
   1.851 -
   1.852 -      <para id="x_ae">Mercurial peut importer l'historique depuis un dépôt Subversion. Il peut
   1.853 -aussi exporter l'ensemble des révisions d'un projet vers un dépôt Subversion.
   1.854 -Ceci rend très facile de <quote>prendre la température</quote> et d'utiliser Mercurial et Subversion
   1.855 -en parallèle, avant de décider de migrer vers Mercurial. La conversion de
   1.856 -l'historique est incrémentale, donc vous pouvez effectuer une conversion
   1.857 -initiale, puis de petites additions par la suite pour ajouter les nouvelles
   1.858 -modifications.
   1.859 -</para>
   1.860 +      <para id="x_a6">Subversion est un des outils de gestion de source les
   1.861 +        plus populaire, il fût développé pour remplacer CVS. Il a une
   1.862 +        architecture client/server centralisée.
   1.863 +      </para>
   1.864 +
   1.865 +      <para id="x_a7">Subversion et Mercurial ont des noms de commandes très
   1.866 +        similaires pour les mêmes opérations, ainsi si vous êtes familier
   1.867 +        avec l'un, c'est facile d'apprendre l'autre. Ces deux outils sont
   1.868 +        portables sur les systèmes d'exploitation les plus populaires.
   1.869 +      </para>
   1.870 +
   1.871 +      <para id="x_a8">Avant la version 1.5, Subversion n'offrait aucune forme
   1.872 +        de support pour les fusions. Lors de l'écriture de ce livre, ses
   1.873 +        capacités de fusion étaient nouvelles, et réputées pour être <ulink
   1.874 +          url="http://svnbook.red-bean.com/nightly/en/svn.branchmerge.advanced.html#svn.branchmerge.advanced.finalword">
   1.875 +          complexes et buguées</ulink>.
   1.876 +      </para>
   1.877 +
   1.878 +      <para id="x_a9">Mercurial dispose d'un avantage substantiel en terme de
   1.879 +        performance par rapport à Subversion sur la plupart des opérations
   1.880 +        que j'ai pu tester. J'ai mesuré une différence de performance allant
   1.881 +        de deux à six fois plus rapide avec le système de stockage de fichier
   1.882 +        local de Subversion 1.4.3 (<emphasis>ra_local</emphasis>), qui est la
   1.883 +        méthode d'accès la plus rapide disponible. Dans un déploiement plus
   1.884 +        réaliste, impliquant un stockage réseau, Subversion serait encore
   1.885 +        plus désavantagé. Parce que la plupart des commandes Subversion
   1.886 +        doivent communiquer avec le serveur et que Subversion n'a pas de
   1.887 +        mécanisme de réplication, la capacité du serveur et la bande passante
   1.888 +        sont devenues des goulots d'étranglement pour les projets de taille
   1.889 +        moyenne ou grande.
   1.890 +      </para>
   1.891 +
   1.892 +      <para id="x_aa">En outre, Subversion implique une surcharge
   1.893 +        substantielle dans le stockage local de certaines données, pour
   1.894 +        éviter des transactions avec le serveur, pour certaines opérations
   1.895 +        communes, telles que la recherche des fichiers modifiés
   1.896 +        (<literal>status</literal>) et l'affichage des modifications par
   1.897 +        rapport à la révision courante (<literal>diff</literal>). En
   1.898 +        conséquence, un répertoire de travail Subversion a souvent la même
   1.899 +        taille, ou est plus grand, qu'un dépôt Mercurial et son espace de
   1.900 +        travail, et ceci bien que le dépôt Mercurial contienne l'intégralité
   1.901 +        de l'historique.
   1.902 +      </para>
   1.903 +
   1.904 +      <para id="x_ab">Subversion est largement supporté par les outils
   1.905 +        tierces. Mercurial est actuellement encore en retrait de ce point de
   1.906 +        vue. L'écart se réduit néanmoins, en effet, certains des outils
   1.907 +        graphiques sont maintenant supérieurs à leurs équivalents Subversion.
   1.908 +        Comme Mercurial, Subversion dispose d'un excellent manuel
   1.909 +        utilisateur.
   1.910 +      </para>
   1.911 +
   1.912 +      <para id="x_ac">Parce que Subversion ne stocke pas l'historique chez
   1.913 +        ses clients, il est parfaitement adapté à la gestion de projets qui
   1.914 +        doivent suivre un ensemble de larges fichiers binaires et opaques. Si
   1.915 +        vous suivez une cinquantaine de versions d'un fichier incompressible
   1.916 +        de 10MB, l'occupation disque coté client d'un projet sous Subversion
   1.917 +        restera à peu près constante. A l'inverse, l'occupation disque du
   1.918 +        même projet sous n'importe lequel des gestionnaires de source
   1.919 +        distribués grandira rapidement, proportionnellement aux nombres de
   1.920 +        versions, car les différences entre chaque révisions seront très
   1.921 +        grandes.
   1.922 +      </para>
   1.923 +
   1.924 +      <para id="x_ad">En outre, c'est souvent difficile ou, généralement,
   1.925 +        impossible de fusionner des différences dans un fichier binaire. La
   1.926 +        capacité de Subversion de verrouiller des fichiers, pour permettre à
   1.927 +        l'utilisateur d'être le seul à le mettre à jour
   1.928 +        (<quote>commit</quote>) temporairement, est un avantage significatif
   1.929 +        dans un projet doté de beaucoup de fichiers binaires.
   1.930 +      </para>
   1.931 +
   1.932 +      <para id="x_ae">Mercurial peut importer l'historique depuis un dépôt
   1.933 +        Subversion. Il peut aussi exporter l'ensemble des révisions d'un
   1.934 +        projet vers un dépôt Subversion. Ceci rend très facile de
   1.935 +        <quote>prendre la température</quote> et d'utiliser Mercurial et
   1.936 +        Subversion en parallèle, avant de décider de migrer vers Mercurial.
   1.937 +        La conversion de l'historique est incrémentale, donc vous pouvez
   1.938 +        effectuer une conversion initiale, puis de petites additions par la
   1.939 +        suite pour ajouter les nouvelle modifications.
   1.940 +      </para>
   1.941  
   1.942  
   1.943      </sect2>
   1.944      <sect2>
   1.945        <title>Git</title>
   1.946  
   1.947 -      <para id="x_af">Git est un outil de gestion de source distribué qui fût développé pour gérer
   1.948 -le code source de noyau de Linux. Comme Mercurial, sa conception initiale a
   1.949 -été inspirée par Monotone.
   1.950 -</para>
   1.951 -
   1.952 -      <para id="x_b0">Git dispose d'un ensemble conséquent de commandes, avec plus de 139 commandes
   1.953 -individuelles pour la version 1.5.0. Il a aussi la réputation d'être difficile
   1.954 -à apprendre. Comparé à Git, le point fort de Mercurial est clairement sa
   1.955 -simplicité.
   1.956 -</para>
   1.957 -
   1.958 -      <para id="x_b1">En terme de performance, Git est extrêmement rapide. Dans la plupart des
   1.959 -cas, il est plus rapide que Mercurial, tout du moins sur Linux, alors que
   1.960 -Mercurial peut être plus performant sur d'autres opérations. Néanmoins, sur
   1.961 -Windows, les performances et le niveau de support général fourni par Git,
   1.962 -au moment de l'écriture de cet ouvrage, est bien derrière celui de Mercurial.
   1.963 -</para>
   1.964 -
   1.965 -      <para id="x_b2">Alors que le dépôt Mercurial ne demande aucune maintenance, un dépôt Git
   1.966 -exige d'exécuter manuellement et régulièrement la commande <quote>repacks</quote> sur
   1.967 -ces métadonnées. Sans ceci, les performances de git se dégradent et la
   1.968 -consommation de l'espace disque augmente rapidement. Un serveur qui contient
   1.969 -plusieurs dépôts Git qui ne sont pas régulièrement et fréquemment <quote>repacked</quote>
   1.970 -deviendra un vrai problème lors des <quote>backups</quote> du disque, et il y eu des
   1.971 -cas, où un <quote>backup</quote> journalier pouvait durer plus de 24 heures. Un dépôt
   1.972 -fraichement <quote>repacked</quote> sera légèrement plus petit qu'un dépôt Mercurial,
   1.973 -mais un dépôt non <quote>repacked</quote> est beaucoup plus grand.
   1.974 -</para>
   1.975 -
   1.976 -      <para id="x_b3">Le cœur de Git est écrit en C. La plupart des commandes Git sont implémentées
   1.977 -sous forme de scripts Shell ou Perl, et la qualité de ces scripts varie
   1.978 -grandement. J'ai plusieurs fois constaté que certains de ces scripts étaient
   1.979 -chargés en mémoire aveuglément et que la présence d'erreurs pouvait s'avérer
   1.980 -fatal.
   1.981 -</para>
   1.982 -
   1.983 -      <para id="x_b4">Mercurial peut importer l'historique d'un dépôt Git.
   1.984 -</para>
   1.985 -
   1.986 -
   1.987 +      <para id="x_af">Git est un outil de gestion de source distribué qui fût
   1.988 +        développé pour gérer le code source de noyau de Linux. Comme
   1.989 +        Mercurial, sa conception initiale a été inspirée par Monotone.
   1.990 +      </para>
   1.991 +
   1.992 +      <para id="x_b0">Git dispose d'un ensemble conséquent de commandes, avec
   1.993 +        plus de 139 commandes individuelles pour la version 1.5.0. Il a aussi
   1.994 +        la réputation d'être difficile à apprendre. Comparé à Git, le point
   1.995 +        fort de Mercurial est clairement sa simplicité.
   1.996 +      </para>
   1.997 +
   1.998 +      <para id="x_b1">En terme de performance, Git est extrêmement rapide.
   1.999 +        Dans la plupart des cas, il est plus rapide que Mercurial, tout du
  1.1000 +        moins sur Linux, alors que Mercurial peut être plus performant sur
  1.1001 +        d'autres opérations. Néanmoins, sur Windows, les performances et le
  1.1002 +        niveau de support général fourni par Git, au moment de l'écriture de
  1.1003 +        cet ouvrage, est bien derrière celui de Mercurial.
  1.1004 +      </para>
  1.1005 +
  1.1006 +      <para id="x_b2">Alors que le dépôt Mercurial ne demande aucune
  1.1007 +        maintenance, un dépôt Git exige d'exécuter manuellement et
  1.1008 +        régulièrement la commande <quote>repacks</quote> sur ses métadonnées.
  1.1009 +        Sans ceci, les performances de git se dégradent et la consommation de
  1.1010 +        l'espace disque augmente rapidement. Un serveur qui contient
  1.1011 +        plusieurs dépôts Git qui ne sont pas régulièrement et fréquemment
  1.1012 +        <quote>repacked</quote> deviendra un vrai problème lors des
  1.1013 +        <quote>backups</quote> du disque, et il y eu des cas, où un
  1.1014 +        <quote>backup</quote> journalier pouvait durer plus de 24 heures. Un
  1.1015 +        dépôt fraichement <quote>repacked</quote> sera légèrement plus petit
  1.1016 +        qu'un dépôt Mercurial, mais un dépôt non <quote>repacked</quote> est
  1.1017 +        beaucoup plus grand.
  1.1018 +      </para>
  1.1019 +
  1.1020 +      <para id="x_b3">Le cœur de Git est écrit en C. La plupart des commandes
  1.1021 +        Git sont implémentées sous forme de scripts Shell ou Perl, et la
  1.1022 +        qualité de ces scripts varie grandement. J'ai plusieurs fois constaté
  1.1023 +        que certains de ces scripts étaient chargés en mémoire aveuglément et
  1.1024 +        que la présence d'erreurs pouvait s'avérer fatal.
  1.1025 +      </para>
  1.1026 +
  1.1027 +      <para id="x_b4">Mercurial peut importer l'historique d'un dépôt Git.</para>
  1.1028  
  1.1029      </sect2>
  1.1030      <sect2>
  1.1031        <title>CVS</title>
  1.1032  
  1.1033 -      <para id="x_b5">CVS est probablement l'outil de gestion de source le plus utilisé aujourd'hui
  1.1034 -dans le monde. À cause de son manque de clarté interne, il n'est plus
  1.1035 -maintenu depuis plusieurs années.
  1.1036 -</para>
  1.1037 -
  1.1038 -      <para id="x_b6">Il a une architecture client/serveur centralisée. Il ne regroupe pas les
  1.1039 -modifications de fichiers dans une opération de <quote>commit</quote> atomique, ce
  1.1040 -qui permet à ses utilisateurs de <quote>casser le <emphasis>build</emphasis></quote> assez
  1.1041 -facilement : une personne peut effectuer une opération de <quote>commit</quote>
  1.1042 -sans problème puis être bloquée par besoin de fusion, avec comme conséquence
  1.1043 -néfaste, que les autres utilisateurs ne récupèreront qu'une partie de ses
  1.1044 -modifications. Ce problème affecte aussi la manière de travailler avec
  1.1045 -l'historique du projet. Si vous voulez voir toutes les modifications d'une
  1.1046 -personne du projet, vous devrez injecter manuellement les descriptions et les
  1.1047 -<emphasis remap="it">timestamps</emphasis> des modifications de chacun des fichiers impliqués (si
  1.1048 -vous savez au moins quels sont ces fichiers).
  1.1049 -</para>
  1.1050 +      <para id="x_b5">CVS est probablement l'outil de gestion de source le
  1.1051 +        plus utilisé aujourd'hui dans le monde. À cause de son manque de
  1.1052 +        clarté interne, il n'est plus maintenu depuis plusieurs années.
  1.1053 +      </para>
  1.1054 +
  1.1055 +      <para id="x_b6">Il a une architecture client/serveur centralisée. Il ne
  1.1056 +        regroupe pas les modifications de fichiers dans une opération de
  1.1057 +        <quote>commit</quote> atomique, ce qui permet à ses utilisateurs de
  1.1058 +        <quote>casser le <emphasis>build</emphasis></quote> assez facilement
  1.1059 +        : une personne peut effectuer une opération de <quote>commit</quote>
  1.1060 +        sans problème puis être bloquée par besoin de fusion, avec comme
  1.1061 +        conséquence néfaste, que les autres utilisateurs ne récupèreront
  1.1062 +        qu'une partie de ses modifications. Ce problème affecte aussi la
  1.1063 +        manière de travailler avec l'historique du projet. Si vous voulez
  1.1064 +        voir toutes les modifications d'une personne du projet, vous devrez
  1.1065 +        injecter manuellement les descriptions et les <emphasis
  1.1066 +          remap="it">timestamps</emphasis> des modifications de chacun des
  1.1067 +        fichiers impliqués (si vous savez au moins quels sont ces fichiers).
  1.1068 +      </para>
  1.1069  
  1.1070        <para id="x_b7">CVS a une notion étrange des <emphasis
  1.1071 -      remap="it">tags</emphasis> et des branches que je n'essayerai
  1.1072 -même pas de décrire ici. Il ne supporte pas bien les opérations de renommage d'un
  1.1073 -fichier ou d'un répertoire, ce qui facilite la corruption de son dépôt. Il n'a
  1.1074 -presque pas pour ainsi dire de contrôle de cohérence interne, il est donc
  1.1075 -pratiquement impossible de dire si un dépôt est corrompu ni à quel point. Je
  1.1076 -ne recommanderai pas CVS pour un projet existant ou nouveau.
  1.1077 -</para>
  1.1078 -
  1.1079 -      <para id="x_b8">Mercurial peut importer l'historique d'un projet CVS. Néanmoins, il y a
  1.1080 -quelques principes à respecter; ce qui est vrai aussi pour les autres
  1.1081 -outils d'import de projet CVS. À cause de l'absence de <quote>commit</quote> atomique
  1.1082 -et gestion de version de l'arborescence, il n'est pas possible de reconstruire
  1.1083 -de manière précise l'ensemble de l'historique. Un travail de <quote>devinette</quote>
  1.1084 -est donc nécessaire, et les fichiers renommés ne sont pas détectés. Parce
  1.1085 -qu'une bonne part de l'administration d'un dépôt CVS est effectuée manuellement,
  1.1086 -et est donc, sujette à erreur, il est courant que les imports CVS rencontrent
  1.1087 -de nombreux problèmes avec les dépôt corrompus (des <emphasis
  1.1088 -remap="it">timestamps</emphasis> de révision complètement buggés et des fichiers 
  1.1089 -verrouillés depuis des années sont deux des problèmes les moins intéressants dont 
  1.1090 -je me souvienne).
  1.1091 -</para>
  1.1092 +          remap="it">tags</emphasis> et des branches que je n'essayerai même
  1.1093 +        pas de décrire ici. Il ne supporte pas bien les opérations de
  1.1094 +        renommage d'un fichier ou d'un répertoire, ce qui facilite la
  1.1095 +        corruption de son dépôt. Il n'a presque pas pour ainsi dire de
  1.1096 +        contrôle de cohérence interne, il est donc pratiquement impossible de
  1.1097 +        dire si un dépôt est corrompu ni à quel point. Je ne recommanderai
  1.1098 +        pas CVS pour un projet existant ou nouveau.
  1.1099 +      </para>
  1.1100 +
  1.1101 +      <para id="x_b8">Mercurial peut importer l'historique d'un projet CVS.
  1.1102 +        Néanmoins, il y a quelques principes à respecter; ce qui est vrai
  1.1103 +        aussi pour les autres outils d'import de projet CVS. À cause de
  1.1104 +        l'absence de <quote>commit</quote> atomique et gestion de version de
  1.1105 +        l'arborescence, il n'est pas possible de reconstruire de manière
  1.1106 +        précise l'ensemble de l'historique. Un travail de
  1.1107 +        <quote>devinette</quote> est donc nécessaire, et les fichiers
  1.1108 +        renommés ne sont pas détectés. Parce qu'une bonne part de
  1.1109 +        l'administration d'un dépôt CVS est effectuée manuellement, et est
  1.1110 +        donc, sujette à erreur, il est courant que les imports CVS
  1.1111 +        rencontrent de nombreux problèmes avec les dépôt corrompus (des
  1.1112 +        <emphasis remap="it">timestamps</emphasis> de révision complètement
  1.1113 +        buggés et des fichiers verrouillés depuis des années sont deux des
  1.1114 +        problèmes les moins intéressants dont je me souvienne).
  1.1115 +      </para>
  1.1116  
  1.1117        <para id="x_b9">Mercurial peut importer l'historique depuis un dépôt CVS.
  1.1118 -</para>
  1.1119 +      </para>
  1.1120  
  1.1121  
  1.1122      </sect2>
  1.1123      <sect2>
  1.1124        <title>Outils propriétaires</title>
  1.1125  
  1.1126 -      <para id="x_ba">Perforce a une architecture client/serveur centralisée, sans aucun
  1.1127 -mécanisme de mise en cache de données coté client. Contrairement à la plupart
  1.1128 -des outils modernes de gestion de source, Perforce exige de ses
  1.1129 -utilisateurs d'exécuter une commande pour informer le serveur
  1.1130 -central de tout fichier qu'ils souhaitent modifier.
  1.1131 -</para>
  1.1132 -
  1.1133 -      <para id="x_bb">Les performances de Perforce sont plutôt bonnes pour des petites
  1.1134 -équipes, mais elles s'effondrent rapidement lorsque le nombre
  1.1135 -d'utilisateurs augmente au delà de la douzaine. Des installations
  1.1136 -de Perforce assez larges nécessitent le déploiement de proxies pour
  1.1137 -supporter la montée en charge associée.
  1.1138 -</para>
  1.1139 -
  1.1140 +      <para id="x_ba">Perforce a une architecture client/serveur centralisée,
  1.1141 +        sans aucun mécanisme de mise en cache de données coté client.
  1.1142 +        Contrairement à la plupart des outils modernes de gestion de source,
  1.1143 +        Perforce exige de ses utilisateurs d'exécuter une commande pour
  1.1144 +        informer le serveur central de tout fichier qu'ils souhaitent
  1.1145 +        modifier.
  1.1146 +      </para>
  1.1147 +
  1.1148 +      <para id="x_bb">Les performances de Perforce sont plutôt bonnes pour
  1.1149 +        des petites équipes, mais elles s'effondrent rapidement lorsque le
  1.1150 +        nombre d'utilisateurs augmente au delà de la douzaine. Des
  1.1151 +        installations de Perforce assez larges nécessitent le déploiement de
  1.1152 +        proxies pour supporter la montée en charge associée.
  1.1153 +      </para>
  1.1154  
  1.1155      </sect2>
  1.1156      <sect2>
  1.1157        <title>Choisir un outil de gestion de source</title>
  1.1158  
  1.1159 -      <para id="x_bc">A l'exception de CVS, tous les outils listés ci-dessus ont des
  1.1160 -forces qui leur sont propres et qui correspondent à certaines
  1.1161 -formes de projet. Il n'y a pas un seul meilleur outil de gestion
  1.1162 -de source qui correspondrait le mieux à toutes les situations.
  1.1163 -</para>
  1.1164 -
  1.1165 -      <para id="x_bd">En guise exemple, Subversion est un très bon choix lorsqu'on travaille
  1.1166 -avec beaucoup de fichiers binaires, qui évoluent régulièrement, grâce
  1.1167 -à sa nature centralisée et sa capacité à verrouiller des fichiers.
  1.1168 -</para>
  1.1169 -
  1.1170 -      <para id="x_be">Personnellement, je préfère Mercurial pour sa simplicité, ses
  1.1171 -performances et sa bonne capacité de fusion, et il m'a très bien rendu service
  1.1172 -de plusieurs années maintenant.
  1.1173 -</para>
  1.1174 -
  1.1175 +      <para id="x_bc">A l'exception de CVS, tous les outils listés ci-dessus
  1.1176 +        ont des forces qui leur sont propres et qui correspondent à certaines
  1.1177 +        formes de projet. Il n'y a pas un seul meilleur outil de gestion de
  1.1178 +        source qui correspondrait le mieux à toutes les situations.
  1.1179 +      </para>
  1.1180 +
  1.1181 +      <para id="x_bd">En guise exemple, Subversion est un très bon choix
  1.1182 +        lorsqu'on travaille avec beaucoup de fichiers binaires, qui évoluent
  1.1183 +        régulièrement, grâce à sa nature centralisée et sa capacité à
  1.1184 +        verrouiller des fichiers.
  1.1185 +      </para>
  1.1186 +
  1.1187 +      <para id="x_be">Personnellement, je préfère Mercurial pour sa
  1.1188 +        simplicité, ses performances et sa bonne capacité de fusion, et il
  1.1189 +        m'a très bien rendu service de plusieurs années maintenant.
  1.1190 +      </para>
  1.1191  
  1.1192      </sect2>
  1.1193    </sect1>
  1.1194    <sect1>
  1.1195      <title>Migrer depuis un outil à Mercurial</title>
  1.1196  
  1.1197 -    <para id="x_bf">Mercurial est livré avec une extension nommée <literal role="hg-ext">convert</literal>, qui
  1.1198 -peut de manière incrémentale importer des révisions depuis différents
  1.1199 -autres outils de gestion de source. Par <quote>incrémental</quote>, j'entends que
  1.1200 -vous pouvez convertir l'historique entier du projet en une seule fois,
  1.1201 -puis relancer l'outil d'import plus tard pour obtenir les modifications
  1.1202 -effectuées depuis votre import initial.
  1.1203 -</para>
  1.1204 -
  1.1205 -    <para id="x_c0">Les outils de gestion de source supportés par <literal role="hg-ext">convert</literal> sont :
  1.1206 -</para>
  1.1207 +    <para id="x_bf">Mercurial est livré avec une extension nommée <literal
  1.1208 +        role="hg-ext">convert</literal>, qui peut, de manière incrémentale
  1.1209 +      importer des révisions depuis différents autres outils de gestion de
  1.1210 +      source. Par <quote>incrémental</quote>, j'entends que vous pouvez
  1.1211 +      convertir l'historique entier du projet en une seule fois, puis
  1.1212 +      relancer l'outil d'import plus tard pour obtenir les modifications
  1.1213 +      effectuées depuis votre import initial.
  1.1214 +    </para>
  1.1215 +
  1.1216 +    <para id="x_c0">Les outils de gestion de source supportés par <literal
  1.1217 +        role="hg-ext">convert</literal> sont :
  1.1218 +    </para>
  1.1219      <itemizedlist>
  1.1220        <listitem><para id="x_c1">Subversion</para></listitem>
  1.1221        <listitem><para id="x_c2">CVS</para></listitem>
  1.1222        <listitem><para id="x_c3">Git</para></listitem>
  1.1223 -      <listitem><para id="x_c4">Darcs</para></listitem></itemizedlist>
  1.1224 -
  1.1225 -    <para id="x_c5">En outre, <literal role="hg-ext">convert</literal> peut exporter les modifications depuis Mercurial
  1.1226 -vers Subversion. Ceci rend possible d'essayer Subversion en parallèle
  1.1227 -avant de choisir une solution définitive, sans aucun risque de perte de
  1.1228 -données.
  1.1229 -</para>
  1.1230 -
  1.1231 -    <para id="x_c6">La commande <command role="hg-ext-conver">convert</command> est très simple à utiliser. Simplement,
  1.1232 -indiquez le chemin ou l'URL du dépôt de source, en lui indiquant éventuellement
  1.1233 -le nom du chemin de destination, et la conversion se met en route. Après cet
  1.1234 -import initial, il suffit de relancer la commande encore une fois pour
  1.1235 -importer les modifications effectuées depuis.
  1.1236 -</para>
  1.1237 +      <listitem><para id="x_c4">Darcs</para></listitem>
  1.1238 +    </itemizedlist>
  1.1239 +
  1.1240 +    <para id="x_c5">En outre, <literal role="hg-ext">convert</literal> peut
  1.1241 +      exporter les modifications depuis Mercurial vers Subversion. Ceci rend
  1.1242 +      possible d'essayer Subversion en parallèle avant de choisir une
  1.1243 +      solution définitive, sans aucun risque de perte de données.
  1.1244 +    </para>
  1.1245 +
  1.1246 +    <para id="x_c6">La commande <command
  1.1247 +        role="hg-ext-conver">convert</command> est très simple à utiliser.
  1.1248 +      Simplement, indiquez le chemin ou l'URL du dépôt de source, en lui
  1.1249 +      indiquant éventuellement le nom du chemin de destination, et la
  1.1250 +      conversion se met en route. Après cet import initial, il suffit de
  1.1251 +      relancer la commande encore une fois pour importer les modifications
  1.1252 +      effectuées depuis.
  1.1253 +    </para>
  1.1254    </sect1>
  1.1255  
  1.1256    <sect1>
  1.1257      <title>Une courte histoire de la gestion de source</title>
  1.1258  
  1.1259      <para id="x_c7">Le plus célèbre des anciens outils de gestion de source
  1.1260 -    est <emphasis remap="it">SCCS</emphasis>
  1.1261 -(Source Code Control System)}, que Marc Rochkind conçu dans les laboratoires de
  1.1262 -recherche de Bell (<emphasis remap="it">Bell Labs</emphasis>), dans le début des années 70.
  1.1263 -<emphasis remap="it">SCCS</emphasis> ne fonctionnait que sur des fichiers individuels, et obligeait chaque
  1.1264 -personne travaillant sur le projet d'avoir un accès à un répertoire de
  1.1265 -travail commun, sur le même système. Seulement une seule personne pouvait
  1.1266 -modifier un fichier au même moment, ce fonctionnement était assuré par
  1.1267 -l'utilisation de verrou (<quote>lock</quote>). Il était courant que des personnes
  1.1268 -verrouillent des fichiers, et plus tard, oublient de le déverrouiller;
  1.1269 -empêchant n'importe qui d'autre de travailler sur ces fichiers sans l'aide de
  1.1270 -l'administrateur...
  1.1271 -</para>
  1.1272 +      est <emphasis remap="it">SCCS</emphasis> (Source Code Control System)},
  1.1273 +      que Marc Rochkind conçu dans les laboratoires de recherche de Bell
  1.1274 +      (<emphasis remap="it">Bell Labs</emphasis>), dans le début des années
  1.1275 +      70. <emphasis remap="it">SCCS</emphasis> ne fonctionnait que sur des
  1.1276 +      fichiers individuels, et obligeait chaque personne travaillant sur le
  1.1277 +      projet d'avoir un accès à un répertoire de travail commun, sur le même
  1.1278 +      système. Seulement une seule personne pouvait modifier un fichier au
  1.1279 +      même moment, ce fonctionnement était assuré par l'utilisation de verrou
  1.1280 +      (<quote>lock</quote>). Il était courant que des personnes verrouillent
  1.1281 +      des fichiers, et plus tard, oublient de le déverrouiller ; empêchant
  1.1282 +      n'importe qui d'autre de travailler sur ces fichiers sans l'aide de
  1.1283 +      l'administrateur...
  1.1284 +    </para>
  1.1285  
  1.1286      <para id="x_c8">Walter Tichy a développé une alternative libre à
  1.1287 -    <emphasis remap="it">SCCS</emphasis> au début des
  1.1288 -années 80, qu'il nomma <emphasis remap="it">RCS (Revision Control System)</emphasis>.  Comme
  1.1289 -<emphasis remap="it">SCCS</emphasis>, <emphasis remap="it">RCS</emphasis> demandait aux développeurs de travailler sur le même
  1.1290 -répertoire partagé, et de verrouiller les
  1.1291 -fichiers pour se prémunir de tout conflit issu de modifications concurrentes.
  1.1292 -</para>
  1.1293 -
  1.1294 -    <para id="x_c9">Un peu plus tard dans les années 1980, Dick Grune utilisa <emphasis remap="it">RCS</emphasis> comme
  1.1295 -une brique de base pour un ensemble de scripts <emphasis
  1.1296 -remap="it">shell</emphasis> qu'il intitula
  1.1297 -cmt, avant de la renommer en <emphasis remap="it">CVS (Concurrent Versions System)</emphasis>.  La
  1.1298 -grande innovation de CVS était que les développeurs pouvaient travailler
  1.1299 -simultanément et indépendamment dans leur propre espace de travail. Ces espaces
  1.1300 -de travail privés assuraient que les développeurs ne se marchent pas
  1.1301 -mutuellement sur les pieds, comme c'était souvent le cas avec RCS et SCCS.
  1.1302 -Chaque développeur disposait donc de sa copie de tous les fichiers du projet,
  1.1303 -et ils pouvaient donc librement les modifier. Ils devaient néanmoins effectuer
  1.1304 -la <quote>fusion</quote> (<emphasis
  1.1305 -remap="it"><quote>merge</quote></emphasis>) de leurs fichiers, avant d'effectuer le
  1.1306 -<quote>commit</quote> de leur modifications sur le dépôt central.
  1.1307 -</para>
  1.1308 -
  1.1309 -<para>Brian Berliner reprit les scripts de Grune's et les réécrit en C, qu'il publia
  1.1310 -en 1989. Depuis, ce code a été modifié jusqu'à devenir la version moderne de
  1.1311 -CVS. CVS a acquis ainsi la capacité de fonctionner en réseau, transformant son
  1.1312 -architecture en client/serveur. L'architecture de CVS est centralisée, seul le
  1.1313 -serveur a une copie de l'historique du projet. L'espace de travail client ne
  1.1314 -contient qu'une copie de la dernière version du projet, et quelques métadonnées
  1.1315 -pour indiquer où le serveur se trouve. CVS a été un grand succès, aujourd'hui
  1.1316 -il est probablement l'outil de gestion de contrôle le plus utilisé au monde.
  1.1317 -</para>
  1.1318 -
  1.1319 -<para>Au début des années 1990, Sun Microsystmes développa un premier outil de
  1.1320 -gestion de source distribué, nommé TeamWare. Un espace de travail TeamWare
  1.1321 -contient une copie complète de l'historique du projet. TeamWare n'a pas de
  1.1322 -notion de dépôt central. (CVS utilisait RCS pour le stockage de l'historique,
  1.1323 -TeamWare utilisait SCCS).
  1.1324 -</para>
  1.1325 -
  1.1326 -<para>Alors que les années 1990 avançaient, les utilisateurs ont pris conscience d'un
  1.1327 -certain nombre de problèmes avec CVS. Il enregistrait simultanément des
  1.1328 -modifications sur différents fichiers individuellement, au lieu de les
  1.1329 -regrouper dans une seule opération cohérente et atomique. Il ne gère pas bien
  1.1330 -sa hiérarchie de fichier, il est donc assez aisé de créer le chaos en renommant
  1.1331 -les fichiers et les répertoires. Pire encore, son code source est difficile à
  1.1332 -lire et à maintenir, ce qui agrandit largement le <quote>niveau de souffrance</quote>
  1.1333 -associé à la réparation de ces problèmes d'architecture de manière prohibitive.
  1.1334 -</para>
  1.1335 -
  1.1336 -<para>En 2001, Jim Blandy et Karl Fogel, deux développeurs qui avaient travaillé sur
  1.1337 -CVS, initièrent un projet pour le remplacer par un outil qui aurait une
  1.1338 -meilleure architecture et un code plus propre. Le résultat, Subversion, ne
  1.1339 -quitte pas le modèle centralisé et client/server de CVS, mais ajoute les
  1.1340 -opérations de <quote>commit</quote> atomique sur de multiples fichiers, une meilleure
  1.1341 -gestion des espaces de noms, et d'autres fonctionnalités qui en font un
  1.1342 -meilleur outil que CVS. Depuis sa première publication, il est rapidement
  1.1343 -devenu très populaire.
  1.1344 -</para>
  1.1345 -
  1.1346 -<para>Plus ou moins simultanément, Graydon Hoare a commencé sur l'ambitieux
  1.1347 -système de gestion distribué Monotone. Bien que Monotone corrige plusieurs
  1.1348 -défauts de CVS's tout en offrant une architecture <quote>peer-to-peer</quote>, il va aussi
  1.1349 -plus loin que la plupart des outils de révision de manière assez innovante. Il
  1.1350 -utilise des <quote>hash</quote> cryptographiques comme identifiants, et il a une notion
  1.1351 -complète de <quote>confiance</quote> du code issu des différentes sources.
  1.1352 -</para>
  1.1353 -
  1.1354 -<para>Mercurial est né en 2005. Bien que très influencé par Monotone, Mercurial se
  1.1355 -concentre sur la facilité d'utilisation, les performances et la capacité à
  1.1356 -monter en charge pour de très gros projets.
  1.1357 -</para>
  1.1358 -
  1.1359 -</sect1>
  1.1360 -
  1.1361 -
  1.1362 +      <emphasis remap="it">SCCS</emphasis> au début des années 80, qu'il
  1.1363 +      nomma <emphasis remap="it">RCS (Revision Control System)</emphasis>.
  1.1364 +      Comme <emphasis remap="it">SCCS</emphasis>, <emphasis
  1.1365 +        remap="it">RCS</emphasis> demandait aux développeurs de travailler
  1.1366 +      sur le même répertoire partagé, et de verrouiller les fichiers pour se
  1.1367 +      prémunir de tout conflit issu de modifications concurrentes.
  1.1368 +    </para>
  1.1369 +
  1.1370 +    <para id="x_c9">Un peu plus tard dans les années 1980, Dick Grune utilisa
  1.1371 +      <emphasis remap="it">RCS</emphasis> comme une brique de base pour un
  1.1372 +      ensemble de scripts <emphasis remap="it">shell</emphasis> qu'il
  1.1373 +      intitula cmt, avant de la renommer en <emphasis remap="it">CVS
  1.1374 +        (Concurrent Versions System)</emphasis>.  La grande innovation de CVS
  1.1375 +      était que les développeurs pouvaient travailler simultanément et
  1.1376 +      indépendamment dans leur propre espace de travail. Ces espaces de
  1.1377 +      travail privés assuraient que les développeurs ne se marchent pas
  1.1378 +      mutuellement sur les pieds, comme c'était souvent le cas avec RCS et
  1.1379 +      SCCS. Tous les développeurs disposaient donc de leur copie de tous les
  1.1380 +      fichiers du projet, et ils pouvaient donc librement les modifier. Ils
  1.1381 +      devaient néanmoins effectuer la <quote>fusion</quote> (<emphasis
  1.1382 +        remap="it"><quote>merge</quote></emphasis>) de leurs fichiers, avant
  1.1383 +      d'effectuer le <quote>commit</quote> de leurs modifications sur le dépôt
  1.1384 +      central.
  1.1385 +    </para>
  1.1386 +    
  1.1387 +    <para>Brian Berliner reprit les scripts de Grune's et les réécrit en C,
  1.1388 +      qu'il publia en 1989. Depuis, ce code a été modifié jusqu'à devenir la
  1.1389 +      version moderne de CVS. CVS a acquis ainsi la capacité de fonctionner
  1.1390 +      en réseau, transformant son architecture en client/serveur.
  1.1391 +      L'architecture de CVS est centralisée, seul le serveur a une copie de
  1.1392 +      l'historique du projet. L'espace de travail client ne contient qu'une
  1.1393 +      copie de la dernière version du projet, et quelques métadonnées pour
  1.1394 +      indiquer où le serveur se trouve. CVS a été un grand succès,
  1.1395 +      aujourd'hui il est probablement l'outil de gestion de contrôle le plus
  1.1396 +      utilisé au monde.
  1.1397 +    </para>
  1.1398 +    
  1.1399 +    <para>Au début des années 1990, Sun Microsystems développa un premier
  1.1400 +      outil de gestion de source distribué, nommé TeamWare. Un espace de
  1.1401 +      travail TeamWare contient une copie complète de l'historique du projet.
  1.1402 +      TeamWare n'a pas de notion de dépôt central. (CVS utilisait RCS pour le
  1.1403 +      stockage de l'historique, TeamWare utilisait SCCS).
  1.1404 +    </para>
  1.1405 +    
  1.1406 +    <para>Alors que les années 1990 avançaient, les utilisateurs ont pris
  1.1407 +      conscience d'un certain nombre de problèmes avec CVS. Il enregistrait
  1.1408 +      simultanément des modifications sur différents fichiers
  1.1409 +      individuellement, au lieu de les regrouper dans une seule opération
  1.1410 +      cohérente et atomique. Il ne gère pas bien sa hiérarchie de fichier, il
  1.1411 +      est donc assez aisé de créer le chaos en renommant les fichiers et les
  1.1412 +      répertoires. Pire encore, son code source est difficile à lire et à
  1.1413 +      maintenir, ce qui agrandit largement le <quote>niveau de
  1.1414 +        souffrance</quote> associé à la réparation de ces problèmes
  1.1415 +      d'architecture de manière prohibitive.
  1.1416 +    </para>
  1.1417 +    
  1.1418 +    <para>En 2001, Jim Blandy et Karl Fogel, deux développeurs qui avaient
  1.1419 +      travaillé sur CVS, initièrent un projet pour le remplacer par un outil
  1.1420 +      qui aurait une meilleure architecture et un code plus propre. Le
  1.1421 +      résultat, Subversion, ne quitte pas le modèle centralisé et
  1.1422 +      client/server de CVS, mais ajoute les opérations de
  1.1423 +      <quote>commit</quote> atomique sur de multiples fichiers, une meilleure
  1.1424 +      gestion des espaces de noms, et d'autres fonctionnalités qui en font un
  1.1425 +      meilleur outil que CVS. Depuis sa première publication, il est
  1.1426 +      rapidement devenu très populaire.
  1.1427 +    </para>
  1.1428 +    
  1.1429 +    <para>Plus ou moins simultanément, Graydon Hoare a commencé sur
  1.1430 +      l'ambitieux système de gestion distribué Monotone. Bien que Monotone
  1.1431 +      corrige plusieurs défauts de CVS tout en offrant une architecture
  1.1432 +      <quote>peer-to-peer</quote>, il va aussi plus loin que la plupart des
  1.1433 +      outils de révision de manière assez innovante. Il utilise des
  1.1434 +      <quote>hashs</quote> cryptographiques comme identifiants, et il a une
  1.1435 +      notion complète de <quote>confiance</quote> du code issu des
  1.1436 +      différentes sources.
  1.1437 +    </para>
  1.1438 +    
  1.1439 +    <para>Mercurial est né en 2005. Bien que très influencé par Monotone,
  1.1440 +      Mercurial se concentre sur la facilité d'utilisation, les performances
  1.1441 +      et la capacité à monter en charge pour de très gros projets.
  1.1442 +    </para>
  1.1443 +  
  1.1444 +  </sect1>
  1.1445  
  1.1446  </chapter>
  1.1447