Differences between revisions 7 and 8
Revision 7 as of 2008-03-24 16:56:24
Size: 2358
Editor: abuehl
Comment:
Revision 8 as of 2008-04-05 09:39:15
Size: 3110
Editor: abuehl
Comment: get rid of subpage inclusion by using LR orientation
Deletions are marked like this. Additions are marked like this.
Line 26: Line 26:
Diagramatically, this looks like: The procedure is as follows:
Line 28: Line 28:
|| [[Include(/fig1)]] || [[Include(/fig2)]] || [[Include(/fig3)]] ||
||<:> [:/fig1:fig 1] ||<:> [:/fig2:fig 2] ||<:> [:/fig2:fig 3] ||
'''~+{{{1: hg update R}}}+~'''
Line 31: Line 30:
The procedure is as follows.  This [:Update:updates] the [:WorkingDirectory:working directory] to revision R.
 Specifically, this means that the contents of the working directory are
 changed to that of revision R, and that R becomes the [:Parent:parent]
 of the working directory.
Line 33: Line 35:
 1. hg update R
    This [:Update:updates] the [:WorkingDirectory:working directory] to revision R.
    Specifically, this means that the contents of the working directory are
    changed to that of revision R, and that R becomes the [:Parent:parent]
    of the working directory.
Line 39: Line 36:
 2. hg revert -r tip --all
    This [:Revert:reverts] the working directory to its contents at [:Tip:tip].
    Since the parent of the working directory is still R, this means that
    the combined contents of all changesets between R and R+k show up as
    the modifications in the working directory.
'''~+{{{2: hg revert -r tip --all}}}+~'''
Line 45: Line 38:
 3. hg ci -m "Combined changesets between R and R+k"
    At this point, [:Commit:committing] these modifications will create a
    changeset containing all combined changesets between revisions R and R+k.
 {{{#!dot
digraph {
  rankdir = LR;
  node [shape=box];
  "working directory" -> R [label="1. update"];
  R -> "R+1" -> "R+2";
  "R+2" -> "R+k" [style=dashed];
  "working directory" -> "R+k" [color=red label="2. revert"];
  "working directory" [shape=ellipse];
}}}
Line 49: Line 49:
 4. hg clone -r tip oldrepo newrepo
    This assumes you want to get rid of your individual changesets (which are a dangling branch in oldrepo) and just keep the combined changeset (see also [:PruningDeadBranches]). newrepo will now just have the combined changeset.
 This [:Revert:reverts] the working directory to its contents at [:Tip:tip].
 Since the parent of the working directory is still R, this means that
 the combined contents of all changesets between R and R+k show up as
 the modifications in the working directory.


'''~+{{{3: hg ci -m "Combined changesets between R and R+k"}}}+~'''

 {{{#!dot
digraph {
  rankdir = LR;
  node [shape=box];
  "working directory" -> "R+k (concatenated)" [color=red label="3. commit"];
  "working directory" -> R [style=invis];
  R -> "R+k (concatenated)";
  R -> "R+1" -> "R+2";
  "R+2" -> "R+k" [style=dashed];
  "working directory" [shape=ellipse];
}}}

 At this point, [:Commit:committing] these modifications will create a
 changeset containing all combined changesets between revisions R and R+k.


'''~+{{{4: hg clone -r tip oldrepo newrepo}}}+~'''

 {{{#!dot
digraph {
  rankdir = LR;
  node [shape=box];
  "working directory" -> R [style=invis];
  "working directory" -> "R+k (concatenated)" [color=red label="4. clone -r tip"]
  R -> "R+k (concatenated)"
  "working directory" [shape=ellipse label="cloned working directory"]
}}}

 This assumes you want to get rid of your individual changesets (which are a dangling branch in oldrepo) and just keep the combined changeset (see also [:PruningDeadBranches]). newrepo will now just have the combined changeset.

Concatenating multiple changesets into one changeset

(See also [:EditingHistory])

Suppose you have a [:Repository:repository] with a number of [:ChangeSet:changesets] which you want to combine into a single changeset.

This can be done as follows using only the basic operations of Mercurial, namely [:Clone:clone], [:Push:push], and [:Pull:pull].

For simplicity, let us assume that the repository in question has a single [:Head:head], and you want to combine the last k [:Revision:revisions] into a single revision.

For concreteness, let us call the base revision R, and the ending revision R+k.

Let us furthermore assume the repository has no [:LocalModifications:local modifications].

The strategy is to take advantage of Mercurial's support for repositories with more than one head. What we do is create a [:Branch:branch] whose root revision is R and which consists of just one changeset (actually it can be multiple changesets, the principle is the same, but for simplicity let us assume one).

The procedure is as follows:

1: hg update R

  • This [:Update:updates] the [:WorkingDirectory:working directory] to revision R. Specifically, this means that the contents of the working directory are changed to that of revision R, and that R becomes the [:Parent:parent] of the working directory.

2: hg revert -r tip --all

  • This [:Revert:reverts] the working directory to its contents at [:Tip:tip]. Since the parent of the working directory is still R, this means that the combined contents of all changesets between R and R+k show up as the modifications in the working directory.

3: hg ci -m "Combined changesets between R and R+k"

  • At this point, [:Commit:committing] these modifications will create a changeset containing all combined changesets between revisions R and R+k.

4: hg clone -r tip oldrepo newrepo

  • This assumes you want to get rid of your individual changesets (which are a dangling branch in oldrepo) and just keep the combined changeset (see also [:PruningDeadBranches]). newrepo will now just have the combined changeset.


CategoryTipsAndTricks

ConcatenatingChangesets (last edited 2013-10-10 10:48:33 by RamiroMorales)