/[escript]/trunk/site_scons/site_init.py
ViewVC logotype

Annotation of /trunk/site_scons/site_init.py

Parent Directory Parent Directory | Revision Log Revision Log


Revision 4295 - (hide annotations)
Fri Mar 8 04:42:01 2013 UTC (6 years, 4 months ago) by caltinay
File MIME type: text/x-python
File size: 7037 byte(s)
de-cluttered sconstruct a bit and fixed a script.

1 ksteube 1810
2 jfenwick 3981 ##############################################################################
3 ksteube 1810 #
4 jfenwick 4154 # Copyright (c) 2003-2013 by University of Queensland
5 jfenwick 3981 # http://www.uq.edu.au
6 ksteube 1810 #
7     # Primary Business: Queensland, Australia
8     # Licensed under the Open Software License version 3.0
9     # http://www.opensource.org/licenses/osl-3.0.php
10     #
11 jfenwick 3981 # Development until 2012 by Earth Systems Science Computational Center (ESSCC)
12     # Development since 2012 by School of Earth Sciences
13     #
14     ##############################################################################
15 ksteube 1810
16 jfenwick 4154 __copyright__="""Copyright (c) 2003-2013 by University of Queensland
17 jfenwick 3981 http://www.uq.edu.au
18 ksteube 1810 Primary Business: Queensland, Australia"""
19     __license__="""Licensed under the Open Software License version 3.0
20     http://www.opensource.org/licenses/osl-3.0.php"""
21 jfenwick 2344 __url__="https://launchpad.net/escript-finley"
22 ksteube 1810
23 caltinay 3975 import sys, os, time, py_compile, re, subprocess
24 caltinay 4295 from SCons.Defaults import Chmod
25     from grouptest import *
26 elspeth 645
27 caltinay 3212 def findLibWithHeader(env, libs, header, paths, lang='c'):
28 caltinay 3214 from SCons.Script.SConscript import Configure
29 caltinay 3212 inc_path=''
30     lib_path=''
31     # 'paths' may be a prefix, so look for lib and include subdirectories
32     if type(paths)==str:
33     # find the header file first
34     for i in 'include','include64','include32','inc':
35     inc=os.path.join(paths, i)
36     if os.path.isfile(os.path.join(inc, header)):
37     inc_path=inc
38     break
39     if inc_path=='':
40     raise RuntimeError('%s not found under %s'%(header,paths))
41    
42     # now try to find a lib directory
43     for l in 'lib','lib64','lib32':
44     lp=os.path.join(paths, l)
45     if os.path.isdir(lp):
46     lib_path=lp
47     break
48     if lib_path=='':
49     raise RuntimeError('No lib directory found under %s'%paths)
50     else:
51     if os.path.isfile(os.path.join(paths[0], header)):
52     inc_path=paths[0]
53     else:
54     raise RuntimeError('%s not found under %s'%(header,paths[0]))
55     if os.path.isdir(paths[1]):
56     lib_path=paths[1]
57     else:
58     raise RuntimeError('%s is not a valid path.'%paths[1])
59    
60     # now try the library
61 caltinay 3229 conf=Configure(env.Clone())
62 caltinay 3212 conf.env.AppendUnique(CPPPATH = [inc_path])
63     conf.env.AppendUnique(LIBPATH = [lib_path])
64     if type(libs)==str: libs=[libs]
65 caltinay 3214 # we can't check for each library by itself since they may depend on each
66     # other, so we add all libraries to the link line and check only for one
67     conf.env.AppendUnique(LIBS = libs)
68     if not conf.CheckLibWithHeader(libs[0], header, lang):
69     conf.Finish()
70     raise RuntimeError('Unable to link against %s (paths: %s, %s)'%(libs,inc_path,lib_path))
71 caltinay 3212
72     conf.Finish()
73     return inc_path, lib_path
74    
75 caltinay 3975 def detectModule(env, module):
76     if env['pythoncmd']=='python':
77     try:
78     __import__(module)
79     except ImportError:
80 caltinay 4295 env[module] = False
81 caltinay 3975 return False
82     else:
83     p=subprocess.call([env['pythoncmd'],'-c','import %s'%module])
84     if p!=0:
85 caltinay 4295 env[module] = False
86 caltinay 3975 return False
87 caltinay 4295 env[module] = True
88 caltinay 3975 return True
89 gross 3580
90 caltinay 4295 def write_buildvars(env):
91     buildvars=open(os.path.join(env['libinstall'], 'buildvars'), 'w')
92     for k,v in sorted(env['buildvars'].items()):
93     buildvars.write("%s=%s\n"%(k,v))
94     buildvars.close()
95    
96     def generateTestScripts(env, TestGroups):
97     try:
98     utest=open('utest.sh','w')
99     utest.write(GroupTest.makeHeader(env['PLATFORM'], env['prefix'], False))
100     for tests in TestGroups:
101     utest.write(tests.makeString())
102     utest.close()
103     env.Execute(Chmod('utest.sh', 0o755))
104     print("Generated utest.sh.")
105     # This version contains only python tests - I want this to be usable
106     # from a binary only install if you have the test files
107     utest=open('itest.sh','w')
108     utest.write(GroupTest.makeHeader(env['PLATFORM'], env['prefix'], True))
109     for tests in TestGroups:
110     if tests.exec_cmd=='$PYTHONRUNNER ':
111     utest.write(tests.makeString())
112     utest.close()
113     env.Execute(Chmod('itest.sh', 0o755))
114     print("Generated itest.sh.")
115     except IOError:
116     env['warnings'].append("Error attempting to write unit test script(s).")
117    
118     # delete scripts upon cleanup
119     env.Clean('target_init', 'utest.sh')
120     env.Clean('target_init', 'itest.sh')
121    
122     # Make sure that the escript wrapper is in place
123     if not os.path.isfile(os.path.join(env['bininstall'], 'run-escript')):
124     print("Copying escript wrapper.")
125     Execute(Copy(os.path.join(env['bininstall'],'run-escript'), 'bin/run-escript'))
126    
127 jgs 268 # Code to build .pyc from .py
128     def build_py(target, source, env):
129 gross 3580 try:
130     py_compile.compile(str(source[0]), str(target[0]), doraise=True)
131     return 0
132 gross 3581 except py_compile.PyCompileError, e:
133 gross 3580 print e
134     return 1
135 jgs 297
136 caltinay 4295
137 jgs 297 # Code to run unit_test executables
138     def runUnitTest(target, source, env):
139 ksteube 1312 time_start = time.time()
140     app = str(source[0].abspath)
141 gross 2502 pn, sn= os.path.split(app)
142 gross 2363 if not os.name== "nt":
143 caltinay 3376 app = "cd "+pn+"; "+os.path.join(env['bininstall'], "run-escript")+" -bv "+os.path.join('.',sn)
144 gross 2416 else:
145     if env['usempi']:
146 trankine 2629 app = "cd %s & mpiexec -np %s -genvlist PYTHONPATH,OMP_NUM_THREADS,"\
147 gross 2423 "FINLEY_TEST_DATA,PYVISI_TEST_DATA_ROOT,PYVISI_WORKDIR,PATH %s"\
148 gross 2502 %(pn,env['ENV']['ESCRIPT_NUM_NODES'], sn)
149     else:
150 trankine 2629 app = "cd "+ pn +" & "+sn
151 ksteube 1312 print "Executing test: " + app
152     if not env.Execute(app):
153 jgs 297 open(str(target[0]),'w').write("PASSED\n")
154 ksteube 1312 else:
155     return 1
156     print "Test execution time: ", round(time.time() - time_start, 1), " seconds wall time for " + str(source[0].abspath)
157     return None
158 cochrane 370
159 robwdcock 682 def runPyUnitTest(target, source, env):
160 ksteube 1312 time_start = time.time()
161     app = str(source[0].abspath)
162 gross 2502 pn, sn= os.path.split(app)
163 gross 2363 if os.name== "nt":
164 gross 2416 if env['usempi']:
165 trankine 2629 app = "cd %s & mpiexec -np %s -genvlist PYTHONPATH,OMP_NUM_THREADS,"\
166 gross 2423 "FINLEY_TEST_DATA,PYVISI_TEST_DATA_ROOT,PYVISI_WORKDIR,PATH %s\pythonMPIredirect.exe %s"\
167 gross 2502 %(pn,env['ENV']['ESCRIPT_NUM_NODES'],env['libinstall'],sn)
168 gross 2416 else:
169 trankine 2629 app = "cd "+ pn +" & "+sys.executable + " " + sn
170 ksteube 1312 else:
171 caltinay 3376 app = "cd "+pn+"; "+os.path.join(env['bininstall'], "run-escript")+" -ov "+sn
172 gross 2502 print "Executing test: ",app
173 gross 1374 if env.Execute(app) == 0:
174 ksteube 1312 open(str(target[0]),'w').write("PASSED\n")
175     else:
176     return 1
177     print "Test execution time: ", round(time.time() - time_start, 1), " seconds wall time for " + str(source[0].abspath)
178     return None
179 phornby 1233
180 jfenwick 2387 def eps2pdf(target, source, env):
181 jfenwick 3053 # if env.Execute("epstopdf "+str(source[0].abspath)+" -o "+str(target[0].abspath))!=0:
182 caltinay 3270 if env.Execute("ps2pdf -dEPSCrop "+str(source[0].abspath)+" "+str(target[0].abspath))!=0:
183 jfenwick 2387 return 1
184 jfenwick 2388 return None
185    
186     def effectiveName(inname):
187     m=re.compile("^r1i[0-9]{1,2}n[0-9]{1,2}$") # savanna names take the form r1i?n?
188     if m.match(inname):
189 jfenwick 3047 return "savanna"
190 jfenwick 2388 return inname

  ViewVC Help
Powered by ViewVC 1.1.26