25
25
class BzrPatchSource(PatchSource):
26
26
def __init__(self, revision=None, file_list=None):
27
from bzrlib.bzrdir import BzrDir
29
27
self.file_list = file_list
30
28
if file_list is not None and len(file_list) > 0:
31
29
location = file_list[0]
35
self.bzrdir = BzrDir.open_containing(location)[0]
36
self.base = self.bzrdir.open_branch().base
33
# Hack to cope with 0.7 and 0.8 bzr
35
from bzrlib.bzrdir import BzrDir
36
self.bzrdir = BzrDir.open_containing(location)[0]
37
self.base = self.bzrdir.open_branch().base
38
self.__readlines = self._v08_readlines
40
from bzrlib.branch import Branch
41
self.branch = Branch.open_containing(location)[0]
42
self.base = self.branch.base
43
self.__readlines = self._v07_readlines
38
45
self.revision = revision
40
47
PatchSource.__init__(self)
42
49
def readlines(self):
50
from StringIO import StringIO
56
def _v07_readlines(self, output):
57
from bzrlib.diff import show_diff
58
show_diff(self.branch, self.revision,
59
specific_files=self.file_list, output=output)
61
def _v08_readlines(self, output):
44
from StringIO import StringIO
45
63
from bzrlib.diff import diff_cmd_helper
47
66
# FIXME diff_cmd_helper() should take an output parameter
51
67
diff_cmd_helper(self.bzrdir.open_workingtree(), self.file_list,
52
external_diff_options=None, old_revision_spec=self.revision)
68
external_diff_options=None, old_revision_spec=self.revision)