/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to status.py

  • Committer: Jelmer Vernooij
  • Date: 2006-05-19 16:37:13 UTC
  • Revision ID: jelmer@samba.org-20060519163713-be77b31c72cbc7e8
Move visualisation code to a separate directory, preparing for bundling 
the GTK+ plugins for bzr.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006 by Szilveszter Farkas (Phanatic) <szilveszter.farkas@gmail.com>
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
 
try:
18
 
    import pygtk
19
 
    pygtk.require("2.0")
20
 
except:
21
 
    pass
22
 
 
23
 
import gtk
24
 
 
25
 
class StatusDialog(gtk.MessageDialog):
26
 
    """ Display Status window and perform the needed actions. """
27
 
    def __init__(self, wt, wtpath):
28
 
        """ Initialize the Status window. """
29
 
        super(StatusDialog, self).__init__(flags=gtk.DIALOG_MODAL, buttons=gtk.BUTTONS_OK)
30
 
        self.set_title("Working tree changes")
31
 
        self.set_image(gtk.Label("Working tree status"))
32
 
        self._create()
33
 
        self.wt = wt
34
 
        self.wtpath = wtpath
35
 
        # Set the old working tree
36
 
        self.old_tree = self.wt.branch.repository.revision_tree(self.wt.branch.last_revision())
37
 
        # Generate status output
38
 
        self._generate_status()
39
 
 
40
 
    def _create(self):
41
 
        self.set_default_size(400, 300)
42
 
        scrolledwindow = gtk.ScrolledWindow()
43
 
        scrolledwindow.set_policy(gtk.POLICY_AUTOMATIC, gtk.POLICY_AUTOMATIC)
44
 
        self.treeview = gtk.TreeView()
45
 
        scrolledwindow.add(self.treeview)
46
 
        self.vbox.pack_start(scrolledwindow, True, True)
47
 
        self.vbox.show_all()
48
 
 
49
 
    def row_diff(self, tv, path, tvc):
50
 
        file = self.model[path][1]
51
 
        if file is None:
52
 
            return
53
 
        from bzrlib.plugins.gtk.diff import DiffWindow
54
 
        window = DiffWindow()
55
 
        window.set_diff("Working tree changes", self.old_tree, self.wt)
56
 
        window.set_file(file)
57
 
        window.show()
58
 
 
59
 
    def _generate_status(self):
60
 
        """ Generate 'bzr status' output. """
61
 
        self.model = gtk.TreeStore(str, str)
62
 
        self.treeview.set_headers_visible(False)
63
 
        self.treeview.set_model(self.model)
64
 
        self.treeview.connect("row-activated", self.row_diff)
65
 
        
66
 
        cell = gtk.CellRendererText()
67
 
        cell.set_property("width-chars", 20)
68
 
        column = gtk.TreeViewColumn()
69
 
        column.pack_start(cell, expand=True)
70
 
        column.add_attribute(cell, "text", 0)
71
 
        self.treeview.append_column(column)
72
 
        
73
 
        delta = self.wt.changes_from(self.old_tree)
74
 
 
75
 
        changes = False
76
 
        
77
 
        if len(delta.added):
78
 
            changes = True
79
 
            titer = self.model.append(None, [ _('Added'), None ])
80
 
            for path, id, kind in delta.added:
81
 
                self.model.append(titer, [ path, path ])
82
 
 
83
 
        if len(delta.removed):
84
 
            changes = True
85
 
            titer = self.model.append(None, [ _('Removed'), None ])
86
 
            for path, id, kind in delta.removed:
87
 
                self.model.append(titer, [ path, path ])
88
 
 
89
 
        if len(delta.renamed):
90
 
            changes = True
91
 
            titer = self.model.append(None, [ _('Renamed'), None ])
92
 
            for oldpath, newpath, id, kind, text_modified, meta_modified \
93
 
                    in delta.renamed:
94
 
                self.model.append(titer, [ oldpath, newpath ])
95
 
 
96
 
        if len(delta.modified):
97
 
            changes = True
98
 
            titer = self.model.append(None, [ _('Modified'), None ])
99
 
            for path, id, kind, text_modified, meta_modified in delta.modified:
100
 
                self.model.append(titer, [ path, path ])
101
 
        
102
 
        done_unknown = False
103
 
        for path in self.wt.unknowns():
104
 
            changes = True
105
 
            if not done_unknown:
106
 
                titer = self.model.append(None, [ _('Unknown'), None ])
107
 
                done_unknown = True
108
 
            self.model.append(titer, [ path, path ])
109
 
 
110
 
        if not changes:
111
 
            self.model.append(None, [ _('No changes.'), None ])
112
 
 
113
 
        self.treeview.expand_all()
114
 
    
115
 
    def display(self):
116
 
        """ Display the Diff window. """
117
 
        self.window.show_all()
118
 
 
119
 
    def close(self, widget=None):
120
 
        self.window.destroy()