annotate en/branch.tex @ 196:4237e45506ee

Add early material describing tags.
author Bryan O'Sullivan <bos@serpentine.com>
date Mon, 16 Apr 2007 16:11:24 -0700
parents b60e2de6dbc3
children 76697ae503db
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
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
4 Mercurial provides two ways for you to manage a project that is making
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
5 progress on multiple fronts at once. To understand these mechanisms,
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
6 let's first take a look at a fairly normal software project structure.
187
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
7
196
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
8 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
9 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
10 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
11 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
12
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
13 \section{Giving a persistent name to a revision}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
14
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
15 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
16 ``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
17 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
18 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
19 new platform, etc).
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
20 \interaction{tag.init}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
21
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
22 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
23 \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
24 ``tags''.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
25 \interaction{tag.tag}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
26
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
27 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
28 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
29 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
30 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
31 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
32 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
33 following characters:
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
34 \begin{itemize}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
35 \item Colon (ASCII 58, ``\texttt{:}'')
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
36 \item Carriage return (ASCII 13, ``\texttt{$\backslash$r}'')
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
37 \item Newline (ASCII 10, ``\texttt{$\backslash$n}'')
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
38 \end{itemize}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
39
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
40 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
41 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
42 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
43 hash of the revision.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
44 \interaction{tag.tags}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
45 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
46 \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
47 identifies the newest revision in the repository.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
48
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
49 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
50 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
51 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
52 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
53
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
54 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
55 associated with it, it will print those tags.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
56 \interaction{tag.log}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
57
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
58 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
59 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
60 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
61 use that.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
62 \interaction{tag.log.v1.0}
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 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
65 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
66 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
67 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
68 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
69 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
70
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
71 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
72 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
73 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
74 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
75 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
76 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
77 buildability.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
78
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
79 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
80 \hgcmdargs{tag}{--remove}.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
81 \interaction{tag.remove}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
82 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
83 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
84 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
85 you \emph{really} want to update the tag.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
86 \interaction{tag.replace}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
87 There will still be a permanent record of the previous identity of the
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
88 tag, but Mercurial will no longer use it.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
89
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
90 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
91 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
92 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
93 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
94 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
95 corresponding changeset in the output of \hgcmd{log}.
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
96 \interaction{tag.tip}
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 \subsection{Handling tag conflicts during a merge}
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
99
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
100 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
101 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
102 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
103 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
104 name of a tag.
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 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
107 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
108 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
109 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
110 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
111
4237e45506ee Add early material describing tags.
Bryan O'Sullivan <bos@serpentine.com>
parents: 187
diff changeset
112 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
113 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
114 \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
115 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
116 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
117 \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
118 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
119 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
120
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
121 %%% Local Variables:
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
122 %%% mode: latex
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
123 %%% TeX-master: "00book"
b60e2de6dbc3 Add chapter on branch management.
Bryan O'Sullivan <bos@serpentine.com>
parents:
diff changeset
124 %%% End: