1#!/usr/bin/env python 2import os 3import sys 4import commands 5 6 7if not hasattr(sys, 'version_info') or not sys.version_info[1] >= 2: 8 print '**** You must have Python version 2.2 or higher to run config/configure.py ******' 9 print '* Python is easy to install for end users or sys-admin. *' 10 print '* http://www.python.org/download/ *' 11 print '* *' 12 print '* You CANNOT configure PETSc without Python *' 13 print '* http://www.mcs.anl.gov/petsc/petsc-as/documentation/installation.html *' 14 print '*********************************************************************************' 15 sys.exit(4) 16 17def check_petsc_arch(opts): 18 # Check for PETSC_ARCH in the following order: 19 # 1. command-line (first occurance) 20 # 2. specified in configure_options(in script) 21 # 3. script name (if not configure.py) 22 23 useName = '' 24 for name in opts: 25 if name.startswith('-PETSC_ARCH'): 26 useName = name 27 break 28 # look for duplicates - and remove them 29 dupnames = [] 30 if useName: 31 for name in opts: 32 if name.startswith('-PETSC_ARCH') and name != useName: 33 opts.remove(name) 34 dupnames.append(name) 35 # print warning for duplicates 36 if dupnames: 37 print '*********************************************************************************' 38 print 'Warning: The following duplicate PETSC_ARCH options are removed:', dupnames 39 print 'Warning: Using the option:', useName 40 print '*********************************************************************************' 41 # If not yet specified - use the filename of script 42 if not useName: 43 filename = os.path.basename(sys.argv[0]) 44 if not filename.startswith('configure'): 45 useName = '-PETSC_ARCH='+os.path.splitext(os.path.basename(sys.argv[0]))[0] 46 opts.append(useName) 47 return 48 49def chkcygwin(): 50 if os.path.exists('/usr/bin/cygcheck.exe'): 51 buf = os.popen('/usr/bin/cygcheck.exe -c cygwin').read() 52 if buf.find('1.5.11-1') > -1: 53 return 1 54 else: 55 return 0 56 return 0 57 58def rhl9(): 59 try: 60 file = open('/etc/redhat-release','r') 61 except: 62 return 0 63 try: 64 buf = file.read() 65 file.close() 66 except: 67 # can't read file - assume dangerous RHL9 68 return 1 69 if buf.find('Shrike') > -1: 70 return 1 71 else: 72 return 0 73 74def petsc_configure(configure_options): 75 print '=================================================================================' 76 print ' Configuring PETSc to compile on your system ' 77 print '=================================================================================' 78 79 sys.argv += configure_options 80 # check PETSC_ARCH 81 check_petsc_arch(sys.argv) 82 83 # support a few standard configure option types 84 for l in range(0,len(sys.argv)): 85 name = sys.argv[l] 86 if name.startswith('--download'): 87 sys.argv[l] = name.lower() 88 if name.startswith('--enable'): 89 sys.argv[l] = name.replace('--enable','--with') 90 if name.find('=') == -1: sys.argv[l] += '=1' 91 if name.startswith('--disable'): 92 sys.argv[l] = name.replace('--disable','--with') 93 if name.find('=') == -1: sys.argv[l] += '=0' 94 elif name.endswith('=1'): sys.argv[l].replace('=1','=0') 95 if name.startswith('--without'): 96 sys.argv[l] = name.replace('--without','--with') 97 if name.find('=') == -1: sys.argv[l] += '=0' 98 elif name.endswith('=1'): sys.argv[l].replace('=1','=0') 99 100 # if language is C then should not be checking C++ 101 usingcxx = 0 102 for j in sys.argv: 103 if j.replace('++','xx') == '--with-clanguage=cxx' or j == '--with-scalar-type=complex': 104 usingcxx = 1 105 break 106 # horrible, horrible hack; downloading Prometheus needs C++ 107 if j.find('--download-prometheus') >= 0: 108 usingcxx = 1 109 break 110 111 if not usingcxx: 112 foundcxx = 0 113 for l in range(0,len(sys.argv)-1): 114 name = sys.argv[l] 115 if name.startswith('--with-cxx'): 116 sys.argv[l] = '--with-cxx=0' 117 foundcxx = 1 118 break 119 if not foundcxx: 120 sys.argv.append('--with-cxx=0') 121 122 # Disable threads on RHL9 123 if rhl9(): 124 sys.argv.append('--useThreads=0') 125 print '=================================================================================' 126 print ' *** RHL9 detected. Threads do not work correctly with this distribution ***' 127 print ' ******** Disabling thread usage for this run of config/configure.py *****' 128 print '=================================================================================' 129 130 # Check for broken cygwin 131 if chkcygwin(): 132 print '=================================================================================' 133 print ' *** cygwin-1.5.11-1 detected. config/configure.py fails with this version ***' 134 print ' *** Please upgrade to cygwin-1.5.12-1 or newer version. This can ***' 135 print ' *** be done by running cygwin-setup, selecting "next" all the way.***' 136 print '=================================================================================' 137 sys.exit(3) 138 139 # Should be run from the toplevel 140 pythonDir = os.path.abspath(os.path.join('python')) 141 bsDir = os.path.join(pythonDir, 'BuildSystem') 142 if not os.path.isdir(pythonDir): 143 raise RuntimeError('Run configure from $PETSC_DIR, not '+os.path.abspath('.')) 144 if not os.path.isdir(bsDir): 145 print '=================================================================================' 146 print '''++ Could not locate BuildSystem in %s/python.''' % os.getcwd() 147 print '''++ Downloading it using "bk clone http://sidl.bkbits.net/BuildSystem %s/python/BuildSystem"''' % os.getcwd() 148 print '=================================================================================' 149 (status,output) = commands.getstatusoutput('bk clone http://sidl.bkbits.net/BuildSystem python/BuildSystem') 150 if status: 151 if output.find('ommand not found') >= 0: 152 print '=================================================================================' 153 print '''** Unable to locate bk (Bitkeeper) to download BuildSystem; make sure bk is in your path''' 154 print '''** or manually copy BuildSystem to $PETSC_DIR/python/BuildSystem from a machine where''' 155 print '''** you do have bk installed and can clone BuildSystem. ''' 156 print '=================================================================================' 157 elif output.find('Cannot resolve host') >= 0: 158 print '=================================================================================' 159 print '''** Unable to download BuildSystem. You must be off the network.''' 160 print '''** Connect to the internet and run config/configure.py again.''' 161 print '=================================================================================' 162 else: 163 print '=================================================================================' 164 print '''** Unable to download BuildSystem. Please send this message to petsc-maint@mcs.anl.gov''' 165 print '=================================================================================' 166 print output 167 sys.exit(3) 168 169 sys.path.insert(0, bsDir) 170 sys.path.insert(0, pythonDir) 171 import config.framework 172 import cPickle 173 174 framework = config.framework.Framework(sys.argv[1:]+['-configModules=PETSc.Configure'], loadArgDB = 0) 175 try: 176 framework.configure(out = sys.stdout) 177 framework.storeSubstitutions(framework.argDB) 178 framework.argDB['configureCache'] = cPickle.dumps(framework) 179 import PETSc.packages 180 for i in framework.packages: 181 if hasattr(i,'postProcess'): 182 i.postProcess() 183 framework.logClear() 184 return 0 185 except RuntimeError, e: 186 emsg = str(e) 187 if not emsg.endswith('\n'): emsg += '\n' 188 msg ='*********************************************************************************\n'\ 189 +' UNABLE to CONFIGURE with GIVEN OPTIONS (see configure.log for details):\n' \ 190 +'---------------------------------------------------------------------------------------\n' \ 191 +emsg+'*********************************************************************************\n' 192 se = '' 193 except TypeError, e: 194 emsg = str(e) 195 if not emsg.endswith('\n'): emsg += '\n' 196 msg ='*********************************************************************************\n'\ 197 +' ERROR in COMMAND LINE ARGUMENT to config/configure.py \n' \ 198 +'---------------------------------------------------------------------------------------\n' \ 199 +emsg+'*********************************************************************************\n' 200 se = '' 201 except ImportError, e : 202 emsg = str(e) 203 if not emsg.endswith('\n'): emsg += '\n' 204 msg ='*********************************************************************************\n'\ 205 +' UNABLE to FIND MODULE for config/configure.py \n' \ 206 +'---------------------------------------------------------------------------------------\n' \ 207 +emsg+'*********************************************************************************\n' 208 se = '' 209 except SystemExit, e: 210 if e.code is None or e.code == 0: 211 return 212 msg ='*********************************************************************************\n'\ 213 +' CONFIGURATION CRASH (Please send configure.log to petsc-maint@mcs.anl.gov)\n' \ 214 +'*********************************************************************************\n' 215 se = str(e) 216 except Exception, e: 217 msg ='*********************************************************************************\n'\ 218 +' CONFIGURATION CRASH (Please send configure.log to petsc-maint@mcs.anl.gov)\n' \ 219 +'*********************************************************************************\n' 220 se = str(e) 221 222 framework.logClear() 223 print msg 224 if hasattr(framework, 'log'): 225 import traceback 226 framework.log.write(msg+se) 227 traceback.print_tb(sys.exc_info()[2], file = framework.log) 228 if os.path.isfile(framework.logName+'.bkp'): 229 framework.logPrintDivider() 230 framework.logPrintBox('Previous configure logs below', debugSection = None) 231 f = file(framework.logName+'.bkp') 232 framework.log.write(f.read()) 233 f.close() 234 sys.exit(1) 235 236if __name__ == '__main__': 237 petsc_configure([]) 238 239