##// END OF EJS Templates
merged with ldap fix
merged with ldap fix

File last commit:

r691:7486da5f beta
r795:ffd96705 merge beta
Show More
changeset.py
187 lines | 7.3 KiB | text/x-python | PythonLexer
renamed project to rhodecode
r547 #!/usr/bin/env python
# encoding: utf-8
# changeset 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 25, 2010
changeset controller for pylons
@author: marcink
"""
from pylons import tmpl_context as c, url, request, response
from pylons.i18n.translation import _
from pylons.controllers.util import redirect
from rhodecode.lib.auth import LoginRequired, HasRepoPermissionAnyDecorator
from rhodecode.lib.base import BaseController, render
fixed raw diff as purly raw without html
r649 from rhodecode.lib.utils import EmptyChangeset
some changes for #45....
r644 import rhodecode.lib.helpers as h
Refactor codes for scm model...
r691 from rhodecode.model.scm import ScmModel
renamed project to rhodecode
r547 from vcs.exceptions import RepositoryError, ChangesetError
from vcs.nodes import FileNode
from vcs.utils import diffs as differ
import logging
import traceback
log = logging.getLogger(__name__)
class ChangesetController(BaseController):
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 @LoginRequired()
@HasRepoPermissionAnyDecorator('repository.read', 'repository.write',
Fixes for raw_id, needed for git...
r636 'repository.admin')
renamed project to rhodecode
r547 def __before__(self):
super(ChangesetController, self).__before__()
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 def index(self, revision):
Refactor codes for scm model...
r691 hg_model = ScmModel()
large initial commits fixup...
r566 cut_off_limit = 1024 * 250
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 def wrap_to_table(str):
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 return '''<table class="code-difftable">
<tr class="line">
<td class="lineno new"></td>
<td class="code"><pre>%s</pre></td>
</tr>
</table>''' % str
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 try:
c.changeset = hg_model.get_repo(c.repo_name).get_changeset(revision)
some changes for #45....
r644 except RepositoryError, e:
renamed project to rhodecode
r547 log.error(traceback.format_exc())
some changes for #45....
r644 h.flash(str(e), category='warning')
Fixes for raw_id, needed for git...
r636 return redirect(url('home'))
renamed project to rhodecode
r547 else:
try:
c.changeset_old = c.changeset.parents[0]
except IndexError:
c.changeset_old = None
c.changes = []
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 #===================================================================
# ADDED FILES
#===================================================================
c.sum_added = 0
for node in c.changeset.added:
Fixes for raw_id, needed for git...
r636
large initial commits fixup...
r566 filenode_old = FileNode(node.path, '', EmptyChangeset())
renamed project to rhodecode
r547 if filenode_old.is_binary or node.is_binary:
diff = wrap_to_table(_('binary file'))
else:
c.sum_added += node.size
if c.sum_added < cut_off_limit:
f_udiff = differ.get_udiff(filenode_old, node)
diff = differ.DiffProcessor(f_udiff).as_html()
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 else:
diff = wrap_to_table(_('Changeset is to big and was cut'
' off, see raw changeset instead'))
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 cs1 = None
Fixes for raw_id, needed for git...
r636 cs2 = node.last_changeset.raw_id
renamed project to rhodecode
r547 c.changes.append(('added', node, diff, cs1, cs2))
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 #===================================================================
# CHANGED FILES
#===================================================================
Fixes for raw_id, needed for git...
r636 c.sum_removed = 0
renamed project to rhodecode
r547 for node in c.changeset.changed:
try:
filenode_old = c.changeset_old.get_node(node.path)
except ChangesetError:
large initial commits fixup...
r566 filenode_old = FileNode(node.path, '', EmptyChangeset())
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 if filenode_old.is_binary or node.is_binary:
diff = wrap_to_table(_('binary file'))
else:
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 if c.sum_removed < cut_off_limit:
f_udiff = differ.get_udiff(filenode_old, node)
diff = differ.DiffProcessor(f_udiff).as_html()
large initial commits fixup...
r566 if diff:
c.sum_removed += len(diff)
renamed project to rhodecode
r547 else:
diff = wrap_to_table(_('Changeset is to big and was cut'
' off, see raw changeset instead'))
Fixes for raw_id, needed for git...
r636
cs1 = filenode_old.last_changeset.raw_id
cs2 = node.last_changeset.raw_id
renamed project to rhodecode
r547 c.changes.append(('changed', node, diff, cs1, cs2))
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 #===================================================================
# REMOVED FILES
#===================================================================
for node in c.changeset.removed:
Fixes for raw_id, needed for git...
r636 c.changes.append(('removed', node, None, None, None))
renamed project to rhodecode
r547 return render('changeset/changeset.html')
def raw_changeset(self, revision):
Fixes for raw_id, needed for git...
r636
Refactor codes for scm model...
r691 hg_model = ScmModel()
renamed project to rhodecode
r547 method = request.GET.get('diff', 'show')
try:
Small fixes for style....
r648 r = hg_model.get_repo(c.repo_name)
c.scm_type = r.alias
c.changeset = r.get_changeset(revision)
renamed project to rhodecode
r547 except RepositoryError:
log.error(traceback.format_exc())
Fixes for raw_id, needed for git...
r636 return redirect(url('home'))
renamed project to rhodecode
r547 else:
try:
c.changeset_old = c.changeset.parents[0]
except IndexError:
c.changeset_old = None
c.changes = []
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 for node in c.changeset.added:
filenode_old = FileNode(node.path, '')
if filenode_old.is_binary or node.is_binary:
fixed raw diff breakline bug
r650 diff = _('binary file') +'\n'
Fixes for raw_id, needed for git...
r636 else:
renamed project to rhodecode
r547 f_udiff = differ.get_udiff(filenode_old, node)
diff = differ.DiffProcessor(f_udiff).raw_diff()
cs1 = None
Fixes for raw_id, needed for git...
r636 cs2 = node.last_changeset.raw_id
renamed project to rhodecode
r547 c.changes.append(('added', node, diff, cs1, cs2))
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 for node in c.changeset.changed:
filenode_old = c.changeset_old.get_node(node.path)
if filenode_old.is_binary or node.is_binary:
diff = _('binary file')
Fixes for raw_id, needed for git...
r636 else:
renamed project to rhodecode
r547 f_udiff = differ.get_udiff(filenode_old, node)
diff = differ.DiffProcessor(f_udiff).raw_diff()
Fixes for raw_id, needed for git...
r636 cs1 = filenode_old.last_changeset.raw_id
cs2 = node.last_changeset.raw_id
c.changes.append(('changed', node, diff, cs1, cs2))
renamed project to rhodecode
r547 response.content_type = 'text/plain'
fixed raw diff breakline bug
r650
renamed project to rhodecode
r547 if method == 'download':
Fixes for raw_id, needed for git...
r636 response.content_disposition = 'attachment; filename=%s.patch' % revision
fixed raw diff breakline bug
r650
renamed project to rhodecode
r547 parent = True if len(c.changeset.parents) > 0 else False
c.parent_tmpl = 'Parent %s' % c.changeset.parents[0].raw_id if parent else ''
Fixes for raw_id, needed for git...
r636
renamed project to rhodecode
r547 c.diffs = ''
for x in c.changes:
c.diffs += x[2]
fixed raw diff as purly raw without html
r649
renamed project to rhodecode
r547 return render('changeset/raw_changeset.html')