14
14
# along with this program; if not, write to the Free Software
15
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21
19
pygtk.require("2.0")
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
from bzrlib.status import show_tree_status
40
from bzrlib.workingtree import WorkingTree
42
from dialog import OliveDialog
26
from guifiles import GLADEFILENAME
45
30
""" Display Status window and perform the needed actions. """
46
def __init__(self, gladefile, comm, dialog):
31
def __init__(self, wt, wtpath):
47
32
""" Initialize the Status window. """
48
self.gladefile = gladefile
49
self.glade = gtk.glade.XML(self.gladefile, 'window_status')
51
# Communication object
33
self.glade = gtk.glade.XML(GLADEFILENAME, 'window_status')
56
35
# Get the Status window widget
57
36
self.window = self.glade.get_widget('window_status')
59
41
# 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)
42
file_id = self.wt.path2id(wtpath)
71
self.notbranch = False
76
44
# Set the old working tree
77
45
self.old_tree = self.wt.branch.repository.revision_tree(self.wt.branch.last_revision())
98
66
column.add_attribute(cell, "text", 0)
99
67
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)
69
delta = self.wt.changes_from(self.old_tree)
106
73
if len(delta.added):
107
75
titer = self.model.append(None, [ _('Added'), None ])
108
76
for path, id, kind in delta.added:
109
77
self.model.append(titer, [ path, path ])
111
79
if len(delta.removed):
112
81
titer = self.model.append(None, [ _('Removed'), None ])
113
82
for path, id, kind in delta.removed:
114
83
self.model.append(titer, [ path, path ])
116
85
if len(delta.renamed):
117
87
titer = self.model.append(None, [ _('Renamed'), None ])
118
88
for oldpath, newpath, id, kind, text_modified, meta_modified \
120
90
self.model.append(titer, [ oldpath, newpath ])
122
92
if len(delta.modified):
123
94
titer = self.model.append(None, [ _('Modified'), None ])
124
95
for path, id, kind, text_modified, meta_modified in delta.modified:
125
96
self.model.append(titer, [ path, path ])
127
98
done_unknown = False
128
99
for path in self.wt.unknowns():
129
101
if not done_unknown:
130
102
titer = self.model.append(None, [ _('Unknown'), None ])
131
103
done_unknown = True
132
104
self.model.append(titer, [ path, path ])
107
self.model.append(None, [ _('No changes.'), None ])
134
109
self.treeview.expand_all()
136
111
def display(self):
137
112
""" 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()
113
self.window.show_all()
145
115
def close(self, widget=None):
146
116
self.window.destroy()