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 | ||
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 17 | """Remove the last revision from the history of the current branch."""
 | 
| 18 | ||
| 19 | # TODO: make the guts of this methods on tree, branch.
 | |
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 20 | |
| 21 | import os | |
| 1956.1.1
by John Arbash Meinel Fix bug #57660: 'bzr uncommit' should preserve pending merges | 22 | |
| 3280.4.4
by John Arbash Meinel uncommit --local in an unbound branch raises the same exception as commit --local | 23 | from bzrlib import ( | 
| 24 | errors, | |
| 25 | revision as _mod_revision, | |
| 26 |     )
 | |
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 27 | from bzrlib.branch import Branch | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 28 | from bzrlib.errors import BoundBranchOutOfDate | 
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 29 | |
| 30 | ||
| 3280.4.1
by John Arbash Meinel Add uncommit --local. | 31 | def uncommit(branch, dry_run=False, verbose=False, revno=None, tree=None, | 
| 32 | local=False): | |
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 33 | """Remove the last revision from the supplied branch. | 
| 34 | ||
| 1185.62.10
by John Arbash Meinel Removed --all from bzr uncommit, it was broken anyway. | 35 |     :param dry_run: Don't actually change anything
 | 
| 36 |     :param verbose: Print each step as you do it
 | |
| 37 |     :param revno: Remove back to this revision
 | |
| 0.3.1
by John Arbash Meinel Creating a plugin for uncommitting the last revision. | 38 |     """
 | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 39 | unlockable = [] | 
| 40 | try: | |
| 1558.1.12
by Aaron Bentley Got uncommit working properly with checkouts | 41 | if tree is not None: | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 42 | tree.lock_write() | 
| 43 | unlockable.append(tree) | |
| 44 | ||
| 45 | branch.lock_write() | |
| 46 | unlockable.append(branch) | |
| 47 | ||
| 1850.3.5
by John Arbash Meinel Fix bug 31426, have uncommit keep track of pending merges. | 48 | pending_merges = [] | 
| 1956.1.1
by John Arbash Meinel Fix bug #57660: 'bzr uncommit' should preserve pending merges | 49 | if tree is not None: | 
| 1908.7.7
by Robert Collins Deprecated WorkingTree.pending_merges. | 50 | pending_merges = tree.get_parent_ids()[1:] | 
| 1850.3.5
by John Arbash Meinel Fix bug 31426, have uncommit keep track of pending merges. | 51 | |
| 3280.4.1
by John Arbash Meinel Add uncommit --local. | 52 | if local: | 
| 53 | master = None | |
| 3280.4.4
by John Arbash Meinel uncommit --local in an unbound branch raises the same exception as commit --local | 54 | if branch.get_bound_location() is None: | 
| 55 | raise errors.LocalRequiresBoundBranch() | |
| 3280.4.1
by John Arbash Meinel Add uncommit --local. | 56 | else: | 
| 57 | master = branch.get_master_branch() | |
| 58 | if master is not None: | |
| 59 | master.lock_write() | |
| 60 | unlockable.append(master) | |
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 61 | rh = branch.revision_history() | 
| 62 | if master is not None and rh[-1] != master.last_revision(): | |
| 63 | raise BoundBranchOutOfDate(branch, master) | |
| 64 | if revno is None: | |
| 65 | revno = len(rh) | |
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 66 | old_revno, old_tip = branch.last_revision_info() | 
| 67 | new_revno = revno -1 | |
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 68 | |
| 69 | files_to_remove = [] | |
| 70 | for r in range(revno-1, len(rh)): | |
| 71 | rev_id = rh.pop() | |
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 72 |             # NB: performance would be better using the revision graph rather
 | 
| 73 |             # than the whole revision.
 | |
| 1850.3.5
by John Arbash Meinel Fix bug 31426, have uncommit keep track of pending merges. | 74 | rev = branch.repository.get_revision(rev_id) | 
| 75 |             # When we finish popping off the pending merges, we want
 | |
| 76 |             # them to stay in the order that they used to be.
 | |
| 77 |             # but we pop from the end, so reverse the order, and
 | |
| 78 |             # then get the order right at the end
 | |
| 79 | pending_merges.extend(reversed(rev.parent_ids[1:])) | |
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 80 | if verbose: | 
| 81 | print 'Removing revno %d: %s' % (len(rh)+1, rev_id) | |
| 82 | ||
| 83 |         # Committing before we start removing files, because
 | |
| 84 |         # once we have removed at least one, all the rest are invalid.
 | |
| 85 | if not dry_run: | |
| 86 | if master is not None: | |
| 87 | master.set_revision_history(rh) | |
| 88 | branch.set_revision_history(rh) | |
| 2598.5.4
by Aaron Bentley Restore original Branch.last_revision behavior, fix bits that care | 89 | new_tip = _mod_revision.ensure_null(branch.last_revision()) | 
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 90 | if master is None: | 
| 91 | hook_local = None | |
| 92 | hook_master = branch | |
| 93 | else: | |
| 94 | hook_local = branch | |
| 95 | hook_master = master | |
| 96 | for hook in Branch.hooks['post_uncommit']: | |
| 2598.5.2
by Aaron Bentley Got all tests passing with Branch returning 'null:' for null revision | 97 | hook_new_tip = new_tip | 
| 98 | if hook_new_tip == _mod_revision.NULL_REVISION: | |
| 99 | hook_new_tip = None | |
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 100 | hook(hook_local, hook_master, old_revno, old_tip, new_revno, | 
| 2598.5.2
by Aaron Bentley Got all tests passing with Branch returning 'null:' for null revision | 101 | hook_new_tip) | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 102 | if tree is not None: | 
| 2598.5.2
by Aaron Bentley Got all tests passing with Branch returning 'null:' for null revision | 103 | if not _mod_revision.is_null(new_tip): | 
| 2246.1.3
by Robert Collins New branch hooks: post_push, post_pull, post_commit, post_uncommit. These | 104 | parents = [new_tip] | 
| 1908.6.1
by Robert Collins Change all callers of set_last_revision to use set_parent_trees. | 105 | else: | 
| 106 | parents = [] | |
| 107 | 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. | 108 | tree.set_parent_ids(parents) | 
| 1558.9.1
by Aaron Bentley Fix uncommit to handle bound branches, and to do locking | 109 | finally: | 
| 110 | for item in reversed(unlockable): | |
| 111 | item.unlock() |