diff options
author | William S Fulton <wsf@fultondesigns.co.uk> | 2007-05-01 21:14:30 +0000 |
---|---|---|
committer | William S Fulton <wsf@fultondesigns.co.uk> | 2007-05-01 21:14:30 +0000 |
commit | ba168b34037711acc4ba282eec7897718c321e76 (patch) | |
tree | ed2521d5f0d644fa26a290990de6e41f0b620d92 /Tools | |
parent | 68b52c4ee5a51f8a10b886c5237aef5a385f6bba (diff) | |
download | swig-ba168b34037711acc4ba282eec7897718c321e76.tar.gz |
More robust error handling and fix last commit
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@9744 626c5289-ae23-0410-ae9c-e8d60b6d4f22
Diffstat (limited to 'Tools')
-rwxr-xr-x | Tools/mkdist.py | 28 |
1 files changed, 17 insertions, 11 deletions
diff --git a/Tools/mkdist.py b/Tools/mkdist.py index 5dfdada8d..56c6fb1dc 100755 --- a/Tools/mkdist.py +++ b/Tools/mkdist.py @@ -7,6 +7,11 @@ import sys import string import os +def failed(): + print "Failed to complete" + sys.exit(1) + + try: version = sys.argv[1] dirname = "swig-" + version @@ -17,7 +22,7 @@ except: # Check name matches normal unix conventions if string.lower(dirname) != dirname: print "directory name ("+dirname+") should be in lowercase" - sys.exit(0) + sys.exit(2) # If directory and tarball exist, remove it print "Removing ", dirname @@ -32,32 +37,33 @@ os.system("rm -f "+dirname+".tar") # Do a SVN export into the directory name print "Grabbing latest SWIG from svn" -os.system("svn export -r HEAD https://swig.svn.sourceforge.net/svnroot/swig/trunk "+dirname) +os.system("svn export -r HEAD https://swig.svn.sourceforge.net/svnroot/swig/trunk "+dirname) == 0 or failed() # Remove the debian directory -- it's not official -os.system("rm -Rf "+dirname+"/debian"); +os.system("rm -Rf "+dirname+"/debian") == 0 or failed() # Blow away all .cvsignore files print "Blowing away .cvsignore files" -os.system("find "+dirname+" -name .cvsignore -exec rm {} \\;"); +os.system("find "+dirname+" -name .cvsignore -exec rm {} \\;") == 0 or failed() # Go build the system print "Building system" -os.system("cd "+dirname+"; ./autogen.sh") -os.system("cd "+dirname+"/Tools/WAD; autoconf") -os.system("cd "+dirname+"; make maintainer") +os.system("cd "+dirname+"; ./autogen.sh") == 0 or failed() +os.system("cd "+dirname+"/Tools/WAD; autoconf") == 0 or failed() +os.system("cd "+dirname+"/Source/CParse; bison -y -d parser.y; mv y.tab.c parser.c; mv y.tab.h parser.h") == 0 or failed() +os.system("cd "+dirname+"; make -f Makefile.in libfiles srcdir=./") == 0 or failed() # Remove autoconf files -os.system("find "+dirname+" -name autom4te.cache -exec rm -rf {} \\;"); +os.system("find "+dirname+" -name autom4te.cache -exec rm -rf {} \\;") # Build documentation print "Building documentation" -os.system("cd "+dirname+"/Doc/Manual; make; rm *.bak") +os.system("cd "+dirname+"/Doc/Manual && make && rm *.bak") == 0 or failed() # Build the tar-ball -os.system("tar -cf "+dirname+".tar "+dirname) -os.system("gzip "+dirname+".tar") +os.system("tar -cf "+dirname+".tar "+dirname) == 0 or failed() +os.system("gzip "+dirname+".tar") == 0 or failed() |