annotate es/tour-merge.tex @ 483:7f1572c365d2

translated up to section 2.1.1, included
author Javier Rojas <jerojasro@devnull.li>
date Fri, 31 Oct 2008 00:19:04 -0500
parents 772b30049b80
children 0abd3d78172e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
480
7ca1186c422f testing push
Javier Rojas <jerojasro@devnull.li>
parents: 435
diff changeset
1 \chapter{Una gira de Mercurial: fusionar trabajo}
435
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
2 \label{chap:tour-merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
25 \end{itemize}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
35 \interaction{tour.merge.cat}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
36
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
37 \begin{figure}[ht]
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
38 \centering
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
42 \label{fig:tour-merge:sep-repos}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
43 \end{figure}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
59
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
60 \begin{figure}[ht]
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
61 \centering
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
65 \label{fig:tour-merge:pull}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
66 \end{figure}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
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
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
78 \interaction{tour.merge.heads}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
79
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
80 \subsection{Performing the merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
81
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
82 What happens if we try to use the normal \hgcmd{update} command to
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
83 update to the new tip?
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
84 \interaction{tour.merge.update}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
85 Mercurial is telling us that the \hgcmd{update} command won't do a
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
86 merge; it won't update the working directory when it thinks we might
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
87 be wanting to do a merge, unless we force it to do so. Instead, we
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
88 use the \hgcmd{merge} command to merge the two heads.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
89 \interaction{tour.merge.merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
90
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
91 \begin{figure}[ht]
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
92 \centering
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
93 \grafix{tour-merge-merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
94 \caption{Working directory and repository during merge, and
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
95 following commit}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
96 \label{fig:tour-merge:merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
97 \end{figure}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
98
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
99 This updates the working directory so that it contains changes from
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
100 \emph{both} heads, which is reflected in both the output of
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
101 \hgcmd{parents} and the contents of \filename{hello.c}.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
102 \interaction{tour.merge.parents}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
103
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
104 \subsection{Committing the results of the merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
105
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
106 Whenever we've done a merge, \hgcmd{parents} will display two parents
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
107 until we \hgcmd{commit} the results of the merge.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
108 \interaction{tour.merge.commit}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
109 We now have a new tip revision; notice that it has \emph{both} of
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
110 our former heads as its parents. These are the same revisions that
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
111 were previously displayed by \hgcmd{parents}.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
112 \interaction{tour.merge.tip}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
113 In figure~\ref{fig:tour-merge:merge}, you can see a representation of
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
114 what happens to the working directory during the merge, and how this
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
115 affects the repository when the commit happens. During the merge, the
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
116 working directory has two parent changesets, and these become the
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
117 parents of the new changeset.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
118
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
119 \section{Merging conflicting changes}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
120
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
121 Most merges are simple affairs, but sometimes you'll find yourself
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
122 merging changes where each modifies the same portions of the same
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
123 files. Unless both modifications are identical, this results in a
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
124 \emph{conflict}, where you have to decide how to reconcile the
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
125 different changes into something coherent.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
126
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
127 \begin{figure}[ht]
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
128 \centering
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
129 \grafix{tour-merge-conflict}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
130 \caption{Conflicting changes to a document}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
131 \label{fig:tour-merge:conflict}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
132 \end{figure}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
133
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
134 Figure~\ref{fig:tour-merge:conflict} illustrates an instance of two
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
135 conflicting changes to a document. We started with a single version
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
136 of the file; then we made some changes; while someone else made
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
137 different changes to the same text. Our task in resolving the
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
138 conflicting changes is to decide what the file should look like.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
139
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
140 Mercurial doesn't have a built-in facility for handling conflicts.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
141 Instead, it runs an external program called \command{hgmerge}. This
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
142 is a shell script that is bundled with Mercurial; you can change it to
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
143 behave however you please. What it does by default is try to find one
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
144 of several different merging tools that are likely to be installed on
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
145 your system. It first tries a few fully automatic merging tools; if
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
146 these don't succeed (because the resolution process requires human
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
147 guidance) or aren't present, the script tries a few different
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
148 graphical merging tools.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
149
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
150 It's also possible to get Mercurial to run another program or script
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
151 instead of \command{hgmerge}, by setting the \envar{HGMERGE}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
152 environment variable to the name of your preferred program.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
153
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
154 \subsection{Using a graphical merge tool}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
155
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
156 My preferred graphical merge tool is \command{kdiff3}, which I'll use
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
157 to describe the features that are common to graphical file merging
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
158 tools. You can see a screenshot of \command{kdiff3} in action in
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
159 figure~\ref{fig:tour-merge:kdiff3}. The kind of merge it is
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
160 performing is called a \emph{three-way merge}, because there are three
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
161 different versions of the file of interest to us. The tool thus
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
162 splits the upper portion of the window into three panes:
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
163 \begin{itemize}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
164 \item At the left is the \emph{base} version of the file, i.e.~the
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
165 most recent version from which the two versions we're trying to
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
166 merge are descended.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
167 \item In the middle is ``our'' version of the file, with the contents
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
168 that we modified.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
169 \item On the right is ``their'' version of the file, the one that
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
170 from the changeset that we're trying to merge with.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
171 \end{itemize}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
172 In the pane below these is the current \emph{result} of the merge.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
173 Our task is to replace all of the red text, which indicates unresolved
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
174 conflicts, with some sensible merger of the ``ours'' and ``theirs''
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
175 versions of the file.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
176
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
177 All four of these panes are \emph{locked together}; if we scroll
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
178 vertically or horizontally in any of them, the others are updated to
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
179 display the corresponding sections of their respective files.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
180
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
181 \begin{figure}[ht]
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
182 \centering
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
183 \grafix{kdiff3}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
184 \caption{Using \command{kdiff3} to merge versions of a file}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
185 \label{fig:tour-merge:kdiff3}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
186 \end{figure}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
187
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
188 For each conflicting portion of the file, we can choose to resolve
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
189 the conflict using some combination of text from the base version,
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
190 ours, or theirs. We can also manually edit the merged file at any
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
191 time, in case we need to make further modifications.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
192
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
193 There are \emph{many} file merging tools available, too many to cover
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
194 here. They vary in which platforms they are available for, and in
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
195 their particular strengths and weaknesses. Most are tuned for merging
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
196 files containing plain text, while a few are aimed at specialised file
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
197 formats (generally XML).
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
198
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
199 \subsection{A worked example}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
200
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
201 In this example, we will reproduce the file modification history of
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
202 figure~\ref{fig:tour-merge:conflict} above. Let's begin by creating a
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
203 repository with a base version of our document.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
204 \interaction{tour-merge-conflict.wife}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
205 We'll clone the repository and make a change to the file.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
206 \interaction{tour-merge-conflict.cousin}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
207 And another clone, to simulate someone else making a change to the
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
208 file. (This hints at the idea that it's not all that unusual to merge
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
209 with yourself when you isolate tasks in separate repositories, and
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
210 indeed to find and resolve conflicts while doing so.)
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
211 \interaction{tour-merge-conflict.son}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
212 Having created two different versions of the file, we'll set up an
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
213 environment suitable for running our merge.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
214 \interaction{tour-merge-conflict.pull}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
215
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
216 In this example, I won't use Mercurial's normal \command{hgmerge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
217 program to do the merge, because it would drop my nice automated
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
218 example-running tool into a graphical user interface. Instead, I'll
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
219 set \envar{HGMERGE} to tell Mercurial to use the non-interactive
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
220 \command{merge} command. This is bundled with many Unix-like systems.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
221 If you're following this example on your computer, don't bother
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
222 setting \envar{HGMERGE}.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
223 \interaction{tour-merge-conflict.merge}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
224 Because \command{merge} can't resolve the conflicting changes, it
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
225 leaves \emph{merge markers} inside the file that has conflicts,
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
226 indicating which lines have conflicts, and whether they came from our
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
227 version of the file or theirs.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
228
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
229 Mercurial can tell from the way \command{merge} exits that it wasn't
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
230 able to merge successfully, so it tells us what commands we'll need to
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
231 run if we want to redo the merging operation. This could be useful
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
232 if, for example, we were running a graphical merge tool and quit
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
233 because we were confused or realised we had made a mistake.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
234
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
235 If automatic or manual merges fail, there's nothing to prevent us from
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
236 ``fixing up'' the affected files ourselves, and committing the results
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
237 of our merge:
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
238 \interaction{tour-merge-conflict.commit}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
239
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
240 \section{Simplifying the pull-merge-commit sequence}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
241 \label{sec:tour-merge:fetch}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
242
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
243 The process of merging changes as outlined above is straightforward,
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
244 but requires running three commands in sequence.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
245 \begin{codesample2}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
246 hg pull
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
247 hg merge
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
248 hg commit -m 'Merged remote changes'
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
249 \end{codesample2}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
250 In the case of the final commit, you also need to enter a commit
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
251 message, which is almost always going to be a piece of uninteresting
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
252 ``boilerplate'' text.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
253
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
254 It would be nice to reduce the number of steps needed, if this were
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
255 possible. Indeed, Mercurial is distributed with an extension called
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
256 \hgext{fetch} that does just this.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
257
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
258 Mercurial provides a flexible extension mechanism that lets people
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
259 extend its functionality, while keeping the core of Mercurial small
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
260 and easy to deal with. Some extensions add new commands that you can
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
261 use from the command line, while others work ``behind the scenes,''
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
262 for example adding capabilities to the server.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
263
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
264 The \hgext{fetch} extension adds a new command called, not
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
265 surprisingly, \hgcmd{fetch}. This extension acts as a combination of
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
266 \hgcmd{pull}, \hgcmd{update} and \hgcmd{merge}. It begins by pulling
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
267 changes from another repository into the current repository. If it
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
268 finds that the changes added a new head to the repository, it begins a
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
269 merge, then commits the result of the merge with an
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
270 automatically-generated commit message. If no new heads were added,
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
271 it updates the working directory to the new tip changeset.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
272
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
273 Enabling the \hgext{fetch} extension is easy. Edit your
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
274 \sfilename{.hgrc}, and either go to the \rcsection{extensions} section
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
275 or create an \rcsection{extensions} section. Then add a line that
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
276 simply reads ``\Verb+fetch +''.
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
277 \begin{codesample2}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
278 [extensions]
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
279 fetch =
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
280 \end{codesample2}
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
281 (Normally, on the right-hand side of the ``\texttt{=}'' would appear
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
282 the location of the extension, but since the \hgext{fetch} extension
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
283 is in the standard distribution, Mercurial knows where to search for
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
284 it.)
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
285
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
286 %%% Local Variables:
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
287 %%% mode: latex
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
288 %%% TeX-master: "00book"
7e52f0cc4516 changed es/hgext.tex
jerojasro@localhost
parents: 432
diff changeset
289 %%% End: