annotate Hg.txt @ 5:2ec53c0ed5d8

Musings on Merging and Mergeability.
author Jim Hague <jim.hague@icc-atcsolutions.com>
date Fri, 06 Mar 2009 14:07:34 +0000
parents 561edf852797
children a942bf7bc2ab
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
1 Inside a distributed version control system
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
2 ===========================================
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
3
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
4 Grinton Lodge is a Youth Hostel that sits on an exposed hillside just
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
5 above the small hamlet of Grinton in Swaledale, in the Yorkshire Dales
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
6 National Park. A former Victorian shooting lodge, it now welcomes
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
7 walkers and other travellers from around the world.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
8
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
9 Tonight, a Wednesday in mid-November, is not one of its busiest
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
10 nights. Kat, the duty staff member, tells me that there is a small
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
11 corporate team-building group in the annex. There's no sign of them at
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
12 present. Otherwise, that portion of the world that has beaten a path
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
13 to the door of this grand building today consists of just me. And Kat
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
14 goes home soon.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
15
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
16 The November CVu, removed from its wrappers and read yesterday, lies
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
17 in my bag. Taunting me. Go on, it says, if you've ever going to put
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
18 finger to keyboard in the name of CVu, well, tonight you are out of
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
19 excuses.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
20
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
21 Bugger.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
22
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
23 Let's look into Mercurial
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
24 -------------------------
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
25
1
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
26 If you're at all interested in version control systems - and any
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
27 software developer not using one daily is a strange beast indeed -
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
28 you'll at least have become vaguely aware in the last few years of the
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
29 growing maturity of the latest group of version control systems
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
30 offering funky new stuff. These are the distributed version control
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
31 systems (DVCS). There is more to them than just their headline
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
32 attributes, being able to check history and do checkins while
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
33 disconnected from a central server, but these are damm useful to start
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
34 with.
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
35
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
36 When I first heard about DVCS, it wasn't immediately obvious to me (to
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
37 put it mildly) how they would work. After years of using a centralised
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
38 version control system, I had rough mental model of what went on. But
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
39 how do you cope without the central server forcing ordering onto the
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
40 changes?
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
41
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
42 Since then I've started using Mercurial. Mercurial is a DVCS. It's one
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
43 of three DVCSs that have gained significant popularity in the last few
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
44 years, the other two being Git and Bazaar. I switched a significant
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
45 work project over to Mercurial (from Subversion) over a year ago,
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
46 because a customer site required on-site work but could not allow
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
47 access back to the company VPN. I chose Mercurial for a variety of
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
48 reasons which I won't bore you with here. If you must know, see the
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
49 box.
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
50
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
51 What I want to do in this article is give you an insight into how a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
52 DVCS works. OK, so specifically I'm going to be talking about
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
53 Mercurial, but Git and Bazaar attack the problem in a similar way. But
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
54 first I'd better give you some idea of how you use Mercurial.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
55
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
56 ::::
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
57 Box: OK, if you must know:
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
58
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
59 o Implementability. I needed the system to work on Windows, Linux and
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
60 AIX. The latter was not one of the directly supported platforms for
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
61 any of the candidates. Git's implementation uses a horde of
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
62 tools. Bazaar requires only Python, but required Python 2.4 while IBM
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
63 stubbornly still supplies only Python 2.3. Mercurial requires Python
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
64 2.3 or greater, and uses some C for speed.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
65
2
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
66 o Simplicity. My users used Subversion daily, but did not generally
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
67 have much experience with other VCS. From the command line,
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
68 Mercurial's core operations will be familiar to a Subversion
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
69 user. This is also true of Bazaar, but was less true of Git. Git has
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
70 improved in this matter since then, but a Mr Winder of this parish
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
71 tells me that it's still possible to seriously embarass
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
72 yourself. There was also a lack of Windows support for Git at the
ee7f1e2c01a6 Expand slightly on simplicity section of 'Why Mercurial'.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 1
diff changeset
73 time.
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
74
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
75 o Speed. Mercurial is fast. In the same ballpark as Git. Bazaar
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
76 wasn't, and although it has improved significantly, has, in my
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
77 estimation, added user complexity in the process, and is still off the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
78 pace for some operations.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
79
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
80 o Documentation. At the time, Bryan O'Sullivan's excellent Mercurial
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
81 book (http://hgbook.red-bean.com) was a clear winner for best
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
82 documentation.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
83 ::::
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
84
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
85 The 5 minute Mercurial overview
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
86 -------------------------------
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
87
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
88 I think it unlikely that someone possessing the taste and discernment
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
89 to be reading CVu would not be familiar with at least one version
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
90 control system. So, while I want to give you a flavour of what it's
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
91 like to use, I'm not going to hang about. If you'd like a proper
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
92 introduction, or you don't follow something, I thoroughly recommend
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
93 you consult the Mercurial book.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
94
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
95 To start using Mercurial to keep track of a project.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
96
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
97 $ hg init
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
98 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
99
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
100 This creates the repository root in the current directory.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
101
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
102 Like CVS with its CVS directory and Subversion with its .svn
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
103 directory, Mercurial keeps its private data in a directory. Mercifully
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
104 there is only one of these, in the top level of your project. And
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
105 rather than holding details of where the actual repository is to be
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
106 found, the .hg directory holds the entire repository.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
107
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
108 Next you need to specify the files you want Mercurial to track.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
109
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
110 $ echo "There was a gibbon one morning" > pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
111 $ hg add pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
112 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
113
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
114 As you might expect, this marks the files as to be added. And as you
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
115 might also expect, you need to commit to record the added files in the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
116 repository. The commit comment can be supplied on the command line; if
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
117 you don't supply a comment, you'll be dropped into an editor to
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
118 provide one.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
119
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
120 There is a suggested format for these messages - a one line summary
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
121 followed by any more required detail on following lines. By default
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
122 Mercurial will only display the first line of commit messages when
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
123 listing changes. In these examples I'll stick to terse messages, and
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
124 I'll enter them from the command line.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
125
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
126 $ hg commit -m "My Pome" -u "Jim Hague <jim.hague@acm.org>"
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
127 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
128
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
129 Mercurial records the user making the change as part of the change
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
130 information. It is usual to give your name and email address as I've
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
131 done here. You can imagine, though, that constantly having to repeat
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
132 this is a bit tedious, so you can set a default user name in a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
133 configuration file. Mercurial keeps global, user and repository
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
134 configurations, and it can go in any of those.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
135
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
136 As with Subversion, after further edits you see how your working copy
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
137 differs from the repository.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
138
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
139 $ hg status
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
140 M pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
141 $ hg diff
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
142 diff -r 33596ef855c1 pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
143 --- a/pome.txt Wed Apr 23 22:36:33 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
144 +++ b/pome.txt Wed Apr 23 22:48:01 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
145 @@ -1,1 +1,2 @@ There was a gibbon one morning
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
146 There was a gibbon one morning
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
147 +said "I think I will fly to the moon".
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
148 $ hg commit -m "A great second line"
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
149 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
150
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
151 And look through a log of changes.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
152
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
153 $ hg log
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
154 changeset: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
155 tag: tip
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
156 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
157 date: Wed Apr 23 22:49:10 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
158 summary: A great second line
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
159
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
160 changeset: 0:33596ef855c1
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
161 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
162 date: Wed Apr 23 22:36:33 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
163 summary: My Pome
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
164
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
165 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
166
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
167 There are some items here that need an explanation.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
168
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
169 The changeset identifer is in fact two identifiers separated by a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
170 colon. The first is the sequence number of the changeset in the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
171 repository, and is directly comparable to the change number in a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
172 Subversion repository. The second is a globally unique identifier for
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
173 that change. As the change is copied from one repository to another
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
174 (this is a distributed system, remember, even if we haven't come to
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
175 that bit yet), its sequence number in any particular repository will
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
176 change, but the global identifier will always remain the same.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
177
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
178 'tip' is a Mercurial term. It means simply the most recent change.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
179
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
180 Want to rename a file?
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
181
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
182 $ hg mv pome.txt poem.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
183 $ hg status
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
184 A poem.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
185 R pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
186 $ hg commit -m "Rename my file"
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
187 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
188
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
189 (The command to rename a file is actually 'hg rename', but Mercurial
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
190 saves Unix-trained fingers from typing embarrassment.)
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
191
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
192 At this point you may be wondering about directories. 'hg mkdir'
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
193 perhaps? Well, no. Mercurial only tracks files. To be sure, the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
194 directory a file occupies is tracked, but effectively only as a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
195 component of the file name. This has the slightly unexpected result
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
196 that you can't record an empty directory in your repository.
1
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
197
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
198 (Footnote: I tripped over this converting a work Subversion
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
199 repository. One possibility is to create a placemaker file in the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
200 directory. In the event I created the directory (which receives build
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
201 products) as part of the build instead.)
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
202
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
203 Given this, and the status output above that suggests strongly that
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
204 Mercurial treats a rename as a copy followed by a delete, you may be
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
205 worried that Mercurial won't cope at all well with rearranging your
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
206 repository. Relax. Mercurial does store the details of the rename as
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
207 part of the changeset, and copes very well with rearrangements.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
208
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
209 (Footnote: The Mercurial designers justify not dealing with
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
210 directories as first class objects by pointing out that provided you
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
211 can correctly move files about in the tree, the other reasons for
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
212 tracking directories are uncommon and do not in their opinion justify
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
213 the considerable added complexity. So far I've found no reason to
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
214 doubt that judgement.)
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
215
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
216 Want to rewind the working copy to a previous revision?
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
217
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
218 $ hg update -r 1
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
219 1 files updated, 0 files merged, 1 files removed, 0 files unresolved
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
220 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
221
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
222 'hg update' updates the working files. In this case I'm specifying
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
223 that I want to go back to local changeset 1. I could also have typed
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
224 '-r 3d65e7a57890', or even '-r 3d'; when specifying the global change
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
225 identifier you only need to type enough digits to make it unique.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
226
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
227 This is all very well, but it's not exactly distributed, is it?
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
228
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
229 Copy an existing repository:
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
230
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
231 elsewhere$ hg clone ssh://jim.home.net/Poem Jim-Poem
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
232 updating working directory
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
233 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
234
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
235 (You can access other repositories via the file system, over http or
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
236 over ssh).
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
237
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
238 elsewhere$ cd Jim-Poem
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
239 elsewhere$ hg log
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
240 changeset: 3:a065eb26e6b9
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
241 tag: tip
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
242 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
243 date: Thu Apr 24 18:52:31 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
244 summary: Rename my file
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
245
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
246 changeset: 2:ff97668b7422
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
247 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
248 date: Thu Apr 24 18:50:22 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
249 summary: Finished first verse
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
250
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
251 changeset: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
252 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
253 date: Wed Apr 23 22:49:10 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
254 summary: A great second line
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
255
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
256 changeset: 0:33596ef855c1
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
257 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
258 date: Wed Apr 23 22:36:33 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
259 summary: My Pome
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
260
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
261 'hg clone' is aptly named. It creates a new repository that contains
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
262 exactly the same changes as the source repository. You can make a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
263 clone just by copying your project directory, if you're confident
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
264 nothing else will access it during the copy. 'hg clone' saves you this
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
265 worry, and sets the default push/pull location in the new repo to the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
266 cloned repo.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
267
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
268 From that point, you use 'hg pull' to collect changes from other
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
269 places into your repo (though note it does not by default update your
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
270 working copy), and, as you might guess, 'hg push' shoves your changes
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
271 into a foreign repository. By default these will act on the repository
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
272 you cloned from, but you can specify any other repository.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
273
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
274 More on those in a moment. First, though, I want to show you something
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
275 you can't do in Subversion. Start with the repository with 4 changes
1
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
276 we just cloned. I want to focus on the first couple of lines, so I'll
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
277 wind the working copy back to the point where only those lines exist.
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
278
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
279 $ hg update -r 1
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
280 1 files updated, 0 files merged, 1 files removed, 0 files unresolved
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
281
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
282 And make a change.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
283
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
284 $ hg diff
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
285 diff -r 3d65e7a57890 pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
286 --- a/pome.txt Wed Apr 23 22:49:10 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
287 +++ b/pome.txt Thu Apr 24 19:13:14 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
288 @@ -1,2 +1,2 @@ There was a gibbon one morning
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
289 -There was a gibbon one morning
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
290 -said "I think I will fly to the moon".
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
291 +There was a baboon who one afternoon
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
292 +said "I think I will fly to the sun".
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
293 $ hg commit -m "Better first two lines"
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
294 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
295
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
296 The alert among you will have sat up at that. Well done! Yes, there's
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
297 something very worrying. How can I commit a change at an old point?
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
298 If you try this in Subversion, it will complain mightily about your
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
299 file being out of date. But Mercurial just went ahead and did
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
300 something. The Bazaar experts among you will know that in Bazaar, if
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
301 you use 'bzr revert -r' to bring the working copy to a past revision,
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
302 make a change and commit, then your latest version will be the past
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
303 revision plus your change. Perhaps that's what Mercurial did?
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
304
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
305 No. What Mercurial did is central to Mercurial's view of the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
306 world. You took your working copy back to an old changeset, and the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
307 committed a fresh change based at that changeset. Mercurial actually
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
308 did just what you asked it to do, no more and no less. Let's see the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
309 initial evidence.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
310
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
311 $ hg heads
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
312 changeset: 4:267d32f158b3
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
313 tag: tip
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
314 parent: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
315 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
316 date: Thu Apr 24 19:13:59 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
317 summary: Better first two lines
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
318
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
319 changeset: 3:a065eb26e6b9
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
320 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
321 date: Thu Apr 24 18:52:31 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
322 summary: Rename my file
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
323
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
324 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
325
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
326 Time for some more Mercurial terminology. You can think of a 'head' in
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
327 Mercurial as the most recent change on a branch. In Mercurial, a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
328 branch is simply what happens when you commit a change that has as its
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
329 parent a change that already has a child. Mercurial has a standard
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
330 extension 'hg glog' which uses some ASCII art to show the current
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
331 state:
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
332
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
333 $ hg glog
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
334 @ changeset: 4:267d32f158b3
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
335 | tag: tip
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
336 | parent: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
337 | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
338 | date: Thu Apr 24 19:13:59 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
339 | summary: Better first two lines
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
340 |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
341 | o changeset: 3:a065eb26e6b9
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
342 | | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
343 | | date: Thu Apr 24 18:52:31 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
344 | | summary: Rename my file
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
345 | |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
346 | o changeset: 2:ff97668b7422
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
347 |/ user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
348 | date: Thu Apr 24 18:50:22 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
349 | summary: Finished first verse
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
350 |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
351 o changeset: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
352 | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
353 | date: Wed Apr 23 22:49:10 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
354 | summary: A great second line
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
355 |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
356 o changeset: 0:33596ef855c1
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
357 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
358 date: Wed Apr 23 22:36:33 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
359 summary: My Pome
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
360
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
361 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
362
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
363 'hg view' shows a nicer graphical view. (Footnote: Though, being
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
364 Tcl/Tk based, not that much nicer.)
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
365
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
366 So the change is in there. It's the latest change, and is simply on a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
367 different branch to the other changes.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
368
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
369 Almost invariably, you will want to bring everything back together and
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
370 merge the branches. A merge is a change that combines two heads back
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
371 into one. It prepares an updated working directory with the merged
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
372 contents of the two heads for you to review and, if satisfactory, commit.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
373
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
374 $ hg merge
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
375 merging pome.txt and poem.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
376 0 files updated, 1 files merged, 0 files removed, 0 files unresolved
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
377 (branch merge, don't forget to commit)
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
378 $ cat poem.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
379 There was a baboon who one afternoon
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
380 said "I think I will fly to the sun".
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
381 So with two great palms strapped to his arms,
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
382 he started his takeoff run.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
383 $ hg commit -m "Merge first line branch"
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
384 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
385
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
386 (Footnote: I'm no poet. The poem is, of course, 'Silly Old Baboon' by
1
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
387 the late, great, Spike Milligan. From 'A Book of Milliganimals',
608947872f72 Add intro and some minor edits.
Jim Hague <jim.hague@acm.org>
parents: 0
diff changeset
388 Puffin, 1971.)
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
389
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
390 Here's the ASCII art again showing what just happened. Oh, and notice
3
175493e0e457 Minor edit pointing better to rename handling.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 2
diff changeset
391 in the above that Mercurial has done the right thing with regard to
175493e0e457 Minor edit pointing better to rename handling.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 2
diff changeset
392 the rename.
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
393
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
394 $ hg glog
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
395 @ changeset: 5:792ab970fc80
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
396 |\ tag: tip
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
397 | | parent: 4:267d32f158b3
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
398 | | parent: 3:a065eb26e6b9
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
399 | | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
400 | | date: Thu Apr 24 19:29:53 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
401 | | summary: Merge first line branch
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
402 | |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
403 | o changeset: 4:267d32f158b3
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
404 | | parent: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
405 | | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
406 | | date: Thu Apr 24 19:13:59 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
407 | | summary: Better first two lines
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
408 | |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
409 o | changeset: 3:a065eb26e6b9
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
410 | | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
411 | | date: Thu Apr 24 18:52:31 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
412 | | summary: Rename my file
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
413 | |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
414 o | changeset: 2:ff97668b7422
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
415 |/ user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
416 | date: Thu Apr 24 18:50:22 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
417 | summary: Finished first verse
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
418 |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
419 o changeset: 1:3d65e7a57890
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
420 | user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
421 | date: Wed Apr 23 22:49:10 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
422 | summary: A great second line
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
423 |
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
424 o changeset: 0:33596ef855c1
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
425 user: Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
426 date: Wed Apr 23 22:36:33 2008 +0100
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
427 summary: My Pome
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
428
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
429 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
430
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
431 So, our little branch change has now been merged back, and we have a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
432 single line of development again. Notice that unlike the other
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
433 changesets, changeset 5 has two parent changesets, indicating it is a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
434 merge changeset. You can only merge two branches in one operation; or
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
435 putting it another way, a changeset can have a maximum of two parents.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
436
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
437 This behaviour is absolutely central to Mercurial's philosophy. If a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
438 change is committed that takes as its starting point a change that
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
439 already has a child, then a branch gets created. Working with
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
440 Mercurial, branches get created frequently, and equally frequently
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
441 merged back. As befits any frequent operation, both are easy to do.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
442
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
443 You're probably thinking at this point that this making a commit onto
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
444 an old version is a slightly strange thing to do, and you'd be right.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
445 But that's exactly what's going to happen the moment you go
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
446 distributed. Two people working independently with their own
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
447 repositories are going to make commits based, typically, on the latest
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
448 changes they happen to have incorporated into their tree. To be
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
449 Distributed, a DVCS has to deal with this. Mercurial faces it head-on.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
450 When you pull changes into your repo (or someone else pushes them), if
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
451 any of the changes overlap - are both based on the same base change -
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
452 you get extra heads, and it's up to you to let these extra heads live
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
453 or merge, as you please.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
454
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
455 In practice this is more manageable then you might think. Consider a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
456 typical Mercurial usage, where the 'master' repo sits on a known
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
457 server, and everyone pulls changes from the master and pushes their
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
458 own efforts the master. But default Mercurial won't let you push if
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
459 the receiving repo will gain an extra head as a result, so you
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
460 typically pull (and do any required merging) just before
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
461 pushing. Subversion users will recognised this pattern. Subversion
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
462 won't let you commit a change if your working copy is not at the very
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
463 latest revision, so the Subversion user will update, and merge if
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
464 necessary, just before committing.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
465
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
466 What, then, about a branch in the conventional sense of '1.0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
467 maintenance branch'? Typically in Mercurial you'd handle this by
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
468 keeping a separate cloned repository for those changes. Cloning is
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
469 fast, and if local uses hard links where possible on filesystems that
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
470 support them, so isn't necessarily extravagant on disc space. You can,
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
471 if you prefer, handle them all in a single repo with 'named
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
472 branches', but cloning is definitely simpler.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
473
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
474 OK, so now you know the basics of using Mercurial. We can proceed to
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
475 looking at how this magic is achieved. In particular, where does this
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
476 magic globally unique identifier for a change come from?
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
477
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
478 Inside the Mercurial repo
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
479 -------------------------
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
480
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
481 The way Mercurial handles its repo is really quite simple.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
482
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
483 That's simple, as in 'most things are simple once you know the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
484 answer'. I found the explanation helpful, so this section attempts
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
485 the 10,000ft (FL100 if you prefer) view of Mercurial.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
486
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
487 (Foornote: Bryan O'Sullivan's excellent Mercurial book has a chapter
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
488 on the subject, and the Mercurial website has a fair amount of detail
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
489 too. This is 'research', OK?)
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
490
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
491 First remember that any file or component can only have one or two
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
492 parents. You can't merge more than one other branch at once.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
493
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
494 We start with the basic building block, which Mercurial calls a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
495 revlog. A revlog is a thing that holds a file and all the changes in
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
496 the file history. (Footnote: For any non-trivial file, this will
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
497 actually be two files on the disc, a data file and an index). The
5
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
498 revlog stores the differences between successive versions
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
499 of the file, though it will periodically store a complete version of
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
500 the file instead of a difference, so that the content of any
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
501 particular file version can always be reconstructed without excessive
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
502 effort.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
503
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
504 Under the secret-squirrel Mercurial .hg directory at the top of your
5
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
505 project is a store which holds a revlog for each file in your
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
506 project. So you have the complete history of the project locally. No
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
507 more round trips to the server.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
508
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
509 Both the differences between successive versions and the periodic
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
510 complete versions of a file are compressed before storing. This is
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
511 surprisingly effective at minimising the storage requirements this
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
512 entire history of your project. <!!!Comparison of .svn space
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
513 requirements for Waldo>.
0
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
514
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
515 Any point in the evolution of a revlog can be uniquely identified with
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
516 a nodeid. This is simply the SHA1 hash of the current file contents
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
517 concatenated with the nodeids of one or both parents of the current
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
518 revision. Note that this way, two file states are identical if and
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
519 only if the file contents are the same *and* the file has the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
520 same history.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
521
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
522 Here's a dump of a revlog index:
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
523
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
524 $ hg debugindex .hg/store/data/pome.txt.i
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
525 rev offset length base linkrev nodeid p1 p2
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
526 0 0 32 0 0 6bbbd5d6cc53 000000000000 000000000000
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
527 1 32 51 0 1 83d266583303 6bbbd5d6cc53 000000000000
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
528 2 83 84 0 2 14a54ec34bb6 83d266583303 000000000000
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
529 3 167 76 3 4 dc4df776b38b 83d266583303 000000000000
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
530 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
531
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
532 Note here that a file state can have two parents. If both the parent
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
533 nodeids are non-null, the file state has two parents, and the state is
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
534 therefore the result of a merge.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
535
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
536 Let's dump out a revlog at a particular revision:
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
537
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
538 $ hg debugdata .hg/store/data/pome.txt.i 2
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
539 There was a gibbon one morning
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
540 said "I think I will fly to the moon".
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
541 So with two great palms strapped to his arms,
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
542 he started his takeoff run.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
543 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
544
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
545 The next component is the manifest. This is simply a list of all the
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
546 files in the project, together with their current nodeids. The
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
547 manifest is a file, held in a revlog. The nodeid of the manifest,
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
548 therefore, identifies the project filesystem at a particular point.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
549
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
550 $ hg debugdata .hg/store/00manifest.i 5
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
551 poem.txt5168b1a5e2f44aa4e0f164e170820845183f50c8
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
552 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
553
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
554 Finally we have the changeset. This is the atomic collection of
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
555 changes to a repository that leads to a new revision. The changeset
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
556 info includes the nodeid of the corresponding manifest, the timestamp
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
557 and committer ID, a list of changed files and a comment. The changeset
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
558 also includes the nodeid of the parent changeset, or the two parents
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
559 if the change is a merge. The changeset description is held in a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
560 revlog, the changelog.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
561
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
562 $ hg debugdata .hg/store/00changelog.i 5
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
563 1ccc11b6f7308cc8fa1573c2f3811a4710c91e3e
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
564 Jim Hague <jim.hague@acm.org>
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
565 1209061793 -3600
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
566 poem.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
567 pome.txt
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
568
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
569 Merge first line branch
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
570 $
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
571
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
572 The nodeid of the changeset, therefore, gives us a globally unique
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
573 identifier for any particular change. Changesets have a
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
574 Subversion-like incrementing change number, but it is peculiar to that
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
575 repository. The nodeid, however, is global.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
576
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
577 One more detail remains to complete the picture. How do we get back
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
578 from a particular file change to find the responsible changeset? Each
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
579 revlog change has a linkrev entry that does just this.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
580
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
581 So, now we have a repository with a history of the changes applied to
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
582 that repository. Each change has a unique identifier. If we find that
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
583 change in another repository, it means that at the point in the other
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
584 repository we have exactly the same state; the file contents and
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
585 history are identical.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
586
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
587 At this point we can see how pulling changes from another repository
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
588 works. Mercurial has to determine which changesets in the source
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
589 repository are missing in the target repository. To do this, for each
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
590 head in the source repo it has to find the most recent change in that
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
591 head that it already present in the target repo, and get any remaining
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
592 changes after that point. These changes are then copied over and
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
593 applied.
48d338d29ce9 First comitted version.
Jim Hague <jim.hague@acm.org>
parents:
diff changeset
594
4
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
595 The Mercurial revlog format has proved remarkably durable. Since the
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
596 first release of Mercurial in April 2005, these have been a total of 5
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
597 changes to the file format. However, of those, all but one have been
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
598 changes to the handling of file names. The most recent change, in
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
599 October 2008, and its predecessor in December 2006, were both
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
600 introduced purely to cope with Windows specific issues. The one change
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
601 that touched the datastructures described above was in April 2006. The
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
602 format introduced, RevLogNG, changed only the details of index data
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
603 held, not the overall design. The chief Mercurial developer, Matt
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
604 Mackall, notes that the code in present-day Mercurial devoted to
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
605 reading the old format comprises 28 lines of Python. Compared with,
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
606 say, the early tribulations of Subversion and the switch from bdfs to
561edf852797 More detail on file format changes, from post by MM to mercurial.general.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 3
diff changeset
607 fsfs, this is an impressive record.
5
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
608
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
609 Reflections on going distributed
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
610 --------------------------------
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
611
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
612 It's nearly traditional at this stage in an introduction to DVCS to
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
613 demonstrate several differenet workflow scanarios that you can build
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
614 with a DVCS. Which makes the important point that a DVCS can be
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
615 adapted to your workflow in a way that is at best unwieldy with a
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
616 CVCS. I intend, though, to break with tradition here.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
617
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
618 By this stage, I hope you can see that distributing version control
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
619 works by introducing branches where development takes place in
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
620 parallel. Mercurial treats these branches as arising naturally from
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
621 the commits made and transferred between repositories. Both Git and
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
622 Bazaar take a slightly different viewpoint, and explicitly generate a
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
623 fresh branch for work in a particular repositories. But in both cases
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
624 the underlying principle of identifying changes by a globally unique
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
625 identifier and resolving parallel development by merges between
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
626 overlapping changes is the same. And all three can be used in a truly
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
627 distributed manner, with full history and the ability to commit being
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
628 available locally.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
629
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
630 I want now to reflect on the consequences all this has for that
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
631 all-important question of whether a DVCS is a suitable vehicle for
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
632 your data.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
633
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
634 The first is a minor and rather obvious point. If you want to store
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
635 files that are both very large and which change often in your DVCS,
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
636 then all the compression in the world is unlikely to stop the storage
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
637 requirements for the full project history from becoming
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
638 uncomfortably large.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
639
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
640 The second, and main, point is that there is an important question you
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
641 need to ask about your data. We've seen that a DVCS relies on
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
642 branching and merging to weave its magic. So take a close look at your
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
643 data, and ask:
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
644
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
645 Will It Merge?
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
646
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
647 The subset of plain old text which comprises program source
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
648 code requires some human oversight, but will merge automatically
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
649 well enough for the process to be well within the bounds of the
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
650 possible.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
651
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
652 Unfortunately when we move further afield mergeability becomes a rarer
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
653 commodity. I nearly began the previous paragraph by stating that
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
654 plain old text will merge well enough. Then Doubt set in - what about
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
655 XML? Or BASE64 encoded content?
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
656
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
657 Of course, merge doesn't necessarily have to be textual merge. I am
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
658 told that Word can be used to diff and merge two Word .doc files, a
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
659 data format notorious for its binary impenetrability. As long as some
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
660 suitable merge agent is available, and the DVCS can be configured to
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
661 use it for data of a particular type (Footnote: Mercurial can have the
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
662 merge and diff tools specified with reference to the file extension on
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
663 which they operate - I assume Bazaar and Git are similar.), then there
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
664 is no bar to successful DVCS use.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
665
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
666 Before this reliance on mergeability causes you to dismiss DVCS out of
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
667 hand, reflect. A CVCS can only handle non-mergeable data by acting as
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
668 a versioned file store; in other words, having as the only available
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
669 merge option the use of one or other of the merge candidates in its
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
670 entireity. Useful though a versioned file store can be, it cannot be
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
671 considered a full-featured version control system. By treating the
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
672 offending unmergeable files as external to the DVCS, or with careful
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
673 workflow - disabling the distributed and mergeable potentials - a DVCS
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
674 can deal with these files, but only at a cost of its distributedness
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
675 or its version control system-ness. In this it differs little from a
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
676 CVCS.
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
677
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
678 So, for all data you want to version control, let your battle cry be
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
679
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
680 Will It Merge?
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
681
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
682 At this point, I have an urge to don lab coat and safety goggles and
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
683 be videoed attempting to mechanically merge data in a variety of
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
684 different formats. Frankly, this is unlike to be as exciting at
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
685 blending iPhones (Ref: www.willitblend.com), but from a system
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
686 development point of view it's rather more important. And, I think
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
687 gives us a large clue as to one of the reasons for the continuing
2ec53c0ed5d8 Musings on Merging and Mergeability.
Jim Hague <jim.hague@icc-atcsolutions.com>
parents: 4
diff changeset
688 popularity of Plain Old Text as a source code representation mechanism.