xref: /petsc/config/configure.py (revision 3bdc3ccdd3ead03cd445570eeb1fb425afb66b68)
15d5a5a7bSMatthew Knepley#!/usr/bin/env python
25b6bfdb9SJed Brownfrom __future__ import print_function
32787667cSMatthew G Knepleyimport os, sys
4db5c7c58SSatish Balay
57c9abfe7SSatish BalayextraLogs = []
6b0b472b0SSatish Balaypetsc_arch = ''
74b8aa89bSBarry Smith
844b0d7f9SSatish Balay# Use en_US as language so that BuildSystem parses compiler messages in english
9b9a05632SSatish Balaydef fixLang(lang):
10b9a05632SSatish Balay  if lang in os.environ and os.environ[lang] != '':
11b9a05632SSatish Balay    lv = os.environ[lang]
12b9a05632SSatish Balay    enc = ''
13b9a05632SSatish Balay    try: lv,enc = lv.split('.')
14b9a05632SSatish Balay    except: pass
15b9a05632SSatish Balay    if lv not in ['en_US','C']: lv = 'en_US'
16b9a05632SSatish Balay    if enc: lv = lv+'.'+enc
17b9a05632SSatish Balay    os.environ[lang] = lv
18b9a05632SSatish Balay
19b9a05632SSatish BalayfixLang('LC_LOCAL')
20b9a05632SSatish BalayfixLang('LANG')
21b9a05632SSatish Balay
2244b0d7f9SSatish Balay
23ccb279e1SMatthew Knepleydef check_for_option_mistakes(opts):
2445faeebdSBarry Smith  for opt in opts[1:]:
25cda0060aSMatthew Knepley    name = opt.split('=')[0]
265715f7bdSSatish Balay    if name.find(' ') >= 0:
275715f7bdSSatish Balay      raise ValueError('The option "'+name+'" has a space character in the name - this is likely incorrect usage.');
28ccb279e1SMatthew Knepley    if name.find('_') >= 0:
29ccb279e1SMatthew Knepley      exception = False
301de7a49fSSatish Balay      for exc in ['mkl_sparse', 'mkl_sparse_optimize', 'mkl_cpardiso', 'mkl_pardiso', 'superlu_dist', 'PETSC_ARCH', 'PETSC_DIR', 'CXX_CXXFLAGS', 'LD_SHARED', 'CC_LINKER_FLAGS', 'CXX_LINKER_FLAGS', 'FC_LINKER_FLAGS', 'AR_FLAGS', 'C_VERSION', 'CXX_VERSION', 'FC_VERSION', 'size_t', 'MPI_Comm','MPI_Fint','int64_t']:
31ccb279e1SMatthew Knepley        if name.find(exc) >= 0:
32ccb279e1SMatthew Knepley          exception = True
33ccb279e1SMatthew Knepley      if not exception:
34ccb279e1SMatthew Knepley        raise ValueError('The option '+name+' should probably be '+name.replace('_', '-'));
35ab610953SSatish Balay    if opt.find('=') >=0:
36ab610953SSatish Balay      optval = opt.split('=')[1]
37ab610953SSatish Balay      if optval == 'ifneeded':
38ab610953SSatish Balay        raise ValueError('The option '+opt+' should probably be '+opt.replace('ifneeded', '1'));
39d1fb55d9SBarry Smith    for exc in ['mkl_sparse', 'mkl_sparse_optimize', 'mkl_cpardiso', 'mkl_pardiso', 'superlu_dist']:
40d1fb55d9SBarry Smith      if name.find(exc.replace('_','-')) > -1:
41d1fb55d9SBarry Smith        raise ValueError('The option '+opt+' should be '+opt.replace(exc.replace('_','-'),exc));
42ccb279e1SMatthew Knepley  return
43ccb279e1SMatthew Knepley
442f393ef5SBarry Smithdef check_for_unsupported_combinations(opts):
452f393ef5SBarry Smith  if '--with-precision=single' in opts and '--with-clanguage=cxx' in opts and '--with-scalar-type=complex' in opts:
462f393ef5SBarry Smith    sys.exit(ValueError('PETSc does not support single precision complex with C++ clanguage, run with --with-clanguage=c'))
472f393ef5SBarry Smith
482af240f0SSatish Balaydef check_for_option_changed(opts):
492af240f0SSatish Balay# Document changes in command line options here.
504544382eSSatish Balay  optMap = [('with-64bit-indices','with-64-bit-indices'),
51008db1b6SSatish Balay            ('with-mpi-exec','with-mpiexec'),
524544382eSSatish Balay            ('c-blas-lapack','f2cblaslapack'),
534544382eSSatish Balay            ('cholmod','suitesparse'),
544544382eSSatish Balay            ('umfpack','suitesparse'),
5569cdbcb9SBarry Smith            ('matlabengine','matlab-engine'),
56b129f54cSBarry Smith            ('sundials','sundials2'),
574544382eSSatish Balay            ('f-blas-lapack','fblaslapack'),
584544382eSSatish Balay            ('with-packages-dir','with-packages-download-dir'),
594544382eSSatish Balay            ('with-external-packages-dir','with-packages-build-dir'),
604544382eSSatish Balay            ('package-dirs','with-packages-search-path'),
614544382eSSatish Balay            ('download-petsc4py-python','with-python-exec'),
624544382eSSatish Balay            ('search-dirs','with-executables-search-path')]
632af240f0SSatish Balay  for opt in opts[1:]:
642af240f0SSatish Balay    optname = opt.split('=')[0].strip('-')
652af240f0SSatish Balay    for oldname,newname in optMap:
66b129f54cSBarry Smith      if optname.find(oldname) >=0 and not optname.find(newname):
672af240f0SSatish Balay        raise ValueError('The option '+opt+' should probably be '+opt.replace(oldname,newname))
682af240f0SSatish Balay  return
692af240f0SSatish Balay
7059e9bfd6SSatish Balaydef check_petsc_arch(opts):
71c43ea0feSSatish Balay  # If PETSC_ARCH not specified - use script name (if not configure.py)
72b0b472b0SSatish Balay  global petsc_arch
73c43ea0feSSatish Balay  found = 0
7459e9bfd6SSatish Balay  for name in opts:
75c43ea0feSSatish Balay    if name.find('PETSC_ARCH=') >= 0:
76b0b472b0SSatish Balay      petsc_arch=name.split('=')[1]
77c43ea0feSSatish Balay      found = 1
7859e9bfd6SSatish Balay      break
7959e9bfd6SSatish Balay  # If not yet specified - use the filename of script
80c43ea0feSSatish Balay  if not found:
8159e9bfd6SSatish Balay      filename = os.path.basename(sys.argv[0])
82e68ebbecSBarry Smith      if not filename.startswith('configure') and not filename.startswith('reconfigure') and not filename.startswith('setup'):
83b0b472b0SSatish Balay        petsc_arch=os.path.splitext(os.path.basename(sys.argv[0]))[0]
84b0b472b0SSatish Balay        useName = 'PETSC_ARCH='+petsc_arch
8559e9bfd6SSatish Balay        opts.append(useName)
861937db7aSSatish Balay  return 0
874b8aa89bSBarry Smith
88f08ee00aSJason Sarichdef chkenable():
89f08ee00aSJason Sarich  #Replace all 'enable-'/'disable-' with 'with-'=0/1/tail
90f08ee00aSJason Sarich  #enable-fortran is a special case, the resulting --with-fortran is ambiguous.
911b266c99SBarry Smith  #Would it mean --with-fc=
925bb5b98aSSatish Balay  en_dash = u'\N{EN DASH}'
935bb5b98aSSatish Balay  if sys.version_info < (3, 0):
945bb5b98aSSatish Balay    en_dash = en_dash.encode('utf-8')
95f08ee00aSJason Sarich  for l in range(0,len(sys.argv)):
96f08ee00aSJason Sarich    name = sys.argv[l]
97f08ee00aSJason Sarich
985bb5b98aSSatish Balay    if name.find(en_dash)  >= 0:
995bb5b98aSSatish Balay      sys.argv[l] = name.replace(en_dash,'-')
1002b700d61SJason Sarich    if name.find('enable-cxx') >= 0:
1012b700d61SJason Sarich      if name.find('=') == -1:
1022b700d61SJason Sarich        sys.argv[l] = name.replace('enable-cxx','with-clanguage=C++')
1032b700d61SJason Sarich      else:
1042b700d61SJason Sarich        head, tail = name.split('=', 1)
1052b700d61SJason Sarich        if tail=='0':
1062b700d61SJason Sarich          sys.argv[l] = head.replace('enable-cxx','with-clanguage=C')
1072b700d61SJason Sarich        else:
1082b700d61SJason Sarich          sys.argv[l] = head.replace('enable-cxx','with-clanguage=C++')
1092b700d61SJason Sarich      continue
1102b700d61SJason Sarich    if name.find('disable-cxx') >= 0:
1112b700d61SJason Sarich      if name.find('=') == -1:
1122b700d61SJason Sarich        sys.argv[l] = name.replace('disable-cxx','with-clanguage=C')
1132b700d61SJason Sarich      else:
1142b700d61SJason Sarich        head, tail = name.split('=', 1)
1152b700d61SJason Sarich        if tail == '0':
1162b700d61SJason Sarich          sys.argv[l] = head.replace('disable-cxx','with-clanguage=C++')
1172b700d61SJason Sarich        else:
1182b700d61SJason Sarich          sys.argv[l] = head.replace('disable-cxx','with-clanguage=C')
1192b700d61SJason Sarich      continue
1202b700d61SJason Sarich
121f08ee00aSJason Sarich
122f08ee00aSJason Sarich    if name.find('enable-') >= 0:
123f08ee00aSJason Sarich      if name.find('=') == -1:
124f08ee00aSJason Sarich        sys.argv[l] = name.replace('enable-','with-')+'=1'
125f08ee00aSJason Sarich      else:
126f08ee00aSJason Sarich        head, tail = name.split('=', 1)
127f08ee00aSJason Sarich        sys.argv[l] = head.replace('enable-','with-')+'='+tail
128f08ee00aSJason Sarich    if name.find('disable-') >= 0:
129f08ee00aSJason Sarich      if name.find('=') == -1:
130f08ee00aSJason Sarich        sys.argv[l] = name.replace('disable-','with-')+'=0'
131f08ee00aSJason Sarich      else:
132f08ee00aSJason Sarich        head, tail = name.split('=', 1)
133f08ee00aSJason Sarich        if tail == '1': tail = '0'
134f08ee00aSJason Sarich        sys.argv[l] = head.replace('disable-','with-')+'='+tail
135f08ee00aSJason Sarich    if name.find('without-') >= 0:
136f08ee00aSJason Sarich      if name.find('=') == -1:
137f08ee00aSJason Sarich        sys.argv[l] = name.replace('without-','with-')+'=0'
138f08ee00aSJason Sarich      else:
139f08ee00aSJason Sarich        head, tail = name.split('=', 1)
140f08ee00aSJason Sarich        if tail == '1': tail = '0'
141f08ee00aSJason Sarich        sys.argv[l] = head.replace('without-','with-')+'='+tail
142f08ee00aSJason Sarich
143f08ee00aSJason Sarichdef chksynonyms():
144f08ee00aSJason Sarich  #replace common configure options with ones that PETSc BuildSystem recognizes
14598d87fb0SBarry Smith  simplereplacements = {'F77' : 'FC', 'F90' : 'FC'}
146f08ee00aSJason Sarich  for l in range(0,len(sys.argv)):
147f08ee00aSJason Sarich    name = sys.argv[l]
148f08ee00aSJason Sarich
14986d91f96SSatish Balay    name = name.replace('download-petsc4py','with-petsc4py')
150c58b03afSBarry Smith    name = name.replace('with-openmpi','with-mpi')
151c58b03afSBarry Smith    name = name.replace('with-mpich','with-mpi')
152c58b03afSBarry Smith    name = name.replace('with-blas-lapack','with-blaslapack')
153*3bdc3ccdSStefano Zampini    name = name.replace('with-cuda-gencodearch','with-cuda-arch')
154c87df54fSBarry Smith
155ce54fb35SBarry Smith    if name.find('with-debug=') >= 0 or name.endswith('with-debug'):
156f08ee00aSJason Sarich      if name.find('=') == -1:
157c58b03afSBarry Smith        name = name.replace('with-debug','with-debugging')+'=1'
158f08ee00aSJason Sarich      else:
159f08ee00aSJason Sarich        head, tail = name.split('=', 1)
160c58b03afSBarry Smith        name = head.replace('with-debug','with-debugging')+'='+tail
161f08ee00aSJason Sarich
162ce54fb35SBarry Smith    if name.find('with-shared=') >= 0 or name.endswith('with-shared'):
163f08ee00aSJason Sarich      if name.find('=') == -1:
164c58b03afSBarry Smith        name = name.replace('with-shared','with-shared-libraries')+'=1'
165f08ee00aSJason Sarich      else:
166f08ee00aSJason Sarich        head, tail = name.split('=', 1)
167c58b03afSBarry Smith        name = head.replace('with-shared','with-shared-libraries')+'='+tail
168f08ee00aSJason Sarich
1698fd71741SJason Sarich    if name.find('with-index-size=') >=0:
1708fd71741SJason Sarich      head,tail = name.split('=',1)
1718fd71741SJason Sarich      if int(tail)==32:
172c58b03afSBarry Smith        name = '--with-64-bit-indices=0'
1738fd71741SJason Sarich      elif int(tail)==64:
174c58b03afSBarry Smith        name = '--with-64-bit-indices=1'
1758fd71741SJason Sarich      else:
1768fd71741SJason Sarich        raise RuntimeError('--with-index-size= must be 32 or 64')
177f08ee00aSJason Sarich
1788fd71741SJason Sarich    if name.find('with-precision=') >=0:
1798fd71741SJason Sarich      head,tail = name.split('=',1)
1808fd71741SJason Sarich      if tail.find('quad')>=0:
181c58b03afSBarry Smith        name='--with-precision=__float128'
182f08ee00aSJason Sarich
18398d87fb0SBarry Smith    for i,j in simplereplacements.items():
18498d87fb0SBarry Smith      if name.find(i+'=') >= 0:
185c58b03afSBarry Smith        name = name.replace(i+'=',j+'=')
18698d87fb0SBarry Smith      elif name.find('with-'+i.lower()+'=') >= 0:
187c58b03afSBarry Smith        name = name.replace(i.lower()+'=',j.lower()+'=')
188c58b03afSBarry Smith
189c58b03afSBarry Smith    # restore 'sys.argv[l]' from the intermediate var 'name'
190c58b03afSBarry Smith    sys.argv[l] = name
191f08ee00aSJason Sarich
192b917b182SSatish Balaydef chkwincompilerusinglink():
1936a8f6897SSatish Balay  for arg in sys.argv:
194b917b182SSatish Balay    if (arg.find('win32fe') >= 0 and (arg.find('f90') >=0 or arg.find('ifort') >=0 or arg.find('icl') >=0)):
1956a8f6897SSatish Balay      return 1
1966a8f6897SSatish Balay  return 0
1976a8f6897SSatish Balay
1988a4600f2SSatish Balaydef chkdosfiles():
199360dfd13SSatish Balay  # cygwin - but not a hg clone - so check one of files in bin dir
2008fb0cc24SJed Brown  if b"\r\n" in open(os.path.join('lib','petsc','bin','petscmpiexec'),"rb").read():
2015b6bfdb9SJed Brown    print('===============================================================================')
2025b6bfdb9SJed Brown    print(' *** Scripts are in DOS mode. Was winzip used to extract petsc sources?    ****')
2035b6bfdb9SJed Brown    print(' *** Please restart with a fresh tarball and use "tar -xzf petsc.tar.gz"   ****')
2045b6bfdb9SJed Brown    print('===============================================================================')
205db1f124cSVasiliy Kozyrev    sys.exit(3)
2068a4600f2SSatish Balay  return
2078a4600f2SSatish Balay
2086a8f6897SSatish Balaydef chkcygwinlink():
209b917b182SSatish Balay  if os.path.exists('/usr/bin/cygcheck.exe') and os.path.exists('/usr/bin/link.exe') and chkwincompilerusinglink():
2106a8f6897SSatish Balay      if '--ignore-cygwin-link' in sys.argv: return 0
2115b6bfdb9SJed Brown      print('===============================================================================')
212b917b182SSatish Balay      print(' *** Cygwin /usr/bin/link detected! Compiles with Intel icl/ifort can break!  **')
213a5b23f4aSJose E. Roman      print(' *** To workaround do: "mv /usr/bin/link.exe /usr/bin/link-cygwin.exe"     **')
214b917b182SSatish Balay      print(' *** Or to ignore this check, use configure option: --ignore-cygwin-link. But compiles can fail. **')
2155b6bfdb9SJed Brown      print('===============================================================================')
2166a8f6897SSatish Balay      sys.exit(3)
2176a8f6897SSatish Balay  return 0
2186a8f6897SSatish Balay
21985ef4d1eSSatish Balaydef chkbrokencygwin():
2209dabcff0SSatish Balay  if os.path.exists('/usr/bin/cygcheck.exe'):
2219dabcff0SSatish Balay    buf = os.popen('/usr/bin/cygcheck.exe -c cygwin').read()
2229dabcff0SSatish Balay    if buf.find('1.5.11-1') > -1:
2235b6bfdb9SJed Brown      print('===============================================================================')
2245b6bfdb9SJed Brown      print(' *** cygwin-1.5.11-1 detected. ./configure fails with this version ***')
2255b6bfdb9SJed Brown      print(' *** Please upgrade to cygwin-1.5.12-1 or newer version. This can  ***')
2265b6bfdb9SJed Brown      print(' *** be done by running cygwin-setup, selecting "next" all the way.***')
2275b6bfdb9SJed Brown      print('===============================================================================')
2281937db7aSSatish Balay      sys.exit(3)
2299dabcff0SSatish Balay  return 0
2309dabcff0SSatish Balay
231ee76e990SSatish Balaydef chkusingwindowspython():
232ee76e990SSatish Balay  if sys.platform == 'win32':
2335b6bfdb9SJed Brown    print('===============================================================================')
2345b6bfdb9SJed Brown    print(' *** Windows python detected. Please rerun ./configure with cygwin-python. ***')
2355b6bfdb9SJed Brown    print('===============================================================================')
236ee76e990SSatish Balay    sys.exit(3)
237ee76e990SSatish Balay  return 0
238ee76e990SSatish Balay
23914f5c25cSSatish Balaydef chkcygwinpython():
2401150532aSSatish Balay  if sys.platform == 'cygwin' :
2411150532aSSatish Balay    import platform
2421150532aSSatish Balay    import re
2431150532aSSatish Balay    r=re.compile("([0-9]+).([0-9]+).([0-9]+)")
2441150532aSSatish Balay    m=r.match(platform.release())
2451150532aSSatish Balay    major=int(m.group(1))
2461150532aSSatish Balay    minor=int(m.group(2))
2471150532aSSatish Balay    subminor=int(m.group(3))
2481150532aSSatish Balay    if ((major < 1) or (major == 1 and minor < 7) or (major == 1 and minor == 7 and subminor < 34)):
2491937db7aSSatish Balay      sys.argv.append('--useThreads=0')
2501937db7aSSatish Balay      extraLogs.append('''\
251a0022257SSatish Balay===============================================================================
2521150532aSSatish Balay** Cygwin version is older than 1.7.34. Python threads do not work correctly. ***
25314f5c25cSSatish Balay** Disabling thread usage for this run of ./configure *******
254a0022257SSatish Balay===============================================================================''')
25571384062SSatish Balay  return 0
25671384062SSatish Balay
257cfb8f47aSBarry Smithdef chkcygwinwindowscompilers():
258cfb8f47aSBarry Smith  '''Adds win32fe for Microsoft/Intel compilers'''
259cfb8f47aSBarry Smith  if os.path.exists('/usr/bin/cygcheck.exe'):
260cfb8f47aSBarry Smith    for l in range(1,len(sys.argv)):
261cfb8f47aSBarry Smith      option = sys.argv[l]
262cfb8f47aSBarry Smith      for i in ['cl','icl','ifort']:
263cfb8f47aSBarry Smith        if option.startswith(i):
264cfb8f47aSBarry Smith          sys.argv[l] = 'win32fe '+option
265cfb8f47aSBarry Smith          break
266cfb8f47aSBarry Smith  return 0
267cfb8f47aSBarry Smith
2681937db7aSSatish Balaydef chkrhl9():
2691937db7aSSatish Balay  if os.path.exists('/etc/redhat-release'):
270836c2c52SSatish Balay    try:
271594eb360SSatish Balay      file = open('/etc/redhat-release','r')
272836c2c52SSatish Balay      buf = file.read()
273836c2c52SSatish Balay      file.close()
274836c2c52SSatish Balay    except:
275836c2c52SSatish Balay      # can't read file - assume dangerous RHL9
2761937db7aSSatish Balay      buf = 'Shrike'
277836c2c52SSatish Balay    if buf.find('Shrike') > -1:
2781937db7aSSatish Balay      sys.argv.append('--useThreads=0')
2791937db7aSSatish Balay      extraLogs.append('''\
280a0022257SSatish Balay==============================================================================
2811937db7aSSatish Balay   *** RHL9 detected. Threads do not work correctly with this distribution ***
282e2e64c6bSBarry Smith   ****** Disabling thread usage for this run of ./configure *********
283a0022257SSatish Balay===============================================================================''')
284836c2c52SSatish Balay  return 0
285836c2c52SSatish Balay
286fd1ac241SSatish Balaydef chktmpnoexec():
287e08ecd42SSatish Balay  if not hasattr(os,'ST_NOEXEC'): return # novermin
288fd1ac241SSatish Balay  if 'TMPDIR' in os.environ: tmpDir = os.environ['TMPDIR']
289fd1ac241SSatish Balay  else: tmpDir = '/tmp'
290e08ecd42SSatish Balay  if os.statvfs(tmpDir).f_flag & os.ST_NOEXEC: # novermin
291e08ecd42SSatish Balay    if os.statvfs(os.path.abspath('.')).f_flag & os.ST_NOEXEC: # novermin
292fd1ac241SSatish Balay      print('************************************************************************')
293fd1ac241SSatish Balay      print('* TMPDIR '+tmpDir+' has noexec attribute. Same with '+os.path.abspath('.')+' where petsc is built.')
294fd1ac241SSatish Balay      print('* Suggest building PETSc in a location without this restriction!')
295fd1ac241SSatish Balay      print('* Alternatively, set env variable TMPDIR to a location that is not restricted to run binaries.')
296fd1ac241SSatish Balay      print('************************************************************************')
297fd1ac241SSatish Balay      sys.exit(4)
298fd1ac241SSatish Balay    else:
299fd1ac241SSatish Balay      newTmp = os.path.abspath('tmp-petsc')
300fd1ac241SSatish Balay      print('************************************************************************')
301fd1ac241SSatish Balay      print('* TMPDIR '+tmpDir+' has noexec attribute. Using '+newTmp+' instead.')
302fd1ac241SSatish Balay      print('************************************************************************')
303fd1ac241SSatish Balay      if not os.path.isdir(newTmp): os.mkdir(os.path.abspath(newTmp))
304fd1ac241SSatish Balay      os.environ['TMPDIR'] = newTmp
305fd1ac241SSatish Balay  return
306fd1ac241SSatish Balay
30705f86fb1SBarry Smithdef check_cray_modules():
30805f86fb1SBarry Smith  import script
30905f86fb1SBarry Smith  '''For Cray systems check if the cc, CC, ftn compiler suite modules have been set'''
31005f86fb1SBarry Smith  cray = os.getenv('CRAY_SITE_LIST_DIR')
31105f86fb1SBarry Smith  if not cray: return
31205f86fb1SBarry Smith  cray = os.getenv('CRAYPE_DIR')
31305f86fb1SBarry Smith  if not cray:
31405f86fb1SBarry Smith   print('************************************************************************')
31505f86fb1SBarry Smith   print('* You are on a Cray system but no programming environments have been loaded')
31605f86fb1SBarry Smith   print('* Perhaps you need:')
31705f86fb1SBarry Smith   print('*       module load intel ; module load PrgEnv-intel')
31805f86fb1SBarry Smith   print('*   or  module load PrgEnv-cray')
31905f86fb1SBarry Smith   print('*   or  module load PrgEnv-gnu')
320a17b96a8SKyle Gerard Felker   print('* See https://petsc.org/release/install/install/#installing-on-large-scale-doe-systems')
32105f86fb1SBarry Smith   print('************************************************************************')
32205f86fb1SBarry Smith   sys.exit(4)
32305f86fb1SBarry Smith
324da58527dSSatish Balaydef check_broken_configure_log_links():
325da58527dSSatish Balay  '''Sometime symlinks can get broken if the original files are deleted. Delete such broken links'''
326da58527dSSatish Balay  import os
327da58527dSSatish Balay  for logfile in ['configure.log','configure.log.bkp']:
328da58527dSSatish Balay    if os.path.islink(logfile) and not os.path.isfile(logfile): os.remove(logfile)
329da58527dSSatish Balay  return
330da58527dSSatish Balay
331da1d79b4SSatish Balaydef move_configure_log(framework):
332af0996ceSBarry Smith  '''Move configure.log to PETSC_ARCH/lib/petsc/conf - and update configure.log.bkp in both locations appropriately'''
333b0b472b0SSatish Balay  global petsc_arch
334b0b472b0SSatish Balay
335b0b472b0SSatish Balay  if hasattr(framework,'arch'): petsc_arch = framework.arch
336b0b472b0SSatish Balay  if hasattr(framework,'logName'): curr_file = framework.logName
337b0b472b0SSatish Balay  else: curr_file = 'configure.log'
338b0b472b0SSatish Balay
339b0b472b0SSatish Balay  if petsc_arch:
340da1d79b4SSatish Balay    import shutil
341da1d79b4SSatish Balay    import os
342b0b472b0SSatish Balay
343b0b472b0SSatish Balay    # Just in case - confdir is not created
344fe998a80SBarry Smith    lib_dir = os.path.join(petsc_arch,'lib')
345be5c6b33SBarry Smith    petsc_dir = os.path.join(petsc_arch,'lib','petsc')
346af0996ceSBarry Smith    conf_dir = os.path.join(petsc_arch,'lib','petsc','conf')
347b0b472b0SSatish Balay    if not os.path.isdir(petsc_arch): os.mkdir(petsc_arch)
348fe998a80SBarry Smith    if not os.path.isdir(lib_dir): os.mkdir(lib_dir)
349be5c6b33SBarry Smith    if not os.path.isdir(petsc_dir): os.mkdir(petsc_dir)
350b0b472b0SSatish Balay    if not os.path.isdir(conf_dir): os.mkdir(conf_dir)
351b0b472b0SSatish Balay
352da1d79b4SSatish Balay    curr_bkp  = curr_file + '.bkp'
353b0b472b0SSatish Balay    new_file  = os.path.join(conf_dir,curr_file)
354da1d79b4SSatish Balay    new_bkp   = new_file + '.bkp'
355da1d79b4SSatish Balay
356af0996ceSBarry Smith    # Keep backup in $PETSC_ARCH/lib/petsc/conf location
357da1d79b4SSatish Balay    if os.path.isfile(new_bkp): os.remove(new_bkp)
358da1d79b4SSatish Balay    if os.path.isfile(new_file): os.rename(new_file,new_bkp)
3599e50940cSSatish Balay    if os.path.isfile(curr_file):
3609e50940cSSatish Balay      shutil.copyfile(curr_file,new_file)
3619e50940cSSatish Balay      os.remove(curr_file)
362da58527dSSatish Balay    if os.path.isfile(new_file): os.symlink(new_file,curr_file)
363af0996ceSBarry Smith    # If the old bkp is using the same PETSC_ARCH/lib/petsc/conf - then update bkp link
364da1d79b4SSatish Balay    if os.path.realpath(curr_bkp) == os.path.realpath(new_file):
365da58527dSSatish Balay      if os.path.isfile(curr_bkp): os.remove(curr_bkp)
366da58527dSSatish Balay      if os.path.isfile(new_bkp): os.symlink(new_bkp,curr_bkp)
367da1d79b4SSatish Balay  return
368da1d79b4SSatish Balay
369d93c4beeSSatish Balaydef print_final_timestamp(framework):
370d93c4beeSSatish Balay  import time
371d93c4beeSSatish Balay  framework.log.write(('='*80)+'\n')
3727a01bd3eSSatish Balay  framework.log.write('Finishing configure run at '+time.strftime('%a, %d %b %Y %H:%M:%S %z')+'\n')
373d93c4beeSSatish Balay  framework.log.write(('='*80)+'\n')
374d93c4beeSSatish Balay  return
375d93c4beeSSatish Balay
3765d5a5a7bSMatthew Knepleydef petsc_configure(configure_options):
3776e464aa7SMatthew G. Knepley  if 'PETSC_DIR' in os.environ:
3784a532159SBarry Smith    petscdir = os.environ['PETSC_DIR']
3796e464aa7SMatthew G. Knepley    if petscdir.find(' ') > -1:
3806e464aa7SMatthew G. Knepley      raise RuntimeError('Your PETSC_DIR '+petscdir+' has spaces in it; this is not allowed.\n Change the directory with PETSc to not have spaces in it')
381e9369aacSJunchao Zhang    if not os.path.isabs(petscdir):
382ebf7aa9eSBarry Smith      raise RuntimeError('PETSC_DIR ("'+petscdir+'") is set as a relative path. It must be set as an absolute path.')
383ebf7aa9eSBarry Smith
3846e464aa7SMatthew G. Knepley    try:
385c3a89c15SBarry Smith      sys.path.append(os.path.join(petscdir,'lib','petsc','bin'))
3864a532159SBarry Smith      import petscnagupgrade
3874a532159SBarry Smith      file     = os.path.join(petscdir,'.nagged')
3884a532159SBarry Smith      if not petscnagupgrade.naggedtoday(file):
3894a532159SBarry Smith        petscnagupgrade.currentversion(petscdir)
3904a532159SBarry Smith    except:
3914a532159SBarry Smith      pass
39229bef039SJacob Faibussowitsch  print('=============================================================================================')
3935b6bfdb9SJed Brown  print('                      Configuring PETSc to compile on your system                            ')
39429bef039SJacob Faibussowitsch  print('=============================================================================================')
39559e9bfd6SSatish Balay
396a258c2c4SMatthew G Knepley  try:
397c43ea0feSSatish Balay    # Command line arguments take precedence (but don't destroy argv[0])
398c43ea0feSSatish Balay    sys.argv = sys.argv[:1] + configure_options + sys.argv[1:]
399ccb279e1SMatthew Knepley    check_for_option_mistakes(sys.argv)
4002af240f0SSatish Balay    check_for_option_changed(sys.argv)
4015b6bfdb9SJed Brown  except (TypeError, ValueError) as e:
402a258c2c4SMatthew G Knepley    emsg = str(e)
403a258c2c4SMatthew G Knepley    if not emsg.endswith('\n'): emsg = emsg+'\n'
404a258c2c4SMatthew G Knepley    msg ='*******************************************************************************\n'\
405a258c2c4SMatthew G Knepley    +'                ERROR in COMMAND LINE ARGUMENT to ./configure \n' \
406a258c2c4SMatthew G Knepley    +'-------------------------------------------------------------------------------\n'  \
407a258c2c4SMatthew G Knepley    +emsg+'*******************************************************************************\n'
408a258c2c4SMatthew G Knepley    sys.exit(msg)
40959e9bfd6SSatish Balay  # check PETSC_ARCH
4102f393ef5SBarry Smith  check_for_unsupported_combinations(sys.argv)
41159e9bfd6SSatish Balay  check_petsc_arch(sys.argv)
412da58527dSSatish Balay  check_broken_configure_log_links()
4135fb2c094SBarry Smith
414f08ee00aSJason Sarich  #rename '--enable-' to '--with-'
415f08ee00aSJason Sarich  chkenable()
416c22cdea9SBarry Smith  # support a few standard configure option types
417f08ee00aSJason Sarich  chksynonyms()
4189dabcff0SSatish Balay  # Check for broken cygwin
4191937db7aSSatish Balay  chkbrokencygwin()
420d65f3bddSMatthew Knepley  # Disable threads on RHL9
4211937db7aSSatish Balay  chkrhl9()
422ee76e990SSatish Balay  # Make sure cygwin-python is used on windows
423ee76e990SSatish Balay  chkusingwindowspython()
42414f5c25cSSatish Balay  # Threads don't work for cygwin & python...
42514f5c25cSSatish Balay  chkcygwinpython()
4266a8f6897SSatish Balay  chkcygwinlink()
4278a4600f2SSatish Balay  chkdosfiles()
428cfb8f47aSBarry Smith  chkcygwinwindowscompilers()
429fd1ac241SSatish Balay  chktmpnoexec()
4309dabcff0SSatish Balay
431a9acdec7SBarry Smith  for l in range(1,len(sys.argv)):
432a9acdec7SBarry Smith    if sys.argv[l].startswith('--with-fc=') and sys.argv[l].endswith('nagfor'):
433a9acdec7SBarry Smith      # need a way to save this value and later CC so that petscnagfor may use them
434a9acdec7SBarry Smith      name = sys.argv[l].split('=')[1]
435a9acdec7SBarry Smith      sys.argv[l] = '--with-fc='+os.path.join(os.path.abspath('.'),'lib','petsc','bin','petscnagfor')
436a9acdec7SBarry Smith      break
437a9acdec7SBarry Smith
438a9acdec7SBarry Smith
43987282423SMatthew Knepley  # Should be run from the toplevel
440dbca6d9dSSatish Balay  configDir = os.path.abspath('config')
441f8833479SBarry Smith  bsDir     = os.path.join(configDir, 'BuildSystem')
442f8833479SBarry Smith  if not os.path.isdir(configDir):
4435d5a5a7bSMatthew Knepley    raise RuntimeError('Run configure from $PETSC_DIR, not '+os.path.abspath('.'))
44487282423SMatthew Knepley  sys.path.insert(0, bsDir)
445f8833479SBarry Smith  sys.path.insert(0, configDir)
446e69ef9dfSMatthew Knepley  import config.base
4475d5a5a7bSMatthew Knepley  import config.framework
448492432c8SJed Brown  import pickle
4494e5e6a77SJed Brown  import traceback
4504f8a5b45SBarry Smith
45105f86fb1SBarry Smith  # Check Cray without modules
45205f86fb1SBarry Smith  check_cray_modules()
45305f86fb1SBarry Smith
45438c5b55eSBarry Smith  tbo = None
4559dd2fdb1SMatthew Knepley  framework = None
4569dd2fdb1SMatthew Knepley  try:
45723a19ef1SSatish Balay    framework = config.framework.Framework(['--configModules=PETSc.Configure','--optionsModule=config.compilerOptions']+sys.argv[1:], loadArgDB = 0)
458d65f3bddSMatthew Knepley    framework.setup()
459d65f3bddSMatthew Knepley    framework.logPrint('\n'.join(extraLogs))
460f24f64feSBarry Smith    framework.configure(out = sys.stdout)
461358ebc22SMatthew Knepley    framework.storeSubstitutions(framework.argDB)
462492432c8SJed Brown    framework.argDB['configureCache'] = pickle.dumps(framework)
4637c939e48SSatish Balay    framework.printSummary()
46412c1d45bSMatthew G Knepley    framework.argDB.save(force = True)
4657cfd0b05SBarry Smith    framework.logClear()
466d93c4beeSSatish Balay    print_final_timestamp(framework)
467eefa2c0fSBarry Smith    framework.closeLog()
4689e50940cSSatish Balay    try:
469da1d79b4SSatish Balay      move_configure_log(framework)
4709e50940cSSatish Balay    except:
4719e50940cSSatish Balay      # perhaps print an error about unable to shuffle logs?
4729e50940cSSatish Balay      pass
473dd50d019SBarry Smith    return 0
4745b6bfdb9SJed Brown  except (RuntimeError, config.base.ConfigureSetupError) as e:
4751a7b8b2eSBarry Smith    tbo = sys.exc_info()[2]
4767d670a3cSBarry Smith    emsg = str(e)
47742351d26SSatish Balay    if not emsg.endswith('\n'): emsg = emsg+'\n'
478a0022257SSatish Balay    msg ='*******************************************************************************\n'\
479fe09c992SBarry Smith    +'         UNABLE to CONFIGURE with GIVEN OPTIONS    (see configure.log for details):\n' \
480a0022257SSatish Balay    +'-------------------------------------------------------------------------------\n'  \
481a0022257SSatish Balay    +emsg+'*******************************************************************************\n'
482e9f3bb17SBarry Smith    se = ''
4835b6bfdb9SJed Brown  except (TypeError, ValueError) as e:
48438c5b55eSBarry Smith    # this exception is automatically deleted by Python so we need to save it to print below
48538c5b55eSBarry Smith    tbo = sys.exc_info()[2]
4867d670a3cSBarry Smith    emsg = str(e)
48742351d26SSatish Balay    if not emsg.endswith('\n'): emsg = emsg+'\n'
488a0022257SSatish Balay    msg ='*******************************************************************************\n'\
489edd0a2d9SBarry Smith    +'    TypeError or ValueError possibly related to ERROR in COMMAND LINE ARGUMENT while running ./configure \n' \
490a0022257SSatish Balay    +'-------------------------------------------------------------------------------\n'  \
491a0022257SSatish Balay    +emsg+'*******************************************************************************\n'
4921a02243aSBarry Smith    se = ''
4935b6bfdb9SJed Brown  except ImportError as e :
494edd0a2d9SBarry Smith    # this exception is automatically deleted by Python so we need to save it to print below
495edd0a2d9SBarry Smith    tbo = sys.exc_info()[2]
4967d670a3cSBarry Smith    emsg = str(e)
49742351d26SSatish Balay    if not emsg.endswith('\n'): emsg = emsg+'\n'
498a0022257SSatish Balay    msg ='*******************************************************************************\n'\
499edd0a2d9SBarry Smith    +'                     ImportError while runing ./configure \n' \
500a0022257SSatish Balay    +'-------------------------------------------------------------------------------\n'  \
501a0022257SSatish Balay    +emsg+'*******************************************************************************\n'
50296dc2fe8SMatthew Knepley    se = ''
5035b6bfdb9SJed Brown  except OSError as e :
5041a7b8b2eSBarry Smith    tbo = sys.exc_info()[2]
50501def6f0SMatthew Knepley    emsg = str(e)
50601def6f0SMatthew Knepley    if not emsg.endswith('\n'): emsg = emsg+'\n'
507a0022257SSatish Balay    msg ='*******************************************************************************\n'\
508edd0a2d9SBarry Smith    +'                    OSError while running ./configure \n' \
509a0022257SSatish Balay    +'-------------------------------------------------------------------------------\n'  \
510a0022257SSatish Balay    +emsg+'*******************************************************************************\n'
51101def6f0SMatthew Knepley    se = ''
5125b6bfdb9SJed Brown  except SystemExit as e:
5131a7b8b2eSBarry Smith    tbo = sys.exc_info()[2]
514d7d3c4beSMatthew Knepley    if e.code is None or e.code == 0:
515d7d3c4beSMatthew Knepley      return
51641f847afSJed Brown    if e.code == 10:
517c524ecbbSBarry Smith      sys.exit(10)
518a0022257SSatish Balay    msg ='*******************************************************************************\n'\
519b1dada7fSMatthew Knepley    +'         CONFIGURATION FAILURE  (Please send configure.log to petsc-maint@mcs.anl.gov)\n' \
520a0022257SSatish Balay    +'*******************************************************************************\n'
521d7d3c4beSMatthew Knepley    se  = str(e)
5225b6bfdb9SJed Brown  except Exception as e:
5231a7b8b2eSBarry Smith    tbo = sys.exc_info()[2]
524a0022257SSatish Balay    msg ='*******************************************************************************\n'\
525fe09c992SBarry Smith    +'        CONFIGURATION CRASH  (Please send configure.log to petsc-maint@mcs.anl.gov)\n' \
526a0022257SSatish Balay    +'*******************************************************************************\n'
527e9f3bb17SBarry Smith    se  = str(e)
528e9f3bb17SBarry Smith
5295b6bfdb9SJed Brown  print(msg)
5309dd2fdb1SMatthew Knepley  if not framework is None:
5319dd2fdb1SMatthew Knepley    framework.logClear()
532e9f3bb17SBarry Smith    if hasattr(framework, 'log'):
53322c95ba3SMatthew G Knepley      try:
534d71f8ab3SSatish Balay        if hasattr(framework,'compilerDefines'):
535bd5137a2SBarry Smith          framework.log.write('**** Configure header '+framework.compilerDefines+' ****\n')
536febd46b0SSatish Balay          framework.outputHeader(framework.log)
537d71f8ab3SSatish Balay        if hasattr(framework,'compilerFixes'):
538bd5137a2SBarry Smith          framework.log.write('**** C specific Configure header '+framework.compilerFixes+' ****\n')
539febd46b0SSatish Balay          framework.outputCHeader(framework.log)
5405b6bfdb9SJed Brown      except Exception as e:
54122c95ba3SMatthew G Knepley        framework.log.write('Problem writing headers to log: '+str(e))
542b1dada7fSMatthew Knepley      try:
543f24f64feSBarry Smith        framework.log.write(msg+se)
54438c5b55eSBarry Smith        traceback.print_tb(tbo, file = framework.log)
545d93c4beeSSatish Balay        print_final_timestamp(framework)
546f73e6a6cSSatish Balay        if hasattr(framework,'log'): framework.log.close()
547da1d79b4SSatish Balay        move_configure_log(framework)
548957f4b51SBarry Smith      except Exception as e:
549957f4b51SBarry Smith        print('Error printing error message from exception or printing the traceback:'+str(e))
5501a7b8b2eSBarry Smith        traceback.print_tb(sys.exc_info()[2])
551e9f3bb17SBarry Smith      sys.exit(1)
5525a74f024SMatthew Knepley    else:
5535b6bfdb9SJed Brown      print(se)
5541a7b8b2eSBarry Smith      traceback.print_tb(tbo)
555957f4b51SBarry Smith  else:
556957f4b51SBarry Smith    print(se)
5571a7b8b2eSBarry Smith    traceback.print_tb(tbo)
558f73e6a6cSSatish Balay  if hasattr(framework,'log'): framework.log.close()
5595d5a5a7bSMatthew Knepley
5605d5a5a7bSMatthew Knepleyif __name__ == '__main__':
561a030c540SBarry Smith  petsc_configure([])
562