annotate es/intro.tex @ 777:3274ff6650df

add old Makefile for tex compilation
author Yoshiki Yazawa <yaz@honeyplanet.jp>
date Sat, 25 Apr 2009 00:02:59 +0900
parents 7e8ef188c72f
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
1 \chapter{Introducción}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
2 \label{chap:intro}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
3
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
4 \section{Acerca del control de revisiones}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
5
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
6 El control de revisiones es el proceso de administrar diferentes
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
7 versiones de una pieza de información. En su forma más simple es algo
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
8 que la mayoría de gente hace a mano: cada vez que usted modifica un
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
9 fichero, lo graba con un nuevo nombre que contiene un número, cada uno
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
10 mayor que el anterior.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
11
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
12 Administrar manualmente muchas versiones de incluso sólo un fichero es una tarea
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
13 propensa a errores, a pesar de que hace bastante tiempo hay
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
14 herramientas que ayudan en este proceso. Las primeras herramientas
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
15 para automatizar el control de revisiones fueron pensadas para que un
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
16 usuario administrara un solo fichero. En las décadas pasadas, el
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
17 alcance de las herramientas de control de revisiones ha ido aumentando
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
18 considerablemente; ahora manejan muchos ficheros y facilitan el
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
19 trabajo en conjunto de varias personas. Las mejores herramientas de
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
20 control de revisiones de la actualidad no tienen problema con miles de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
21 personas trabajando en proyectos que consisten de cientos de miles de
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
22 ficheros.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
23
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
24 \subsection{¿Por qué usar control de revisiones?}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
25
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
26 Hay muchas razones por las cuales usted o su equipo desearía usar una
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
27 herramienta automática de control de revisiones para un proyecto.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
28 \begin{itemize}
616
3f32047a3f25 changed all "de el" to "del"
Javier Rojas <jerojasro@devnull.li>
parents: 615
diff changeset
29 \item Llevar registro del historial y la evolución de su proyecto, para
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
30 evitar hacer la tarea manualmente. Por cada cambio, tendrá una
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
31 bitácora de \emph{quién} lo hizo; \emph{por qué} se hizo;
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
32 \emph{cuándo} se hizo; y de \emph{qué} se trataba el cambio.
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
33 \item Cuando trabaja con más personas, los programas de control de
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
34 revisiones facilitan la colaboración. Por ejemplo, cuando varias
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
35 personas hacen cambios potencialmente incompatibles de forma casi
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
36 simultánea, el programa le ayudará a identificar y resolver tales
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
37 conflictos.
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
38 \item Puede ayudarle a recuperarse de equivocaciones. Si aplica un
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
39 cambio que posteriormente se evidencia como un error, puede
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
40 revertirlo a una versión previa a uno o muchos ficheros. De hecho,
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
41 una herramienta \emph{realmente} buena, incluso puede ayudarle
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
42 efectivamente a darse cuenta exactamente cuándo se introdujo el
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
43 error (para más detalles ver la sección~\ref{sec:undo:bisect}).
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
44 \item Le ayudará a trabajar simultáneamente, y a manejar las diferencias
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
45 entre múltiples versiones de su proyecto.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
46 \end{itemize}
575
cf6b9bf14af7 corrected some typos, added a note about the meaning of a sentence
Javier Rojas <jerojasro@devnull.li>
parents: 508
diff changeset
47 La mayoría de estas razones son igualmente válidas ---por lo menos en
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
48 teoría--- así esté trabajando en un proyecto solo usted, o con mucha gente.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
49
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
50 Algo fundamental acerca de lo práctico de un sistema de control de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
51 revisiones en estas dos escalas (``un hacker solitario'' y ``un equipo
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
52 gigantesco'') es cómo se comparan los \emph{beneficios} con los
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
53 \emph{costos}. Una herramienta de control de revisiones que sea
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
54 difícil de entender o usar impondrá un costo alto.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
55
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
56 Un proyecto de quinientas personas es muy propenso a colapsar
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
57 solamente con su peso inmediatamente sin una herramienta y un proceso
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
58 de control de versiones. En este caso, el costo de usar control de
575
cf6b9bf14af7 corrected some typos, added a note about the meaning of a sentence
Javier Rojas <jerojasro@devnull.li>
parents: 508
diff changeset
59 revisiones ni siquiera se tiene en cuenta, puesto que \emph{sin} él,
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
60 el fracaso está casi garantizado.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
61
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
62 Por otra parte, un ``arreglo rápido'' de una sola persona, excluiría
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
63 la necesidad de usar una herramienta de control de revisiones, porque
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
64 casi seguramente, el costo de usar una estaría cerca del costo del
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
65 proyecto. ¿No es así?
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
66
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
67 Mercurial soporta \emph{ambas} escalas de de desarrollo de manera
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
68 única. Puede aprender lo básico en pocos minutos, y dado su bajo
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
69 sobrecosto, puede aplicar el control de revisiones al proyecto más
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
70 pequeño con facilidad. Su simplicidad significa que no tendrá que
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
71 preocuparse por conceptos obtusos o secuencias de órdenes compitiendo
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
72 por espacio mental con lo que sea que \emph{realmente} esté tratando
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
73 de hacer. Al mismo tiempo, Mercurial tiene alto desempeño y su
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
74 %TODO distribuida? en vez de p2p
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
75 naturaleza peer-to-peer le permite escalar indoloramente para manejar
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
76 grandes proyectos.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
77
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
78 Ninguna herramienta de control de revisiones puede salvar un
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
79 proyecto mal administrado, pero la elección de herramientas puede
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
80 hacer una gran diferencia en la fluidez con la cual usted puede
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
81 trabajar en un proyecto.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
82
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
83 \subsection{La cantidad de nombres del control de revisiones}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
84
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
85 El control de revisiones es un campo amplio, tan amplio que no hay un
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
86 acrónimo o nombre único. A continuación presentamos un listado de
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
87 nombres comunes y acrónimos que se podrían encontrar:
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
88 \begin{itemize}
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
89 \item Control de revisiones (RCS)
609
98fb436b58c1 corrected some typos
Javier Rojas <jerojasro@devnull.li>
parents: 608
diff changeset
90 \item Manejo de Configuraciones de Programas (SCM), o administracón de
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
91 configuraciones
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
92 \item Administración de código fuente
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
93 \item Control de Código Fuente, o Control de Fuentes
609
98fb436b58c1 corrected some typos
Javier Rojas <jerojasro@devnull.li>
parents: 608
diff changeset
94 \item Control de Versiones (VCS)
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
95 \end{itemize}
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
96 Algunas personas aducen que estos términos tienen significados
625
7e8ef188c72f removed the anglicism "sobrelapar". Thanks to Mario Palomo
Javier Rojas <jerojasro@devnull.li>
parents: 616
diff changeset
97 diversos, pero en la práctica se sobreponen tanto que no hay una
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
98 forma acordada o incluso adecuada de separarlos.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
99
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
100 \section{Historia resumida del control de revisiones}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
101
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
102 La herramienta de control de revisiones más antigua conocida es SCCS
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
103 (Sistema de Control de Código), escrito por Marc Rochkind en Bell
609
98fb436b58c1 corrected some typos
Javier Rojas <jerojasro@devnull.li>
parents: 608
diff changeset
104 Labs, a comienzos de los setentas (1970s). SCCS operaba sobre ficheros
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
105 individuales, y requería que cada persona que trabajara en el proyecto
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
106 tuviera acceso a un espacio compartido en un solo sistema. Solamente
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
107 una persona podía modificar un fichero en un momento dado; el
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
108 arbitramiento del acceso a los ficheros se hacía con candados. Era
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
109 común que la gente pusiera los candados a los ficheros, y que
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
110 posteriormente olvidara quitarlos, impidiendo que otro pudiera
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
111 modificar los ficheros en cuestión sin la intervención del
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
112 administrador.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
113
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
114 Walter Tichy desarrolló una alternativa gratuita a SCCS a comienzos
609
98fb436b58c1 corrected some typos
Javier Rojas <jerojasro@devnull.li>
parents: 608
diff changeset
115 de los ochentas (1980s); llamó a su programa RCS (Sistema de Control de
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
116 Revisiones). Al igual que SCCS, RCS requería que los desarrolladores
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
117 trabajaran en un único espacio compartido y colocaran candados a los
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
118 ficheros para evitar que varias personas los modificaran
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
119 simultáneamente.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
120
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
121 Después en los ochenta, Dick Grune usó RCS como un bloque de
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
122 construcción para un conjunto de guiones de línea de comando, que
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
123 inicialmente llamó cmt, pero que renombró a CVS (Sistema Concurrente de
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
124 Versiones). La gran innovación de CVS era que permitía a los
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
125 desarrolladores trabajar simultáneamente de una forma más o menos
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
126 independiente en sus propios espacios de trabajo. Los espacios de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
127 trabajo personales impedían que los desarrolladores se pisaran las
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
128 mangueras todo el tiempo, situación común con SCCS y RCS. Cada
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
129 desarrollador tenía una copia de todos los ficheros del proyecto y podía
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
130 modificar sus copias independientemente, Tenían que fusionar sus
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
131 ediciones antes de consignar los cambios al repositorio central.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
132
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
133 Brian Berliner tomó los scripts originales de Grune y los reescribió
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
134 en~C, publicando en 1989 el código sobre el cual se ha
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
135 desarrollado la versión moderna de CVS. CVS adquirió posteriormente
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
136 la habilidad de operar sobre una conexión de red, dotándolo de una
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
137 arquitectura, cliente/servidor. La arquitectura de CVS es
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
138 centralizada; el historial del proyecto está únicamente en el
502
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
139 repositorio central. Los espacios de trabajo de los clientes
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
140 contienen únicamente copias recientes de las versiones de los
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
141 ficheros, y pocos metadatos para indicar dónde está el servidor. CVS
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
142 ha tenido un éxito enorme; Es probablemente el sistema de control de
4cdeb830118b Starting translating intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 501
diff changeset
143 revisiones más extendido del planeta.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
144
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
145 A comienzos de los noventa~(1990s), Sun MicroSystems desarrollo un
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
146 temprano sistema distribuido de control de revisiones llamado
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
147 TeamWare.
616
3f32047a3f25 changed all "de el" to "del"
Javier Rojas <jerojasro@devnull.li>
parents: 615
diff changeset
148 Un espacio de trabajo TeamWare contiene una copia completa del
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
149 historial del proyecto. TeamWare no tiene la noción de repositorio
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
150 central. (CVS se basaba en RCS para el almacenamiento de su historial;
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
151 TeamWare usaba SCCS.)
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
152
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
153 A medida que avanzaba la decada de los noventa, se empezó a
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
154 evidenciar los problemas de CVS. Almacena cambios simultáneos a muchos
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
155 ficheros de forma individual, en lugar de agruparlos como una
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
156 operación única y atómica lógicamente. No maneja bien su jerarquía de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
157 ficheros; es fácil desordenar un repositorio al renombrar ficheros
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
158 y directorios. Peor aún, su código fuente es difícil de leer y
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
159 mantener, lo que hizo que su ``umbral de dolor'' para arreglar sus
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
160 problemas arquitecturales fuera algo prohibitivo.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
161
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
162 En 2001, Jim Blandy y Karl Fogel, dos desarrolladores que habían
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
163 trabajado en CVS, comenzaron un proyecto para reemplazarlo con una
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
164 herramienta con mejor arquitectura y código más limpio. El resultado,
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
165 Subversion, no se separó del modelo centralizado cliente/servidor de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
166 CVS, pero añadió consignaciones atómicas de varios ficheros, mejor
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
167 manejo de espacios de nombres , y otras características que lo hacen
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
168 mejor que CVS. Desde su versión inicial, ha ido creciendo en
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
169 popularidad rápidamente.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
170
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
171 Más o menos en forma simultánea Graydon Hoare comenzó a trabajar en un
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
172 ambicioso sistema distribuido de control de versiones que llamó
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
173 Monotone. Mientras que Monotone se enfocaba a evitar algunas fallas de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
174 diseño de CVS con una arquitectura peer-to-peer, fue mucho más
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
175 allá de las herramientas anteriores (y posteriores) de
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
176 control de revisiones en varios aspectos innovadores. Usa hashes
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
177 criptográficos como identificadores, y tiene una noción integral de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
178 ``confianza'' para código de diversas fuentes.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
179
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
180 Mercurial nació en el 2005. Algunos de sus aspectos de de diseño
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
181 fueron influenciados por Monotone, pero Mercurial se enfoca en la
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
182 facilidad de uso, gran rendimiento y escalabilidad para proyectos muy
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
183 grandes.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
184
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
185 \section{Tendencias en el control de revisiones}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
186
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
187 Ha habido una tendencia inconfundible en el desarrollo y uso de las herramientas
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
188 de control de revisiones en las cuatro décadas pasadas, mientras la
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
189 gente se ha hecho familiar con las capacidades de sus herramientas y
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
190 se ha visto restringida por sus limitaciones.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
191
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
192 La primera generación comenzó administrando ficheros individuales en
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
193 computadores por persona. A pesar de que tales herramientas
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
194 representaron un avance importante frente al control de revisiones
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
195 manual, su modelo de candados y la dependencia a un sólo computador
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
196 los limitó a equipos de trabajo pequeños y acoplados.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
197
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
198 La segunda generación dejó atrás esas limitaciones moviéndose a
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
199 arquitecturas centradas en redes, y administrando proyectos completos
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
200 a la vez. A medida que los proyectos crecían, nacieron nuevos
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
201 problemas. Con la necesidad de comunicación frecuente con los
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
202 servidores, escalar estas máquinas se convirtió en un problema en
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
203 proyectos realmente grandes. Las redes con poca estabilidad podrían
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
204 impedir que usuarios remotos se conectaran al servidor. A medida que
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
205 los
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
206 proyectos de código abierto comenzaron a ofrecer acceso de sólo lectura
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
207 de forma anónima a cualquiera, la gente sin permiso para consignar
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
208 vio que no podían usar tales herramientas para interactuar en un
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
209 proyecto de forma natural, puesto que no podían guardar sus cambios.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
210
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
211 La generación actual de herramientas de control de revisiones es
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
212 peer-to-peer por naturaleza. Todos estos sistemas han eliminado la
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
213 dependencia de un único servidor central, y han permitido que la
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
214 gente distribuya sus datos de control de revisiones donde realmente se
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
215 necesita. La colaboración a través de Internet ha cambiado las
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
216 limitantes tecnológicas por la cuestión de elección y consenso. Las
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
217 herramientas modernas pueden operar sin conexión indefinidamente y
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
218 autónomamente, necesitando una conexión de red solamente para
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
219 sincronizar los cambios con otro repositorio.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
220
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
221 \section{Algunas ventajas del control distribuido de revisiones}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
222
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
223 A pesar de que las herramientas para el control distribuido de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
224 revisiones lleva varios años siendo tan robustas y usables como la
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
225 generación previa de sus contrapartes, algunas personas que usan las
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
226 herramientas más antiguas no se han percatado de sus ventajas. Hay
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
227 gran cantidad
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
228 de situaciones en las cuales las herramientas distribuidas brillan
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
229 frente a las centralizadas.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
230
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
231 Para un desarrollador individual, las herramientas distribuidas casi
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
232 siempre son más rápidas que las centralizadas. Por una razón sencilla:
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
233 Una herramienta centralizada necesita comunicarse por red para las
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
234 operaciones más usuales, debido a que los metadatos se almacenan en
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
235 una sola copia en el servidor central. Una herramienta distribuida
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
236 almacena todos sus metadatos localmente. Con todo lo demás de la
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
237 misma forma, comunicarse por red tiene un sobrecosto en una
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
238 herramienta centralizada. No subestime el valor de una herramienta de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
239 respuesta rápida: Usted empleará mucho tiempo interactuando con su
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
240 programa de control de revisiones.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
241
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
242 Las herramientas distribuidas son indiferentes a los caprichos de su
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
243 infraestructura de servidores, de nuevo, debido a la replicación de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
244 metadatos en tantos lugares. Si usa un sistema centralizado y su
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
245 servidor explota, ojalá los medios físicos de su copia de seguridad
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
246 sean confiables, y que su última copia sea reciente y además
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
247 funcione. Con una herramienta distribuida tiene tantas copias de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
248 seguridad disponibles como computadores de contribuidores.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
249
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
250 La confiabilidad de su red afectará las herramientas distribuidas de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
251 una forma mucho menor que a las herramientas centralizadas. Usted no puede
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
252 siquiera usar una herramienta centralizada sin conexión de red,
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
253 excepto por algunas órdenes muy limitadas. Con herramientas
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
254 distribuidas, si sus conexión cae mientras usted está trabajando,
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
255 podría nisiquiera darse cuenta. Lo único que que no podrá hacer es
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
256 comunicarse con repositorios en otros computadores, algo que es
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
257 relativamente raro comparado con las operaciones locales. Si tiene
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
258 colaboradores remotos en su equipo, puede ser importante.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
259
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
260 \subsection{Ventajas para proyectos de código abierto}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
261
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
262 Si descubre un proyecto de código abierto y decide que desea comenzar
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
263 a trabajar en él, y ese proyecto usa una herramienta de control
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
264 distribuido de revisiones, usted es de inmediato un par con la gente que se
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
265 considera el ``alma'' del proyecto. Si ellos publican sus
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
266 repositorios, usted puede copiar inmediatamente el historial del proyecto,
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
267 hacer cambios y guardar su trabajo, usando las mismas herramientas de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
268 la misma forma que ellos. En contraste, con una herramienta
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
269 centralizada, usted debe usar el programa en un modo ``sólo lectura'' a
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
270 menos que alguien le otorgue permisos para consignar cambios en el
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
271 repositorio central. Hasta entonces, no podrá almacenar sus cambios y
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
272 sus modificaciones locales correrán el riesgo de dañarse cuando trate
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
273 de actualizar su vista del repositorio.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
274
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
275 \subsubsection{Las bifurcaciones (forks) no son un problema}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
276
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
277 Se ha mencionado que las herramientas de control distribuido de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
278 versiones albergan un riesgo a los proyectos de código abierto, puesto
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
279 que se vuelve muy sencillo hacer una ``bifurcación''\ndt{fork.} del
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
280 desarrollo del proyecto. Una bifurcación sucede cuando hay diferencias
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
281 de opinión o actitud entre grupos de desarrolladores que desemboca en
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
282 la decisión de la imposibilidad de continuar trabajando juntos. Cada
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
283 parte toma una copia más o menos completa del código fuente del
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
284 proyecto y toma su propio rumbo.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
285
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
286 En algunas ocasiones los líderes de las bifurcaciones reconcilian sus
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
287 diferencias. Con un sistema centralizado de control de revisiones, el
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
288 proceso \emph{técnico} de reconciliarse es doloroso, y se hace de
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
289 forma muy manual. Usted tiene que decidir qué historial de revisiones va a
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
290 ``ganar'', e injertar los cambios del otro equipo en el árbol de alguna
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
291 manera. Con esto usualmente se pierde algo o todo del historial de la
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
292 revisión de alguna de las partes.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
293
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
294 Lo que las herramientas distribuidas hacen con respecto a las
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
295 bifurcaciones, es que las bifurcaciones son la \emph{única} forma de
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
296 desarrollar un proyecto. Cada cambio que usted hace es potencialmente
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
297 un punto de bifurcación. La gran fortaleza de esta aproximación es que
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
298 las herramientas distribuidas de control de revisiones tiene que ser
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
299 bueno al \emph{fusionar} las bifurcaciones, porque las bifurcaciones
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
300 son absolutamente fundamentales: pasan todo el tiempo.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
301
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
302 Si todas las porciones de trabajo que todos hacen, todo el tiempo, se
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
303 enmarcan en términos de bifurcaciones y fusiones, entonces a aquello a
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
304 lo que se refiere en el mundo del código abierto a una ``bifurcación''
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
305 se convierte \emph{puramente} en una cuestión social. Lo que hacen las
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
306 herramientas distribuidas es \emph{disminuir} la posibilidad de una
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
307 bifurcación porque:
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
308 \begin{itemize}
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
309 \item Eliminan la distinción social que imponen las herramientas
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
310 centralizadas: aquélla entre miembros (personas con permiso de
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
311 consignar) y forasteros (los que no tienen el permiso).
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
312 \item Facilitan la reconciliación después de una bifurcación social,
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
313 porque todo lo que concierne al programa de control de revisiones es
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
314 una fusión.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
315 \end{itemize}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
316
503
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
317 Algunas personas se resisten a las herramientas distribuidas porque
1839fd383e50 translated a few subsections of intro
Igor TAmara <igor@tamarapatino.org>
parents: 502
diff changeset
318 desean mantener control completo sobre sus proyectos, y creen que las
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
319 herramientas centralizadas les dan tal control. En todo caso, si este
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
320 es su parecer, y usted publica sus repositorios de CVS o Subversion, hay
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
321 muchas herramientas disponibles que pueden obtener el historial
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
322 completo (aunque sea lentamente) y recrearlo en otro sitio que usted no
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
323 controla. Siendo así un control ilusorio, puesto que está impidiendo
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
324 la fluidez de colaboración en lugar de prevenir que alguien se sienta
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
325 impulsado a obtener una copia y hacer una bifurcación con su historial.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
326
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
327 \subsection{Ventajas para proyectos comerciales}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
328
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
329 Muchos proyectos comerciales tienen grupos de trabajo distribuidos
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
330 alrededor del globo. Quienes contribuyen y están lejos de un
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
331 repositorio central verán una ejecución más lenta de los comandos y tal
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
332 vez menos confiabilidad. Los sistemas de control de revisión
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
333 comerciales intentan amortiguar estos problemas con adiciones de
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
334 replicación remota que usualmente son muy costosos y complicados de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
335 administrar. Un sistema distribuido no padece estos problemas. Mejor
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
336 aún, puede colocar varios servidores autorizados, por ejemplo, uno por
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
337 sitio, de tal forma que no haya comunicación redundante entre
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
338 repositorios sobre enlaces de conexión costosos.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
339
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
340 Los sistemas de control de revisiones distribuidos tienden a ser poco
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
341 escalables. No es inusual que costosos sistemas centralizados caigan
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
342 ante la carga combinada de unas cuantas docenas de usuarios
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
343 concurrentes. De nuevo, las respuestas típicas de replicación tienden
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
344 a ser costosas y complejas de instalar y administrar. Dado que la
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
345 carga en un servidor central---si es que tiene uno---es muchas veces
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
346 menor con una herramienta distribuida (debido a que los datos están
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
347 replicados en todas partes), un solo servidor económico puede tratar
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
348 las necesidades de equipos mucho más grandes, y la replicación para
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
349 balancear la carga se vuelve cosa de guiones.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
350
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
351 Si tiene un empleado en el campo, se beneficiará grandemente de un
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
352 sistema distribuido de control de versiones al resolver problemas en
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
353 el sitio del cliente. La herramienta le permitirá generar
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
354 construcciones a la medida, probar diferentes arreglos de forma
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
355 independiente y buscar de forma eficiente las fuentes de fallos en el
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
356 historial y regresiones en los ambientes de los clientes, todo sin
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
357 necesidad de conectarse al servidor de su compañía.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
358
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
359 \section{¿Por qué elegir Mercurial?}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
360
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
361 Mercurial cuenta con un conjunto único de propiedades que lo hacen
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
362 una elección particularmente buena como sistema de control de
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
363 revisiones, puesto que:
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
364 \begin{itemize}
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
365 \item Es fácil de aprender y usar.
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
366 \item Es liviano.
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
367 \item Escala de forma excelente.
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
368 \item Es fácil de acondicionar.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
369 \end{itemize}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
370
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
371 Si los sistemas de control de revisiones le son familiares, debería
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
372 estar listo para usar Mercurial en menos de cinco minutos. Si no, sólo va a
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
373 tomar unos pocos minutos más. Las órdenes de Mercurial y su conjunto
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
374 de características son uniformes y consistentes generalmente, y basta
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
375 con que siga unas pocas reglas generales en lugar de un montón de
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
376 excepciones.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
377
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
378 En un proyecto pequeño, usted puede comenzar a trabajar con Mercurial en
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
379 pocos momentos. Crear nuevos cambios y ramas, transferir cambios (localmente
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
380 o por la red); y las operaciones relacionadas con el estado y el
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
381 historial son rápidas. Mercurial buscar ser ligero y no incomodar en su
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
382 camino combinando poca sobrecarga cognitiva con operaciones
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
383 asombrosamente rápidas.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
384
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
385 La utilidad de Mercurial no se limita a proyectos pequeños: está
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
386 siendo usado por proyectos con centenas de miles de contribuyentes,
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
387 cada uno conteniendo decenas de miles de ficheros y centenas de
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
388 megabytes de código fuente
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
389
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
390 Si la funcionalidad básica de Mercurial no es suficiente para usted,
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
391 es muy fácil extenderlo. Mercurial se comporta muy bien con tareas de
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
392 scripting y su limpieza interna junto con su implementación en Python
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
393 permiten añadir características fácilmente en forma de extensiones.
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
394 Hay un buen número de extensiones útiles y populares en este momento,
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
395 desde ayudar a identificar fallos hasta mejorar su desempeño.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
396
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
397 \section{Comparación de Mercurial con otras herramientas}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
398
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
399 Antes de leer, por favor tenga en cuenta que esta sección
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
400 necesariamente refleja mis propias experiencias, intereses y (tengo que
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
401 decirlo) mis preferencias. He usado cada una de las herramientas de
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
402 control de versiones listadas a continuación, y en muchos casos por
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
403 varios años.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
404
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
405
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
406 \subsection{Subversion}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
407
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
408 Subversion es una herramienta de control de revisiones muy popular,
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
409 desarrollada para reemplazar a CVS. Tiene una arquitectura
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
410 centralizada tipo cliente/servidor.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
411
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
412 Subversion y Mercurial tienen comandos con nombres similares para hacer
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
413 las mismas operaciones, por lo que si le son familiares en una, será
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
414 sencillo aprender a usar la otra. Ambas herramientas son portables en
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
415 todos los sistemas operativos populares.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
416
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
417 Antes de la versión 1.5, Subversion no tenía soporte para fusiones. En
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
418 el momento de la escritura, sus capcidades para llevar cuenta de las
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
419 funciones son nuevas,
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
420 \href{http://svnbook.red-bean.com/nightly/en/svn.branchmerge.advanced.html#svn.branchmerge.advanced.finalword}{complicadas
508
04ba1c7785ae Fixing build prevention, goofy translator. Taking a new chapter
Igor TAmara <igor@tamarapatino.org>
parents: 507
diff changeset
421 y poco estables\ndt{buggy}}.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
422
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
423 Mercurial tiene una ventaja considerable en desempeño sobre
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
424 Subversion en cualquier operación de control de revisiones que yo haya
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
425 medido. He medido sus ventajas con factores desde dos hasta seis veces
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
426 comparando con almacenamiento de ficheros \emph{ra\_local}
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
427 Subversion~1.4.3, el cual es el método de acceso más rápido. En los
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
428 escenarios más realistas incluyendo almacenamiento con la red de por
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
429 medio, Subversion se encuentra en desventaja aún mayor. Dado que casi
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
430 todas las órdenes de Subversion deben tratar con el servidor y
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
431 Subversion no tiene utilidades de replicación adecuadas, la capacidad
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
432 del servidor y el ancho de banda se convierten en cuellos de botella
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
433 para proyectos modestamente grandes.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
434
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
435 Adicionalmente, Subversion tiene un sobrecosto considerable en
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
436 almacenamiento para evitar transacciones por red en algunas
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
437 operaciones,
609
98fb436b58c1 corrected some typos
Javier Rojas <jerojasro@devnull.li>
parents: 608
diff changeset
438 tales como encontrar ficheros modificados (\texttt{status}) y desplegar
98fb436b58c1 corrected some typos
Javier Rojas <jerojasro@devnull.li>
parents: 608
diff changeset
439 información frente a la revisión actual (\texttt{diff}). Como
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
440 resultado, la copia de trabajo de Subversion termina siendo del mismo
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
441 tamaño o más grande que un repositorio de Mercurial y el directorio de
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
442 trabajo, a pesar de que el repositorio de Mercurial contiene el
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
443 historial completo del proyecto.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
444
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
445 Subversion tiene soporte amplio de otras herramientas. Mercurial por
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
446 ahora está bastante atrás en este aspecto. Esta diferencia está
508
04ba1c7785ae Fixing build prevention, goofy translator. Taking a new chapter
Igor TAmara <igor@tamarapatino.org>
parents: 507
diff changeset
447 disminuyendo, y algunas de las herramientas GUI\ndt{Interfaz de
506
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
448 Usuario Gráfica}, eclipsan sus equivalentes de Subversion. Al igual
8b564f6f57f2 Translating Subversion Vs. Mercurial
Igor TAmara <igor@tamarapatino.org>
parents: 504
diff changeset
449 que Mercurial, Subversion tiene un excelente manual de usuario.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
450
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
451 Dado que Subversion no almacena el historial de revisiones en el
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
452 cliente, es muy bueno para administrar proyectos que tienen muchos
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
453 ficheros binarios grandes y opacos. Si consigna cincuenta revisiones
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
454 de un fichero de 10MB que no es comprimible, el esapacio en el cliente
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
455 de Subversion se mantendrá constante mientras que el espacio usado por
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
456 cualquier Sistema Distribuido de Control de Revisiones crecerá
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
457 rápidamente en proporción con el número de revisiones, debido a que
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
458 las diferencias entre cada revisión es grande.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
459
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
460 Adicionalmente, generalmente es difícil o más bien, imposible mezclar
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
461 diferentes versiones de un fichero binario. La habilidad de Subversion
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
462 para permitirle al usuario poner una cerradura a un fichero, de modo
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
463 que tenga un permiso exclusivo para consignar cambios, puede ser una
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
464 ventaja significativa en un proyecto donde los ficheros binarios sean
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
465 usados ampliamente.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
466
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
467 Mercurial puede importar el historial de revisiones de un repositorio
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
468 de Subversion. También puede exportar el historial de revisiones a un
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
469 repositorio de Subversion. De esta forma es sencillo ``dar un
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
470 vistazo'' y usar Mercurial y Subversion en paralelo antes de decidirse
616
3f32047a3f25 changed all "de el" to "del"
Javier Rojas <jerojasro@devnull.li>
parents: 615
diff changeset
471 a dar el paso. La conversión del historial es incremental, de modo
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
472 que puede aplicar una conversión inicial, y después conversiones
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
473 pequeñas y adicionales posteriormente para traer nuevos cambios.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
474
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
475 \subsection{Git}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
476
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
477 Git es una herramienta distribuida de control de revisiones
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
478 desarrollada para administrar el arbol del kernel de Linux. Al igual
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
479 que Mercurial los principios de su diseño fueron influenciados por
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
480 Monotone.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
481
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
482 Git tiene un conjunto de órdenes muy grande; en la versión~1.5.0
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
483 ofrece~139 órdenes individuales. Tiene cierta reputación de ser
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
484 difícil de aprender. Comparado con Git, Mercurial tiene un fuerte
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
485 enfoque hacia la facilidad.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
486
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
487 En términos de rendimiento, Git es extremadamente rápido. En muchos
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
488 casos, es más rápido que Mercurial, por lo menos en Linux, mientras
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
489 que Mercurial se comporta mejor en otras operaciones. De todas
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
490 maneras en Windows, el desempeño y el nivel general de soporte que
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
491 ofrece Git, al momento de la escritura, está bastante atrás de
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
492 Mercurial.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
493
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
494 Mientras que el repositorio de Mercurial no requiere mantenimiento, el
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
495 repositorio de Git requiere frecuentes ``reempaquetados'' de sus metadatos.
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
496 Sin estos, el desempeño se degrada y el uso de espacio crece rápidamente. Un
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
497 servidor que contenga repositorios de Git que no sean reempacados
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
498 rigurosa y frecuentemente requerirá trabajo intenso de disco durante
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
499 las copias de seguridad, y ha habido situaciones en copias de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
500 seguridad diaria que toman más de~24 horas como resultado. Un
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
501 repositorio recién reempacado de Git es un poco más pequeño que un
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
502 repositorio de Mercurial, pero un repositorio sin reempacar es varios
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
503 órdenes de magnitud más grande.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
504
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
505 El corazón de Git está escrito en C. Muchas órdenes de Git están
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
506 implementadas como guiones de línea de comandos o de Perl y la calidad de esos
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
507 guiones varía ampliamente. He encontrado muchas situaciones en las
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
508 cuales los guiones no tuvieron en cuenta la presencia de errores que
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
509 podrían haber sido fatales.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
510
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
511 Mercurial puede importar el historial de revisiones de un repositorio
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
512 de Git.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
513
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
514 \subsection{CVS}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
515
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
516 CVS es probablemente la herramienta de control de revisiones más
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
517 ampliamente usada en el planeta. Debido a su edad y su poca pulcritud
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
518 interna, ha sido ligeramente mantenida en muchos años.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
519
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
520 Tiene una arquitectura centralizada cliente/servidor. No agrupa
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
521 cambios relacionados en consignaciones atómicas, pemitiendo que con
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
522 facilidad la gente ``rompa la construcción'': una persona puede
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
523 consignar exitósamente parte del cambio y estar bloqueada por la
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
524 necesidad de una mezcla, forzando a otras personas a ver solamente una
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
525 porción del trabajo que estaban buscando hacer. Esto afecta también
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
526 la forma como usted trabaja con el historial del proyecto. Si quiere
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
527 ver todas las modificaciones que alguien hizo como parte de una tarea,
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
528 necesitará inspeccionar manualmente las descripciones y las marcas de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
529 tiempo de cambio de cada fichero involucrado (esto, si usted saber
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
530 cuáles eran tales ficheros).
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
531
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
532 CVS tiene una noción confusa de etiquetas y ramas que yo no trataría
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
533 incluso de describir. No soporta renombramiento de ficheros o
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
534 directorios adecuadamente, facilitando el corromper un
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
535 repositorio. Casi no tiene chequeo de consistencia interna, por lo
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
536 tanto es casi imposible identificar por que o cómo se corrompió un
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
537 repositorio. Yo no recomendaría un repositorio de CVS para proyecto
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
538 alguno, ni existente ni nuevo.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
539
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
540 Mercurial puede importar el historial de revisiones de CVS. De todas
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
541 maneras hay ciertas precauciones que aplican; las cuales también son
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
542 necesarias para cualquier herramienta importadora de historial de
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
543 CVS. Debido a la falta de atomicidad de cambios y el no versionamiento
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
544 de la jerarquía del sistema de ficheros, es imposible reconstruir
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
545 completamente el historial de CVS con precisión; hay cierto trabajo de
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
546 conjetura involucrado y los renombramientos tampoco se
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
547 mostrarán. Debido a que gran parte de la administración avanzada de
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
548 CVS tiene que hacerse manualmente y por lo tanto es proclive al error,
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
549 es común que los importadores de CVS encuentren muchos problemas con
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
550 repositorios corruptos (marcas de tiempo totalmente desubicadas y
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
551 ficheros que han permanecido con candados por más de una década son
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
552 dos de los problemas menos interesantes de los que puedo retomar de mi
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
553 experiencia personal).
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
554
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
555 Mercurial puede importar el historial de revisiones de un repositorio
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
556 CVS.
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
557
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
558 \subsection{Herramientas comerciales}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
559
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
560 Perforce tiene una arquitectura centralizada cliente/servidor sin
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
561 almacenamiento de dato alguno de caché en el lado del cliente. A diferencia de
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
562 las herramientas modernas de control de revisiones, Perforce requiere
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
563 que un usuario ejecute un comando para informar al servidor acerca de
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
564 todo fichero que se vaya a editar.
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
565
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
566 El rendimiento de Perforce es muy bueno para equipos pequeños, pero se
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
567 degrada rápidamente cuando el número de usuarios va más allá de pocas
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
568 docenas. Instalaciones modestamente grandes de Perforce requiere la
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
569 organización de proxies para soportar la carga que sus usuarios generan.
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
570
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
571 \subsection{Elegir una herramienta de control de revisiones}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
572
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
573 Con la excepción de CVS, toda las herramientas que se han listado
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
574 anteriormente tienen fortalezas únicas que las hacen valiosas de acuerdo al
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
575 tipo de trabajo. No hay una única herramienta de control de revisiones
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
576 que sea la mejor en todas las situaciones.
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
577
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
578 Por ejemplo, Subversion es una buena elección para trabajar con
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
579 edición frecuente de ficheros binarios, debido a su naturaleza
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
580 centralizada y soporte para poner candados a ficheros.
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
581
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
582 Personalmente encuentro las propiedades de simplicidad, desempeño, y
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
583 buen soporte de fusiones de Mercurial una combinación llamativa que ha
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
584 dado buenos frutos por varios años.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
585
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
586
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
587 \section{Migrar de otra herramienta hacia Mercurial}
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
588
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
589 Mercurial viene con una extensión llamada \hgext{convert}, que puede
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
590 importar historiales de revisiones de forma incremental desde varias
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
591 herramientas de control de revisiones. Por ``incremental'', quiero
615
9da096de3c52 changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents: 609
diff changeset
592 decir que puede migrar toda el historial de un proyecto en una primera
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
593 instancia y después volver a ejecutar la migración posteriormente para
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
594 obtener los nuevos cambios que han sucedido después de la migración
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
595 inicial.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
596
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
597 A continuación presentamos las herramientas de revisiones que soporta
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
598 el comando \hgext{convert}:
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
599 \begin{itemize}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
600 \item Subversion
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
601 \item CVS
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
602 \item Git
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
603 \item Darcs
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
604 \end{itemize}
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
605
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
606 Adicionalmente, \hgext{convert} puede exportar cambios de Mercurial
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
607 hacia Subversion. Lo que hace posible probar Subversion y Mercurial
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
608 en paralelo antes de lanzarse a un migración total, sin arriesgarse a
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
609 perder trabajo alguno.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
610
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
611 El comando \hgxcmd{conver}{convert} es sencillo de usar. Basta con
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
612 apuntarlo hacia la ruta o el URL del repositorio fuente, opcionalmente
507
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
613 darle el nombre del nombre del repositorio destino y comenzará a hacer
56914d368af4 Finished translation of intro to spanish
Igor TAmara <igor@tamarapatino.org>
parents: 506
diff changeset
614 su trabajo. Después de la conversión inicial, basta con invocar de
608
e98a8c3afcef finished revision of intro.tex. there are some standing issues yet, though
Javier Rojas <jerojasro@devnull.li>
parents: 575
diff changeset
615 nuevo el comando para importar cambios nuevos.
501
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
616
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
617
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
618 %%% Local Variables:
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
619 %%% mode: latex
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
620 %%% TeX-master: "00book"
b05e35d641e4 Copying the files from en to es and taking intro chapter
Igor TAmara <igor@tamarapatino.org>
parents: 432
diff changeset
621 %%% End: