annotate en/branch.tex @ 487:9fdb45b994d4

Finished backing out section
author Igor TAmara <igor@tamarapatino.org>
date Sun, 02 Nov 2008 21:00:40 -0500
parents c36a6f534b99
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
1 \chapter{Managing releases and branchy development}
187
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
2 \label{chap:branch}
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
3
197
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
4 Mercurial provides several mechanisms for you to manage a project that
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
5 is making progress on multiple fronts at once. To understand these
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
6 mechanisms, let's first take a brief look at a fairly normal software
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
7 project structure.
187
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
8
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
9 Many software projects issue periodic ``major'' releases that contain
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
10 substantial new features. In parallel, they may issue ``minor''
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
11 releases. These are usually identical to the major releases off which
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
12 they're based, but with a few bugs fixed.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
13
197
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
14 In this chapter, we'll start by talking about how to keep records of
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
15 project milestones such as releases. We'll then continue on to talk
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
16 about the flow of work between different phases of a project, and how
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
17 Mercurial can help you to isolate and manage this work.
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
18
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
19 \section{Giving a persistent name to a revision}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
20
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
21 Once you decide that you'd like to call a particular revision a
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
22 ``release'', it's a good idea to record the identity of that revision.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
23 This will let you reproduce that release at a later date, for whatever
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
24 purpose you might need at the time (reproducing a bug, porting to a
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
25 new platform, etc).
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
26 \interaction{tag.init}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
27
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
28 Mercurial lets you give a permanent name to any revision using the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
29 \hgcmd{tag} command. Not surprisingly, these names are called
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
30 ``tags''.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
31 \interaction{tag.tag}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
32
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
33 A tag is nothing more than a ``symbolic name'' for a revision. Tags
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
34 exist purely for your convenience, so that you have a handy permanent
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
35 way to refer to a revision; Mercurial doesn't interpret the tag names
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
36 you use in any way. Neither does Mercurial place any restrictions on
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
37 the name of a tag, beyond a few that are necessary to ensure that a
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
38 tag can be parsed unambiguously. A tag name cannot contain any of the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
39 following characters:
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
40 \begin{itemize}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
41 \item Colon (ASCII 58, ``\texttt{:}'')
261
a24b370a16ee Fix escaping.
Bryan O'Sullivan <bos@serpentine.com>
parents: 259
diff changeset
42 \item Carriage return (ASCII 13, ``\Verb+\r+'')
a24b370a16ee Fix escaping.
Bryan O'Sullivan <bos@serpentine.com>
parents: 259
diff changeset
43 \item Newline (ASCII 10, ``\Verb+\n+'')
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
44 \end{itemize}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
45
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
46 You can use the \hgcmd{tags} command to display the tags present in
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
47 your repository. In the output, each tagged revision is identified
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
48 first by its name, then by revision number, and finally by the unique
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
49 hash of the revision.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
50 \interaction{tag.tags}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
51 Notice that \texttt{tip} is listed in the output of \hgcmd{tags}. The
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
52 \texttt{tip} tag is a special ``floating'' tag, which always
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
53 identifies the newest revision in the repository.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
54
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
55 In the output of the \hgcmd{tags} command, tags are listed in reverse
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
56 order, by revision number. This usually means that recent tags are
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
57 listed before older tags. It also means that \texttt{tip} is always
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
58 going to be the first tag listed in the output of \hgcmd{tags}.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
59
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
60 When you run \hgcmd{log}, if it displays a revision that has tags
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
61 associated with it, it will print those tags.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
62 \interaction{tag.log}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
63
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
64 Any time you need to provide a revision~ID to a Mercurial command, the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
65 command will accept a tag name in its place. Internally, Mercurial
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
66 will translate your tag name into the corresponding revision~ID, then
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
67 use that.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
68 \interaction{tag.log.v1.0}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
69
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
70 There's no limit on the number of tags you can have in a repository,
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
71 or on the number of tags that a single revision can have. As a
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
72 practical matter, it's not a great idea to have ``too many'' (a number
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
73 which will vary from project to project), simply because tags are
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
74 supposed to help you to find revisions. If you have lots of tags, the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
75 ease of using them to identify revisions diminishes rapidly.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
76
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
77 For example, if your project has milestones as frequent as every few
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
78 days, it's perfectly reasonable to tag each one of those. But if you
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
79 have a continuous build system that makes sure every revision can be
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
80 built cleanly, you'd be introducing a lot of noise if you were to tag
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
81 every clean build. Instead, you could tag failed builds (on the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
82 assumption that they're rare!), or simply not use tags to track
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
83 buildability.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
84
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
85 If you want to remove a tag that you no longer want, use
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
86 \hgcmdargs{tag}{--remove}.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
87 \interaction{tag.remove}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
88 You can also modify a tag at any time, so that it identifies a
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
89 different revision, by simply issuing a new \hgcmd{tag} command.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
90 You'll have to use the \hgopt{tag}{-f} option to tell Mercurial that
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
91 you \emph{really} want to update the tag.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
92 \interaction{tag.replace}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
93 There will still be a permanent record of the previous identity of the
197
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
94 tag, but Mercurial will no longer use it. There's thus no penalty to
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
95 tagging the wrong revision; all you have to do is turn around and tag
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
96 the correct revision once you discover your error.
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
97
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
98 Mercurial stores tags in a normal revision-controlled file in your
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
99 repository. If you've created any tags, you'll find them in a file
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
100 named \sfilename{.hgtags}. When you run the \hgcmd{tag} command,
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
101 Mercurial modifies this file, then automatically commits the change to
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
102 it. This means that every time you run \hgcmd{tag}, you'll see a
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
103 corresponding changeset in the output of \hgcmd{log}.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
104 \interaction{tag.tip}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
105
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
106 \subsection{Handling tag conflicts during a merge}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
107
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
108 You won't often need to care about the \sfilename{.hgtags} file, but
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
109 it sometimes makes its presence known during a merge. The format of
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
110 the file is simple: it consists of a series of lines. Each line
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
111 starts with a changeset hash, followed by a space, followed by the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
112 name of a tag.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
113
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
114 If you're resolving a conflict in the \sfilename{.hgtags} file during
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
115 a merge, there's one twist to modifying the \sfilename{.hgtags} file:
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
116 when Mercurial is parsing the tags in a repository, it \emph{never}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
117 reads the working copy of the \sfilename{.hgtags} file. Instead, it
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
118 reads the \emph{most recently committed} revision of the file.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
119
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
120 An unfortunate consequence of this design is that you can't actually
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
121 verify that your merged \sfilename{.hgtags} file is correct until
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
122 \emph{after} you've committed a change. So if you find yourself
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
123 resolving a conflict on \sfilename{.hgtags} during a merge, be sure to
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
124 run \hgcmd{tags} after you commit. If it finds an error in the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
125 \sfilename{.hgtags} file, it will report the location of the error,
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
126 which you can then fix and commit. You should then run \hgcmd{tags}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
127 again, just to be sure that your fix is correct.
187
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
128
198
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
129 \subsection{Tags and cloning}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
130
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
131 You may have noticed that the \hgcmd{clone} command has a
259
Johannes Hoff <wbunaarfubss@gmail.com>
parents: 207
diff changeset
132 \hgopt{clone}{-r} option that lets you clone an exact copy of the
198
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
133 repository as of a particular changeset. The new clone will not
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
134 contain any project history that comes after the revision you
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
135 specified. This has an interaction with tags that can surprise the
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
136 unwary.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
137
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
138 Recall that a tag is stored as a revision to the \sfilename{.hgtags}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
139 file, so that when you create a tag, the changeset in which it's
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
140 recorded necessarily refers to an older changeset. When you run
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
141 \hgcmdargs{clone}{-r foo} to clone a repository as of tag
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
142 \texttt{foo}, the new clone \emph{will not contain the history that
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
143 created the tag} that you used to clone the repository. The result
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
144 is that you'll get exactly the right subset of the project's history
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
145 in the new repository, but \emph{not} the tag you might have expected.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
146
197
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
147 \subsection{When permanent tags are too much}
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
148
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
149 Since Mercurial's tags are revision controlled and carried around with
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
150 a project's history, everyone you work with will see the tags you
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
151 create. But giving names to revisions has uses beyond simply noting
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
152 that revision \texttt{4237e45506ee} is really \texttt{v2.0.2}. If
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
153 you're trying to track down a subtle bug, you might want a tag to
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
154 remind you of something like ``Anne saw the symptoms with this
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
155 revision''.
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
156
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
157 For cases like this, what you might want to use are \emph{local} tags.
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
158 You can create a local tag with the \hgopt{tag}{-l} option to the
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
159 \hgcmd{tag} command. This will store the tag in a file called
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
160 \sfilename{.hg/localtags}. Unlike \sfilename{.hgtags},
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
161 \sfilename{.hg/localtags} is not revision controlled. Any tags you
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
162 create using \hgopt{tag}{-l} remain strictly local to the repository
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
163 you're currently working in.
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
164
198
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
165 \section{The flow of changes---big picture vs. little}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
166
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
167 To return to the outline I sketched at the beginning of a chapter,
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
168 let's think about a project that has multiple concurrent pieces of
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
169 work under development at once.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
170
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
171 There might be a push for a new ``main'' release; a new minor bugfix
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
172 release to the last main release; and an unexpected ``hot fix'' to an
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
173 old release that is now in maintenance mode.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
174
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
175 The usual way people refer to these different concurrent directions of
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
176 development is as ``branches''. However, we've already seen numerous
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
177 times that Mercurial treats \emph{all of history} as a series of
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
178 branches and merges. Really, what we have here is two ideas that are
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
179 peripherally related, but which happen to share a name.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
180 \begin{itemize}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
181 \item ``Big picture'' branches represent the sweep of a project's
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
182 evolution; people give them names, and talk about them in
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
183 conversation.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
184 \item ``Little picture'' branches are artefacts of the day-to-day
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
185 activity of developing and merging changes. They expose the
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
186 narrative of how the code was developed.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
187 \end{itemize}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
188
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
189 \section{Managing big-picture branches in repositories}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
190
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
191 The easiest way to isolate a ``big picture'' branch in Mercurial is in
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
192 a dedicated repository. If you have an existing shared
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
193 repository---let's call it \texttt{myproject}---that reaches a ``1.0''
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
194 milestone, you can start to prepare for future maintenance releases on
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
195 top of version~1.0 by tagging the revision from which you prepared
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
196 the~1.0 release.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
197 \interaction{branch-repo.tag}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
198 You can then clone a new shared \texttt{myproject-1.0.1} repository as
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
199 of that tag.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
200 \interaction{branch-repo.clone}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
201
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
202 Afterwards, if someone needs to work on a bug fix that ought to go
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
203 into an upcoming~1.0.1 minor release, they clone the
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
204 \texttt{myproject-1.0.1} repository, make their changes, and push them
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
205 back.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
206 \interaction{branch-repo.bugfix}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
207 Meanwhile, development for the next major release can continue,
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
208 isolated and unabated, in the \texttt{myproject} repository.
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
209 \interaction{branch-repo.new}
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
210
199
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
211 \section{Don't repeat yourself: merging across branches}
198
615f3c6b30e1 Start to describe branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents: 197
diff changeset
212
199
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
213 In many cases, if you have a bug to fix on a maintenance branch, the
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
214 chances are good that the bug exists on your project's main branch
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
215 (and possibly other maintenance branches, too). It's a rare developer
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
216 who wants to fix the same bug multiple times, so let's look at a few
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
217 ways that Mercurial can help you to manage these bugfixes without
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
218 duplicating your work.
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
219
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
220 In the simplest instance, all you need to do is pull changes from your
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
221 maintenance branch into your local clone of the target branch.
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
222 \interaction{branch-repo.pull}
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
223 You'll then need to merge the heads of the two branches, and push back
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
224 to the main branch.
58e3a6c76725 More branch/merge stuff.
Bryan O'Sullivan <bos@serpentine.com>
parents: 198
diff changeset
225 \interaction{branch-repo.merge}
197
76697ae503db Local branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 196
diff changeset
226
202
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
227 \section{Naming branches within one repository}
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
228
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
229 In most instances, isolating branches in repositories is the right
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
230 approach. Its simplicity makes it easy to understand; and so it's
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
231 hard to make mistakes. There's a one-to-one relationship between
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
232 branches you're working in and directories on your system. This lets
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
233 you use normal (non-Mercurial-aware) tools to work on files within a
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
234 branch/repository.
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
235
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
236 If you're more in the ``power user'' category (\emph{and} your
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
237 collaborators are too), there is an alternative way of handling
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
238 branches that you can consider. I've already mentioned the
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
239 human-level distinction between ``small picture'' and ``big picture''
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
240 branches. While Mercurial works with multiple ``small picture''
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
241 branches in a repository all the time (for example after you pull
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
242 changes in, but before you merge them), it can \emph{also} work with
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
243 multiple ``big picture'' branches.
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
244
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
245 The key to working this way is that Mercurial lets you assign a
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
246 persistent \emph{name} to a branch. There always exists a branch
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
247 named \texttt{default}. Even before you start naming branches
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
248 yourself, you can find traces of the \texttt{default} branch if you
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
249 look for them.
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
250
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
251 As an example, when you run the \hgcmd{commit} command, and it pops up
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
252 your editor so that you can enter a commit message, look for a line
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
253 that contains the text ``\texttt{HG: branch default}'' at the bottom.
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
254 This is telling you that your commit will occur on the branch named
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
255 \texttt{default}.
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
256
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
257 To start working with named branches, use the \hgcmd{branches}
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
258 command. This command lists the named branches already present in
203
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
259 your repository, telling you which changeset is the tip of each.
202
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
260 \interaction{branch-named.branches}
203
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
261 Since you haven't created any named branches yet, the only one that
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
262 exists is \texttt{default}.
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
263
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
264 To find out what the ``current'' branch is, run the \hgcmd{branch}
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
265 command, giving it no arguments. This tells you what branch the
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
266 parent of the current changeset is on.
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
267 \interaction{branch-named.branch}
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
268
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
269 To create a new branch, run the \hgcmd{branch} command again. This
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
270 time, give it one argument: the name of the branch you want to create.
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
271 \interaction{branch-named.create}
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
272
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
273 After you've created a branch, you might wonder what effect the
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
274 \hgcmd{branch} command has had. What do the \hgcmd{status} and
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
275 \hgcmd{tip} commands report?
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
276 \interaction{branch-named.status}
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
277 Nothing has changed in the working directory, and there's been no new
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
278 history created. As this suggests, running the \hgcmd{branch} command
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
279 has no permanent effect; it only tells Mercurial what branch name to
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
280 use the \emph{next} time you commit a changeset.
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
281
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
282 When you commit a change, Mercurial records the name of the branch on
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
283 which you committed. Once you've switched from the \texttt{default}
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
284 branch to another and committed, you'll see the name of the new branch
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
285 show up in the output of \hgcmd{log}, \hgcmd{tip}, and other commands
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
286 that display the same kind of output.
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
287 \interaction{branch-named.commit}
d7615e15510f More about named branches, and early use of them.
Bryan O'Sullivan <bos@serpentine.com>
parents: 202
diff changeset
288 The \hgcmd{log}-like commands will print the branch name of every
205
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
289 changeset that's not on the \texttt{default} branch. As a result, if
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
290 you never use named branches, you'll never see this information.
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
291
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
292 Once you've named a branch and committed a change with that name,
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
293 every subsequent commit that descends from that change will inherit
206
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
294 the same branch name. You can change the name of a branch at any
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
295 time, using the \hgcmd{branch} command.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
296 \interaction{branch-named.rebranch}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
297 In practice, this is something you won't do very often, as branch
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
298 names tend to have fairly long lifetimes. (This isn't a rule, just an
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
299 observation.)
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
300
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
301 \section{Dealing with multiple named branches in a repository}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
302
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
303 If you have more than one named branch in a repository, Mercurial will
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
304 remember the branch that your working directory on when you start a
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
305 command like \hgcmd{update} or \hgcmdargs{pull}{-u}. It will update
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
306 the working directory to the tip of this branch, no matter what the
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
307 ``repo-wide'' tip is. To update to a revision that's on a different
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
308 named branch, you may need to use the \hgopt{update}{-C} option to
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
309 \hgcmd{update}.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
310
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
311 This behaviour is a little subtle, so let's see it in action. First,
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
312 let's remind ourselves what branch we're currently on, and what
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
313 branches are in our repository.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
314 \interaction{branch-named.parents}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
315 We're on the \texttt{bar} branch, but there also exists an older
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
316 \hgcmd{foo} branch.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
317
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
318 We can \hgcmd{update} back and forth between the tips of the
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
319 \texttt{foo} and \texttt{bar} branches without needing to use the
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
320 \hgopt{update}{-C} option, because this only involves going backwards
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
321 and forwards linearly through our change history.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
322 \interaction{branch-named.update-switchy}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
323
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
324 If we go back to the \texttt{foo} branch and then run \hgcmd{update},
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
325 it will keep us on \texttt{foo}, not move us to the tip of
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
326 \texttt{bar}.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
327 \interaction{branch-named.update-nothing}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
328
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
329 Committing a new change on the \texttt{foo} branch introduces a new
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
330 head.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
331 \interaction{branch-named.foo-commit}
205
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
332
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
333 \section{Branch names and merging}
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
334
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
335 As you've probably noticed, merges in Mercurial are not symmetrical.
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
336 Let's say our repository has two heads, 17 and 23. If I
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
337 \hgcmd{update} to 17 and then \hgcmd{merge} with 23, Mercurial records
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
338 17 as the first parent of the merge, and 23 as the second. Whereas if
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
339 I \hgcmd{update} to 23 and then \hgcmd{merge} with 17, it records 23
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
340 as the first parent, and 17 as the second.
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
341
206
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
342 This affects Mercurial's choice of branch name when you merge. After
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
343 a merge, Mercurial will retain the branch name of the first parent
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
344 when you commit the result of the merge. If your first parent's
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
345 branch name is \texttt{foo}, and you merge with \texttt{bar}, the
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
346 branch name will still be \texttt{foo} after you merge.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
347
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
348 It's not unusual for a repository to contain multiple heads, each with
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
349 the same branch name. Let's say I'm working on the \texttt{foo}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
350 branch, and so are you. We commit different changes; I pull your
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
351 changes; I now have two heads, each claiming to be on the \texttt{foo}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
352 branch. The result of a merge will be a single head on the
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
353 \texttt{foo} branch, as you might hope.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
354
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
355 But if I'm working on the \texttt{bar} branch, and I merge work from
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
356 the \texttt{foo} branch, the result will remain on the \texttt{bar}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
357 branch.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
358 \interaction{branch-named.merge}
205
c76a3e2a600c Brief update.
Bryan O'Sullivan <bos@serpentine.com>
parents: 203
diff changeset
359
206
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
360 To give a more concrete example, if I'm working on the
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
361 \texttt{bleeding-edge} branch, and I want to bring in the latest fixes
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
362 from the \texttt{stable} branch, Mercurial will choose the ``right''
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
363 (\texttt{bleeding-edge}) branch name when I pull and merge from
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
364 \texttt{stable}.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
365
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
366 \section{Branch naming is generally useful}
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
367
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
368 You shouldn't think of named branches as applicable only to situations
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
369 where you have multiple long-lived branches cohabiting in a single
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
370 repository. They're very useful even in the one-branch-per-repository
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
371 case.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
372
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
373 In the simplest case, giving a name to each branch gives you a
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
374 permanent record of which branch a changeset originated on. This
266
08ae82a18abd just another typo
bab@draketo.de
parents: 261
diff changeset
375 gives you more context when you're trying to follow the history of a
206
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
376 long-lived branchy project.
6519f3b983b4 More material about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 205
diff changeset
377
207
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
378 If you're working with shared repositories, you can set up a
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
379 \hook{pretxnchangegroup} hook on each that will block incoming changes
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
380 that have the ``wrong'' branch name. This provides a simple, but
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
381 effective, defence against people accidentally pushing changes from a
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
382 ``bleeding edge'' branch to a ``stable'' branch. Such a hook might
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
383 look like this inside the shared repo's \hgrc.
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
384 \begin{codesample2}
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
385 [hooks]
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
386 pretxnchangegroup.branch = hg heads --template '{branches} ' | grep mybranch
54ca4e00e569 Add an example hook to enforce branch naming.
Bryan O'Sullivan <bos@serpentine.com>
parents: 206
diff changeset
387 \end{codesample2}
202
6f167e644762 Start writing about named branches.
Bryan O'Sullivan <bos@serpentine.com>
parents: 199
diff changeset
388
187
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
389 %%% Local Variables:
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
390 %%% mode: latex
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
391 %%% TeX-master: "00book"
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
392 %%% End: