14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16
16
from bzrlib.branch import Branch
17
from bzrlib.errors import NoSuchRevision, InstallFailed, BzrCommandError
18
def fetch_ghosts(branch, no_fix):
19
"""Install ghosts from copies in another branch."""
20
this_branch = Branch.open_containing('.')[0]
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('.')
22
branch = this_branch.get_parent()
24
raise BzrCommandError('No branch specified and no location saved.')
26
print "Using saved location %s" % branch
24
branch = this_branch.controlfile("x-pull", "rb").read().rstrip('\n')
25
print "Using last location: %s" % branch
27
if e.errno != errno.ENOENT:
30
raise BzrCommandError("No pull location known or specified.")
28
other_branch = Branch.open_containing(branch)[0]
32
other_branch = Branch.open_containing(branch)
31
lock_other = this_branch.base != other_branch.base
33
this_branch.lock_write()
36
other_branch.lock_read()
36
# Because iter_missing_ancestors tests for existence after our last fetch
37
# is complete, it won't falsely report an ancestor as missing.
39
missing = iter_missing_ancestors(this_branch)
40
for revision in missing:
38
# Because iter_ghosts tests for existence after our last fetch
39
# is complete, it won't falsely report an ancestor as a ghost.
41
ghosts = iter_ghosts(this_branch)
42
for revision in ghosts:
44
this_branch.fetch(other_branch, revision)
45
installed.append(revision)
47
failed.append(revision)
49
if this_branch.last_revision() is None:
50
print "No revisions in branch."
51
if len(installed) > 0:
56
print "Still missing:"
65
if not no_fix and len(installed) > 0:
66
from bzrlib.builtins import cmd_reconcile
67
cmd_reconcile().run(".")
69
def iter_ghosts(branch):
42
greedy_fetch(this_branch, other_branch, revision)
43
installed.append(revision)
45
failed.append(revision)
46
if len(installed) > 0:
51
print "Still missing:"
55
def iter_missing_ancestors(branch):
70
56
"""Find all ancestors that aren't stored in this branch."""
72
lines = [branch.last_revision()]
58
lines = [branch.last_patch()]
75
59
while len(lines) > 0: