From 95ebabe76aab54d5bae6bafe4d26e902ac1b434a Mon Sep 17 00:00:00 2001 From: Tony Mack Date: Sun, 3 May 2009 00:44:21 +0000 Subject: [PATCH] using shutil.rmtree to remove directories saves a lot of code --- setup.py | 39 ++++++--------------------------------- 1 file changed, 6 insertions(+), 33 deletions(-) diff --git a/setup.py b/setup.py index 90f852a9..6787958c 100755 --- a/setup.py +++ b/setup.py @@ -6,34 +6,13 @@ Installation script for the geniwrapper module from distutils.core import setup, Extension import os, sys +import shutil version = '0.2' scripts = ['geni/gimport.py', 'geni/plc.py', 'cmdline/sfi.py'] package_dirs = ['geni', 'geni/util', 'geni/methods'] data_files = [('/etc/geni/', ['geni/aggregates.xml', 'geni/registries.xml', 'geni/util/geni_config', 'cmdline/configSfi.sh'])] -def list_dir(directory): - # list the files in this directory - try: - files = os.listdir(directory) - add_directory_path = lambda path: directory + os.sep + path - # add absolute path to files - files = map(add_directory_path, files) - # separate files from directories - files_only = lambda path: os.path.isfile(path) - directories_only = lambda path: os.path.isdir(path) - directories = filter(directories_only, files) - files = filter(files_only, files) - for d in directories: - try: - (fs, ds) = list_dir(d) - files.extend(fs) - except: - print "Error listing", d - return (files, directories) - except: - return ([], []) - if sys.argv[1] in ['uninstall', 'remove', 'delete']: python_path = sys.path @@ -43,25 +22,19 @@ if sys.argv[1] in ['uninstall', 'remove', 'delete']: site_packages_path = map(add_geni_path, site_packages_path) remove_dirs = ['/etc/geni/'] + site_packages_path remove_files = ['/usr/bin/gimport.py', '/usr/bin/plc.py', '/usr/bin/sfi.py'] - # update list of files/directories to remove - for directory in remove_dirs: - files, dirs = list_dir(directory) - remove_files.extend(list(set(files))) - remove_dirs.extend(dirs) - remove_dirs.reverse() - + # remove files for filepath in remove_files: - print "removing", filepath, " ... ", + print "removing", filepath, "...", try: os.remove(filepath) print "success" except: print "failed" # remove directories for directory in remove_dirs: - print "removing", directory, " ... ", + print "removing", directory, "...", try: - os.rmdir(directory) + shutil.rmtree(directory) print "success" except: print "failed" @@ -74,7 +47,7 @@ else: py_modules = [], scripts = scripts, url = 'http://svn.planet-lab.org/svn/geniwrapper/', - description = "Geni api", + description = "Geni API", long_description = """\ Geniwrapper implements the Geni interface which serves as a layer between the existing PlanetLab interfaces -- 2.47.0