/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
1852.7.1 by Robert Collins
Move RevisionTree out of tree.py.
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
1908.11.2 by Robert Collins
Implement WorkingTree interface conformance tests for
21
from bzrlib import revision
1852.7.1 by Robert Collins
Move RevisionTree out of tree.py.
22
from bzrlib.tree import Tree
23
24
25
class RevisionTree(Tree):
26
    """Tree viewing a previous revision.
27
28
    File text can be retrieved from the text store.
29
30
    TODO: Some kind of `__repr__` method, but a good one
31
           probably means knowing the branch and revision number,
32
           or at least passing a description to the constructor.
33
    """
34
    
35
    def __init__(self, branch, inv, revision_id):
36
        # for compatability the 'branch' parameter has not been renamed to 
37
        # repository at this point. However, we should change RevisionTree's
38
        # construction to always be via Repository and not via direct 
39
        # construction - this will mean that we can change the constructor
40
        # with much less chance of breaking client code.
41
        self._repository = branch
42
        self._weave_store = branch.weave_store
43
        self._inventory = inv
1910.2.6 by Aaron Bentley
Update for merge review, handle deprecations
44
        assert inv.root is not None
1852.7.1 by Robert Collins
Move RevisionTree out of tree.py.
45
        self._revision_id = revision_id
46
47
    def get_parent_ids(self):
48
        """See Tree.get_parent_ids.
49
50
        A RevisionTree's parents match the revision graph.
51
        """
1908.11.2 by Robert Collins
Implement WorkingTree interface conformance tests for
52
        if self._revision_id == revision.NULL_REVISION:
53
            return []
54
        else:
55
            parent_ids = self._repository.get_revision(
56
                self._revision_id).parent_ids
1852.7.1 by Robert Collins
Move RevisionTree out of tree.py.
57
        return parent_ids
58
        
59
    def get_revision_id(self):
60
        """Return the revision id associated with this tree."""
61
        return self._revision_id
62
63
    def get_weave(self, file_id):
64
        return self._weave_store.get_weave(file_id,
65
                self._repository.get_transaction())
66
67
    def get_file_lines(self, file_id):
68
        ie = self._inventory[file_id]
69
        weave = self.get_weave(file_id)
70
        return weave.get_lines(ie.revision)
71
72
    def get_file_text(self, file_id):
73
        return ''.join(self.get_file_lines(file_id))
74
75
    def get_file(self, file_id):
76
        return StringIO(self.get_file_text(file_id))
77
78
    def get_file_size(self, file_id):
79
        return self._inventory[file_id].text_size
80
81
    def get_file_sha1(self, file_id, path=None):
82
        ie = self._inventory[file_id]
83
        if ie.kind == "file":
84
            return ie.text_sha1
85
        return None
86
87
    def get_file_mtime(self, file_id, path=None):
88
        ie = self._inventory[file_id]
89
        revision = self._repository.get_revision(ie.revision)
90
        return revision.timestamp
91
92
    def is_executable(self, file_id, path=None):
93
        ie = self._inventory[file_id]
94
        if ie.kind != "file":
95
            return None 
96
        return self._inventory[file_id].executable
97
98
    def has_filename(self, filename):
99
        return bool(self.inventory.path2id(filename))
100
1907.1.1 by Aaron Bentley
Unshelved all changes except those related to removing RootEntry
101
    def list_files(self):
1852.7.1 by Robert Collins
Move RevisionTree out of tree.py.
102
        # The only files returned by this are those from the version
103
        entries = self.inventory.iter_entries()
104
        # skip the root for compatability with the current apis.
1907.1.1 by Aaron Bentley
Unshelved all changes except those related to removing RootEntry
105
        entries.next()
1852.7.1 by Robert Collins
Move RevisionTree out of tree.py.
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
1852.15.3 by Robert Collins
Add a first-cut Tree.walkdirs method.
122
    def walkdirs(self, prefix=""):
123
        _directory = 'directory'
124
        inv = self.inventory
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
125
        top_id = inv.path2id(prefix)
126
        if top_id is None:
127
            pending = []
128
        else:
129
            pending = [(prefix, '', _directory, None, top_id, None)]
1852.15.3 by Robert Collins
Add a first-cut Tree.walkdirs method.
130
        while pending:
131
            dirblock = []
132
            currentdir = pending.pop()
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
133
            # 0 - relpath, 1- basename, 2- kind, 3- stat, id, v-kind
1852.15.3 by Robert Collins
Add a first-cut Tree.walkdirs method.
134
            if currentdir[0]:
135
                relroot = currentdir[0] + '/'
136
            else:
137
                relroot = ""
138
            # FIXME: stash the node in pending
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
139
            entry = inv[currentdir[4]]
1852.15.3 by Robert Collins
Add a first-cut Tree.walkdirs method.
140
            for name, child in entry.sorted_children():
141
                toppath = relroot + name
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
142
                dirblock.append((toppath, name, child.kind, None,
1852.15.3 by Robert Collins
Add a first-cut Tree.walkdirs method.
143
                    child.file_id, child.kind
144
                    ))
1852.15.10 by Robert Collins
Tweak the Tree.walkdirs interface more to be more useful.
145
            yield (currentdir[0], entry.file_id), dirblock
1852.15.3 by Robert Collins
Add a first-cut Tree.walkdirs method.
146
            # push the user specified dirs from dirblock
147
            for dir in reversed(dirblock):
148
                if dir[2] == _directory:
149
                    pending.append(dir)