33
33
import bzrlib.errors as errors
35
if bzrlib.version_info < (0, 9):
36
# function deprecated after 0.9
37
from bzrlib.delta import compare_trees
39
35
from bzrlib.status import show_tree_status
40
36
from bzrlib.workingtree import WorkingTree
45
41
""" Display Status window and perform the needed actions. """
46
def __init__(self, gladefile, comm, dialog):
42
def __init__(self, gladefile, wt, wtpath):
47
43
""" Initialize the Status window. """
48
44
self.gladefile = gladefile
49
45
self.glade = gtk.glade.XML(self.gladefile, 'window_status')
51
# Communication object
56
47
# Get the Status window widget
57
48
self.window = self.glade.get_widget('window_status')
59
52
# Check if current location is a branch
61
(self.wt, path) = WorkingTree.open_containing(self.comm.get_path())
62
branch = self.wt.branch
63
55
except errors.NotBranchError:
64
56
self.notbranch = True
69
file_id = self.wt.path2id(path)
61
file_id = self.wt.path2id(wtpath)
71
63
self.notbranch = False
72
64
if file_id is None:
98
90
column.add_attribute(cell, "text", 0)
99
91
self.treeview.append_column(column)
101
if bzrlib.version_info < (0, 9):
102
delta = compare_trees(self.old_tree, self.wt)
104
delta = self.wt.changes_from(self.old_tree)
93
delta = self.wt.changes_from(self.old_tree)
106
97
if len(delta.added):
107
99
titer = self.model.append(None, [ _('Added'), None ])
108
100
for path, id, kind in delta.added:
109
101
self.model.append(titer, [ path, path ])
111
103
if len(delta.removed):
112
105
titer = self.model.append(None, [ _('Removed'), None ])
113
106
for path, id, kind in delta.removed:
114
107
self.model.append(titer, [ path, path ])
116
109
if len(delta.renamed):
117
111
titer = self.model.append(None, [ _('Renamed'), None ])
118
112
for oldpath, newpath, id, kind, text_modified, meta_modified \
119
113
in delta.renamed:
120
114
self.model.append(titer, [ oldpath, newpath ])
122
116
if len(delta.modified):
123
118
titer = self.model.append(None, [ _('Modified'), None ])
124
119
for path, id, kind, text_modified, meta_modified in delta.modified:
125
120
self.model.append(titer, [ path, path ])
127
122
done_unknown = False
128
123
for path in self.wt.unknowns():
129
125
if not done_unknown:
130
126
titer = self.model.append(None, [ _('Unknown'), None ])
131
127
done_unknown = True
132
128
self.model.append(titer, [ path, path ])
131
self.model.append(None, [ _('No changes.'), None ])
134
133
self.treeview.expand_all()
136
135
def display(self):
137
136
""" Display the Diff window. """
138
137
if self.notbranch:
139
self.dialog.error_dialog(_('Directory is not a branch'),
138
error_dialog(_('Directory is not a branch'),
140
139
_('You can perform this action only in a branch.'))