1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
#!/usr/bin/env python
# IVLE - Informatics Virtual Learning Environment
# Copyright (C) 2007-2008 The University of Melbourne
#
# 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; either version 2 of the License, or
# (at your option) any later version.
#
# 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 St, Fifth Floor, Boston, MA 02110-1301 USA
# Module: setup
# Author: Matt Giuca
# Date: 12/12/2007
# This is a command-line application, for use by the administrator.
# This program is a frontend for the modules in the setup packages that
# configure, build and install IVLE in three separate steps.
# It is called with at least one argument, which specifies which operation to
# take.
import sys
import setup.configure
import setup.build
import setup.install
import setup.listmake
def main(argv=None):
if argv is None:
argv = sys.argv
# Print the opening spiel including the GPL notice
print """IVLE - Informatics Virtual Learning Environment Setup
Copyright (C) 2007-2008 The University of Melbourne
IVLE comes with ABSOLUTELY NO WARRANTY.
This is free software, and you are welcome to redistribute it
under certain conditions. See LICENSE.txt for details.
IVLE Setup
"""
# First argument is the name of the setup operation
try:
operation = argv[1]
except IndexError:
# Print usage message and exit
help([])
return 1
oper_func = call_operator(operation)
return oper_func(argv[2:])
def help(args):
if len(args)!=1:
print """Usage: python setup.py operation [options]
Operation (and options) can be:
help [operation]
listmake (developer use only)
config [args]
build
install [--nojail] [--nosubjects] [-n|--dry]
For help on a specific operation use 'help [operation]'."""
else:
operator = args[0]
oper_func = call_operator(operator)
oper_func(['operator','--help'])
def call_operator(operation):
# Call the requested operation's function
try:
oper_func = {
'help' : help,
'config' : setup.configure.configure,
'build' : setup.build.build,
'listmake' : setup.listmake.listmake,
'install' : setup.install.install,
#'updatejails' : None,
}[operation]
except KeyError:
print >>sys.stderr, (
"""Invalid operation '%s'. Try python setup.py help."""
% operation)
sys.exit(1)
return oper_func
if __name__ == "__main__":
sys.exit(main())
|