提交 b25df87f 编写于 作者: F Felipe Contreras 提交者: Junio C Hamano

remote-bzr: fix partially pushed merge

If part of the merge was already pushed, we don't have the blob_marks
available, however, the commits are already stored in bazaar, so we can
use the revision_tree to fetch the contents.

We want to do this only when there's no other option.

There's no easy way to test this.
Signed-off-by: NFelipe Contreras <felipe.contreras@gmail.com>
Signed-off-by: NJunio C Hamano <gitster@pobox.com>
上级 38e7167e
......@@ -387,6 +387,7 @@ class CustomTree():
global files_cache
self.updates = {}
self.branch = repo
def copy_tree(revid):
files = files_cache[revid] = {}
......@@ -515,13 +516,21 @@ class CustomTree():
return changes
def get_file_with_stat(self, file_id, path=None):
def get_content(self, file_id):
path, mark = self.rev_files[file_id]
return (StringIO.StringIO(blob_marks[mark]), None)
if mark:
return blob_marks[mark]
# last resort
tree = self.branch.repository.revision_tree(self.base_id)
return tree.get_file_text(file_id)
def get_file_with_stat(self, file_id, path=None):
content = self.get_content(file_id)
return (StringIO.StringIO(content), None)
def get_symlink_target(self, file_id):
path, mark = self.rev_files[file_id]
return blob_marks[mark]
return self.get_content(file_id)
def id2path(self, file_id):
path, mark = self.rev_files[file_id]
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册