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

« back to all changes in this revision

Viewing changes to setup.py

  • Committer: mattgiuca
  • Date: 2008-02-01 05:48:34 UTC
  • Revision ID: svn-v3-trunk0:2b9c9e99-6f39-0410-b283-7f802c844ae2:trunk:371
setup.py: Fixed chmodding python-console. (Turns out this was a bug in setup,
    not a missing action).

Show diffs side-by-side

added added

removed removed

Lines of Context:
35
35
# Configures IVLE with machine-specific details, most notably, various paths.
36
36
# Either prompts the administrator for these details or accepts them as
37
37
# command-line args.
38
 
# Creates lib/conf/conf.py and trampoline/conf.h.
 
38
# Creates www/conf/conf.py and trampoline/conf.h.
39
39
 
40
40
# setup.py build
41
41
# Compiles all files and sets up a jail template in the source directory.
70
70
 
71
71
# Import modules from the website is tricky since they're in the www
72
72
# directory.
73
 
sys.path.append(os.path.join(os.getcwd(), 'lib'))
 
73
sys.path.append(os.path.join(os.getcwd(), 'www'))
74
74
import conf
75
75
import common.makeuser
76
76
 
100
100
    '/bin/echo',
101
101
    # Needed by python
102
102
    '/usr/bin/python%s' % PYTHON_VERSION,
103
 
    # Needed by fileservice
104
 
    '/lib/libcom_err.so.2',
105
 
    '/lib/libcrypt.so.1',
106
 
    '/lib/libkeyutils.so.1',
107
 
    '/lib/libresolv.so.2',
108
 
    '/lib/librt.so.1',
109
 
    '/lib/libuuid.so.1',
110
 
    '/usr/lib/libapr-1.so.0',
111
 
    '/usr/lib/libaprutil-1.so.0',
112
 
    '/usr/lib/libdb-4.4.so',
113
 
    '/usr/lib/libexpat.so.1',
114
 
    '/usr/lib/libgcrypt.so.11',
115
 
    '/usr/lib/libgnutls.so.13',
116
 
    '/usr/lib/libgpg-error.so.0',
117
 
    '/usr/lib/libgssapi_krb5.so.2',
118
 
    '/usr/lib/libk5crypto.so.3',
119
 
    '/usr/lib/libkrb5.so.3',
120
 
    '/usr/lib/libkrb5support.so.0',
121
 
    '/usr/lib/liblber.so.2',
122
 
    '/usr/lib/libldap_r.so.2',
123
 
    '/usr/lib/libneon.so.26',
124
 
    '/usr/lib/libpq.so.5',
125
 
    '/usr/lib/libsasl2.so.2',
126
 
    '/usr/lib/libsqlite3.so.0',
127
 
    '/usr/lib/libsvn_client-1.so.1',
128
 
    '/usr/lib/libsvn_delta-1.so.1',
129
 
    '/usr/lib/libsvn_diff-1.so.1',
130
 
    '/usr/lib/libsvn_fs-1.so.1',
131
 
    '/usr/lib/libsvn_fs_base-1.so.1',
132
 
    '/usr/lib/libsvn_fs_fs-1.so.1',
133
 
    '/usr/lib/libsvn_ra-1.so.1',
134
 
    '/usr/lib/libsvn_ra_dav-1.so.1',
135
 
    '/usr/lib/libsvn_ra_local-1.so.1',
136
 
    '/usr/lib/libsvn_ra_svn-1.so.1',
137
 
    '/usr/lib/libsvn_repos-1.so.1',
138
 
    '/usr/lib/libsvn_subr-1.so.1',
139
 
    '/usr/lib/libsvn_wc-1.so.1',
140
 
    '/usr/lib/libtasn1.so.3',
141
 
    '/usr/lib/libxml2.so.2',
142
103
    # Needed by matplotlib
143
104
    '/usr/lib/i686/cmov/libssl.so.0.9.8',
144
105
    '/usr/lib/i686/cmov/libcrypto.so.0.9.8',
159
120
    '/usr/lib/libXdmcp.so.6',
160
121
    '/lib/libgcc_s.so.1',
161
122
    '/etc/matplotlibrc',
