/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
1
# -*- coding: UTF-8 -*-
2
"""Tree model.
3
4
"""
5
6
__copyright__ = "Copyright © 2005 Canonical Ltd."
7
__author__    = "Gary van der Merwe <garyvdm@gmail.com>"
8
9
10
import gtk
11
import gobject
12
import pango
292.1.1 by Daniel Schierbeck
Removed email address from committer column in the revision history window.
13
import re
413 by Daniel Schierbeck
Made the treeview escape XML in the revision messages.
14
from xml.sax.saxutils import escape
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
15
359 by Daniel Schierbeck
Simplified date format.
16
from time import (strftime, localtime)
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
17
18
REVID = 0
19
NODE = 1
20
LINES = 2
21
LAST_LINES = 3
22
REVNO = 4
23
MESSAGE = 5
24
COMMITER = 6
25
TIMESTAMP = 7
26
REVISION = 8
27
PARENTS = 9
28
CHILDREN = 10
29
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
30
class TreeModel(gtk.GenericTreeModel):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
31
32
    
328 by Jelmer Vernooij
Use repository instead of branch in more places, to make it easier to support multiple branches in viz.
33
    def __init__ (self, repository, line_graph_data):
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
34
        gtk.GenericTreeModel.__init__(self)
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
35
        self.revisions = {}
328 by Jelmer Vernooij
Use repository instead of branch in more places, to make it easier to support multiple branches in viz.
36
        self.repository = repository
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
37
        self.line_graph_data = line_graph_data
38
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
39
    def on_get_flags(self):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
40
        return gtk.TREE_MODEL_LIST_ONLY
41
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
42
    def on_get_n_columns(self):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
43
        return 11
44
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
45
    def on_get_column_type(self, index):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
46
        if index == REVID: return gobject.TYPE_STRING
47
        if index == NODE: return gobject.TYPE_PYOBJECT
48
        if index == LINES: return gobject.TYPE_PYOBJECT
49
        if index == LAST_LINES: return gobject.TYPE_PYOBJECT
50
        if index == REVNO: return gobject.TYPE_STRING
51
        if index == MESSAGE: return gobject.TYPE_STRING
52
        if index == COMMITER: return gobject.TYPE_STRING
53
        if index == TIMESTAMP: return gobject.TYPE_STRING
54
        if index == REVISION: return gobject.TYPE_PYOBJECT
55
        if index == PARENTS: return gobject.TYPE_PYOBJECT
56
        if index == CHILDREN: return gobject.TYPE_PYOBJECT
57
        
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
58
    def on_get_iter(self, path):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
59
        return path[0]
60
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
61
    def on_get_path(self, rowref):
62
        return rowref
63
    
64
    def on_get_value(self, rowref, column):
421.1.1 by Gary van der Merwe
Make viz not throw errors when there are 0 commits.
65
        if len(self.line_graph_data) > 0:
66
            (revid, node, lines, parents,
67
             children, revno_sequence) = self.line_graph_data[rowref]
68
        else:
69
            (revid, node, lines, parents,
70
             children, revno_sequence) = (None, (0, 0), (), (),
71
                                          (), ())
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
72
        if column == REVID: return revid
73
        if column == NODE: return node
74
        if column == LINES: return lines
75
        if column == PARENTS: return parents
76
        if column == CHILDREN: return children
77
        if column == LAST_LINES:
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
78
            if rowref>0:
79
                return self.line_graph_data[rowref-1][2]
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
80
            return []
81
        if column == REVNO: return ".".join(["%d" % (revno)
82
                                      for revno in revno_sequence])
83
        
421.1.1 by Gary van der Merwe
Make viz not throw errors when there are 0 commits.
84
        if revid is None:
85
            return None
256.2.41 by Gary van der Merwe
Revert GTKTreeModel on_ref_node implementation.
86
        if revid not in self.revisions:
328 by Jelmer Vernooij
Use repository instead of branch in more places, to make it easier to support multiple branches in viz.
87
            revision = self.repository.get_revisions([revid])[0]
256.2.41 by Gary van der Merwe
Revert GTKTreeModel on_ref_node implementation.
88
            self.revisions[revid] = revision
89
        else:
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
90
            revision = self.revisions[revid]
256.2.41 by Gary van der Merwe
Revert GTKTreeModel on_ref_node implementation.
91
        
92
        if column == REVISION: return revision
414 by Daniel Schierbeck
Switched to using Revision.get_summary() to get the first line of a revision's log message instead of home brewn code.
93
        if column == MESSAGE: return escape(revision.get_summary())
292.1.1 by Daniel Schierbeck
Removed email address from committer column in the revision history window.
94
        if column == COMMITER: return re.sub('<.*@.*>', '', 
95
                                             revision.committer).strip(' ')
359 by Daniel Schierbeck
Simplified date format.
96
        if column == TIMESTAMP: 
97
            return strftime("%Y-%m-%d %H:%M", localtime(revision.timestamp))
98
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
99
    def on_iter_next(self, rowref):
100
        if rowref < len(self.line_graph_data) - 1:
101
            return rowref+1
102
        return None
103
    
104
    def on_iter_children(self, parent):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
105
        if parent is None: return 0
106
        return None
107
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
108
    def on_iter_has_child(self, rowref):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
109
        return False
110
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
111
    def on_iter_n_children(self, rowref):
112
        if rowref is None: return len(self.line_graph_data)
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
113
        return 0
114
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
115
    def on_iter_nth_child(self, parent, n):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
116
        if parent is None: return n
117
        return None
118
    
256.2.36 by Gary van der Merwe
Revert back to GenericTreeModel and implement on_ref_node
119
    def on_iter_parent(self, child):
256.2.29 by Gary van der Merwe
Implement a TreeModel that loads revisions incrementaly.
120
        return None