/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: John Arbash Meinel
  • Date: 2006-08-18 22:17:03 UTC
  • mto: This revision was merged to the branch mainline in revision 1989.
  • Revision ID: john@arbash-meinel.com-20060818221703-958786fafe340fd9
2 changes to knits. Delay creating the .knit or .kndx file until we have actually tried to write data. Because of this, we must allow the Knit to create the prefix directories

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
        assert inv.root is not None
 
44
        self._revision_id = revision_id
 
45
 
 
46
    def get_parent_ids(self):
 
47
        """See Tree.get_parent_ids.
 
48
 
 
49
        A RevisionTree's parents match the revision graph.
 
50
        """
 
51
        parent_ids = self._repository.get_revision(self._revision_id).parent_ids
 
52
        return parent_ids
 
53
        
 
54
    def get_revision_id(self):
 
55
        """Return the revision id associated with this tree."""
 
56
        return self._revision_id
 
57
 
 
58
    def get_weave(self, file_id):
 
59
        return self._weave_store.get_weave(file_id,
 
60
                self._repository.get_transaction())
 
61
 
 
62
    def get_file_lines(self, file_id):
 
63
        ie = self._inventory[file_id]
 
64
        weave = self.get_weave(file_id)
 
65
        return weave.get_lines(ie.revision)
 
66
 
 
67
    def get_file_text(self, file_id):
 
68
        return ''.join(self.get_file_lines(file_id))
 
69
 
 
70
    def get_file(self, file_id):
 
71
        return StringIO(self.get_file_text(file_id))
 
72
 
 
73
    def get_file_size(self, file_id):
 
74
        return self._inventory[file_id].text_size
 
75
 
 
76
    def get_file_sha1(self, file_id, path=None):
 
77
        ie = self._inventory[file_id]
 
78
        if ie.kind == "file":
 
79
            return ie.text_sha1
 
80
        return None
 
81
 
 
82
    def get_file_mtime(self, file_id, path=None):
 
83
        ie = self._inventory[file_id]
 
84
        revision = self._repository.get_revision(ie.revision)
 
85
        return revision.timestamp
 
86
 
 
87
    def is_executable(self, file_id, path=None):
 
88
        ie = self._inventory[file_id]
 
89
        if ie.kind != "file":
 
90
            return None 
 
91
        return self._inventory[file_id].executable
 
92
 
 
93
    def has_filename(self, filename):
 
94
        return bool(self.inventory.path2id(filename))
 
95
 
 
96
    def list_files(self):
 
97
        # The only files returned by this are those from the version
 
98
        entries = self.inventory.iter_entries()
 
99
        # skip the root for compatability with the current apis.
 
100
        entries.next()
 
101
        for path, entry in entries:
 
102
            yield path, 'V', entry.kind, entry.file_id, entry
 
103
 
 
104
    def get_symlink_target(self, file_id):
 
105
        ie = self._inventory[file_id]
 
106
        return ie.symlink_target;
 
107
 
 
108
    def kind(self, file_id):
 
109
        return self._inventory[file_id].kind
 
110
 
 
111
    def lock_read(self):
 
112
        self._repository.lock_read()
 
113
 
 
114
    def unlock(self):
 
115
        self._repository.unlock()
 
116
 
 
117