graph.py
84 lines
| 3.1 KiB
| text/x-python
|
PythonLexer
r252 | #!/usr/bin/env python | |||
# encoding: utf-8 | ||||
# graph controller for pylons | ||||
# Copyright (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com> | ||||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; version 2 | ||||
# of the License or (at your opinion) any later version of the license. | ||||
# | ||||
# This program is distributed in the hope that it will be useful, | ||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
# | ||||
# You should have received a copy of the GNU General Public License | ||||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, | ||||
# MA 02110-1301, USA. | ||||
""" | ||||
Created on April 21, 2010 | ||||
graph controller for pylons | ||||
@author: marcink | ||||
""" | ||||
r191 | from mercurial.graphmod import revisions as graph_rev, colored, CHANGESET | |||
from mercurial.node import short | ||||
r252 | from pylons import request, tmpl_context as c | |||
r191 | from pylons_app.lib.auth import LoginRequired | |||
r106 | from pylons_app.lib.base import BaseController, render | |||
r191 | from pylons_app.lib.filters import age as _age, person | |||
r106 | from pylons_app.model.hg_model import HgModel | |||
r191 | from simplejson import dumps | |||
from webhelpers.paginate import Page | ||||
import logging | ||||
r93 | ||||
log = logging.getLogger(__name__) | ||||
class GraphController(BaseController): | ||||
r191 | ||||
@LoginRequired() | ||||
r106 | def __before__(self): | |||
r191 | super(GraphController, self).__before__() | |||
r106 | ||||
r93 | def index(self): | |||
# Return a rendered template | ||||
r106 | hg_model = HgModel() | |||
if request.POST.get('size'): | ||||
c.size = int(request.params.get('size', 20)) | ||||
else: | ||||
c.size = int(request.params.get('size', 20)) | ||||
c.jsdata, c.canvasheight = self.graph(hg_model.get_repo(c.repo_name), c.size) | ||||
return render('/graph.html') | ||||
def graph(self, repo, size): | ||||
revcount = size | ||||
p = int(request.params.get('page', 1)) | ||||
c.pagination = Page(repo.revisions, page=p, item_count=len(repo.revisions), items_per_page=revcount) | ||||
r137 | if not repo.revisions:return dumps([]), 0 | |||
r106 | max_rev = repo.revisions[-1] | |||
offset = 1 if p == 1 else ((p - 1) * revcount) | ||||
rev_start = repo.revisions[(-1 * offset)] | ||||
bg_height = 39 | ||||
revcount = min(max_rev, revcount) | ||||
rev_end = max(0, rev_start - revcount) | ||||
dag = graph_rev(repo.repo, rev_start, rev_end) | ||||
tree = list(colored(dag)) | ||||
canvasheight = (len(tree) + 1) * bg_height - 27 | ||||
data = [] | ||||
for (id, type, ctx, vtx, edges) in tree: | ||||
if type != CHANGESET: | ||||
continue | ||||
node = short(ctx.node()) | ||||
age = _age(ctx.date()) | ||||
desc = ctx.description() | ||||
user = person(ctx.user()) | ||||
branch = ctx.branch() | ||||
branch = branch, repo.repo.branchtags().get(branch) == ctx.node() | ||||
data.append((node, vtx, edges, desc, user, age, branch, ctx.tags())) | ||||
return dumps(data), canvasheight | ||||