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

« back to all changes in this revision

Viewing changes to services/svnlogservice

  • Committer: David Coles
  • Date: 2010-02-23 09:28:32 UTC
  • Revision ID: coles.david@gmail.com-20100223092832-5jsmysvrmdensnhg
exercises: Show error for bad reStructuredText rather than crashing

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})