bzr branch
http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
| 1704.2.25
by Martin Pool Remove obsolete shebang line; add copyright | 1 | # Copyright (C) 2006 Canonical Ltd
 | 
| 2 | #
 | |
| 3 | # This program is free software; you can redistribute it and/or modify
 | |
| 4 | # it under the terms of the GNU General Public License as published by
 | |
| 5 | # the Free Software Foundation; either version 2 of the License, or
 | |
| 6 | # (at your option) any later version.
 | |
| 7 | #
 | |
| 8 | # This program is distributed in the hope that it will be useful,
 | |
| 9 | # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| 10 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| 11 | # GNU General Public License for more details.
 | |
| 12 | #
 | |
| 13 | # You should have received a copy of the GNU General Public License
 | |
| 14 | # along with this program; if not, write to the Free Software
 | |
| 15 | # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | |
| 16 | ||
| 17 | """Remove the last revision from the history of the current branch.
 | |
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 18 | """
 | 
| 19 | ||
| 20 | import os | |
| 1956.1.1
by John Arbash Meinel Fix bug #57660: 'bzr uncommit' should preserve pending merges | 21 | |
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 22 | from bzrlib.errors import BoundBranchOutOfDate | 
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 23 | |
| 24 | ||
| 1558.1.12
by Aaron Bentley Got uncommit working properly with checkouts | 25 | def uncommit(branch, dry_run=False, verbose=False, revno=None, tree=None): | 
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 26 | """Remove the last revision from the supplied branch. | 
| 27 | ||
| 1185.62.10
by John Arbash Meinel Removed --all from bzr uncommit, it was broken anyway. | 28 |     :param dry_run: Don't actually change anything
 | 
| 29 |     :param verbose: Print each step as you do it
 | |
| 30 |     :param revno: Remove back to this revision
 | |
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 31 |     """
 | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 32 | unlockable = [] | 
| 33 | try: | |
| 1558.1.12
by Aaron Bentley Got uncommit working properly with checkouts | 34 | if tree is not None: | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 35 | tree.lock_write() | 
| 36 | unlockable.append(tree) | |
| 37 | ||
| 38 | branch.lock_write() | |
| 39 | unlockable.append(branch) | |
| 40 | ||
| 1850.3.5
by John Arbash Meinel Fix bug 31426, have uncommit keep track of pending merges. | 41 | pending_merges = [] | 
| 1956.1.1
by John Arbash Meinel Fix bug #57660: 'bzr uncommit' should preserve pending merges | 42 | if tree is not None: | 
| 1908.7.7
by Robert Collins Deprecated WorkingTree.pending_merges. | 43 | pending_merges = tree.get_parent_ids()[1:] | 
| 1850.3.5
by John Arbash Meinel Fix bug 31426, have uncommit keep track of pending merges. | 44 | |
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 45 | master = branch.get_master_branch() | 
| 46 | if master is not None: | |
| 47 | master.lock_write() | |
| 48 | unlockable.append(master) | |
| 49 | rh = branch.revision_history() | |
| 50 | if master is not None and rh[-1] != master.last_revision(): | |
| 51 | raise BoundBranchOutOfDate(branch, master) | |
| 52 | if revno is None: | |
| 53 | revno = len(rh) | |
| 54 | ||
| 55 | files_to_remove = [] | |
| 56 | for r in range(revno-1, len(rh)): | |
| 57 | rev_id = rh.pop() | |
| 1850.3.5
by John Arbash Meinel Fix bug 31426, have uncommit keep track of pending merges. | 58 | rev = branch.repository.get_revision(rev_id) | 
| 59 |             # When we finish popping off the pending merges, we want
 | |
| 60 |             # them to stay in the order that they used to be.
 | |
| 61 |             # but we pop from the end, so reverse the order, and
 | |
| 62 |             # then get the order right at the end
 | |
| 63 | pending_merges.extend(reversed(rev.parent_ids[1:])) | |
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 64 | if verbose: | 
| 65 | print 'Removing revno %d: %s' % (len(rh)+1, rev_id) | |
| 66 | ||
| 67 |         # Committing before we start removing files, because
 | |
| 68 |         # once we have removed at least one, all the rest are invalid.
 | |
| 69 | if not dry_run: | |
| 70 | if master is not None: | |
| 71 | master.set_revision_history(rh) | |
| 72 | branch.set_revision_history(rh) | |
| 73 | if tree is not None: | |
| 1908.6.1
by Robert Collins Change all callers of set_last_revision to use set_parent_trees. | 74 | branch_tip = branch.last_revision() | 
| 75 | if branch_tip is not None: | |
| 76 | parents = [branch.last_revision()] | |
| 77 | else: | |
| 78 | parents = [] | |
| 79 | parents.extend(reversed(pending_merges)) | |
| 1908.6.3
by Robert Collins Tidy up the last_revision_id and add_pending_merge conversion to use cleaner apis. | 80 | tree.set_parent_ids(parents) | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 81 | finally: | 
| 82 | for item in reversed(unlockable): | |
| 83 | item.unlock() |