18
17
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25
from paste.httpexceptions import HTTPServerError
23
from cherrypy import InternalError
27
25
from loggerhead import util
28
from loggerhead.controllers import TemplatedBranchView
31
class ChangeLogUI(TemplatedBranchView):
33
template_path = 'loggerhead.templates.changelog'
35
def get_values(self, path, kwargs, headers):
36
history = self._history
37
revid = self.get_revid()
38
filter_file_id = kwargs.get('filter_file_id', None)
39
query = kwargs.get('q', None)
40
start_revid = history.fix_revid(kwargs.get('start_revid', None))
41
orig_start_revid = start_revid
42
pagesize = 20#int(config.get('pagesize', '20'))
45
if filter_file_id is None and path is not None:
46
filter_file_id = history.get_file_id(revid, path)
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
49
revid, start_revid, revid_list = history.get_view(
50
revid, start_revid, filter_file_id, query)
51
util.set_context(kwargs)
53
if (query is not None) and (len(revid_list) == 0):
56
if len(revid_list) == 0:
57
scan_list = revid_list
45
revid = h.fix_revid(args[0])
59
if revid in revid_list: # XXX is this always true?
60
i = revid_list.index(revid)
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
63
scan_list = revid_list[i:]
64
change_list = scan_list[:pagesize]
65
changes = list(history.get_changes(change_list))
67
for i, c in enumerate(changes):
69
data[str(i)] = urllib.quote(urllib.quote(c.revid, safe=''))
71
self.log.exception('Exception fetching changes')
72
raise HTTPServerError('Could not fetch changes')
74
navigation = util.Container(
75
pagesize=pagesize, revid=revid, start_revid=start_revid,
76
revid_list=revid_list, filter_file_id=filter_file_id,
77
scan_url='/changes', branch=self._branch, feed=True, history=history)
79
navigation.query = query
80
util.fill_in_navigation(navigation)
82
# Directory Breadcrumbs
83
directory_breadcrumbs = (
84
util.directory_breadcrumbs(
85
self._branch.friendly_name,
90
for change in changes:
91
if change.tags is not None:
96
'branch': self._branch,
98
'show_tag_col': show_tag_col,
99
'data': simplejson.dumps(data),
103
'navigation': navigation,
104
'filter_file_id': filter_file_id,
105
'start_revid': start_revid,
106
'viewing_from': (orig_start_revid is not None) and
107
(orig_start_revid != history.last_revid),
109
'search_failed': search_failed,
110
'url': self._branch.context_url,
111
'directory_breadcrumbs': directory_breadcrumbs,
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))