162
 
    # Needed for resolv
163
 
    '/lib/libnss_dns.so.2',
164
 
    #'/lib/libnss_mdns4.so',
165
 
    '/etc/hosts',
166
 
    '/etc/resolv.conf',
167
 
    #'/etc/hosts.conf',
168
 
    #'/etc/hostname',
169
 
    '/etc/nsswitch.conf',
170
 
    '/lib/libnss_files.so.2',
171
123
]
172
124
# Symlinks to make within the jail. Src mapped to dst.
173
125
JAIL_LINKS = {
200
152
 
201
153
# Configuration options, defaults and descriptions
202
154
config_options = []
203
 
config_options.append(ConfigOption("root_dir", "/",
 
155
config_options.append(ConfigOption("root_dir", "/ivle",
204
156
    """Root directory where IVLE is located (in URL space):""",
205
157
    """
206
158
# In URL space, where in the site is IVLE located. (All URLs will be prefixed
213
165
# In the local file system, where IVLE is actually installed.
214
166
# This directory should contain the "www" and "bin" directories."""))
215
167
config_options.append(ConfigOption("jail_base", "/home/informatics/jails",
216
 
    """Location of Directories
217
 
=======================
218
 
Root directory where the jails (containing user files) are stored
 
168
    """Root directory where the jails (containing user files) are stored
219
169
(on the local file system):""",
220
170
    """
221
171
# In the local file system, where are the student/user file spaces located.
229
179
# In the local file system, where are the per-subject file spaces located.
230
180
# The individual subject directories are expected to be located immediately
231
181
# in subdirectories of this location."""))
232
 
config_options.append(ConfigOption("exercises_base",
233
 
    "/home/informatics/exercises",
234
 
    """Root directory where the exercise directories (containing
235
 
subject-independent exercise sheets) are stored (on the local file
236
 
system):""",
237
 
    """
238
 
# In the local file system, where are the subject-independent exercise sheet
239
 
# file spaces located."""))
240
182
config_options.append(ConfigOption("public_host", "public.localhost",
241
183
    """Hostname which will cause the server to go into "public mode",
242
184
providing login-free access to student's published work:""",
272
214
    """Database name:""",
273
215
    """
274
216
# Database name"""))
275
 
config_options.append(ConfigOption("db_forumdbname", "ivle_forum",
276
 
    """Forum Database name:""",
277
 
    """
278
 
# Forum Database name"""))
279
217
config_options.append(ConfigOption("db_user", "postgres",
280
218
    """Username for DB server login:""",
281
219
    """
282
220
# Database username"""))
283
221
config_options.append(ConfigOption("db_password", "",
284
222
    """Password for DB server login:
285
 
    (Caution: This password is stored in plaintext in lib/conf/conf.py)""",
 
223
    (Caution: This password is stored in plaintext in www/conf/conf.py)""",
286
224
    """
287
225
# Database password"""))
288
 
config_options.append(ConfigOption("auth_modules", "ldap_auth",
289
 
    """Authentication config
290
 
=====================
291
 
Comma-separated list of authentication modules. Only "ldap" is available
292
 
by default.""",
293
 
    """
294
 
# Comma-separated list of authentication modules.
295
 
# These refer to importable Python modules in the www/auth directory.
296
 
# Modules "ldap" and "guest" are available in the source tree, but
297
 
# other modules may be plugged in to auth against organisation-specific
298
 
# auth backends."""))
299
 
config_options.append(ConfigOption("ldap_url", "ldaps://www.example.com",
300
 
    """(LDAP options are only relevant if "ldap" is included in the list of
301
 
auth modules).
302
 
URL for LDAP authentication server:""",
303
 
    """
304
 
# URL for LDAP authentication server"""))
305
 
config_options.append(ConfigOption("ldap_format_string",
306
 
    "uid=%s,ou=users,o=example",
307
 
    """Format string for LDAP auth request:
308
 
    (Must contain a single "%s" for the user's login name)""",
309
 
    """
310
 
# Format string for LDAP auth request
311
 
# (Must contain a single "%s" for the user's login name)"""))
312
 
config_options.append(ConfigOption("svn_addr", "http://svn.localhost/",
313
 
    """Subversion config
314
 
=================
315
 
The base url for accessing subversion repositories:""",
316
 
    """
317
 
# The base url for accessing subversion repositories."""))
318
 
config_options.append(ConfigOption("svn_conf", "/opt/ivle/svn/svn.conf",
319
 
    """The location of the subversion configuration file used by apache
320
 
to host the user repositories:""",
321
 
    """
322
 
# The location of the subversion configuration file used by
323
 
# apache to host the user repositories."""))
324
 
config_options.append(ConfigOption("svn_repo_path", "/home/informatics/repositories",
325
 
    """The root directory for the subversion repositories:""",
326
 
    """
327
 
# The root directory for the subversion repositories."""))
328
 
config_options.append(ConfigOption("svn_auth_ivle", "/opt/ivle/svn/ivle.auth",
329
 
    """The location of the password file used to authenticate users
330
 
of the subversion repository from the ivle server:""",
331
 
    """
332
 
# The location of the password file used to authenticate users
333
 
# of the subversion repository from the ivle server."""))
334
 
config_options.append(ConfigOption("svn_auth_local", "/opt/ivle/svn/local.auth",
335
 
    """The location of the password file used to authenticate local users
336
 
of the subversion repository:""",
337
 
    """
338
 
# The location of the password file used to authenticate local users
339
 
# of the subversion repository."""))
340
 
config_options.append(ConfigOption("usrmgt_host", "localhost",
341
 
    """User Management Server config
342
 
============================
343
 
The hostname where the usrmgt-server runs:""",
344
 
    """
345
 
# The hostname where the usrmgt-server runs."""))
346
 
config_options.append(ConfigOption("usrmgt_port", "2178",
347
 
    """The port where the usrmgt-server runs:""",
348
 
    """
349
 
# The port where the usrmgt-server runs."""))
350
 
config_options.append(ConfigOption("usrmgt_magic", "",
351
 
    """The password for the usrmgt-server:""",
352
 
    """
353
 
# The password for the usrmgt-server."""))
354
226
 
355
227
# Try importing existing conf, but if we can't just set up defaults
356
228
# The reason for this is that these settings are used by other phases
357
229
# of setup besides conf, so we need to know them.
358
230
# Also this allows you to hit Return to accept the existing value.
359
231
try:
360
 
    confmodule = __import__("lib/conf/conf")
 
232
    confmodule = __import__("www/conf/conf")
361
233
    for opt in config_options:
362
234
        try:
363
235
            globals()[opt.option_name] = confmodule.__dict__[opt.option_name]
381
253
# as necessary, and include it in the distribution.
382
254
listmake_mimetypes = ['text/x-python', 'text/html',
383
255
    'application/x-javascript', 'application/javascript',
384
 
    'text/css', 'image/png', 'image/gif', 'application/xml']
 
256
    'text/css', 'image/png', 'application/xml']
385
257
 
386
258
# Main function skeleton from Guido van Rossum
387
259
# http://www.artima.com/weblogs/viewpost.jsp?thread=4829
472
344
to rebuild/install), just provide ivle_install_dir as the IVLE trunk
473
345
directory, and run build/install one time.
474
346
 
475
 
Creates lib/conf/conf.py and trampoline/conf.h.
 
347
Creates www/conf/conf.py and trampoline/conf.h.
476
348
 
477
349
Args are:"""
478
350
        for opt in config_options:
505
377
Copy subjects/ to subjects directory (unless --nosubjects specified).
506
378
 
507
379
--nojail        Do not copy the jail.
508
 
--nosubjects    Do not copy the subjects and exercises directories.
 
380
--nosubjects    Do not copy the subjects.
509
381
--dry | -n  Print out the actions but don't do anything."""
510
382
    elif operation == 'updatejails':
511
383
        print """sudo python setup.py updatejails [--dry|-n]
522
394
def listmake(args):
523
395
    # We build two separate lists, by walking www and console
524
396
    list_www = build_list_py_files('www')
525
 
    list_lib = build_list_py_files('lib')
 
397
    list_console = build_list_py_files('console')
526
398
    list_subjects = build_list_py_files('subjects', no_top_level=True)
527
 
    list_exercises = build_list_py_files('exercises', no_top_level=True)
528
 
    list_scripts = [
529
 
        "scripts/python-console",
530
 
        "scripts/fileservice",
531
 
        "scripts/usrmgt-server",
532
 
        "scripts/diffservice",
533
 
    ]
534
399
    # Make sure that the files generated by conf are in the list
535
400
    # (since listmake is typically run before conf)
536
 
    if "lib/conf/conf.py" not in list_lib:
537
 
        list_lib.append("lib/conf/conf.py")
 
401
    if "www/conf/conf.py" not in list_www:
 
402
        list_www.append("www/conf/conf.py")
 
403
    # Make sure that console/python-console is in the list
 
404
    if "console/python-console" not in list_console:
 
405
        list_console.append("console/python-console")
538
406
    # Write these out to a file
539
407
    cwd = os.getcwd()
540
408
    # the files that will be created/overwritten
554
422
list_www = """)
555
423
        writelist_pretty(file, list_www)
556
424
        file.write("""
557
 
# List of all installable files in lib directory.
558
 
list_lib = """)
559
 
        writelist_pretty(file, list_lib)
560
 
        file.write("""
561
 
# List of all installable files in scripts directory.
562
 
list_scripts = """)
563
 
        writelist_pretty(file, list_scripts)
 
425
# List of all installable files in console directory.
 
426
list_console = """)
 
427
        writelist_pretty(file, list_console)
564
428
        file.write("""
565
429
# List of all installable files in subjects directory.
566
430
# This is to install sample subjects and material.
567
431
list_subjects = """)
568
432
        writelist_pretty(file, list_subjects)
569
 
        file.write("""
570
 
# List of all installable files in exercises directory.
571
 
# This is to install sample exercise material.
572
 
list_exercises = """)
573
 
        writelist_pretty(file, list_exercises)
574
433
 
575
434
        file.close()
576
435
    except IOError, (errno, strerror):
616
475
        file.write(']\n')
617
476
 
618
477
def conf(args):
619
 
    global db_port, usrmgt_port
 
478
    global db_port
620
479
    # Set up some variables
621
480
 
622
481
    cwd = os.getcwd()
623
482
    # the files that will be created/overwritten
624
 
    conffile = os.path.join(cwd, "lib/conf/conf.py")
625
 
    jailconffile = os.path.join(cwd, "lib/conf/jailconf.py")
 
483
    conffile = os.path.join(cwd, "www/conf/conf.py")
626
484
    conf_hfile = os.path.join(cwd, "trampoline/conf.h")
627
 
    phpBBconffile = os.path.join(cwd, "www/php/phpBB3/config.php")
628
485
 
629
486
    # Get command-line arguments to avoid asking questions.
630
487
 
643
500
        print """This tool will create the following files:
644
501
    %s
645
502
    %s
646
 
    %s
647
503
prompting you for details about your configuration. The file will be
648
504
overwritten if it already exists. It will *not* install or deploy IVLE.
649
505
 
650
506
Please hit Ctrl+C now if you do not wish to do this.
651
 
""" % (conffile, jailconffile, conf_hfile)
 
507
""" % (conffile, conf_hfile)
652
508
 
653
509
        # Get information from the administrator
654
510
        # If EOF is encountered at any time during the questioning, just exit
680
536
        "Invalid DB port (%s).\n"
681
537
        "Must be an integer between 0 and 65535." % repr(db_port))
682
538
        return 1
683
 
    try:
684
 
        usrmgt_port = int(usrmgt_port)
685
 
        if usrmgt_port < 0 or usrmgt_port >= 65536: raise ValueError()
686
 
    except ValueError:
687
 
        print >>sys.stderr, (
688
 
        "Invalid user management port (%s).\n"
689
 
        "Must be an integer between 0 and 65535." % repr(usrmgt_port))
690
 
        return 1
691
539
 
692
 
    # Write lib/conf/conf.py
 
540
    # Write www/conf/conf.py
693
541
 
694
542
    try:
695
543
        conf = open(conffile, "w")
708
556
        print "IO error(%s): %s" % (errno, strerror)
709
557
        sys.exit(1)
710
558
 
711
 
    print "Successfully wrote lib/conf/conf.py"
712
 
 
713
 
    # Write conf/jailconf.py
714
 
 
715
 
    try:
716
 
        conf = open(jailconffile, "w")
717
 
 
718
 
        # In the "in-jail" version of conf, we don't need MOST of the details
719
 
        # (it would be a security risk to have them here).
720
 
        # So we just write root_dir, and jail_base is "/".
721
 
        # (jail_base being "/" means "jail-relative" paths are relative to "/"
722
 
        # when inside the jail.)
723
 
        conf.write("""# IVLE Configuration File
724
 
# conf.py
725
 
# Miscellaneous application settings
726
 
# (User jail version)
727
 
 
728
 
 
729
 
# In URL space, where in the site is IVLE located. (All URLs will be prefixed
730
 
# with this).
731
 
# eg. "/" or "/ivle".
732
 
root_dir = %s
733
 
 
734
 
# In the local file system, where are the student/user file spaces located.
735
 
# The user jails are expected to be located immediately in subdirectories of
736
 
# this location.
737
 
jail_base = '/'
738
 
 
739
 
# The hostname for serving publicly accessible pages
740
 
public_host = %s
741
 
""" % (repr(root_dir),repr(public_host)))
742
 
 
743
 
        conf.close()
744
 
    except IOError, (errno, strerror):
745
 
        print "IO error(%s): %s" % (errno, strerror)
746
 
        sys.exit(1)
747
 
 
748
 
    print "Successfully wrote lib/conf/jailconf.py"
 
559
    print "Successfully wrote www/conf/conf.py"
749
560
 
750
561
    # Write trampoline/conf.h
751
562
 
770
581
 * (Note that root is an implicit member of this list).
771
582
 */
772
583
static const int allowed_uids[] = { %s };
773
 
""" % (repr(jail_base)[1:-1], repr(allowed_uids_list)[1:-1]))
774
 
    # Note: The above uses PYTHON reprs, not C reprs
775
 
    # However they should be the same with the exception of the outer
776
 
    # characters, which are stripped off and replaced
 
584
""" % (jail_base, repr(allowed_uids_list)[1:-1]))
777
585
 
778
586
        conf.close()
779
587
    except IOError, (errno, strerror):
782
590
 
783
591
    print "Successfully wrote trampoline/conf.h"
784
592
 
785
 
    # Write www/php/phpBB3/config.php
786
 
 
787
 
    try:
788
 
        conf = open(phpBBconffile, "w")
789
 
        
790
 
        # php-pg work around
791
 
        if db_host == 'localhost':
792
 
            forumdb_host = '127.0.0.1'
793
 
        else:
794
 
            forumdb_host = db_host
795
 
 
796
 
        conf.write( """<?php
797
 
// phpBB 3.0.x auto-generated configuration file
798
 
// Do not change anything in this file!
799
 
$dbms = 'postgres';
800
 
$dbhost = '""" + forumdb_host + """';
801
 
$dbport = '""" + str(db_port) + """';
802
 
$dbname = '""" + db_forumdbname + """';
803
 
$dbuser = '""" + db_user + """';
804
 
$dbpasswd = '""" + db_password + """';
805
 
 
806
 
$table_prefix = 'phpbb_';
807
 
$acm_type = 'file';
808
 
$load_extensions = '';
809
 
@define('PHPBB_INSTALLED', true);
810
 
// @define('DEBUG', true);
811
 
//@define('DEBUG_EXTRA', true);
812
 
?>"""   )
813
 
    
814
 
        conf.close()
815
 
    except IOError, (errno, strerror):
816
 
        print "IO error(%s): %s" % (errno, strerror)
817
 
        sys.exit(1)
818
 
 
819
 
    print "Successfully wrote www/php/phpBB3/config.php"
820
 
 
821
593
    print
822
594
    print "You may modify the configuration at any time by editing"
823
595
    print conffile
824
 
    print jailconffile
825
596
    print conf_hfile
826
 
    print phpBBconffile
827
597
    print
828
598
    return 0
829
599
 
848
618
    action_mkdir('jail/home', dry)
849
619
    action_mkdir('jail/tmp', dry)
850
620
 
851
 
    # Chmod the tmp directory to world writable
852
 
    action_chmod_w('jail/tmp', dry)
853
 
 
854
621
    # Copy all console and operating system files into the jail
855
 
    action_copylist(install_list.list_scripts, 'jail/opt/ivle', dry)
 
622
    action_copylist(install_list.list_console, 'jail/opt/ivle', dry)
856
623
    copy_os_files_jail(dry)
857
624
    # Chmod the python console
858
 
    action_chmod_x('jail/opt/ivle/scripts/python-console', dry)
859
 
    action_chmod_x('jail/opt/ivle/scripts/fileservice', dry)
 
625
    action_chmod_x('jail/opt/ivle/console/python-console', dry)
860
626
    
861
 
    # Also copy the IVLE lib directory into the jail
862
 
    # This is necessary for running certain scripts
863
 
    action_copylist(install_list.list_lib, 'jail/opt/ivle', dry)
864
 
    # IMPORTANT: The file jail/opt/ivle/lib/conf/conf.py contains details
865
 
    # which could compromise security if left in the jail (such as the DB
866
 
    # password).
867
 
    # The "safe" version is in jailconf.py. Delete conf.py and replace it with
868
 
    # jailconf.py.
869
 
    action_copyfile('lib/conf/jailconf.py',
870
 
        'jail/opt/ivle/lib/conf/conf.py', dry)
871
627
 
872
628
    # Compile .py files into .pyc or .pyo files
873
629
    compileall.compile_dir('www', quiet=True)
874
 
    compileall.compile_dir('lib', quiet=True)
875
 
    compileall.compile_dir('scripts', quiet=True)
876
 
    compileall.compile_dir('jail/opt/ivle/lib', quiet=True)
877
 
 
878
 
    # Set up ivle.pth inside the jail
879
 
    # Need to set /opt/ivle/lib to be on the import path
880
 
    ivle_pth = \
881
 
        "jail/usr/lib/python%s/site-packages/ivle.pth" % PYTHON_VERSION
882
 
    f = open(ivle_pth, 'w')
883
 
    f.write('/opt/ivle/lib\n')
884
 
    f.close()
 
630
    compileall.compile_dir('console', quiet=True)
885
631
 
886
632
    return 0
887
633
 
929
675
    # chown trampoline to root and set setuid bit
930
676
    action_chown_setuid(tramppath, dry)
931
677
 
932
 
    # Create a scripts directory to put the usrmgt-server in.
933
 
    action_mkdir(os.path.join(ivle_install_dir, 'scripts'), dry)
934
 
    usrmgtpath = os.path.join(ivle_install_dir, 'scripts/usrmgt-server')
935
 
    action_copyfile('scripts/usrmgt-server', usrmgtpath, dry)
936
 
    action_chmod_x(usrmgtpath, dry)
937
 
 
938
 
    # Copy the www and lib directories using the list
 
678
    # Copy the www directory using the list
939
679
    action_copylist(install_list.list_www, ivle_install_dir, dry)
940
 
    action_copylist(install_list.list_lib, ivle_install_dir, dry)
941
 
    
942
 
    # Copy the php directory
943
 
    action_copytree('www/php/phpBB3',os.path.join(ivle_install_dir,'www/php/phpBB3'), 
944
 
    dry)
945
680
 
946
681
    if not nojail:
947
682
        # Copy the local jail directory built by the build action
949
684
        # for all the students' jails).
950
685
        action_copytree('jail', os.path.join(jail_base, 'template'), dry)
951
686
    if not nosubjects:
952
 
        # Copy the subjects and exercises directories across
 
687
        # Copy the subjects directory across
953
688
        action_copylist(install_list.list_subjects, subjects_base, dry,
954
689
            srcdir="./subjects")
955
 
        action_copylist(install_list.list_exercises, exercises_base, dry,
956
 
            srcdir="./exercises")
957
690
 
958
691
    # Append IVLE path to ivle.pth in python site packages
959
692
    # (Unless it's already there)
960
693
    ivle_pth = os.path.join(sys.prefix,
961
694
        "lib/python%s/site-packages/ivle.pth" % PYTHON_VERSION)
962
695
    ivle_www = os.path.join(ivle_install_dir, "www")
963
 
    ivle_lib = os.path.join(ivle_install_dir, "lib")
964
696
    write_ivle_pth = True
965
 
    write_ivle_lib_pth = True
966
697
    try:
967
698
        file = open(ivle_pth, 'r')
968
699
        for line in file:
969
700
            if line.strip() == ivle_www:
970
701
                write_ivle_pth = False
971
 
            elif line.strip() == ivle_lib:
972
 
                write_ivle_lib_pth = False
973
 
        file.close()
 
702
                break
974
703
    except (IOError, OSError):
975
704
        pass
976
705
    if write_ivle_pth:
977
706
        action_append(ivle_pth, ivle_www)
978
 
    if write_ivle_lib_pth:
979
 
        action_append(ivle_pth, ivle_lib)
980
707
 
981
708
    return 0
982
709
 
1044
771
    if ret != 0:
1045
772
        raise RunError(prog, ret)
1046
773
 
1047
 
def action_remove(path, dry):
1048
 
    """Calls rmtree, deleting the target file if it exists."""
1049
 
    try:
1050
 
        print "rm -r", path
1051
 
        if not dry:
1052
 
            shutil.rmtree(path, True)
1053
 
    except OSError, (err, msg):
1054
 
        if err != errno.EEXIST:
1055
 
            raise
1056
 
        # Otherwise, didn't exist, so we don't care
1057
 
 
1058
774
def action_rename(src, dst, dry):
1059
775
    """Calls rename. Deletes the target if it already exists."""
1060
 
    action_remove(dst, dry)
 
776
    if os.access(dst, os.F_OK):
 
777
        print "rm -r", dst
 
778
        if not dry:
 
779
            shutil.rmtree(dst, True)
1061
780
    print "mv ", src, dst
1062
781
    if dry: return
1063
782
    try:
1083
802
    directories as necessary.
1084
803
 
1085
804
    See shutil.copytree."""
1086
 
    # Allow copying over itself
1087
 
    if (os.path.normpath(os.path.join(os.getcwd(),src)) ==
1088
 
        os.path.normpath(os.path.join(os.getcwd(),dst))):
1089
 
        return
1090
 
    action_remove(dst, dry)
 
805
    if os.access(dst, os.F_OK):
 
806
        print "rm -r", dst
 
807
        if not dry:
 
808
            shutil.rmtree(dst, True)
1091
809
    print "cp -r", src, dst
1092
810
    if dry: return
1093
811
    shutil.copytree(src, dst, True)
1096
814
    """Hard-links an entire directory tree. Same as copytree but the created
1097
815
    files are hard-links not actual copies. Removes the existing destination.
1098
816
    """
1099
 
    action_remove(dst, dry)
 
817
    if os.access(dst, os.F_OK):
 
818
        print "rm -r", dst
 
819
        if not dry:
 
820
            shutil.rmtree(dst, True)
1100
821
    print "<cp with hardlinks> -r", src, dst
1101
822
    if dry: return
1102
823
    common.makeuser.linktree(src, dst)
1177
898
        os.chmod(file, stat.S_IXUSR | stat.S_IRUSR | stat.S_IWUSR
1178
899
            | stat.S_IXGRP | stat.S_IRGRP | stat.S_IXOTH | stat.S_IROTH)
1179
900
 
1180
 
 
1181
 
def action_chmod_w(file, dry):
1182
 
    """Chmod 777 a file (sets permissions to rwxrwxrwx)."""
1183
 
    print "chmod 777", file
1184
 
    if not dry:
1185
 
        os.chmod(file, stat.S_IXUSR | stat.S_IRUSR | stat.S_IWUSR
1186
 
            | stat.S_IXGRP | stat.S_IWGRP | stat.S_IRGRP | stat.S_IXOTH
1187
 
            | stat.S_IWOTH | stat.S_IROTH)
1188
 
 
1189
901
def query_user(default, prompt):
1190
902
    """Prompts the user for a string, which is read from a line of stdin.
1191
903
    Exits silently if EOF is encountered. Returns the string, with spaces