/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/revisiontree.py

  • Committer: Robert Collins
  • Date: 2006-11-08 00:36:30 UTC
  • mto: This revision was merged to the branch mainline in revision 2124.
  • Revision ID: robertc@robertcollins.net-20061108003630-feb31613c83f7096
(Robert Collins) Extend the problem reporting command line UI to use
apport to report more detailed diagnostics which should help in in getting
faults reported in Malone and provides the basis for capturing more
information such as detailed logging data from the current invocation of
bzr in the future (without cluttering 'bzr.log' unnecessarily).
apport is available from Ubuntu Edgy onwards.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2005 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
 
 
17
"""RevisionTree - a Tree implementation backed by repository data for a revision."""
 
18
 
 
19
from cStringIO import StringIO
 
20
 
 
21
from bzrlib.tree import Tree
 
22
 
 
23
 
 
24
class RevisionTree(Tree):
 
25
    """Tree viewing a previous revision.
 
26
 
 
27
    File text can be retrieved from the text store.
 
28
 
 
29
    TODO: Some kind of `__repr__` method, but a good one
 
30
           probably means knowing the branch and revision number,
 
31
           or at least passing a description to the constructor.
 
32
    """
 
33
    
 
34
    def __init__(self, branch, inv, revision_id):
 
35
        # for compatability the 'branch' parameter has not been renamed to 
 
36
        # repository at this point. However, we should change RevisionTree's
 
37
        # construction to always be via Repository and not via direct 
 
38
        # construction - this will mean that we can change the constructor
 
39
        # with much less chance of breaking client code.
 
40
        self._repository = branch
 
41
        self._weave_store = branch.weave_store
 
42
        self._inventory = inv
 
43
        self._revision_id = revision_id
 
44
 
 
45
    def get_parent_ids(self):
 
46
        """See Tree.get_parent_ids.
 
47
 
 
48
        A RevisionTree's parents match the revision graph.
 
49
        """
 
50
        if self._revision_id not in (None, 'null:'):
 
51
            parent_ids = self._repository.get_revision(
 
52
                self._revision_id).parent_ids
 
53
        else:
 
54
            parent_ids = []
 
55
        return parent_ids
 
56
        
 
57
    def get_revision_id(self):
 
58
        """Return the revision id associated with this tree."""
 
59
        return self._revision_id
 
60
 
 
61
    def get_weave(self, file_id):
 
62
        return self._weave_store.get_weave(file_id,
 
63
                self._repository.get_transaction())
 
64
 
 
65
    def get_file_lines(self, file_id):
 
66
        ie = self._inventory[file_id]
 
67
        weave = self.get_weave(file_id)
 
68
        return weave.get_lines(ie.revision)
 
69
 
 
70
    def get_file_text(self, file_id):
 
71
        return ''.join(self.get_file_lines(file_id))
 
72
 
 
73
    def get_file(self, file_id):
 
74
        return StringIO(self.get_file_text(file_id))
 
75
 
 
76
    def get_file_size(self, file_id):
 
77
        return self._inventory[file_id].text_size
 
78
 
 
79
    def get_file_sha1(self, file_id, path=None):
 
80
        ie = self._inventory[file_id]
 
81
        if ie.kind == "file":
 
82
            return ie.text_sha1
 
83
        return None
 
84
 
 
85
    def get_file_mtime(self, file_id, path=None):
 
86
        ie = self._inventory[file_id]
 
87
        revision = self._repository.get_revision(ie.revision)
 
88
        return revision.timestamp
 
89
 
 
90
    def is_executable(self, file_id, path=None):
 
91
        ie = self._inventory[file_id]
 
92
        if ie.kind != "file":
 
93
            return None 
 
94
        return self._inventory[file_id].executable
 
95
 
 
96
    def has_filename(self, filename):
 
97
        return bool(self.inventory.path2id(filename))
 
98
 
 
99
    def list_files(self, include_root=False):
 
100
        # The only files returned by this are those from the version
 
101
        entries = self.inventory.iter_entries()
 
102
        # skip the root for compatability with the current apis.
 
103
        if self.inventory.root is not None and not include_root:
 
104
            # skip the root for compatability with the current apis.
 
105
            entries.next()
 
106
        for path, entry in entries:
 
107
            yield path, 'V', entry.kind, entry.file_id, entry
 
108
 
 
109
    def get_symlink_target(self, file_id):
 
110
        ie = self._inventory[file_id]
 
111
        return ie.symlink_target;
 
112
 
 
113
    def kind(self, file_id):
 
114
        return self._inventory[file_id].kind
 
115
 
 
116
    def lock_read(self):
 
117
        self._repository.lock_read()
 
118
 
 
119
    def unlock(self):
 
120
        self._repository.unlock()
 
121
 
 
122