Mercurial > hgbook
annotate es/tour-merge.tex @ 748:d13c7c706a58
Merge with http://hg.serpentine.com/mercurial/book
author | Dongsheng Song <dongsheng.song@gmail.com> |
---|---|
date | Fri, 20 Mar 2009 15:40:06 +0800 |
parents | 3f32047a3f25 |
children |
rev | line source |
---|---|
480 | 1 \chapter{Una gira de Mercurial: fusionar trabajo} |
435 | 2 \label{chap:tour-merge} |
3 | |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
4 Hasta ahora hemos cubierto cómo clonar un repositorio, hacer cambios, |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
5 y jalar o empujar dichos cambios de un repositorio a otro. Nuestro |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
6 siguiente paso es \emph{fusionar} cambios de repositorios separados. |
435 | 7 |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
8 % TODO cambié streams por líneas. check please |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
9 \section{Fusionar líneas de trabajo} |
435 | 10 |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
11 Fusionar es una parte fundamental de trabajar con una herramienta |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
12 de control distribuido de versiones. |
435 | 13 \begin{itemize} |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
14 \item Alicia y Roberto tienen cada uno una copia personal del |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
15 repositorio de un proyecto en el que están trabajando. Alicia |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
16 arregla un fallo en su repositorio; Roberto añade una nueva |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
17 característica en el suyo. Ambos desean que el repositorio |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
18 compartido contenga el arreglo del fallo y la nueva |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
19 característica. |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
20 \item Frecuentemente trabajo en varias tareas diferentes en un mismo |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
21 proyecto al mismo tiempo, cada una aislada convenientemente de las |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
22 otras en su propio repositorio. Trabajar de esta manera significa |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
23 que a menudo debo fusionar una parte de mi propio trabajo con |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
24 otra. |
435 | 25 \end{itemize} |
26 | |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
27 Como fusionar es una operación tan necesaria y común, Mercurial la |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
28 facilita. Revisemos el proceso. Empezaremos clonando (otro) |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
29 % TODO poner interrogante de apertura |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
30 repositorio (ve lo seguido que aparecen?) y haciendo un cambio en él. |
435 | 31 \interaction{tour.merge.clone} |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
32 Ahora deberíamos tener dos copias de \filename{hello.c} con contenidos |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
33 diferentes. El historial de los dos repositorios diverge ahora, como |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
34 se ilustra en la figura~\ref{fig:tour-merge:sep-repos}. |
435 | 35 \interaction{tour.merge.cat} |
36 | |
37 \begin{figure}[ht] | |
38 \centering | |
39 \grafix{tour-merge-sep-repos} | |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
40 \caption{Historial reciente divergente de los repositorios |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
41 \dirname{my-hello} y \dirname{my-new-hello}} |
435 | 42 \label{fig:tour-merge:sep-repos} |
43 \end{figure} | |
44 | |
482
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
45 Ya sabemos que jalar los cambios desde nuestro repositorio |
772b30049b80
translated a couple of paragraphs
Javier Rojas <jerojasro@devnull.li>
parents:
480
diff
changeset
|
46 \dirname{my-hello} no tendrá efecto en el directorio de trabajo. |
435 | 47 \interaction{tour.merge.pull} |
483
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
48 Sin embargo, el comando \hgcmd{pull} dice algo acerca de |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
49 ``frentes''\ndt{El autor se refiere a \emph{heads} aquí.}. |
435 | 50 |
483
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
51 \subsection{Conjuntos de cambios de frentes} |
435 | 52 |
483
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
53 Un frente es un cambio que no tiene descendientes, o hijos, como |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
54 también se les conoce. La revisión de punta es, por tanto, un frente, |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
55 porque la revisión más reciente en un repositorio no tiene ningún |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
56 % TODO cambio en la redacción de la frase, pero espero que conserve el |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
57 % sentido. Querido human@, apruebe o corrija :D |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
58 hijo. Sin embargo, un repositorio puede contener más de un frente. |
435 | 59 |
60 \begin{figure}[ht] | |
61 \centering | |
62 \grafix{tour-merge-pull} | |
483
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
63 \caption{Contenidos del repositorio después de jalar |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
64 \dirname{my-hello} a \dirname{my-new-hello}} |
435 | 65 \label{fig:tour-merge:pull} |
66 \end{figure} | |
67 | |
483
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
68 En la figura~\ref{fig:tour-merge:pull} usted puede ver el efecto que |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
69 tiene jalar los cambios de \dirname{my-hello} a \dirname{my-new-hello}. |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
70 El historial que ya existía en \dirname{my-new-hello} se mantiene |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
71 intacto, pero fue añadida una nueva revisión. Refiriéndonos a la |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
72 figura~\ref{fig:tour-merge:sep-repos}, podemos ver que el \emph{ID del |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
73 conjunto de cambios} se mantiene igual en el nuevo repositorio, pero |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
74 el \emph{número de revisión} ha cambiado. (Incidentalmente, éste es un |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
75 buen ejemplo de porqué no es seguro usar números de revisión cuando se |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
76 habla de conjuntos de cambios). Podemos ver los frentes en un |
7f1572c365d2
translated up to section 2.1.1, included
Javier Rojas <jerojasro@devnull.li>
parents:
482
diff
changeset
|
77 repositorio usando el comando \hgcmd{heads}\ndt{Frentes.}. |
435 | 78 \interaction{tour.merge.heads} |
79 | |
484
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
80 \subsection{Hacer la fusión} |
435 | 81 |
484
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
82 % TODO poner interrogante de apertura |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
83 Qué pasa si tratamos de usar el comando usual, \hgcmd{update}, para |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
84 actualizar el nuevo frente? |
435 | 85 \interaction{tour.merge.update} |
484
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
86 Mercurial nos indica que el comando \hgcmd{update} no hará la fusión; |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
87 no actualizará el directorio de trabajo cuando considera que lo que |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
88 deseamos hacer es una fusión, a menos que lo obliguemos a hacerlo. |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
89 En vez de \hgcmd{update}, usamos el comando \hgcmd{merge} para hacer |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
90 la fusión entre los dos frentes. |
435 | 91 \interaction{tour.merge.merge} |
92 | |
93 \begin{figure}[ht] | |
94 \centering | |
95 \grafix{tour-merge-merge} | |
484
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
96 \caption{Directorio de trabajo y repositorio durante la fusión, y |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
97 consignación consecuente} |
435 | 98 \label{fig:tour-merge:merge} |
99 \end{figure} | |
100 | |
484
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
101 Esto actualiza el directorio de trabajo, de tal forma que contenga los |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
102 cambios de \emph{ambos} frentes, lo que se ve reflejado tanto en la |
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
103 salida de \hgcmd{parents} como en los contenidos de \filename{hello.c}. |
435 | 104 \interaction{tour.merge.parents} |
105 | |
484
0abd3d78172e
finished translation of a figure
Javier Rojas <jerojasro@devnull.li>
parents:
483
diff
changeset
|
106 \subsection{Consignar los resultados de la fusión} |
435 | 107 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
108 Siempre que hacemos una fusión, \hgcmd{parents} mostrará dos padres |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
109 hasta que consignemos (\hgcmd{commit}) los resultados de la fusión. |
435 | 110 \interaction{tour.merge.commit} |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
111 Ahora tenemos una nueva revisión de punta; note que tiene \emph{los |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
112 dos} frentes anteriores como sus padres. Estos son las mismas |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
113 revisiones que mostró previamente el comando \hgcmd{parents}. |
435 | 114 \interaction{tour.merge.tip} |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
115 En la figura~\ref{fig:tour-merge:merge} usted puede apreciar una |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
116 representación de lo que pasa en el directorio de trabajo durante la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
117 fusión cuando se hace la consignación. Durante la fusión, el |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
118 directorio de trabajo tiene dos conjuntos de cambios como sus padres, |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
119 y éstos se vuelven los padres del nuevo conjunto de cambios. |
435 | 120 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
121 \section{Fusionar cambios con conflictos} |
435 | 122 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
123 La mayoría de las fusiones son algo simple, pero a veces usted se |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
124 encontrará fusionando cambios donde más de uno de ellos afecta las |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
125 mismas secciones de los mismos ficheros. A menos que ambas |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
126 modificaciones sean idénticas, el resultado es un \emph{conflicto}, en |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
127 donde usted debe decidir cómo reconciliar ambos cambios y producir un |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
128 resultado coherente. |
435 | 129 |
130 \begin{figure}[ht] | |
131 \centering | |
132 \grafix{tour-merge-conflict} | |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
133 \caption{Cambios con conflictos a un documento} |
435 | 134 \label{fig:tour-merge:conflict} |
135 \end{figure} | |
136 | |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
137 La figura~\ref{fig:tour-merge:conflict} ilustra un ejemplo con dos |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
138 cambios generando conflictos en un documento. Empezamos con una sola |
616
3f32047a3f25
changed all "de el" to "del"
Javier Rojas <jerojasro@devnull.li>
parents:
615
diff
changeset
|
139 versión del fichero; luego hicimos algunos cambios; mientras tanto, |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
140 alguien más hizo cambios diferentes en el mismo texto. Lo que debemos |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
141 hacer para resolver el conflicto causado por ambos cambios es decidir |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
142 cómo debe quedar finalmente el fichero. |
435 | 143 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
144 Mercurial no tiene ninguna utilidad integrada para manejar conflictos. |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
145 En vez de eso, ejecuta un programa externo llamado \command{hgmerge}. |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
146 Es un guión de línea de comandos que es instalado junto con Mercurial; |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
147 usted puede modificarlo para que se comporte como usted lo desee. Por |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
148 defecto, lo que hace es tratar de encontrar una de varias herramientas |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
149 para fusionar que es probable que estén instaladas en su sistema. |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
150 Primero se intenta con unas herramientas para fusionar cambios |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
151 automáticamente; si esto no tiene éxito (porque la fusión demanda |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
152 una guía humana) o dichas herramientas no están presentes, el guión |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
153 intenta con herramientas gráficas para fusionar. |
435 | 154 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
155 También es posible hacer que Mercurial ejecute otro programa o guión |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
156 en vez de \command{hgmerge}, definiendo la variable de entorno |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
157 \envar{HGMERGE} con el nombre del programa de su preferencia. |
435 | 158 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
159 \subsection{Usar una herramienta gráfica para fusión} |
435 | 160 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
161 Mi herramienta favorita para hacer fusiones es \command{kdiff3}, y la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
162 usaré para describir las características comunes de las herramientas |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
163 gráficas para hacer fusiones. Puede ver una captura de pantalla de |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
164 \command{kdiff3} ejecutándose, en la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
165 figura~\ref{fig:tour-merge:kdiff3}. El tipo de fusión que la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
166 herramienta hace se conoce como \emph{fusión de tres vías}, porque hay |
615
9da096de3c52
changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents:
491
diff
changeset
|
167 tres versiones diferentes del fichero en que estamos interesados. |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
168 Debido a esto la herramienta divide la parte superior de la ventana en |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
169 tres paneles. |
435 | 170 \begin{itemize} |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
171 \item A la izquierda está la revisión \emph{base} del fichero, p.ej.~la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
172 versión más reciente de la que descienden las dos versiones que |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
173 estamos tratando de fusionar. |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
174 \item En la mitad está ``nuestra'' versión del fichero, con las |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
175 modificaciones que hemos hecho. |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
176 \item A la derecha está la versión del fichero de ``ellos'', la que |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
177 forma parte del conjunto de cambios que estamos tratando de |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
178 fusionar. |
435 | 179 \end{itemize} |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
180 En el panel inferior se encuentra el \emph{resultado} actual de la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
181 fusión. Nuestra tarea es reemplazar todo el texto rojo, que muestra |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
182 los conflictos sin resolver, con una fusión adecuada de ``nuestra'' |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
183 versión del fichero y la de ``ellos''. |
435 | 184 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
185 Los cuatro paneles están \emph{enlazados}; si avanzamos vertical o |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
186 horizontalmente en cualquiera de ellos, los otros son actualizados |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
187 para mostrar las secciones correspondientes del fichero que tengan |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
188 asociado. |
435 | 189 |
190 \begin{figure}[ht] | |
191 \centering | |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
192 \grafix[width=\textwidth]{kdiff3} |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
193 \caption{Usando \command{kdiff3} para fusionar versiones de un |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
194 fichero} |
435 | 195 \label{fig:tour-merge:kdiff3} |
196 \end{figure} | |
197 | |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
198 En cada conflicto del fichero podemos escoger resolverlo usando |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
199 cualquier combinación del texto de la revisión base, la nuestra, o la |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
200 de ellos. También podemos editar manualmente el fichero en que queda |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
201 la fusión, si es necesario hacer cambios adicionales. |
435 | 202 |
489
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
203 Hay \emph{muchas} herramientas para fusionar ficheros disponibles. Se |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
204 diferencian en las plataformas para las que están disponibles, y en |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
205 sus fortalezas y debilidades particulares. La mayoría están afinadas |
c3a867bba34a
modified definitions to allow optional arguments for the inclusion of images.
Javier Rojas <jerojasro@devnull.li>
parents:
484
diff
changeset
|
206 para fusionar texto plano, mientras que otras están pensadas para |
615
9da096de3c52
changed "historia" to "historial".
Javier Rojas <jerojasro@devnull.li>
parents:
491
diff
changeset
|
207 formatos de ficheros especializados (generalmente XML). |
435 | 208 |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
209 % TODO traduje "worked" como "real" |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
210 \subsection{Un ejemplo real} |
435 | 211 |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
212 En este ejemplo, reproduciremos el historial de modificaciones al |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
213 fichero de la figura~\ref{fig:tour-merge:conflict} mostrada |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
214 anteriormente. Empecemos creando un repositorio con la versión base |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
215 de nuestro documento. |
435 | 216 \interaction{tour-merge-conflict.wife} |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
217 Clonaremos el repositorio y haremos un cambio al fichero. |
435 | 218 \interaction{tour-merge-conflict.cousin} |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
219 Y haremos otro clon, para simular a alguien más haciendo un cambio al |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
220 mismo fichero. (Esto introduce la idea de que no es tan inusual hacer |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
221 fusiones consigo mismo, cuando usted aísla tareas en repositorios |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
222 separados, y de hecho encuentra conflictos al hacerlo.) |
435 | 223 \interaction{tour-merge-conflict.son} |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
224 Ahora que tenemos dos versiones diferentes de nuestro fichero, |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
225 crearemos un entorno adecuado para hacer la fusión. |
435 | 226 \interaction{tour-merge-conflict.pull} |
227 | |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
228 En este ejemplo, no usaré el comando normal de Mercurial para hacer la |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
229 fusión (\command{hgmerge}), porque lanzaría mi linda herramienta |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
230 automatizada para correr ejemplos dentro de una interfaz gráfica de |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
231 usuario. En vez de eso, definiré la variable de entorno |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
232 \envar{HGMERGE} para indicarle a Mercurial que use el comando |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
233 \command{merge}. Este comando forma parte de la instalación base de |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
234 muchos sistemas Unix y similares. Si usted está ejecutando este |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
235 ejemplo en su computador, no se moleste en definir \envar{HGMERGE}. |
435 | 236 \interaction{tour-merge-conflict.merge} |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
237 Debido a que \command{merge} no puede resolver los conflictos que |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
238 aparecen, él deja \emph{marcadores de fusión} en el fichero con |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
239 conflictos, indicando si provienen de nuestra versión o de la de |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
240 ellos. |
435 | 241 |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
242 Mercurial puede saber ---por el código de salida del comando |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
243 \command{merge}--- que no fue posible hacer la fusión exitosamente, |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
244 así que nos indica qué comandos debemos ejecutar si queremos rehacer |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
245 la fusión. Esto puede ser útil si, por ejemplo, estamos ejecutando una |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
246 herramienta gráfica de fusión y salimos de ella porque nos confundimos |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
247 o cometimos un error. |
435 | 248 |
490
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
249 Si la fusión ---automática o manual--- falla, no hay nada que nos |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
250 impida ``arreglar'' los ficheros afectados por nosotros mismos, y |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
251 consignar los resultados de nuestra fusión: |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
252 % TODO este mercurial no tiene el comando resolve. Revisar si sigue |
53b4a0d0052e
finished translation of section 2.2
Javier Rojas <jerojasro@devnull.li>
parents:
489
diff
changeset
|
253 % siendo necesario |
435 | 254 \interaction{tour-merge-conflict.commit} |
255 | |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
256 \section{Simplificar el ciclo jalar-fusionar-consignar} |
435 | 257 \label{sec:tour-merge:fetch} |
258 | |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
259 El proceso de fusionar cambios delineado anteriomente es directo, pero |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
260 requiere la ejecución de tres comandos en sucesión. |
435 | 261 \begin{codesample2} |
262 hg pull | |
263 hg merge | |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
264 hg commit -m 'Fusionados cambios remotos' |
435 | 265 \end{codesample2} |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
266 En la consignación final usted debe proveer un mensaje adecuado, que |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
267 casi siempre es un fragmento de texto ``de relleno'' carente de valor |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
268 particular. |
435 | 269 |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
270 Sería agradable reducir la cantidad de pasos necesarios, si fuera |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
271 posible. De hecho, Mercurial es distribuido junto con una extensión |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
272 llamada \hgext{fetch}\ndt{Descargar, traer.} que hace precisamente |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
273 esto. |
435 | 274 |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
275 Mercurial cuenta con un mecanismo de extensión flexible que le permite |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
276 % TODO lets people => permite a usuarios |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
277 a sus usuarios extender su funcionalidad, manteniendo el núcleo de |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
278 Mercurial pequeño y fácil de manejar. Algunas extensiones añaden |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
279 nuevos comandos que usted puede usar desde la línea de comandos, |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
280 mientras que otros funcionan ``tras bambalinas'', por ejemplo, |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
281 añadiendo funcionalidad al servidor. |
435 | 282 |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
283 La extensión \hgext{fetch} añade un comando llamado, no |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
284 sorpresivamente, \hgcmd{fetch}. Esta extensión actúa como una |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
285 combinación de \hgcmd{pull}, \hgcmd{update} y \hgcmd{merge}. Empieza |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
286 jalando cambios de otro repositorio al repositorio actual. Si |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
287 encuentra que los cambios añaden un nuevo frente en el repositorio |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
288 actual, inicia una fusión, y luego consigna el resultado de la misma |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
289 con un mensaje generado automáticamente. Si no se añadieron nuevos |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
290 frentes, actualiza el directorio de trabajo con el nuevo conjunto de |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
291 cambios de punta. |
435 | 292 |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
293 Activar la extensión \hgext{fetch} es fácil. Edite su |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
294 \sfilename{.hgrc}, y vaya a (o cree) la sección |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
295 \rcsection{extensions}. Luego añada una línea que diga simplemente |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
296 ``\Verb+fetch +''. |
435 | 297 \begin{codesample2} |
298 [extensions] | |
299 fetch = | |
300 \end{codesample2} | |
491
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
301 (Normalmente, a la derecha del ``\texttt{=}'' debería aparecer la |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
302 ubicación de la extensión, pero como el comando \hgext{fetch} es parte |
4fa646914ff8
finished translation of chapter 2, and updated project status
Javier Rojas <jerojasro@devnull.li>
parents:
490
diff
changeset
|
303 de la distribución estándar, Mercurial sabe dónde buscarla.) |
435 | 304 |
305 %%% Local Variables: | |
306 %%% mode: latex | |
307 %%% TeX-master: "00book" | |
308 %%% End: |