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