/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to doc/developers/uncommit.txt

  • Committer: Vincent Ladeuil
  • Date: 2008-01-29 15:16:31 UTC
  • mto: (3206.1.1 trunk)
  • mto: This revision was merged to the branch mainline in revision 3207.
  • Revision ID: v.ladeuil+lp@free.fr-20080129151631-vqjd13tb405mobx6
Fix two more leaking tmp dirs, by reworking TransformPreview lock handling.

* bzrlib/tests/test_transform.py:
(TestTransformMerge): Revert previous patch and cleanly call
preview.finalize now that we can.

* bzrlib/tests/test_merge.py:
(TestMerge.test_make_preview_transform): Catch TransformPreview
leak.

* bzrlib/builtins.py:
(cmd_merge._do_preview): Finalize the TransformPreview or the
limbodir will stay in /tmp.

* bzrlib/transform.py:
(TreeTransformBase.__init__): Create the _deletiondir since it's
reffered to by finalize.
(TreeTransformBase.finalize): Delete the dir only if _deletiondir
is set.
(TreeTransform.__init__): Use a temp var for deletiondir and set
the attribute after the base class __init__ has been called.
(TransformPreview.__init__): Read locks the tree since finalize
wants to unlock it (as suggested by Aaron).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
Uncommit Performance Notes
 
2
==========================
 
3
 
 
4
Specification of uncommit
 
5
-------------------------
 
6
 
 
7
``uncommit`` removes revisions from the head of a branch.  (By default, only
 
8
the very latest revision is removed, but optionally more can be taken.)
 
9
Uncommit does not affect the repository (garbage collection is a separate
 
10
step and not done by default).  The working tree is not logically
 
11
modified (revert is a different operation), except as described below
 
12
about merges.
 
13
 
 
14
Uncommit can be performed on either a branch or a working tree (and
 
15
implicitly its branch.)
 
16
 
 
17
If the uncommitted revisions includes one or more merges, after the
 
18
uncommit those revisions are in the working tree's list of pending merges,
 
19
because their tree changes are still present in the tree.
 
20
 
 
21
For a bound branch, uncommit fails unless the local branch is up to date.