changeset 608:e98a8c3afcef

finished revision of intro.tex. there are some standing issues yet, though
author Javier Rojas <jerojasro@devnull.li>
date Mon, 12 Jan 2009 19:45:41 -0500
parents c054534808e6
children 98fb436b58c1
files es/Leame.1st es/intro.tex
diffstat 2 files changed, 144 insertions(+), 135 deletions(-) [+]
line wrap: on
line diff
--- a/es/Leame.1st	Mon Jan 12 16:46:25 2009 -0500
+++ b/es/Leame.1st	Mon Jan 12 19:45:41 2009 -0500
@@ -125,7 +125,7 @@
 || undo.tex       || Javier Rojas  ||            ||            ||             ||
 || tour-merge.tex ||               ||            ||            ||             ||
 || concepts.tex   ||               ||            ||            ||             ||
-|| intro.tex      ||               ||            ||            ||             ||
+|| intro.tex      || Javier Rojas  ||    100%    || 12/01/2009 ||  12/01/2009 ||
 || collab.tex     || Javier Rojas  ||            ||            ||             ||
 || mq.tex         ||               ||            ||            ||             ||
 || hgext.tex      ||               ||            ||            ||             ||
--- a/es/intro.tex	Mon Jan 12 16:46:25 2009 -0500
+++ b/es/intro.tex	Mon Jan 12 19:45:41 2009 -0500
@@ -6,10 +6,10 @@
 El control de revisiones es el proceso de administrar diferentes
 versiones de una pieza de información. En su forma más simple es algo
 que la mayoría de gente hace a mano: cada vez que usted modifica un
-fichero, lo graba con un nuevo nombre que contiene un número, el
-siguiente mayor que el anterior.
+fichero, lo graba con un nuevo nombre que contiene un número, cada uno
+mayor que el anterior.
 
-Administrar manualmente muchas versiones de un fichero es una tarea
+Administrar manualmente muchas versiones de incluso sólo un fichero es una tarea
 propensa a errores, a pesar de que hace bastante tiempo hay
 herramientas que ayudan en este proceso.  Las primeras herramientas
 para automatizar el control de revisiones fueron pensadas para que un
@@ -18,7 +18,7 @@
 considerablemente; ahora manejan muchos ficheros y facilitan el
 trabajo en conjunto de varias personas. Las mejores herramientas de
 control de revisiones de la actualidad no tienen problema con miles de
-personas trabajando en proyectos que consisten de decenas de miles de
+personas trabajando en proyectos que consisten de cientos de miles de
 ficheros.
 
 \subsection{¿Por qué usar control de revisiones?}
@@ -26,36 +26,37 @@
 Hay muchas razones por las cuales usted o su equipo desearía usar una
 herramienta automática de control de revisiones para un proyecto.
 \begin{itemize}
-\item Contar con la historia y la evolución de su proyecto, para
-  evitar hacer la tarea manualmente. Por cada cambio tendrá una
+        %TODO historia
+\item Llevar registro de la historia y la evolución de su proyecto, para
+  evitar hacer la tarea manualmente. Por cada cambio, tendrá una
   bitácora de \emph{quién} lo hizo; \emph{por qué} se hizo;
   \emph{cuándo} se hizo; y de \emph{qué} se trataba el cambio.
 \item Cuando trabaja con más personas, los programas de control de
   revisiones facilitan la colaboración.  Por ejemplo, cuando varias
-  personas de forma casi simultanea pueden hacer cambios
-  incompatibles, el programa le ayudará a identificar y resolver tales
+  personas hacen cambios potencialmente incompatibles de forma casi
+  simultánea, el programa le ayudará a identificar y resolver tales
   conflictos.
 \item Puede ayudarle a recuperarse de equivocaciones. Si aplica un
   cambio que posteriormente se evidencia como un error, puede
   revertirlo a una versión previa a uno o muchos ficheros. De hecho,
   una herramienta \emph{realmente} buena, incluso puede ayudarle
   efectivamente a darse cuenta exactamente cuándo se introdujo el
-  error( para más detalles ver la sección~\ref{sec:undo:bisect}).
-\item Le permitirá trabajar simultáneamente, y manejar las diferencias
+  error (para más detalles ver la sección~\ref{sec:undo:bisect}).
+\item Le ayudará a trabajar simultáneamente, y a manejar las diferencias
   entre múltiples versiones de su proyecto.
 \end{itemize}
 La mayoría de estas razones son igualmente válidas ---por lo menos en
-teoría--- así esté trabajando en un proyecto solo, o con mucha gente.
+teoría--- así esté trabajando en un proyecto solo usted, o con mucha gente.
 
 Algo fundamental acerca de lo práctico de un sistema de control de
