15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16
16
from bzrlib.branch import Branch
17
17
from bzrlib.fetch import greedy_fetch
18
from bzrlib.errors import NoSuchRevision, InstallFailed
19
def fetch_missing(branch):
20
"""Install the revisions of missing ancestors from another branch."""
21
this_branch = Branch.open_containing('.')
18
from bzrlib.errors import NoSuchRevision, InstallFailed, BzrCommandError
19
def fetch_ghosts(branch, no_fix):
20
"""Install ghosts from copies in another branch."""
21
this_branch = Branch.open_containing('.')[0]
23
23
branch = this_branch.get_parent()
25
raise BzrCommandError('No branch specified and no location saved.')
27
print "Using saved location %s" % branch
25
other_branch = Branch.open_containing(branch)
29
other_branch = Branch.open_containing(branch)[0]
29
# Because iter_missing_ancestors tests for existence after our last fetch
30
# is complete, it won't falsely report an ancestor as missing.
32
missing = iter_missing_ancestors(this_branch)
33
for revision in missing:
32
lock_other = this_branch.base != other_branch.base
34
this_branch.lock_write()
37
other_branch.lock_read()
35
greedy_fetch(this_branch, other_branch, revision)
36
installed.append(revision)
38
failed.append(revision)
39
if len(installed) > 0:
44
print "Still missing:"
39
# Because iter_ghosts tests for existence after our last fetch
40
# is complete, it won't falsely report an ancestor as a ghost.
42
ghosts = iter_ghosts(this_branch)
43
for revision in ghosts:
45
greedy_fetch(this_branch, other_branch, revision)
46
installed.append(revision)
48
failed.append(revision)
50
if this_branch.last_revision() is None:
51
print "No revisions in branch."
52
if len(installed) > 0:
57
print "Still missing:"
48
def iter_missing_ancestors(branch):
66
if not no_fix and len(installed) > 0:
67
from reweave_inventory import cmd_fix
70
def iter_ghosts(branch):
49
71
"""Find all ancestors that aren't stored in this branch."""
51
lines = [branch.last_patch()]
73
lines = [branch.last_revision()]
52
76
while len(lines) > 0: