##// END OF EJS Templates
Implemented mercurial style diff-lib
marcink -
r131:49c7e191 default
parent child Browse files
Show More
@@ -1,60 +1,62 b''
1 import logging
1 import logging
2
2
3 from pylons import request, response, session, tmpl_context as c, url, config, app_globals as g
3 from pylons import request, response, session, tmpl_context as c, url, config, app_globals as g
4 from pylons.controllers.util import abort, redirect
4 from pylons.controllers.util import abort, redirect
5
5
6 from pylons_app.lib.base import BaseController, render
6 from pylons_app.lib.base import BaseController, render
7 from pylons_app.lib.utils import get_repo_slug
7 from pylons_app.lib.utils import get_repo_slug
8 from pylons_app.model.hg_model import HgModel
8 from pylons_app.model.hg_model import HgModel
9 from difflib import unified_diff
10 from pylons_app.lib.differ import render_udiff
11
9 log = logging.getLogger(__name__)
12 log = logging.getLogger(__name__)
10
13
11 class FilesController(BaseController):
14 class FilesController(BaseController):
12 def __before__(self):
15 def __before__(self):
13 c.repos_prefix = config['repos_name']
16 c.repos_prefix = config['repos_name']
14 c.repo_name = get_repo_slug(request)
17 c.repo_name = get_repo_slug(request)
15
18
16 def index(self, repo_name, revision, f_path):
19 def index(self, repo_name, revision, f_path):
17 hg_model = HgModel()
20 hg_model = HgModel()
18 c.repo = repo = hg_model.get_repo(c.repo_name)
21 c.repo = repo = hg_model.get_repo(c.repo_name)
19 c.cur_rev = revision
22 c.cur_rev = revision
20 c.f_path = f_path
23 c.f_path = f_path
21 c.changeset = repo.get_changeset(repo._get_revision(revision))
24 c.changeset = repo.get_changeset(repo._get_revision(revision))
22
25
23 c.files_list = c.changeset.get_node(f_path)
26 c.files_list = c.changeset.get_node(f_path)
24
27
25 c.file_history = self._get_history(repo, c.files_list, f_path)
28 c.file_history = self._get_history(repo, c.files_list, f_path)
26 return render('files/files.html')
29 return render('files/files.html')
27
30
28 def diff(self, repo_name, f_path):
31 def diff(self, repo_name, f_path):
29 hg_model = HgModel()
32 hg_model = HgModel()
30 diff1 = request.GET.get('diff1')
33 diff1 = request.GET.get('diff1')
31 diff2 = request.GET.get('diff2')
34 diff2 = request.GET.get('diff2')
35 c.no_changes = diff1 == diff2
32 c.f_path = f_path
36 c.f_path = f_path
33 c.repo = hg_model.get_repo(c.repo_name)
37 c.repo = hg_model.get_repo(c.repo_name)
34 c.changeset_1 = c.repo.get_changeset(diff1)
38 c.changeset_1 = c.repo.get_changeset(diff1)
35 c.changeset_2 = c.repo.get_changeset(diff2)
39 c.changeset_2 = c.repo.get_changeset(diff2)
36
40
37 c.file_1 = c.changeset_1.get_node(f_path).content
41 c.file_1 = c.changeset_1.get_node(f_path).content
38 c.file_2 = c.changeset_2.get_node(f_path).content
42 c.file_2 = c.changeset_2.get_node(f_path).content
39 c.diff1 = 'r%s:%s' % (c.changeset_1.revision, c.changeset_1._short)
43 c.diff1 = 'r%s:%s' % (c.changeset_1.revision, c.changeset_1._short)
40 c.diff2 = 'r%s:%s' % (c.changeset_2.revision, c.changeset_2._short)
44 c.diff2 = 'r%s:%s' % (c.changeset_2.revision, c.changeset_2._short)
41 from difflib import unified_diff
42 d = unified_diff(c.file_1.splitlines(1), c.file_2.splitlines(1))
43 c.diff = ''.join(d)
44
45
45 from pylons_app.lib.differ import render_udiff
46 d2 = unified_diff(c.file_1.splitlines(1), c.file_2.splitlines(1))
46 d2 = unified_diff(c.file_1.splitlines(1), c.file_2.splitlines(1))
47 c.diff_2 = render_udiff(udiff=d2)
47 c.diff_files = render_udiff(udiff=d2)
48
48
49 if len(c.diff_files) < 1:
50 c.no_changes = True
49 return render('files/file_diff.html')
51 return render('files/file_diff.html')
50
52
51 def _get_history(self, repo, node, f_path):
53 def _get_history(self, repo, node, f_path):
52 from vcs.nodes import NodeKind
54 from vcs.nodes import NodeKind
53 if not node.kind is NodeKind.FILE:
55 if not node.kind is NodeKind.FILE:
54 return []
56 return []
55 changesets = node.history
57 changesets = node.history
56 hist_l = []
58 hist_l = []
57 for chs in changesets:
59 for chs in changesets:
58 n_desc = 'r%s:%s' % (chs.revision, chs._short)
60 n_desc = 'r%s:%s' % (chs.revision, chs._short)
59 hist_l.append((chs._short, n_desc,))
61 hist_l.append((chs._short, n_desc,))
60 return hist_l
62 return hist_l
General Comments 0
You need to be logged in to leave comments. Login now