xref: /petsc/config/PETSc/options/arch.py (revision 70211a5b3274930cafb12688f7eb9040c26c5fba)
19d310bb7SBarry Smithimport config.base
29d310bb7SBarry Smithimport os
39d310bb7SBarry Smithimport re
49d310bb7SBarry Smith
59d310bb7SBarry Smithclass Configure(config.base.Configure):
69d310bb7SBarry Smith  def __init__(self, framework):
79d310bb7SBarry Smith    config.base.Configure.__init__(self, framework)
89d310bb7SBarry Smith    self.headerPrefix = 'PETSC'
99d310bb7SBarry Smith    self.substPrefix  = 'PETSC'
109d310bb7SBarry Smith    return
119d310bb7SBarry Smith
129d310bb7SBarry Smith  def __str1__(self):
139d310bb7SBarry Smith    if not hasattr(self, 'arch'):
149d310bb7SBarry Smith      return ''
159d310bb7SBarry Smith    desc = ['PETSc:']
169d310bb7SBarry Smith    desc.append('  PETSC_ARCH: '+str(self.arch))
179d310bb7SBarry Smith    return '\n'.join(desc)+'\n'
189d310bb7SBarry Smith
199d310bb7SBarry Smith  def setupHelp(self, help):
209d310bb7SBarry Smith    import nargs
219d310bb7SBarry Smith    help.addArgument('PETSc', '-PETSC_ARCH=<string>',     nargs.Arg(None, None, 'The configuration name'))
229d310bb7SBarry Smith    help.addArgument('PETSc', '-with-petsc-arch=<string>',nargs.Arg(None, None, 'The configuration name'))
239d310bb7SBarry Smith    return
249d310bb7SBarry Smith
25*70211a5bSSatish Balay  def createArchitecture(self):
26*70211a5bSSatish Balay    import sys
27*70211a5bSSatish Balay    arch = 'arch-' + sys.platform.replace('cygwin','mswin')
28*70211a5bSSatish Balay    # use opt/debug, c/c++ tags.s
29*70211a5bSSatish Balay    arch+= '-'+self.framework.argDB['with-clanguage'].lower().replace('+','x')
30*70211a5bSSatish Balay    if self.framework.argDB['with-debugging']:
31*70211a5bSSatish Balay      arch += '-debug'
32*70211a5bSSatish Balay    else:
33*70211a5bSSatish Balay      arch += '-opt'
34*70211a5bSSatish Balay    return arch
35*70211a5bSSatish Balay
369d310bb7SBarry Smith  def configureArchitecture(self):
379d310bb7SBarry Smith    '''Checks PETSC_ARCH and sets if not set'''
389d310bb7SBarry Smith    # Warn if PETSC_ARCH doesnt match env variable
399d310bb7SBarry Smith    if 'PETSC_ARCH' in self.framework.argDB and 'PETSC_ARCH' in os.environ and self.framework.argDB['PETSC_ARCH'] != os.environ['PETSC_ARCH']:
409d310bb7SBarry Smith      self.logPrintBox('''\
419d310bb7SBarry SmithWarning: PETSC_ARCH from environment does not match command-line or name of script.
429d310bb7SBarry SmithWarning: Using from command-line or name of script: %s, ignoring environment: %s''' % (str(self.framework.argDB['PETSC_ARCH']), str(os.environ['PETSC_ARCH'])))
4357ea55fdSJed Brown      os.environ['PETSC_ARCH'] = self.framework.argDB['PETSC_ARCH']
449d310bb7SBarry Smith    if 'with-petsc-arch' in self.framework.argDB:
459d310bb7SBarry Smith      self.arch = self.framework.argDB['with-petsc-arch']
46*70211a5bSSatish Balay      msg = 'option -with-petsc-arch='+str(self.arch)
479d310bb7SBarry Smith    elif 'PETSC_ARCH' in self.framework.argDB:
489d310bb7SBarry Smith      self.arch = self.framework.argDB['PETSC_ARCH']
49*70211a5bSSatish Balay      msg = 'option PETSC_ARCH='+str(self.arch)
50*70211a5bSSatish Balay    elif 'PETSC_ARCH' in os.environ:
519d310bb7SBarry Smith      self.arch = os.environ['PETSC_ARCH']
52*70211a5bSSatish Balay      msg = 'environment variable PETSC_ARCH='+str(self.arch)
539d310bb7SBarry Smith    else:
54*70211a5bSSatish Balay      self.arch = self.createArchitecture()
559d310bb7SBarry Smith    if self.arch.find('/') >= 0 or self.arch.find('\\') >= 0:
56*70211a5bSSatish Balay      raise RuntimeError('PETSC_ARCH should not contain path characters, but you have specified with '+msg)
57002ae2c9SLisandro Dalcin    if self.arch.startswith('-'):
58*70211a5bSSatish Balay      raise RuntimeError('PETSC_ARCH should not start with "-", but you have specified with '+msg)
59*70211a5bSSatish Balay    if self.arch.startswith('.'):
60*70211a5bSSatish Balay      raise RuntimeError('PETSC_ARCH should not start with ".", but you have specified with '+msg)
61*70211a5bSSatish Balay    if not len(self.arch):
62*70211a5bSSatish Balay      raise RuntimeError('PETSC_ARCH cannot be empty string. Use a valid string or do not set one. Currently set with '+msg)
639d310bb7SBarry Smith    self.archBase = re.sub(r'^(\w+)[-_]?.*$', r'\1', self.arch)
649d310bb7SBarry Smith    self.addDefine('ARCH', '"'+self.arch+'"')
659d310bb7SBarry Smith    return
669d310bb7SBarry Smith
679d310bb7SBarry Smith  def configure(self):
689d310bb7SBarry Smith    self.executeTest(self.configureArchitecture)
699d310bb7SBarry Smith    # required by top-level configure.py
709d310bb7SBarry Smith    self.framework.arch = self.arch
719d310bb7SBarry Smith    return
72