Differences between revisions 14 and 15
Revision 14 as of 2015-06-12 07:27:25
Size: 2316
Comment: Mark as abandonned
Revision 15 as of 2015-06-12 07:39:12
Size: 2188
Deletions are marked like this. Additions are marked like this.
Line 5: Line 5:
Line 11: Line 13:

<!> This proposal is inactive for 3 years, it's implementation have not been tested with the last version of Mercurial and are likely broken with them. See ChangesetEvolution for an alternative.
Line 81: Line 81:
== See Also ==

 * ChangesetEvolution

/!\ This page is primarily intended for Mercurial's developers.

{i} This page appears to contain material that is no longer relevant. Please help improve this page by updating its content.

/!\ This page is no longer relevant but is kept for historical purposes.

Poisoned Changesets

Status: abandoned

Proponent: MartinGeisler

Original proposal: RFC: dealing with dead, anonymous feature branches

Implementation of proposal: http://bitbucket.org/mg/dead-branches

1. Definitions

We will use the following definitions:

poisoned changeset

a changeset with poisoned=1 in its extra dict.

dead head
a poisoned changeset that is also a head.
dead changeset
a changeset from which you can only reach dead heads.
dead branch
a set of dead changesets

2. Rules for Push

When pushing changesets, the following two rules are observed:

  1. First, send changesets that are not on a dead branch.
  2. Then, send changesets descending from what is now remote heads.

The discovery protocols gives us the heads of the common set of nodes. From these we can compute the changesets that are not on a dead branch (rule 1). We can then look at the remaining heads among the nodes in the common set and push descendants of these.

No new information is neede by this protocol, everything can be computed locally from information about the common set of nodes.

3. Rules for Pull

Symmetric to push, but the server needs to filter the changesets.

4. Use Cases

An experiment can be stopped, whether it has been pushed to another server or not:

A new commit is made:

A pull is made, bringing ind C, D, and E and it is decided that X is no longer is relevant:

5. See Also

CategoryDeveloper CategoryNewFeatures

PoisonedChangesetsPlan (last edited 2015-06-12 08:45:14 by Pierre-YvesDavid)