17
17
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23
from cherrypy import InternalError
20
from paste.httpexceptions import HTTPServerError
25
22
from loggerhead import util
28
class ChangeLogUI (object):
30
def __init__(self, branch):
35
@util.strip_whitespace
36
@turbogears.expose(html='loggerhead.templates.changelog')
37
def default(self, *args, **kw):
39
h = self._branch.get_history()
40
config = self._branch.config
23
from loggerhead.controllers import TemplatedBranchView
26
class ChangeLogUI(TemplatedBranchView):
28
template_path = 'loggerhead.templates.changelog'
30
def get_values(self, h, args, kw, headers):
32
revid = h.fix_revid(args[0])
36
filter_file_id = kw.get('filter_file_id', None)
37
query = kw.get('q', None)
38
start_revid = h.fix_revid(kw.get('start_revid', None))
39
orig_start_revid = start_revid
40
pagesize = 20#int(config.get('pagesize', '20'))
45
revid = h.fix_revid(args[0])
44
revid, start_revid, revid_list = h.get_view(
45
revid, start_revid, filter_file_id, query)
48
if (query is not None) and (len(revid_list) == 0):
51
if len(revid_list) == 0:
52
scan_list = revid_list
49
file_id = kw.get('file_id', None)
50
query = kw.get('q', None)
51
start_revid = h.fix_revid(kw.get('start_revid', None))
52
orig_start_revid = start_revid
53
pagesize = int(config.get('pagesize', '20'))
57
revid, start_revid, revid_list = h.get_view(revid, start_revid, file_id, query)
58
kw['start_revid'] = start_revid
61
if (query is not None) and (len(revid_list) == 0):
64
if len(revid_list) == 0:
65
scan_list = revid_list
54
if revid in revid_list: # XXX is this always true?
55
i = revid_list.index(revid)
67
if revid in revid_list: # XXX is this always true?
68
i = revid_list.index(revid)
71
scan_list = revid_list[i:]
72
change_list = scan_list[:pagesize]
73
changes = list(h.get_changes(change_list))
74
h.add_changes(changes)
76
self.log.exception('Exception fetching changes')
77
raise InternalError('Could not fetch changes')
79
navigation = util.Container(pagesize=pagesize, revid=revid, start_revid=start_revid, revid_list=revid_list,
80
file_id=file_id, scan_url='/changes', branch=self._branch, feed=True)
82
navigation.query = query
83
util.fill_in_navigation(navigation)
85
# add parent & merge-point branch-nick info, in case it's useful
86
h.get_branch_nicks(changes)
88
# does every change on this page have the same committer? if so,
89
# tell the template to show committer info in the "details block"
90
# instead of on each line.
91
all_same_author = True
94
author = changes[0].author
96
if e.author != author:
97
all_same_author = False
101
'branch': self._branch,
106
'navigation': navigation,
108
'start_revid': start_revid,
109
'viewing_from': (orig_start_revid is not None) and (orig_start_revid != h.last_revid),
111
'search_failed': search_failed,
112
'all_same_author': all_same_author,
115
self.log.info('/changes %r: %r secs' % (revid, time.time() - z))
58
scan_list = revid_list[i:]
59
change_list = scan_list[:pagesize]
60
changes = list(h.get_changes(change_list))
61
h.add_changes(changes)
63
self.log.exception('Exception fetching changes')
64
raise HTTPServerError('Could not fetch changes')
66
navigation = util.Container(
67
pagesize=pagesize, revid=revid, start_revid=start_revid,
68
revid_list=revid_list, filter_file_id=filter_file_id,
69
scan_url='/changes', branch=self._branch, feed=True, history=h)
71
navigation.query = query
72
util.fill_in_navigation(navigation)
74
# add parent & merge-point branch-nick info, in case it's useful
75
h.get_branch_nicks(changes)
77
# does every change on this page have the same committer? if so,
78
# tell the template to show committer info in the "details block"
79
# instead of on each line.
80
all_same_author = True
83
author = changes[0].author
85
if e.author != author:
86
all_same_author = False
90
'branch': self._branch,
95
'navigation': navigation,
96
'filter_file_id': filter_file_id,
97
'start_revid': start_revid,
98
'viewing_from': (orig_start_revid is not None) and (orig_start_revid != h.last_revid),
100
'search_failed': search_failed,
101
'all_same_author': all_same_author,
102
'url': self._branch.context_url,