hgbook
diff es/intro.tex @ 509:e98a8c3afcef
finished revision of intro.tex. there are some standing issues yet, though
author | Javier Rojas <jerojasro@devnull.li> |
---|---|
date | Mon Jan 12 19:45:41 2009 -0500 (2009-01-12) |
parents | cf6b9bf14af7 |
children | 98fb436b58c1 |
line diff
1.1 --- a/es/intro.tex Wed Dec 31 11:44:58 2008 -0500 1.2 +++ b/es/intro.tex Mon Jan 12 19:45:41 2009 -0500 1.3 @@ -6,10 +6,10 @@ 1.4 El control de revisiones es el proceso de administrar diferentes 1.5 versiones de una pieza de información. En su forma más simple es algo 1.6 que la mayoría de gente hace a mano: cada vez que usted modifica un 1.7 -fichero, lo graba con un nuevo nombre que contiene un número, el 1.8 -siguiente mayor que el anterior. 1.9 - 1.10 -Administrar manualmente muchas versiones de un fichero es una tarea 1.11 +fichero, lo graba con un nuevo nombre que contiene un número, cada uno 1.12 +mayor que el anterior. 1.13 + 1.14 +Administrar manualmente muchas versiones de incluso sólo un fichero es una tarea 1.15 propensa a errores, a pesar de que hace bastante tiempo hay 1.16 herramientas que ayudan en este proceso. Las primeras herramientas 1.17 para automatizar el control de revisiones fueron pensadas para que un 1.18 @@ -18,7 +18,7 @@ 1.19 considerablemente; ahora manejan muchos ficheros y facilitan el 1.20 trabajo en conjunto de varias personas. Las mejores herramientas de 1.21 control de revisiones de la actualidad no tienen problema con miles de 1.22 -personas trabajando en proyectos que consisten de decenas de miles de 1.23 +personas trabajando en proyectos que consisten de cientos de miles de 1.24 ficheros. 1.25 1.26 \subsection{¿Por qué usar control de revisiones?} 1.27 @@ -26,36 +26,37 @@ 1.28 Hay muchas razones por las cuales usted o su equipo desearía usar una 1.29 herramienta automática de control de revisiones para un proyecto. 1.30 \begin{itemize} 1.31 -\item Contar con la historia y la evolución de su proyecto, para 1.32 - evitar hacer la tarea manualmente. Por cada cambio tendrá una 1.33 + %TODO historia 1.34 +\item Llevar registro de la historia y la evolución de su proyecto, para 1.35 + evitar hacer la tarea manualmente. Por cada cambio, tendrá una 1.36 bitácora de \emph{quién} lo hizo; \emph{por qué} se hizo; 1.37 \emph{cuándo} se hizo; y de \emph{qué} se trataba el cambio. 1.38 \item Cuando trabaja con más personas, los programas de control de 1.39 revisiones facilitan la colaboración. Por ejemplo, cuando varias 1.40 - personas de forma casi simultanea pueden hacer cambios 1.41 - incompatibles, el programa le ayudará a identificar y resolver tales 1.42 + personas hacen cambios potencialmente incompatibles de forma casi 1.43 + simultánea, el programa le ayudará a identificar y resolver tales 1.44 conflictos. 1.45 \item Puede ayudarle a recuperarse de equivocaciones. Si aplica un 1.46 cambio que posteriormente se evidencia como un error, puede 1.47 revertirlo a una versión previa a uno o muchos ficheros. De hecho, 1.48 una herramienta \emph{realmente} buena, incluso puede ayudarle 1.49 efectivamente a darse cuenta exactamente cuándo se introdujo el 1.50 - error( para más detalles ver la sección~\ref{sec:undo:bisect}). 1.51 -\item Le permitirá trabajar simultáneamente, y manejar las diferencias 1.52 + error (para más detalles ver la sección~\ref{sec:undo:bisect}). 1.53 +\item Le ayudará a trabajar simultáneamente, y a manejar las diferencias 1.54 entre múltiples versiones de su proyecto. 1.55 \end{itemize} 1.56 La mayoría de estas razones son igualmente válidas ---por lo menos en 1.57 -teoría--- así esté trabajando en un proyecto solo, o con mucha gente. 1.58 +teoría--- así esté trabajando en un proyecto solo usted, o con mucha gente. 1.59 1.60 Algo fundamental acerca de lo práctico de un sistema de control de 1.61 -revisiones en estas dos escalas (``un hacker solo'' y ``un equipo 1.62 +revisiones en estas dos escalas (``un hacker solitario'' y ``un equipo 1.63 gigantesco'') es cómo se comparan los \emph{beneficios} con los 1.64 \emph{costos}. Una herramienta de control de revisiones que sea 1.65 difícil de entender o usar impondrá un costo alto. 1.66 1.67 Un proyecto de quinientas personas es muy propenso a colapsar 1.68 -solamente con su peso inmediatamente sin una herramienta de control de 1.69 -versiones y un proceso. En este caso, el costo de usar control de 1.70 +solamente con su peso inmediatamente sin una herramienta y un proceso 1.71 +de control de versiones. En este caso, el costo de usar control de 1.72 revisiones ni siquiera se tiene en cuenta, puesto que \emph{sin} él, 1.73 el fracaso está casi garantizado. 1.74 1.75 @@ -64,26 +65,25 @@ 1.76 casi seguramente, el costo de usar una estaría cerca del costo del 1.77 proyecto. ¿No es así? 1.78 1.79 -%TODO el sentido de uniquely va más a decir que hace ambas cosas sin problema, 1.80 -% no a que ``apenas''las soporta, no? 1.81 -Mercurial solamente soporta \emph{ambas} escalas de de 1.82 -desarrollo. Puede aprender lo básico en pocos minutos, y dado su bajo 1.83 +Mercurial soporta \emph{ambas} escalas de de desarrollo de manera 1.84 +única. Puede aprender lo básico en pocos minutos, y dado su bajo 1.85 sobrecosto, puede aplicar el control de revisiones al proyecto más 1.86 pequeño con facilidad. Su simplicidad significa que no tendrá que 1.87 preocuparse por conceptos obtusos o secuencias de órdenes compitiendo 1.88 por espacio mental con lo que sea que \emph{realmente} esté tratando 1.89 de hacer. Al mismo tiempo, Mercurial tiene alto desempeño y su 1.90 +%TODO distribuida? en vez de p2p 1.91 naturaleza peer-to-peer le permite escalar indoloramente para manejar 1.92 grandes proyectos. 1.93 1.94 Ninguna herramienta de control de revisiones puede salvar un 1.95 proyecto mal administrado, pero la elección de herramientas puede 1.96 -hacer una gran diferencia en la fluidez con la cual puede trabajar en 1.97 -el proyecto. 1.98 +hacer una gran diferencia en la fluidez con la cual usted puede 1.99 +trabajar en un proyecto. 1.100 1.101 \subsection{La cantidad de nombres del control de revisiones} 1.102 1.103 -El control de revisiones es un campo amplio, tan ampli que no hay un 1.104 +El control de revisiones es un campo amplio, tan amplio que no hay un 1.105 acrónimo o nombre único. A continuación presentamos un listado de 1.106 nombres comunes y acrónimos que se podrían encontrar: 1.107 \begin{itemize} 1.108 @@ -95,8 +95,8 @@ 1.109 \item Control de Versiones(VCS) 1.110 \end{itemize} 1.111 Algunas personas aducen que estos términos tienen significados 1.112 -diversos, pero en la práctica se sobrelapan tanto que no hay un 1.113 -acuerdo o una forma adecuada de separarlos. 1.114 +diversos, pero en la práctica se sobrelapan tanto que no hay una 1.115 +forma acordada o incluso adecuada de separarlos. 1.116 1.117 \section{Historia resumida del control de revisiones} 1.118 1.119 @@ -112,30 +112,31 @@ 1.120 modificar los ficheros en cuestión sin la intervención del 1.121 administrador. 1.122 1.123 -Walter Tichy desarrolló una alternativa gratutita a SCCS a comienzos 1.124 -de los ochentas(1980s), llamó a su programa RCS(Sistema de Control de 1.125 +Walter Tichy desarrolló una alternativa gratuita a SCCS a comienzos 1.126 +de los ochentas(1980s); llamó a su programa RCS (Sistema de Control de 1.127 Revisiones). Al igual que SCCS, RCS requería que los desarrolladores 1.128 trabajaran en un único espacio compartido y colocaran candados a los 1.129 -ficheros para evitar que varias personas los estuvieran modificando 1.130 +ficheros para evitar que varias personas los modificaran 1.131 simultáneamente. 1.132 1.133 Después en los ochenta, Dick Grune usó RCS como un bloque de 1.134 construcción para un conjunto de guiones de línea de comando, que 1.135 -inicialmente llamó cmt, pero que renombró a CVS(Sistema Concurrente de 1.136 +inicialmente llamó cmt, pero que renombró a CVS (Sistema Concurrente de 1.137 Versiones). La gran innovación de CVS era que permitía a los 1.138 desarrolladores trabajar simultáneamente de una forma más o menos 1.139 independiente en sus propios espacios de trabajo. Los espacios de 1.140 -trabajo personales impedian que los desarrolladores se pisaran las 1.141 +trabajo personales impedían que los desarrolladores se pisaran las 1.142 mangueras todo el tiempo, situación común con SCCS y RCS. Cada 1.143 -desarrollador tenía una copia de todo el fichero del proyecto y podía 1.144 -modificar su copia independientemente, Tenían que fusionar sus 1.145 +desarrollador tenía una copia de todos los ficheros del proyecto y podía 1.146 +modificar sus copias independientemente, Tenían que fusionar sus 1.147 ediciones antes de consignar los cambios al repositorio central. 1.148 1.149 Brian Berliner tomó los scripts originales de Grune y los reescribió 1.150 -en~C, haciéndolos públicos en 1989, código sobre el cual se ha 1.151 -desarrollado la versión moderna de CVS. CVS posteriormente adquirió 1.152 +en~C, publicando en 1989 el código sobre el cual se ha 1.153 +desarrollado la versión moderna de CVS. CVS adquirió posteriormente 1.154 la habilidad de operar sobre una conexión de red, dotándolo de una 1.155 arquitectura, cliente/servidor. La arquitectura de CVS es 1.156 +%TODO historia/historial 1.157 centralizada; La historia del proyecto está únicamente en el 1.158 repositorio central. Los espacios de trabajo de los clientes 1.159 contienen únicamente copias recientes de las versiones de los 1.160 @@ -143,36 +144,37 @@ 1.161 ha tenido un éxito enorme; Es probablemente el sistema de control de 1.162 revisiones más extendido del planeta. 1.163 1.164 -A comienzos de los noventa(1990s), Sun MicroSystems desarrollo un 1.165 -temprano sistema distribuido de revisión de controles llamado TeamWare 1.166 +A comienzos de los noventa~(1990s), Sun MicroSystems desarrollo un 1.167 +temprano sistema distribuido de control de revisiones llamado 1.168 +TeamWare. 1.169 Un espacio de trabajo TeamWare contiene una copia completa de la 1.170 historia del proyecto. TeamWare no tiene la noción de repositorio 1.171 central. (CVS se basaba en RCS para el almacenamiento de su historia; 1.172 TeamWare usaba SCCS.) 1.173 1.174 -A medida que avanzaba la decada de los noventa, se empezño a 1.175 -evidenciar los problemas de CVS. Alacena cambios simultáneos a muchos 1.176 +A medida que avanzaba la decada de los noventa, se empezó a 1.177 +evidenciar los problemas de CVS. Almacena cambios simultáneos a muchos 1.178 ficheros de forma individual, en lugar de agruparlos como una 1.179 operación única y atómica lógicamente. No maneja bien su jerarquía de 1.180 -ficheros bien; es fácil desordenar un repositorio renombrando ficheros 1.181 +ficheros; es fácil desordenar un repositorio al renombrar ficheros 1.182 y directorios. Peor aún, su código fuente es difícil de leer y 1.183 -mantener, lo que hace que su ``umbral de dolor'' para arreglar sus 1.184 -problemas arquitecturales algo prohibitivo. 1.185 +mantener, lo que hizo que su ``umbral de dolor'' para arreglar sus 1.186 +problemas arquitecturales fuera algo prohibitivo. 1.187 1.188 En 2001, Jim Blandy y Karl Fogel, dos desarrolladores que habían 1.189 trabajado en CVS, comenzaron un proyecto para reemplazarlo con una 1.190 herramienta con mejor arquitectura y código más limpio. El resultado, 1.191 Subversion, no se separó del modelo centralizado cliente/servidor de 1.192 CVS, pero añadió consignaciones atómicas de varios ficheros, mejor 1.193 -manejo de nombres de espacios, y otras características que lo hacen 1.194 +manejo de espacios de nombres , y otras características que lo hacen 1.195 mejor que CVS. Desde su versión inicial, ha ido creciendo en 1.196 -popularidad. 1.197 +popularidad rápidamente. 1.198 1.199 Más o menos en forma simultánea Graydon Hoare comenzó a trabajar en un 1.200 -sistema distribuido de control de versiones ambicioso que llamó 1.201 +ambicioso sistema distribuido de control de versiones que llamó 1.202 Monotone. Mientras que Monotone se enfocaba a evitar algunas fallas de 1.203 diseño de CVS con una arquitectura peer-to-peer, fue mucho más 1.204 -allá(junto con otros proyectos subsecuentes) que unas herramientas de 1.205 +allá de las herramientas anteriores (y posteriores) de 1.206 control de revisiones en varios aspectos innovadores. Usa hashes 1.207 criptográficos como identificadores, y tiene una noción integral de 1.208 ``confianza'' para código de diversas fuentes. 1.209 @@ -184,45 +186,47 @@ 1.210 1.211 \section{Tendencias en el control de revisiones} 1.212 1.213 -Ha habido varias tendencias en el desarrollo y uso de las herramientas 1.214 -de control de revisiones en las pasadas cuatro décadas, mientras la 1.215 -gente se ha vuelto familiar con las capacidades de sus herramientas 1.216 -así mismo con sus limitaciones. 1.217 +Ha habido una tendencia inconfundible en el desarrollo y uso de las herramientas 1.218 +de control de revisiones en las cuatro décadas pasadas, mientras la 1.219 +gente se ha hecho familiar con las capacidades de sus herramientas y 1.220 +se ha visto restringida por sus limitaciones. 1.221 1.222 La primera generación comenzó administrando ficheros individuales en 1.223 computadores por persona. A pesar de que tales herramientas 1.224 representaron un avance importante frente al control de revisiones 1.225 -manual, su modelo de candados y la limitación a un sólo computador, 1.226 -determinó equipos de trabajo pequeños y acoplados. 1.227 +manual, su modelo de candados y la dependencia a un sólo computador 1.228 +los limitó a equipos de trabajo pequeños y acoplados. 1.229 1.230 La segunda generación dejó atrás esas limitaciones moviéndose a 1.231 arquitecturas centradas en redes, y administrando proyectos completos 1.232 -uno a la vez. A medida que los proyectos crecían, nacieron nuevos 1.233 +a la vez. A medida que los proyectos crecían, nacieron nuevos 1.234 problemas. Con la necesidad de comunicación frecuente con los 1.235 servidores, escalar estas máquinas se convirtió en un problema en 1.236 -proyectos realmente grandes. Las redes con poca estabilidad impidieron 1.237 -que usuarios remotos se conectaran al servidor. A medida que los 1.238 -proyecos de código abierto comenzaron a ofrecer acceso de sólo lectura 1.239 -de forma anónima a cualquiera, la gente sin permiso para consignar, 1.240 +proyectos realmente grandes. Las redes con poca estabilidad podrían 1.241 +impedir que usuarios remotos se conectaran al servidor. A medida que 1.242 +los 1.243 +proyectos de código abierto comenzaron a ofrecer acceso de sólo lectura 1.244 +de forma anónima a cualquiera, la gente sin permiso para consignar 1.245 vio que no podían usar tales herramientas para interactuar en un 1.246 proyecto de forma natural, puesto que no podían guardar sus cambios. 1.247 1.248 -La generación actual de herramientas de control de revisiones es de 1.249 -forma natural peer-to-peer. Todos estos sistemas han eliminado la 1.250 +La generación actual de herramientas de control de revisiones es 1.251 +peer-to-peer por naturaleza. Todos estos sistemas han eliminado la 1.252 dependencia de un único servidor central, y han permitido que la 1.253 gente distribuya sus datos de control de revisiones donde realmente se 1.254 necesita. La colaboración a través de Internet ha cambiado las 1.255 -limitantes tecnológicas a la cuestión de elección y consenso. Las 1.256 -herramientas modernas pueden operar sin conexión indefinidamenta y 1.257 +limitantes tecnológicas por la cuestión de elección y consenso. Las 1.258 +herramientas modernas pueden operar sin conexión indefinidamente y 1.259 autónomamente, necesitando una conexión de red solamente para 1.260 sincronizar los cambios con otro repositorio. 1.261 1.262 \section{Algunas ventajas del control distribuido de revisiones} 1.263 1.264 A pesar de que las herramientas para el control distribuido de 1.265 -revisiones lleva varios años siendo tan robusto y usable como la 1.266 -generación previa de su contraparte, personas que usan herramientas 1.267 -más antiguas no se han percatado de sus ventajas. Hay gran cantidad 1.268 +revisiones lleva varios años siendo tan robustas y usables como la 1.269 +generación previa de sus contrapartes, algunas personas que usan las 1.270 +herramientas más antiguas no se han percatado de sus ventajas. Hay 1.271 +gran cantidad 1.272 de situaciones en las cuales las herramientas distribuidas brillan 1.273 frente a las centralizadas. 1.274 1.275 @@ -246,37 +250,38 @@ 1.276 seguridad disponibles como computadores de contribuidores. 1.277 1.278 La confiabilidad de su red afectará las herramientas distribuidas de 1.279 -una forma mucho menor que las herramientas centralizadas No puede 1.280 +una forma mucho menor que a las herramientas centralizadas. Usted no puede 1.281 siquiera usar una herramienta centralizada sin conexión de red, 1.282 -excepto con algunas órdenes muy limitadas. Con herramientas 1.283 +excepto por algunas órdenes muy limitadas. Con herramientas 1.284 distribuidas, si sus conexión cae mientras usted está trabajando, 1.285 podría nisiquiera darse cuenta. Lo único que que no podrá hacer es 1.286 comunicarse con repositorios en otros computadores, algo que es 1.287 relativamente raro comparado con las operaciones locales. Si tiene 1.288 -colaboradores remotos en su equipo, puede ser significante. 1.289 +colaboradores remotos en su equipo, puede ser importante. 1.290 1.291 \subsection{Ventajas para proyectos de código abierto} 1.292 1.293 Si descubre un proyecto de código abierto y decide que desea comenzar 1.294 a trabajar en él, y ese proyecto usa una herramienta de control 1.295 -distribuido de revisiones, usted es un par con la gente que se 1.296 -considera el ``alma'' del proyecto. Si ellos publican los 1.297 -repositorios, se puede copiar inmediatamente la historia del proyecto, 1.298 +distribuido de revisiones, usted es de inmediato un par con la gente que se 1.299 +considera el ``alma'' del proyecto. Si ellos publican sus 1.300 +%TODO historia/historial 1.301 +repositorios, usted puede copiar inmediatamente la historia del proyecto, 1.302 hacer cambios y guardar su trabajo, usando las mismas herramientas de 1.303 la misma forma que ellos. En contraste, con una herramienta 1.304 -centralizada, debe usar el programa en un modo ``sólo lectura'' a 1.305 +centralizada, usted debe usar el programa en un modo ``sólo lectura'' a 1.306 menos que alguien le otorgue permisos para consignar cambios en el 1.307 repositorio central. Hasta entonces, no podrá almacenar sus cambios y 1.308 sus modificaciones locales correrán el riesgo de dañarse cuando trate 1.309 de actualizar su vista del repositorio. 1.310 1.311 -\subsubsection{Las bifurcaciones(forks) no son un problema} 1.312 +\subsubsection{Las bifurcaciones (forks) no son un problema} 1.313 1.314 Se ha mencionado que las herramientas de control distribuido de 1.315 versiones albergan un riesgo a los proyectos de código abierto, puesto 1.316 -que se vuelve muy sencillo hacer una ``bifurcanción''\ndt{fork.} del 1.317 -desarrollo del proyecto. Una bifurcación pasa cuando hay diferencias 1.318 -de opinión o actitud entre grupos de desarrolladores que desenvoca en 1.319 +que se vuelve muy sencillo hacer una ``bifurcación''\ndt{fork.} del 1.320 +desarrollo del proyecto. Una bifurcación sucede cuando hay diferencias 1.321 +de opinión o actitud entre grupos de desarrolladores que desemboca en 1.322 la decisión de la imposibilidad de continuar trabajando juntos. Cada 1.323 parte toma una copia más o menos completa del código fuente del 1.324 proyecto y toma su propio rumbo. 1.325 @@ -284,8 +289,10 @@ 1.326 En algunas ocasiones los líderes de las bifurcaciones reconcilian sus 1.327 diferencias. Con un sistema centralizado de control de revisiones, el 1.328 proceso \emph{técnico} de reconciliarse es doloroso, y se hace de 1.329 -forma muy manual. Tiene que decidir qué historia de revisiones va a 1.330 -``win'', e injertar los cambios del otro equipo en el árbol de alguna 1.331 +%TODO historia/historial 1.332 +forma muy manual. Usted tiene que decidir qué historia de revisiones va a 1.333 +``ganar'', e injertar los cambios del otro equipo en el árbol de alguna 1.334 +%TODO historia/historial 1.335 manera. Con esto usualmente se pierde algo o todo del historial de la 1.336 revisión de alguna de las partes. 1.337 1.338 @@ -297,16 +304,16 @@ 1.339 bueno al \emph{fusionar} las bifurcaciones, porque las bifurcaciones 1.340 son absolutamente fundamentales: pasan todo el tiempo. 1.341 1.342 -Si todas las porciones de trabajo que todos hacen todo el tiempo, se 1.343 -enmarca en términos de bifurcaciones y fusiones, entonces a aquello a 1.344 +Si todas las porciones de trabajo que todos hacen, todo el tiempo, se 1.345 +enmarcan en términos de bifurcaciones y fusiones, entonces a aquello a 1.346 lo que se refiere en el mundo del código abierto a una ``bifurcación'' 1.347 se convierte \emph{puramente} en una cuestión social. Lo que hacen las 1.348 herramientas distribuidas es \emph{disminuir} la posibilidad de una 1.349 bifurcación porque: 1.350 \begin{itemize} 1.351 -\item Eliminan la distinción social que las herramientas centralizadas 1.352 - imponen: esto entre los miembros (personas con permiso de consignar) 1.353 - y forasteros(los que no tienen el permiso). 1.354 +\item Eliminan la distinción social que imponen las herramientas 1.355 + centralizadas: aquélla entre miembros (personas con permiso de 1.356 + consignar) y forasteros (los que no tienen el permiso). 1.357 \item Facilitan la reconciliación después de una bifurcación social, 1.358 porque todo lo que concierne al programa de control de revisiones es 1.359 una fusión. 1.360 @@ -314,10 +321,10 @@ 1.361 1.362 Algunas personas se resisten a las herramientas distribuidas porque 1.363 desean mantener control completo sobre sus proyectos, y creen que las 1.364 -herramientas centralizadas les da tal control. En todo caso, si este 1.365 -es su parecer, y publica sus repositorios de CVS o Subversion, hay 1.366 +herramientas centralizadas les dan tal control. En todo caso, si este 1.367 +es su parecer, y usted publica sus repositorios de CVS o Subversion, hay 1.368 muchas herramientas disponibles que pueden obtener la historia 1.369 -completa(A pesar de lo lento) y recrearla en otro sitio que usted no 1.370 +completa (aunque sea lentamente) y recrearla en otro sitio que usted no 1.371 controla. Siendo así un control ilusorio, puesto que está impidiendo 1.372 la fluidez de colaboración en lugar de prevenir que alguien se sienta 1.373 impulsado a obtener una copia y hacer una bifurcación con su historia. 1.374 @@ -326,38 +333,38 @@ 1.375 1.376 Muchos proyectos comerciales tienen grupos de trabajo distribuidos 1.377 alrededor del globo. Quienes contribuyen y están lejos de un 1.378 -repositorio central verán una ejecución más lenta de las órdenes y tal 1.379 +repositorio central verán una ejecución más lenta de los comandos y tal 1.380 vez menos confiabilidad. Los sistemas de control de revisión 1.381 comerciales intentan amortiguar estos problemas con adiciones de 1.382 replicación remota que usualmente son muy costosos y complicados de 1.383 -administradr. Un sistema distribuido no padece estos problemas. Mejor 1.384 +administrar. Un sistema distribuido no padece estos problemas. Mejor 1.385 aún, puede colocar varios servidores autorizados, por ejemplo, uno por 1.386 sitio, de tal forma que no haya comunicación redundante entre 1.387 repositorios sobre enlaces de conexión costosos. 1.388 1.389 Los sistemas de control de revisiones distribuidos tienden a ser poco 1.390 -escalables. No es inusual quw costosos sistemas centralizados caigan 1.391 +escalables. No es inusual que costosos sistemas centralizados caigan 1.392 ante la carga combinada de unas cuantas docenas de usuarios 1.393 -concurrentes. De nuevo, las respuestas típicas de replibcación tienden 1.394 +concurrentes. De nuevo, las respuestas típicas de replicación tienden 1.395 a ser costosas y complejas de instalar y administrar. Dado que la 1.396 carga en un servidor central---si es que tiene uno---es muchas veces 1.397 -menor con una herramienta distribuida(debido a que los datos están 1.398 -replicados en todas partes), un sólo servidor económico puede tratar 1.399 +menor con una herramienta distribuida (debido a que los datos están 1.400 +replicados en todas partes), un solo servidor económico puede tratar 1.401 las necesidades de equipos mucho más grandes, y la replicación para 1.402 -balancear la carga se vuelve cosa de scripts. 1.403 +balancear la carga se vuelve cosa de guiones. 1.404 1.405 Si tiene un empleado en el campo, se beneficiará grandemente de un 1.406 sistema distribuido de control de versiones al resolver problemas en 1.407 el sitio del cliente. La herramienta le permitirá generar 1.408 construcciones a la medida, probar diferentes arreglos de forma 1.409 independiente y buscar de forma eficiente las fuentes de fallos en la 1.410 -historia y regresiones en los ambientes de los clientes, todo, sin 1.411 +historia y regresiones en los ambientes de los clientes, todo sin 1.412 necesidad de conectarse al servidor de su compañía. 1.413 1.414 \section{¿Por qué elegir Mercurial?} 1.415 1.416 Mercurial cuenta con un conjunto único de propiedades que lo hacen 1.417 -particularmente una buena elección como un sistema de control de 1.418 +una elección particularmente buena como sistema de control de 1.419 revisiones, puesto que: 1.420 \begin{itemize} 1.421 \item Es fácil de aprender y usar. 1.422 @@ -367,14 +374,14 @@ 1.423 \end{itemize} 1.424 1.425 Si los sistemas de control de revisiones le son familiares, debería 1.426 -estar listo para usar Mercurial en menos de cinco minutos. Si no, va a 1.427 +estar listo para usar Mercurial en menos de cinco minutos. Si no, sólo va a 1.428 tomar unos pocos minutos más. Las órdenes de Mercurial y su conjunto 1.429 de características son uniformes y consistentes generalmente, y basta 1.430 con que siga unas pocas reglas generales en lugar de un montón de 1.431 excepciones. 1.432 1.433 -En un proyecto pequeño, puede comenzar a trabajar con Mercurial poco a 1.434 -poco. Creando nuevos cambios y ramas, transfiriendo cambios(localmente 1.435 +En un proyecto pequeño, usted puede comenzar a trabajar con Mercurial en 1.436 +pocos momentos. Crear nuevos cambios y ramas, transferir cambios (localmente 1.437 o por la red); y las operaciones relacionadas con el estado y la 1.438 historia son rápidas. Mercurial buscar ser ligero y no incomodar en su 1.439 camino combinando poca sobrecarga cognitiva con operaciones 1.440 @@ -390,13 +397,12 @@ 1.441 scripting y su limpieza interna junto con su implementación en Python 1.442 permiten añadir características fácilmente en forma de extensiones. 1.443 Hay un buen número de extensiones útiles y populares en este momento, 1.444 -desde ayudar a identificar fallos hasta el mejoramiento de su 1.445 -desempeño. 1.446 +desde ayudar a identificar fallos hasta mejorar su desempeño. 1.447 1.448 \section{Comparación de Mercurial con otras herramientas} 1.449 1.450 Antes de leer, por favor tenga en cuenta que esta sección 1.451 -necesariamente refleja mis propias experiencias, intereses y(tengo que 1.452 +necesariamente refleja mis propias experiencias, intereses y (tengo que 1.453 decirlo) mis preferencias. He usado cada una de las herramientas de 1.454 control de versiones listadas a continuación, y en muchos casos por 1.455 varios años. 1.456 @@ -405,10 +411,10 @@ 1.457 \subsection{Subversion} 1.458 1.459 Subversion es una herramienta de control de revisiones muy popular, 1.460 -desarrollada para reemplazar a CVS. Su arquitectura es centralizada 1.461 -en cliente/servidor. 1.462 - 1.463 -Subversion y Mercurial tienen órdenes con nombres similares para hacer 1.464 +desarrollada para reemplazar a CVS. Tiene una arquitectura 1.465 +centralizada tipo cliente/servidor. 1.466 + 1.467 +Subversion y Mercurial tienen comandos con nombres similares para hacer 1.468 las mismas operaciones, por lo que si le son familiares en una, será 1.469 sencillo aprender a usar la otra. Ambas herramientas son portables en 1.470 todos los sistemas operativos populares. 1.471 @@ -419,20 +425,21 @@ 1.472 \href{http://svnbook.red-bean.com/nightly/en/svn.branchmerge.advanced.html#svn.branchmerge.advanced.finalword}{complicadas 1.473 y poco estables\ndt{buggy}}. 1.474 1.475 -Mercurial tiene una ventaja considerable en el desempeño sobre 1.476 +Mercurial tiene una ventaja considerable en desempeño sobre 1.477 Subversion en cualquier operación de control de revisiones que yo haya 1.478 medido. He medido sus ventajas con factores desde dos hasta seis veces 1.479 comparando con almacenamiento de ficheros \emph{ra\_local} 1.480 Subversion~1.4.3, el cual es el método de acceso más rápido. En los 1.481 -escenarios más sencillos incluyendo almacenamiento con la red de por 1.482 +escenarios más realistas incluyendo almacenamiento con la red de por 1.483 medio, Subversion se encuentra en desventaja aún mayor. Dado que casi 1.484 todas las órdenes de Subversion deben tratar con el servidor y 1.485 -Subversion no tiene utilidades de replicación sencillas, la capacidad 1.486 +Subversion no tiene utilidades de replicación adecuadas, la capacidad 1.487 del servidor y el ancho de banda se convierten en cuellos de botella 1.488 para proyectos modestamente grandes. 1.489 1.490 -Adicionalmente, Subversion tiene un sobrecosto en almacentamiento 1.491 -considerable para evitar transacciones por red en algunas operaciones, 1.492 +Adicionalmente, Subversion tiene un sobrecosto considerable en 1.493 +almacenamiento para evitar transacciones por red en algunas 1.494 +operaciones, 1.495 tales como encontrar ficheros modificados(\texttt{status}) y desplegar 1.496 información frente a la revisión actual(\texttt{diff}). Como 1.497 resultado, la copia de trabajo de Subversion termina siendo del mismo 1.498 @@ -473,11 +480,11 @@ 1.499 \subsection{Git} 1.500 1.501 Git es una herramienta distribuida de control de revisiones 1.502 -desarrollada para administrar el arbol del Kernel de Linux. Al igual 1.503 +desarrollada para administrar el arbol del kernel de Linux. Al igual 1.504 que Mercurial los principios de su diseño fueron influenciados por 1.505 Monotone. 1.506 1.507 -Git tiene un conjunto de órdenes muy grande en la versión~1.5.0 1.508 +Git tiene un conjunto de órdenes muy grande; en la versión~1.5.0 1.509 ofrece~139 órdenes individuales. Tiene cierta reputación de ser 1.510 difícil de aprender. Comparado con Git, Mercurial tiene un fuerte 1.511 enfoque hacia la facilidad. 1.512 @@ -486,24 +493,24 @@ 1.513 casos, es más rápido que Mercurial, por lo menos en Linux, mientras 1.514 que Mercurial se comporta mejor en otras operaciones. De todas 1.515 maneras en Windows, el desempeño y el nivel general de soporte que 1.516 -ofrece Git, al momento de la escritura, está lejos detrás de 1.517 +ofrece Git, al momento de la escritura, está bastante atrás de 1.518 Mercurial. 1.519 1.520 Mientras que el repositorio de Mercurial no requiere mantenimiento, el 1.521 -repositorio de Git requiere frecuentes ``repacks'' a sus metadatos. 1.522 -Sin estos, el desempeño se degrada y el espacio crece rápidamente. Un 1.523 +repositorio de Git requiere frecuentes ``reempaquetados'' de sus metadatos. 1.524 +Sin estos, el desempeño se degrada y el uso de espacio crece rápidamente. Un 1.525 servidor que contenga repositorios de Git que no sean reempacados 1.526 -rigurosa y frecuentemente requerirá trabajo-intenso de disco durante 1.527 +rigurosa y frecuentemente requerirá trabajo intenso de disco durante 1.528 las copias de seguridad, y ha habido situaciones en copias de 1.529 -seguridad diaria que toman más de 24 horas como resultado. Un 1.530 +seguridad diaria que toman más de~24 horas como resultado. Un 1.531 repositorio recién reempacado de Git es un poco más pequeño que un 1.532 repositorio de Mercurial, pero un repositorio sin reempacar es varios 1.533 órdenes de magnitud más grande. 1.534 1.535 El corazón de Git está escrito en C. Muchas órdenes de Git están 1.536 -implementadas como scripts de shell o Perl y la calidad de esos 1.537 -scripts varía ampliamente. He encontrado muchas situaciones en las 1.538 -cuales los scripts no tuvieron en cuenta la presencia de errores que 1.539 +implementadas como guiones de línea de comandos o de Perl y la calidad de esos 1.540 +guiones varía ampliamente. He encontrado muchas situaciones en las 1.541 +cuales los guiones no tuvieron en cuenta la presencia de errores que 1.542 podrían haber sido fatales. 1.543 1.544 Mercurial puede importar el historial de revisiones de un repositorio 1.545 @@ -513,52 +520,54 @@ 1.546 1.547 CVS es probablemente la herramienta de control de revisiones más 1.548 ampliamente usada en el planeta. Debido a su edad y su poca pulcritud 1.549 -nterna, ha sido ligeramente mantenido en muchos años. 1.550 +interna, ha sido ligeramente mantenida en muchos años. 1.551 1.552 Tiene una arquitectura centralizada cliente/servidor. No agrupa 1.553 -cambios relacionadso en consignaciones atómicas, pemitiendo que con 1.554 +cambios relacionados en consignaciones atómicas, pemitiendo que con 1.555 facilidad la gente ``rompa la construcción'': una persona puede 1.556 consignar exitósamente parte del cambio y estar bloqueada por la 1.557 necesidad de una mezcla, forzando a otras personas a ver solamente una 1.558 porción del trabajo que estaban buscando hacer. Esto afecta también 1.559 +%TODO historia/historial 1.560 la forma como usted trabaja con la historia del proyecto. Si quiere 1.561 ver todas las modificaciones que alguien hizo como parte de una tarea, 1.562 necesitará inspeccionar manualmente las descripciones y las marcas de 1.563 -tiempo de cambio de cada fichero involucrado(esto, si usted saber 1.564 +tiempo de cambio de cada fichero involucrado (esto, si usted saber 1.565 cuáles eran tales ficheros). 1.566 1.567 CVS tiene una noción confusa de etiquetas y ramas que yo no trataría 1.568 incluso de describir. No soporta renombramiento de ficheros o 1.569 -directorios de buena forma, facilitando el corromper un 1.570 +directorios adecuadamente, facilitando el corromper un 1.571 repositorio. Casi no tiene chequeo de consistencia interna, por lo 1.572 tanto es casi imposible identificar por que o cómo se corrompió un 1.573 repositorio. Yo no recomendaría un repositorio de CVS para proyecto 1.574 alguno, ni existente ni nuevo. 1.575 1.576 Mercurial puede importar la historia de revisiones de CVS. De todas 1.577 -maneras hay ciertos trucos para aplicar; los cuales también son 1.578 -necesarios para cualquier herramienta importadora de historial de 1.579 +maneras hay ciertas precauciones que aplican; las cuales también son 1.580 +necesarias para cualquier herramienta importadora de historial de 1.581 CVS. Debido a la falta de atomicidad de cambios y el no versionamiento 1.582 -de la jerarquía del sistema de archivos, es imposible reconstruir la 1.583 -completamente la historia de CVS acertadamente; hay cierto trabajo de 1.584 +de la jerarquía del sistema de ficheros, es imposible reconstruir 1.585 +completamente la historia de CVS con precisión; hay cierto trabajo de 1.586 conjetura involucrado y los renombramientos tampoco se 1.587 mostrarán. Debido a que gran parte de la administración avanzada de 1.588 CVS tiene que hacerse manualmente y por lo tanto es proclive al error, 1.589 es común que los importadores de CVS encuentren muchos problemas con 1.590 -repositorios corruptos( marcas de tiempo totalmente desubicadas y 1.591 -archivos que han permanecido con candados por más de una década son 1.592 -dos de los problemas más interesantes de los que puedo retomar de mi 1.593 +repositorios corruptos (marcas de tiempo totalmente desubicadas y 1.594 +ficheros que han permanecido con candados por más de una década son 1.595 +dos de los problemas menos interesantes de los que puedo retomar de mi 1.596 experiencia personal). 1.597 1.598 +%TODO historia/historial 1.599 Mercurial puede importar la historia de revisiones de un repositorio 1.600 CVS. 1.601 1.602 \subsection{Herramientas comerciales} 1.603 1.604 Perforce tiene una arquitectura centralizada cliente/servidor sin 1.605 -almacenamiento de dato alguno en el lado del cliente. A diferencia de 1.606 +almacenamiento de dato alguno de caché en el lado del cliente. A diferencia de 1.607 las herramientas modernas de control de revisiones, Perforce requiere 1.608 -que un usuario ejecute una orden para informar al servidor acerca de 1.609 +que un usuario ejecute un comando para informar al servidor acerca de 1.610 todo fichero que se vaya a editar. 1.611 1.612 El rendimiento de Perforce es muy bueno para equipos pequeños, pero se 1.613 @@ -569,7 +578,7 @@ 1.614 \subsection{Elegir una herramienta de control de revisiones} 1.615 1.616 Con la excepción de CVS, toda las herramientas que se han listado 1.617 -anteriormente tienen fortalezas que los hacen valiosos de acuerdo al 1.618 +anteriormente tienen fortalezas únicas que las hacen valiosas de acuerdo al 1.619 tipo de trabajo. No hay una única herramienta de control de revisiones 1.620 que sea la mejor en todas las situaciones. 1.621 1.622 @@ -592,8 +601,8 @@ 1.623 obtener los nuevos cambios que han sucedido después de la migración 1.624 inicial. 1.625 1.626 -A continuación presentamos las herramientas de revisiones que la 1.627 -orden\hgext{convert} soporta: 1.628 +A continuación presentamos las herramientas de revisiones que soporta 1.629 +el comando \hgext{convert}: 1.630 \begin{itemize} 1.631 \item Subversion 1.632 \item CVS 1.633 @@ -606,11 +615,11 @@ 1.634 en paralelo antes de lanzarse a un migración total, sin arriesgarse a 1.635 perder trabajo alguno. 1.636 1.637 -La orden \hgxcmd{conver}{convert} es sencilla de usar. Basta con 1.638 -apuntarla hacia la ruta o el URL del repositorio fuente, opcionalmente 1.639 +El comando \hgxcmd{conver}{convert} es sencillo de usar. Basta con 1.640 +apuntarlo hacia la ruta o el URL del repositorio fuente, opcionalmente 1.641 darle el nombre del nombre del repositorio destino y comenzará a hacer 1.642 su trabajo. Después de la conversión inicial, basta con invocar de 1.643 -nuevo la orden para importar nuevos cambios. 1.644 +nuevo el comando para importar cambios nuevos. 1.645 1.646 1.647 %%% Local Variables: