~azzar1/unity/add-show-desktop-key

« back to all changes in this revision

Viewing changes to services/svnlogservice

  • Committer: William Grant
  • Date: 2010-02-26 01:09:49 UTC
  • Revision ID: grantw@unimelb.edu.au-20100226010949-xka8c9s6y7aq4id1
Scroll to the end of the console output after *every* output, not just some. This removes some artifiacts resulting from scrolling a fraction of a second too late.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/python
 
2
 
 
3
# IVLE - Informatics Virtual Learning Environment
 
4
# Copyright (C) 2008-2009 The University of Melbourne
 
5
#
 
6
# This program is free software; you can redistribute it and/or modify
 
7
# it under the terms of the GNU General Public License as published by
 
8
# the Free Software Foundation; either version 2 of the License, or
 
9
# (at your option) any later version.
 
10
#
 
11
# This program is distributed in the hope that it will be useful,
 
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
14
# GNU General Public License for more details.
 
15
#
 
16
# You should have received a copy of the GNU General Public License
 
17
# along with this program; if not, write to the Free Software
 
18
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 
19
 
 
20
# Author: William Grant
 
21
 
 
22
'''
 
23
A script for viewing a Subversion log. It is intended to be run via trampoline
 
24
by ivle.webapp.filesystem.svnlog.SubversionLogView.
 
25
'''
 
26
 
 
27
import os
 
28
import sys
 
29
import locale
 
30
 
 
31
import cjson
 
32
import pysvn
 
33
 
 
34
import ivle.svn
 
35
 
 
36
# Set locale to UTF-8
 
37
locale.setlocale(locale.LC_CTYPE, "en_US.UTF-8")
 
38
 
 
39
try:
 
40
    client = pysvn.Client()
 
41
    client.exception_style = 1
 
42
    logs = client.log(os.path.join('/home', sys.argv[1].decode('utf-8')),
 
43
                      discover_changed_paths=True)
 
44
    print cjson.encode({'logs': [{'revno': log.revision.number,
 
45
                                  'author': log.author.decode('utf-8'),
 
46
                                  'message': log.message.decode('utf-8'),
 
47
                                  'date': log.date,
 
48
                                  'paths': [(p.path.decode('utf-8'), p.action)
 
49
                                            for p in log.changed_paths]}
 
50
                                 for log in logs]})
 
51
except pysvn.ClientError, e:
 
52
    error = e[0]
 
53
 
 
54
    try:
 
55
        code = e[1][0][1]
 
56
        # See subversion/include/svn_error_codes.h.
 
57
        # 150000: ERR_ENTRY_NOT_FOUND
 
58
        # 155007: WC_NOT_DIRECTORY.
 
59
        # 160006: FS_NO_SUCH_REVISION
 
60
        # 160013: FS_NOT_FOUND
 
61
        # 200005: UNVERSIONED_RESOURCE
 
62
        if code in (150000, 155007, 160006, 160013, 200005):
 
63
            error = 'notfound'
 
64
        else:
 
65
            error = '%s (code %d)' % (error, code)
 
66
    except IndexError:
 
67
        pass
 
68
 
 
69
    print cjson.encode({'error': error})