21
21
pygtk.require("2.0")
33
31
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
33
from bzrlib.status import show_tree_status
40
34
from bzrlib.workingtree import WorkingTree
42
from dialog import OliveDialog
36
from dialog import error_dialog
38
from olive import gladefile
45
41
""" Display Status window and perform the needed actions. """
46
def __init__(self, gladefile, comm, dialog):
42
def __init__(self, wt, wtpath):
47
43
""" Initialize the Status window. """
48
self.gladefile = gladefile
49
self.glade = gtk.glade.XML(self.gladefile, 'window_status')
51
# Communication object
44
self.glade = gtk.glade.XML(gladefile, 'window_status')
56
46
# Get the Status window widget
57
47
self.window = self.glade.get_widget('window_status')
59
51
# Check if current location is a branch
61
(self.wt, path) = WorkingTree.open_containing(self.comm.get_path())
62
branch = self.wt.branch
63
except errors.NotBranchError:
69
file_id = self.wt.path2id(path)
52
file_id = self.wt.path2id(wtpath)
71
self.notbranch = False
76
54
# Set the old working tree
77
55
self.old_tree = self.wt.branch.repository.revision_tree(self.wt.branch.last_revision())
98
76
column.add_attribute(cell, "text", 0)
99
77
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)
79
delta = self.wt.changes_from(self.old_tree)
106
83
if len(delta.added):
107
85
titer = self.model.append(None, [ _('Added'), None ])
108
86
for path, id, kind in delta.added:
109
87
self.model.append(titer, [ path, path ])
111
89
if len(delta.removed):
112
91
titer = self.model.append(None, [ _('Removed'), None ])
113
92
for path, id, kind in delta.removed:
114
93
self.model.append(titer, [ path, path ])
116
95
if len(delta.renamed):
117
97
titer = self.model.append(None, [ _('Renamed'), None ])
118
98
for oldpath, newpath, id, kind, text_modified, meta_modified \
120
100
self.model.append(titer, [ oldpath, newpath ])
122
102
if len(delta.modified):
123
104
titer = self.model.append(None, [ _('Modified'), None ])
124
105
for path, id, kind, text_modified, meta_modified in delta.modified:
125
106
self.model.append(titer, [ path, path ])
127
108
done_unknown = False
128
109
for path in self.wt.unknowns():
129
111
if not done_unknown:
130
112
titer = self.model.append(None, [ _('Unknown'), None ])
131
113
done_unknown = True
132
114
self.model.append(titer, [ path, path ])
117
self.model.append(None, [ _('No changes.'), None ])
134
119
self.treeview.expand_all()
136
121
def display(self):
137
122
""" Display the Diff window. """
139
self.dialog.error_dialog(_('Directory is not a branch'),
140
_('You can perform this action only in a branch.'))
143
self.window.show_all()
123
self.window.show_all()
145
125
def close(self, widget=None):
146
126
self.window.destroy()