From bbd7e72fe81003f8e1baee6df38ff96cf3c2b8ad Mon Sep 17 00:00:00 2001 From: Mahesh Balasubramaniam Date: Tue, 29 Jan 2013 15:30:28 +0000 Subject: [PATCH] setup_Makefile split seperately from the previous setup_code.py --- code/setup/setup_Makefile.py | 63 ++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 code/setup/setup_Makefile.py diff --git a/code/setup/setup_Makefile.py b/code/setup/setup_Makefile.py new file mode 100644 index 000000000..fe576986b --- /dev/null +++ b/code/setup/setup_Makefile.py @@ -0,0 +1,63 @@ +#!/usr/bin/env python +import os,string,re,damask + + +architectures = { + 'marc': { + 'parent': 'DAMASK_marc.f90', + 'versions' : ['%%MARCVERSION%%','2010','2011','2012'], + }, + } + + +damaskEnv = damask.Environment('../../') # script location relative to root +baseDir = damaskEnv.relPath('code/') + +for arch in architectures: + me = architectures[arch] + try: + parentFile = open(baseDir+os.sep+me['parent']) + parentContent = parentFile.readlines() + parentFile.close() + except IOError: + print 'unable to open',me['parent'] + continue + + + for version in me['versions'][1:]: + childFile = open(baseDir+os.sep+version.join(os.path.splitext(me['parent'])),'w') + for line in parentContent: + childFile.write(line.replace(me['versions'][0],version)) + childFile.close() + +# changing dirs in makefile +makefile = open(os.path.join(baseDir,'Makefile')) +content = makefile.readlines() +makefile.close() +makefile = open(os.path.join(baseDir,'Makefile'),'w') +for line in content: + m = re.match(r'(FFTW|IMKL|ACML|LAPACK)ROOT\s*\?=',line) + if m: + if m.group(1).lower() in damaskEnv.pathInfo: + substitution = damaskEnv.pathInfo[m.group(1).lower()] + else: + substitution = '' + line = '%sROOT ?= %s\n'%(m.group(1),substitution) + makefile.write(line) +makefile.close() + + + + + + + + + + + + + + + +