Mercurial > hgbook
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: