##// END OF EJS Templates
few validation bugfixes/ new repo changesets, first commit changesets
few validation bugfixes/ new repo changesets, first commit changesets

File last commit:

r282:237470e6 default
r285:42f5c368 default
Show More
changelog.py
96 lines | 3.3 KiB | text/x-python | PythonLexer
licensing updates, code cleanups
r252 #!/usr/bin/env python
# encoding: utf-8
# changelog 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
changelog controller for pylons
@author: marcink
"""
Reimplemented way of caching repos list, hg model now get's repos objects right from cached dict, this way we skipp creating instances of MercurialRepository and gain performance. Some import cleanup
r245 from pylons import request, session, tmpl_context as c
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 from pylons_app.lib.auth import LoginRequired
Reimplemented way of caching repos list, hg model now get's repos objects right from cached dict, this way we skipp creating instances of MercurialRepository and gain performance. Some import cleanup
r245 from pylons_app.lib.base import BaseController, render
changed way of getting repository in changelog. + some code cleanups
r276 from pylons_app.model.hg_model import HgModel
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 from webhelpers.paginate import Page
import logging
moved all cache function out to Base Controller for easier maintainance
r196 log = logging.getLogger(__name__)
added empty controllers for branches tags files graph, routing and test for them
r93
class ChangelogController(BaseController):
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192
@LoginRequired()
added empty controllers for branches tags files graph, routing and test for them
r93 def __before__(self):
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 super(ChangelogController, self).__before__()
added empty controllers for branches tags files graph, routing and test for them
r93 def index(self):
bugfix
r213 limit = 100
default = 20
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 if request.params.get('size'):
version bump. Bugfix when changelog parameter was not an int. Added limit for 100 changelogs to view at once.
r211 try:
int_size = int(request.params.get('size'))
except ValueError:
int_size = default
int_size = int_size if int_size <= limit else limit
c.size = int_size
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 session['changelog_size'] = c.size
session.save()
Changeg graph to changelog, and changelog to shortlog
r142 else:
switched filters into webhelpers for easy of usage....
r282 c.size = int(session.get('changelog_size', default))
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192
changed way of getting repository in changelog. + some code cleanups
r276 changesets = HgModel().get_repo(c.repo_name)
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192
p = int(request.params.get('page', 1))
switched filters into webhelpers for easy of usage....
r282 c.total_cs = len(changesets)
c.pagination = Page(changesets, page=p, item_count=c.total_cs,
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 items_per_page=c.size)
#self._graph(c.repo, c.size,p)
Changeg graph to changelog, and changelog to shortlog
r142
return render('changelog/changelog.html')
full changelog caching, secured changelog with LoginRequired, some minor changes in graph
r192 def _graph(self, repo, size, p):
licensing updates, code cleanups
r252 pass
# revcount = size
# if not repo.revisions:return dumps([]), 0
#
# max_rev = repo.revisions[-1]
# offset = 1 if p == 1 else ((p - 1) * revcount)
# rev_start = repo.revisions[(-1 * offset)]
# c.bg_height = 120
#
# revcount = min(max_rev, revcount)
# rev_end = max(0, rev_start - revcount)
# dag = graph_rev(repo.repo, rev_start, rev_end)
#
# c.dag = tree = list(colored(dag))
# canvasheight = (len(tree) + 1) * c.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()))
#
# c.jsdata = dumps(data)
# c.canvasheight = canvasheight
Changeg graph to changelog, and changelog to shortlog
r142