-revisiones en estas dos escalas (``un hacker solo'' y ``un equipo
+revisiones en estas dos escalas (``un hacker solitario'' y ``un equipo
 gigantesco'') es cómo se comparan los \emph{beneficios} con los
 \emph{costos}.  Una herramienta de control de revisiones que sea
 difícil de entender o usar impondrá un costo alto.
 
 Un proyecto de quinientas personas es muy propenso a colapsar
-solamente con su peso inmediatamente sin una herramienta de control de
-versiones y un proceso. En este caso, el costo de usar control de
+solamente con su peso inmediatamente sin una herramienta y un proceso
+de control de versiones. En este caso, el costo de usar control de
 revisiones ni siquiera se tiene en cuenta, puesto que \emph{sin} él,
 el fracaso está casi garantizado.
 
@@ -64,26 +65,25 @@
 casi seguramente, el costo de usar una estaría cerca del costo del
 proyecto. ¿No es así?
 
-%TODO el sentido de uniquely va más a decir que hace ambas cosas sin problema,
-% no a que ``apenas''las soporta, no?
-Mercurial solamente soporta \emph{ambas} escalas de de
-desarrollo. Puede aprender lo básico en pocos minutos, y dado su bajo
+Mercurial soporta \emph{ambas} escalas de de desarrollo de manera
+única. Puede aprender lo básico en pocos minutos, y dado su bajo
 sobrecosto, puede aplicar el control de revisiones al proyecto más
 pequeño con facilidad. Su simplicidad significa que no tendrá que
 preocuparse por conceptos obtusos o secuencias de órdenes compitiendo
 por espacio mental con lo que sea que \emph{realmente} esté tratando
 de hacer.  Al mismo tiempo, Mercurial tiene alto desempeño y su
+%TODO distribuida? en vez de p2p
 naturaleza peer-to-peer le permite escalar indoloramente para manejar
 grandes proyectos.
 
 Ninguna herramienta de control de revisiones puede salvar un
 proyecto mal administrado, pero la elección de herramientas puede
-hacer una gran diferencia en la fluidez con la cual puede trabajar en
-el proyecto.
+hacer una gran diferencia en la fluidez con la cual usted puede
+trabajar en un proyecto.
 
 \subsection{La cantidad de nombres del control de revisiones}
 
-El control de revisiones es un campo amplio, tan ampli que no hay un
+El control de revisiones es un campo amplio, tan amplio que no hay un
 acrónimo o nombre único. A continuación presentamos un listado de
 nombres comunes y acrónimos que se podrían encontrar:
 \begin{itemize}
@@ -95,8 +95,8 @@
 \item Control de Versiones(VCS)
 \end{itemize}
 Algunas personas aducen que estos términos tienen significados
-diversos, pero en la práctica se sobrelapan tanto que no hay un
-acuerdo o una forma adecuada de separarlos.
+diversos, pero en la práctica se sobrelapan tanto que no hay una
+forma acordada o incluso adecuada de separarlos.
 
 \section{Historia resumida del control de revisiones}
 
@@ -112,30 +112,31 @@
 modificar los ficheros en cuestión sin la intervención del
 administrador.
 
-Walter Tichy desarrolló una alternativa gratutita a SCCS a comienzos
-de los ochentas(1980s), llamó a su programa RCS(Sistema de Control de
+Walter Tichy desarrolló una alternativa gratuita a SCCS a comienzos
+de los ochentas(1980s); llamó a su programa RCS (Sistema de Control de
 Revisiones).  Al igual que SCCS, RCS requería que los desarrolladores
 trabajaran en un único espacio compartido y colocaran candados a los
-ficheros para evitar que varias personas los estuvieran modificando
+ficheros para evitar que varias personas los modificaran
 simultáneamente.
 
 Después en los ochenta, Dick Grune usó RCS como un bloque de
 construcción para un conjunto de guiones de línea de comando, que
-inicialmente llamó cmt, pero que renombró a CVS(Sistema Concurrente de
+inicialmente llamó cmt, pero que renombró a CVS (Sistema Concurrente de
 Versiones).  La gran innovación de CVS era que permitía a los
 desarrolladores trabajar simultáneamente de una forma más o menos
 independiente en sus propios espacios de trabajo. Los espacios de
-trabajo personales impedian que los desarrolladores se pisaran las
+trabajo personales impedían que los desarrolladores se pisaran las
 mangueras todo el tiempo, situación común con SCCS y RCS.  Cada
-desarrollador tenía una copia de todo el fichero del proyecto y podía
-modificar su copia independientemente, Tenían que fusionar sus
+desarrollador tenía una copia de todos los ficheros del proyecto y podía
+modificar sus copias independientemente, Tenían que fusionar sus
 ediciones antes de consignar los cambios al repositorio central.
 
 Brian Berliner tomó los scripts originales de Grune y los reescribió
-en~C, haciéndolos públicos en 1989, código sobre el cual se ha
-desarrollado la versión moderna de CVS.  CVS posteriormente adquirió
+en~C, publicando en 1989 el código sobre el cual se ha
+desarrollado la versión moderna de CVS.  CVS adquirió posteriormente 
 la habilidad de operar sobre una conexión de red, dotándolo de una
 arquitectura, cliente/servidor. La arquitectura de CVS es
+%TODO historia/historial
 centralizada; La historia del proyecto está únicamente en el
 repositorio central.  Los espacios de trabajo de los clientes
 contienen únicamente copias recientes de las versiones de los
@@ -143,36 +144,37 @@
 ha tenido un éxito enorme; Es probablemente el sistema de control de
 revisiones más extendido del planeta.
 
-A comienzos de los noventa(1990s), Sun MicroSystems desarrollo un
-temprano sistema distribuido de revisión de controles llamado TeamWare
+A comienzos de los noventa~(1990s), Sun MicroSystems desarrollo un
+temprano sistema distribuido de control de revisiones llamado
+TeamWare.
 Un espacio de trabajo TeamWare contiene una copia completa de la
 historia del proyecto. TeamWare no tiene la noción de repositorio
 central. (CVS se basaba en RCS para el almacenamiento de su historia;
 TeamWare usaba SCCS.)
 
-A medida que avanzaba la decada de los noventa, se empezño a
-evidenciar los problemas de CVS.  Alacena cambios simultáneos a muchos
+A medida que avanzaba la decada de los noventa, se empezó a
+evidenciar los problemas de CVS.  Almacena cambios simultáneos a muchos
 ficheros de forma individual, en lugar de agruparlos como una
 operación única y atómica lógicamente.  No maneja bien su jerarquía de
-ficheros bien; es fácil desordenar un repositorio renombrando ficheros
+ficheros; es fácil desordenar un repositorio al renombrar ficheros
 y directorios. Peor aún, su código fuente es difícil de leer y
-mantener, lo que hace que su ``umbral de dolor'' para arreglar sus
-problemas arquitecturales algo prohibitivo.
+mantener, lo que hizo que su ``umbral de dolor'' para arreglar sus
+problemas arquitecturales fuera algo prohibitivo.
 
 En 2001, Jim Blandy y Karl Fogel, dos desarrolladores que habían
 trabajado en CVS, comenzaron un proyecto para reemplazarlo con una
 herramienta con mejor arquitectura y código más limpio.  El resultado,
 Subversion, no se separó del modelo centralizado cliente/servidor de
 CVS, pero añadió consignaciones atómicas de varios ficheros, mejor
-manejo de nombres de espacios, y otras características que lo hacen
+manejo de espacios de nombres , y otras características que lo hacen
 mejor que CVS. Desde su versión inicial, ha ido creciendo en
-popularidad.
+popularidad rápidamente.
 
 Más o menos en forma simultánea Graydon Hoare comenzó a trabajar en un
-sistema distribuido de control de versiones ambicioso que llamó
+ambicioso sistema distribuido de control de versiones que llamó
 Monotone. Mientras que Monotone se enfocaba a evitar algunas fallas de
 diseño de CVS con una arquitectura peer-to-peer, fue mucho más
-allá(junto con otros proyectos subsecuentes) que unas herramientas de
+allá de las herramientas anteriores (y posteriores) de
 control de revisiones en varios aspectos innovadores. Usa hashes
 criptográficos como identificadores, y tiene una noción integral de 
 ``confianza'' para código de diversas fuentes.
@@ -184,45 +186,47 @@
 
 \section{Tendencias en el control de revisiones}
 
-Ha habido varias tendencias en el desarrollo y uso de las herramientas
-de control de revisiones en las pasadas cuatro décadas, mientras la
-gente se ha vuelto familiar con las capacidades de sus herramientas
-así mismo con sus limitaciones.
+Ha habido una tendencia inconfundible en el desarrollo y uso de las herramientas
+de control de revisiones en las cuatro décadas pasadas, mientras la
+gente se ha hecho familiar con las capacidades de sus herramientas y
+se ha visto restringida por sus limitaciones.
 
 La primera generación comenzó administrando ficheros individuales en
 computadores por persona. A pesar de que tales herramientas
 representaron un avance importante frente al control de revisiones
-manual, su modelo de candados y la limitación a un sólo computador,
-determinó equipos de trabajo pequeños y acoplados.
+manual, su modelo de candados y la dependencia a un sólo computador
+los limitó a equipos de trabajo pequeños y acoplados.
 
 La segunda generación dejó atrás esas limitaciones moviéndose a
 arquitecturas centradas en  redes, y administrando proyectos completos
-uno a la vez. A medida que los proyectos crecían, nacieron nuevos
+a la vez. A medida que los proyectos crecían, nacieron nuevos
 problemas. Con la necesidad de comunicación frecuente con los
 servidores, escalar estas máquinas se convirtió en un problema en
-proyectos realmente grandes. Las redes con poca estabilidad impidieron
-que usuarios remotos se conectaran al servidor. A medida que los
-proyecos de código abierto comenzaron a ofrecer acceso de sólo lectura
-de forma anónima a cualquiera, la gente sin permiso para consignar,
+proyectos realmente grandes. Las redes con poca estabilidad podrían
+impedir que usuarios remotos se conectaran al servidor. A medida que
+los
+proyectos de código abierto comenzaron a ofrecer acceso de sólo lectura
+de forma anónima a cualquiera, la gente sin permiso para consignar
 vio que no podían usar tales herramientas para interactuar en un
 proyecto de forma natural, puesto que no podían guardar sus cambios.
 
-La generación actual de herramientas de control de revisiones es de
-forma natural peer-to-peer.  Todos estos sistemas han eliminado la
+La generación actual de herramientas de control de revisiones es
+peer-to-peer por naturaleza.  Todos estos sistemas han eliminado la
 dependencia de un único servidor central, y han permitido que la
 gente distribuya sus datos de control de revisiones donde realmente se
 necesita. La colaboración a través de Internet ha cambiado las
-limitantes tecnológicas a la cuestión de elección y consenso. Las
-herramientas modernas pueden operar sin conexión indefinidamenta y
+limitantes tecnológicas por la cuestión de elección y consenso. Las
+herramientas modernas pueden operar sin conexión indefinidamente y
 autónomamente, necesitando una conexión de red solamente para
 sincronizar los cambios con otro repositorio.
 
 \section{Algunas ventajas del control distribuido de revisiones}
 
 A pesar de que las herramientas para el control distribuido de
-revisiones lleva varios años siendo tan robusto y usable como la
-generación previa de su contraparte, personas que usan herramientas
-más antiguas no se han percatado de sus ventajas.  Hay gran cantidad
+revisiones lleva varios años siendo tan robustas y usables como la
+generación previa de sus contrapartes, algunas personas que usan las
+herramientas más antiguas no se han percatado de sus ventajas.  Hay
+gran cantidad
 de situaciones en las cuales las herramientas distribuidas brillan
 frente a las centralizadas.
 
@@ -246,37 +250,38 @@
 seguridad disponibles como computadores de contribuidores.
 
 La confiabilidad de su red afectará las herramientas distribuidas de
-una forma mucho menor que las herramientas centralizadas No puede
+una forma mucho menor que a las herramientas centralizadas. Usted no puede
 siquiera usar una herramienta centralizada sin conexión de red,
-excepto con algunas órdenes muy limitadas. Con herramientas
+excepto por algunas órdenes muy limitadas. Con herramientas
 distribuidas, si sus conexión cae mientras usted está trabajando,
 podría nisiquiera darse cuenta. Lo único que que no podrá hacer es
 comunicarse  con repositorios en otros computadores, algo que es
 relativamente raro comparado con las operaciones locales. Si tiene
-colaboradores remotos en su equipo, puede ser significante.
+colaboradores remotos en su equipo, puede ser importante.
 
 \subsection{Ventajas para proyectos de código abierto}
 
 Si descubre un proyecto de código abierto y decide que desea comenzar
 a trabajar en él, y ese proyecto usa una herramienta de control
-distribuido de revisiones, usted es un par con la gente que se
-considera el ``alma'' del proyecto.  Si ellos publican los
-repositorios, se puede copiar inmediatamente la historia del proyecto,
+distribuido de revisiones, usted es de inmediato un par con la gente que se
+considera el ``alma'' del proyecto.  Si ellos publican sus
+%TODO historia/historial
+repositorios, usted puede copiar inmediatamente la historia del proyecto,
 hacer cambios y guardar su trabajo, usando las mismas herramientas de
 la misma forma que ellos. En contraste, con una herramienta
-centralizada, debe usar el programa en un modo ``sólo lectura'' a
+centralizada, usted debe usar el programa en un modo ``sólo lectura'' a
 menos que alguien le otorgue permisos para consignar cambios en el
 repositorio central. Hasta entonces, no podrá almacenar sus cambios y
 sus modificaciones locales correrán el riesgo de dañarse cuando trate
 de actualizar su vista del repositorio.
 
-\subsubsection{Las bifurcaciones(forks) no son un problema}
+\subsubsection{Las bifurcaciones (forks) no son un problema}
 
 Se ha mencionado que las herramientas de control distribuido de
 versiones albergan un riesgo a los proyectos de código abierto, puesto
-que se vuelve muy sencillo hacer una ``bifurcanción''\ndt{fork.} del
-desarrollo del proyecto.  Una bifurcación pasa cuando hay diferencias
-de opinión o actitud entre grupos de desarrolladores que desenvoca en
+que se vuelve muy sencillo hacer una ``bifurcación''\ndt{fork.} del
+desarrollo del proyecto.  Una bifurcación sucede cuando hay diferencias
+de opinión o actitud entre grupos de desarrolladores que desemboca en
 la decisión de la imposibilidad de continuar trabajando juntos. Cada
 parte toma una copia más o menos completa del código fuente del
 proyecto y toma su propio rumbo.
@@ -284,8 +289,10 @@
 En algunas ocasiones los líderes de las bifurcaciones reconcilian sus
 diferencias. Con un sistema centralizado de control de revisiones, el
 proceso \emph{técnico} de reconciliarse es doloroso, y se hace de
-forma muy manual.  Tiene que decidir qué historia de revisiones va a
-``win'', e injertar los cambios del otro equipo en el árbol de alguna
+%TODO historia/historial
+forma muy manual.  Usted tiene que decidir qué historia de revisiones va a
+``ganar'', e injertar los cambios del otro equipo en el árbol de alguna
+%TODO historia/historial
 manera. Con esto usualmente se pierde algo o todo del historial de la
 revisión de alguna de las partes.
 
@@ -297,16 +304,16 @@
 bueno al \emph{fusionar} las bifurcaciones, porque las bifurcaciones
 son absolutamente fundamentales: pasan todo el tiempo.
 
-Si todas las porciones de trabajo que todos hacen todo el tiempo, se
-enmarca en términos de bifurcaciones y fusiones, entonces a aquello a
+Si todas las porciones de trabajo que todos hacen, todo el tiempo, se
+enmarcan en términos de bifurcaciones y fusiones, entonces a aquello a
 lo que se refiere en el mundo del código abierto a una ``bifurcación''
 se convierte \emph{puramente} en una cuestión social. Lo que hacen las
 herramientas distribuidas es \emph{disminuir} la posibilidad de una
 bifurcación porque:
 \begin{itemize}
-\item Eliminan la distinción social que las herramientas centralizadas
-  imponen: esto entre los miembros (personas con permiso de consignar)
-  y forasteros(los que no tienen el permiso).
+\item Eliminan la distinción social que imponen las herramientas
+  centralizadas: aquélla entre miembros (personas con permiso de
+  consignar) y forasteros (los que no tienen el permiso).
 \item Facilitan la reconciliación después de una bifurcación social,
   porque todo lo que concierne al programa de control de revisiones es
   una fusión.
@@ -314,10 +321,10 @@
 
 Algunas personas se resisten a las herramientas distribuidas porque
 desean mantener control completo sobre sus proyectos, y creen que las
-herramientas centralizadas les da tal control. En todo caso, si este
-es su parecer, y publica sus repositorios de CVS o Subversion, hay
+herramientas centralizadas les dan tal control. En todo caso, si este
+es su parecer, y usted publica sus repositorios de CVS o Subversion, hay
 muchas herramientas disponibles que pueden obtener la historia
-completa(A pesar de lo lento) y recrearla en otro sitio que usted no
+completa (aunque sea lentamente) y recrearla en otro sitio que usted no
 controla. Siendo así un control ilusorio, puesto que está impidiendo
 la fluidez de colaboración en lugar de prevenir que alguien se sienta
 impulsado a obtener una copia y hacer una bifurcación con su historia.
@@ -326,38 +333,38 @@
 
 Muchos proyectos comerciales tienen grupos de trabajo distribuidos
 alrededor del globo.  Quienes contribuyen y están lejos de un
-repositorio central verán una ejecución más lenta de las órdenes y tal
+repositorio central verán una ejecución más lenta de los comandos y tal
 vez menos confiabilidad. Los sistemas de control de revisión
 comerciales intentan amortiguar estos problemas con adiciones de
 replicación remota que usualmente son muy costosos y complicados de
-administradr. Un sistema distribuido no padece estos problemas. Mejor
+administrar. Un sistema distribuido no padece estos problemas. Mejor
 aún, puede colocar varios servidores autorizados, por ejemplo, uno por
 sitio, de tal forma que no haya comunicación redundante entre
 repositorios sobre enlaces de conexión costosos.
 
 Los sistemas de control de revisiones distribuidos tienden a ser poco
-escalables. No es inusual quw costosos sistemas centralizados caigan
+escalables. No es inusual que costosos sistemas centralizados caigan
 ante la carga combinada de unas cuantas docenas de usuarios
-concurrentes. De nuevo, las respuestas típicas de replibcación tienden
+concurrentes. De nuevo, las respuestas típicas de replicación tienden
 a ser costosas y complejas de instalar y administrar. Dado que la
 carga en un servidor central---si es que tiene uno---es muchas veces
-menor con una herramienta distribuida(debido a que los datos están
-replicados en todas partes), un sólo servidor económico puede tratar
+menor con una herramienta distribuida (debido a que los datos están
+replicados en todas partes), un solo servidor económico puede tratar
 las necesidades de equipos mucho más grandes, y la replicación para
-balancear la carga se vuelve cosa de scripts.
+balancear la carga se vuelve cosa de guiones.
 
 Si tiene un empleado en el campo, se beneficiará grandemente de un
 sistema distribuido de control de versiones al resolver problemas en
 el sitio del cliente. La herramienta le permitirá generar
 construcciones a la medida, probar diferentes arreglos de forma
 independiente y buscar de forma eficiente las fuentes de fallos en la
-historia y regresiones en los ambientes de los clientes, todo, sin
+historia y regresiones en los ambientes de los clientes, todo sin
 necesidad de conectarse al servidor de su compañía.
 
 \section{¿Por qué elegir Mercurial?}
 
 Mercurial cuenta con un conjunto único de propiedades que lo hacen
-particularmente una buena elección como un sistema de control de
+una elección particularmente buena como sistema de control de
 revisiones, puesto que:
 \begin{itemize}
 \item Es fácil de aprender y usar.
@@ -367,14 +374,14 @@
 \end{itemize}
 
 Si los sistemas de control de revisiones le son familiares, debería
-estar listo para usar Mercurial en menos de cinco minutos. Si no, va a
+estar listo para usar Mercurial en menos de cinco minutos. Si no, sólo va a
 tomar unos pocos minutos más. Las órdenes de Mercurial y su conjunto
 de características son uniformes y consistentes generalmente, y basta
 con que siga unas pocas reglas generales en lugar de un montón de
 excepciones.
 
-En un proyecto pequeño, puede comenzar a trabajar con Mercurial poco a
-poco. Creando nuevos cambios y ramas, transfiriendo cambios(localmente
+En un proyecto pequeño, usted puede comenzar a trabajar con Mercurial en
+pocos momentos. Crear nuevos cambios y ramas, transferir cambios (localmente
 o por la red); y las operaciones relacionadas con el estado y la
 historia son rápidas. Mercurial buscar ser ligero y no incomodar en su
 camino combinando poca sobrecarga cognitiva con operaciones
@@ -390,13 +397,12 @@
 scripting y su limpieza interna junto con su implementación en Python
 permiten añadir características fácilmente en forma de extensiones.
 Hay un buen número de extensiones útiles y populares en este momento,
-desde ayudar a identificar fallos hasta el mejoramiento de su
-desempeño.
+desde ayudar a identificar fallos hasta mejorar su desempeño.
 
 \section{Comparación de Mercurial con otras herramientas}
 
 Antes de leer, por favor tenga en cuenta que esta sección
-necesariamente refleja mis propias experiencias, intereses y(tengo que
+necesariamente refleja mis propias experiencias, intereses y (tengo que
 decirlo) mis preferencias. He usado cada una de las herramientas de
 control de versiones listadas a continuación, y en muchos casos por
 varios años.
@@ -405,10 +411,10 @@
 \subsection{Subversion}
 
 Subversion es una herramienta de control de revisiones muy popular,
-desarrollada para reemplazar a CVS.  Su arquitectura es centralizada
-en cliente/servidor.
+desarrollada para reemplazar a CVS.  Tiene una arquitectura
+centralizada tipo cliente/servidor.
 
-Subversion y Mercurial tienen órdenes con nombres similares para hacer
+Subversion y Mercurial tienen comandos con nombres similares para hacer
 las mismas operaciones, por lo que si le son familiares en una, será
 sencillo aprender a usar la otra. Ambas herramientas son portables en
 todos los sistemas operativos populares.
@@ -419,20 +425,21 @@
 \href{http://svnbook.red-bean.com/nightly/en/svn.branchmerge.advanced.html#svn.branchmerge.advanced.finalword}{complicadas
   y poco estables\ndt{buggy}}.
 
-Mercurial tiene una ventaja considerable en el desempeño sobre
+Mercurial tiene una ventaja considerable en desempeño sobre
 Subversion en cualquier operación de control de revisiones que yo haya
 medido. He medido sus ventajas con factores desde dos hasta seis veces
 comparando con almacenamiento de ficheros \emph{ra\_local}
 Subversion~1.4.3, el cual es el método de acceso más rápido.  En los
-escenarios más sencillos incluyendo almacenamiento con la red de por
+escenarios más realistas incluyendo almacenamiento con la red de por
 medio, Subversion se encuentra en desventaja aún mayor. Dado que casi
 todas las órdenes de Subversion deben tratar con el servidor y
-Subversion no tiene utilidades de replicación sencillas, la capacidad
+Subversion no tiene utilidades de replicación adecuadas, la capacidad
 del servidor y el ancho de banda se convierten en cuellos de botella
 para proyectos modestamente grandes.
 
-Adicionalmente, Subversion tiene un sobrecosto en almacentamiento
-considerable para evitar transacciones por red en algunas operaciones,
+Adicionalmente, Subversion tiene un sobrecosto considerable en
+almacenamiento para evitar transacciones por red en algunas
+operaciones,
 tales como encontrar ficheros modificados(\texttt{status}) y desplegar
 información frente a la revisión actual(\texttt{diff}).  Como
 resultado, la copia de trabajo de Subversion termina siendo del mismo
@@ -473,11 +480,11 @@
 \subsection{Git}
 
 Git es una herramienta distribuida de control de revisiones
-desarrollada para administrar el arbol del Kernel de Linux.  Al igual
+desarrollada para administrar el arbol del kernel de Linux.  Al igual
 que Mercurial los principios de su diseño fueron influenciados por 
 Monotone.
 
-Git tiene un conjunto de órdenes muy grande en la versión~1.5.0
+Git tiene un conjunto de órdenes muy grande; en la versión~1.5.0
 ofrece~139 órdenes individuales.  Tiene cierta reputación de ser
 difícil de aprender. Comparado con Git, Mercurial tiene un fuerte
 enfoque hacia la facilidad.
@@ -486,24 +493,24 @@
 casos, es más rápido que Mercurial, por lo menos en Linux, mientras
 que Mercurial se comporta mejor en otras operaciones.  De todas
 maneras en Windows, el desempeño y el nivel general de soporte que
-ofrece Git, al momento de la escritura, está lejos detrás de
+ofrece Git, al momento de la escritura, está bastante atrás de
 Mercurial.
 
 Mientras que el repositorio de Mercurial no requiere mantenimiento, el
-repositorio de Git requiere frecuentes ``repacks'' a sus metadatos.
-Sin estos, el desempeño se degrada y el espacio crece rápidamente. Un
+repositorio de Git requiere frecuentes ``reempaquetados'' de sus metadatos.
+Sin estos, el desempeño se degrada y el uso de espacio crece rápidamente. Un
 servidor que contenga repositorios de Git que no sean reempacados
-rigurosa y frecuentemente requerirá trabajo-intenso de disco durante
+rigurosa y frecuentemente requerirá trabajo intenso de disco durante
 las copias de seguridad, y ha habido situaciones en copias de
-seguridad diaria que toman más de 24 horas como resultado. Un
+seguridad diaria que toman más de~24 horas como resultado. Un
 repositorio recién reempacado de Git es un poco más pequeño que un
 repositorio de Mercurial, pero un repositorio sin reempacar es varios
 órdenes de magnitud más grande.
 
 El corazón de Git está escrito en C.  Muchas órdenes de Git están
-implementadas como scripts de shell o Perl y la calidad de esos
-scripts varía ampliamente. He encontrado muchas situaciones en las
-cuales los scripts no tuvieron en cuenta la presencia de errores que
+implementadas como guiones de línea de comandos o de Perl y la calidad de esos
+guiones varía ampliamente. He encontrado muchas situaciones en las
+cuales los guiones no tuvieron en cuenta la presencia de errores que
 podrían haber sido fatales.
 
 Mercurial puede importar el historial de revisiones de un repositorio
@@ -513,52 +520,54 @@
 
 CVS es probablemente la herramienta de control de revisiones más
 ampliamente usada en el planeta.  Debido a su edad y su poca pulcritud
-nterna, ha sido ligeramente mantenido en muchos años.
+interna, ha sido ligeramente mantenida en muchos años.
 
 Tiene una arquitectura centralizada cliente/servidor. No agrupa
-cambios relacionadso en consignaciones atómicas, pemitiendo que con
+cambios relacionados en consignaciones atómicas, pemitiendo que con
 facilidad la gente ``rompa la construcción'': una persona puede
 consignar exitósamente parte del cambio y estar bloqueada por la
 necesidad de una mezcla, forzando a otras personas a ver solamente una
 porción del trabajo que estaban buscando hacer.  Esto afecta también
+%TODO historia/historial
 la forma como usted trabaja con la historia del proyecto. Si quiere
 ver todas las modificaciones que alguien hizo como parte de una tarea,
 necesitará inspeccionar manualmente las descripciones y las marcas de
-tiempo de cambio de cada fichero involucrado(esto, si usted saber
+tiempo de cambio de cada fichero involucrado (esto, si usted saber
 cuáles eran tales ficheros).
 
 CVS tiene una noción confusa de etiquetas y ramas que yo no trataría
 incluso de describir.  No soporta renombramiento de ficheros o
-directorios de buena forma, facilitando el corromper un
+directorios adecuadamente, facilitando el corromper un
 repositorio. Casi no tiene chequeo de consistencia interna, por lo
 tanto es casi imposible identificar por que o cómo se corrompió un
 repositorio. Yo no recomendaría un repositorio de CVS para proyecto
 alguno, ni existente ni nuevo.
 
 Mercurial puede importar la historia de revisiones de CVS.  De todas
-maneras hay ciertos trucos para aplicar; los cuales también son
-necesarios para cualquier herramienta importadora de historial de
+maneras hay ciertas precauciones que aplican; las cuales también son
+necesarias para cualquier herramienta importadora de historial de
 CVS. Debido a la falta de atomicidad de cambios y el no versionamiento
-de la jerarquía del sistema de archivos, es imposible reconstruir la
-completamente la historia de CVS acertadamente; hay cierto trabajo de
+de la jerarquía del sistema de ficheros, es imposible reconstruir
+completamente la historia de CVS con precisión; hay cierto trabajo de
 conjetura involucrado y los renombramientos tampoco se
 mostrarán. Debido a que gran parte de la administración avanzada de
 CVS tiene que hacerse manualmente y por lo tanto es proclive al error,
 es común que los importadores de CVS encuentren muchos problemas con
-repositorios corruptos( marcas de tiempo totalmente desubicadas y
-archivos que han permanecido con candados por más de una década son
-dos de los problemas más interesantes de los que puedo retomar de mi
+repositorios corruptos (marcas de tiempo totalmente desubicadas y
+ficheros que han permanecido con candados por más de una década son
+dos de los problemas menos interesantes de los que puedo retomar de mi
 experiencia personal).
 
+%TODO historia/historial
 Mercurial puede importar la historia de revisiones de un repositorio
 CVS.
 
 \subsection{Herramientas comerciales}
 
 Perforce tiene una arquitectura centralizada cliente/servidor sin
-almacenamiento de dato alguno en el lado del cliente. A diferencia de
+almacenamiento de dato alguno de caché en el lado del cliente. A diferencia de
 las herramientas modernas de control de revisiones, Perforce requiere
-que un usuario ejecute una orden para informar al servidor acerca de
+que un usuario ejecute un comando para informar al servidor acerca de
 todo fichero que se vaya a editar.
 
 El rendimiento de Perforce es muy bueno para equipos pequeños, pero se
@@ -569,7 +578,7 @@
 \subsection{Elegir una herramienta de control de revisiones}
 
 Con la excepción de CVS, toda las herramientas que se han listado
-anteriormente tienen fortalezas que los hacen valiosos de acuerdo al
+anteriormente tienen fortalezas únicas que las hacen valiosas de acuerdo al
 tipo de trabajo. No hay una única herramienta de control de revisiones
 que sea la mejor en todas las situaciones.
 
@@ -592,8 +601,8 @@
 obtener los nuevos cambios que han sucedido después de la migración
 inicial.
 
-A continuación presentamos las herramientas de revisiones que la
-orden\hgext{convert} soporta:
+A continuación presentamos las herramientas de revisiones que soporta
+el comando \hgext{convert}:
 \begin{itemize}
 \item Subversion
 \item CVS
@@ -606,11 +615,11 @@
 en paralelo antes de lanzarse a un migración total, sin arriesgarse a
 perder trabajo alguno.
 
-La orden \hgxcmd{conver}{convert} es sencilla de usar. Basta con
-apuntarla hacia la ruta o el URL del repositorio fuente, opcionalmente
+El comando \hgxcmd{conver}{convert} es sencillo de usar. Basta con
+apuntarlo hacia la ruta o el URL del repositorio fuente, opcionalmente
 darle el nombre del nombre del repositorio destino y comenzará a hacer
 su trabajo. Después de la conversión inicial, basta con invocar de
-nuevo la orden para importar nuevos cambios.
+nuevo el comando para importar cambios nuevos.
 
 
 %%% Local Variables: