/[escript]/branches/numpy/SConstruct
ViewVC logotype

Annotation of /branches/numpy/SConstruct

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1634 - (hide annotations)
Sat Jul 12 09:08:33 2008 UTC (10 years, 9 months ago) by phornby
Original Path: trunk/SConstruct
File size: 33243 byte(s)
linux_gcc_eg_options.py:
remove the std99 option, it is no longer needed as the code compiles without
C 1999 extension (need for these extensions elinminated in windows port).
Turn on all warnings except unknown pragmas. Should catch a lot of stuff.

SConstruct:
Impassioned plea

system_dep.h:
Add the standard incantation for dealing with const declarations
in C code called from C and C++

blocktimer:
Get the calling interface right for C code called from C and C++
and use __const as defined in system_dep.h
(Should be re-factored into compiler_dep.h file).

MeshAdapterFactory.cpp:
Since we have (effectively) no control over netCDF policy,
cast const char *'s to char *'s


1 jongui 961 # Copyright 2006 by ACcESS MNRF
2 jgs 214 #
3 matt 863 # http://www.access.edu.au
4     # Primary Business: Queensland, Australia
5     # Licensed under the Open Software License version 3.0
6     # http://www.opensource.org/licenses/osl-3.0.php
7 jgs 455
8 robwdcock 682 # top-level Scons configuration file for all esys13 modules
9     # Begin initialisation Section
10 matt 863 # all of this section just intialises default environments and helper
11 robwdcock 682 # scripts. You shouldn't need to modify this section.
12     EnsureSConsVersion(0,96,91)
13     EnsurePythonVersion(2,3)
14 jgs 214
15 gross 1133 #===============================================================
16     # import tools:
17 gross 700 import glob
18 ksteube 1247 import sys, os, re
19 robwdcock 682 # Add our extensions
20     if sys.path.count('scons')==0: sys.path.append('scons')
21     import scons_extensions
22 jgs 192
23 gross 1374 # We may also need to know where python's site-packages subdirectory lives
24     python_version = 'python%s.%s'%(sys.version_info[0],sys.version_info[1])
25    
26 gross 1133 #===============================================================
27 gross 806
28 phornby 1232 tools_prefix="/usr"
29 gross 806
30 gross 1133 #==============================================================================================
31     #
32 ksteube 1215 # get the installation prefix
33 gross 1133 #
34 gross 1375 prefix = ARGUMENTS.get('prefix', sys.prefix )
35 ksteube 1217
36     # We may also need to know where python's site-packages subdirectory lives
37     python_version = 'python%s.%s'%(sys.version_info[0],sys.version_info[1])
38 phornby 1243 # Install as a standard python package in /usr/lib64 if available, else in /usr/lib
39     if os.path.isdir( prefix+"/lib64/"+python_version+"/site-packages"):
40     sys_dir_packages = prefix+"/lib64/"+python_version+"/site-packages/esys"
41     sys_dir_libraries = prefix+"/lib64"
42 ksteube 1217 else:
43 phornby 1243 sys_dir_packages = prefix+"/lib/"+python_version+"/site-packages/esys"
44     sys_dir_libraries = prefix+"/lib"
45 ksteube 1217
46 phornby 1243 sys_dir_examples = prefix+"/share/doc/esys"
47    
48     source_root = Dir('#.').abspath
49    
50     dir_packages = os.path.join(source_root,"esys")
51     dir_examples = os.path.join(source_root,"examples")
52     dir_libraries = os.path.join(source_root,"lib")
53    
54 ksteube 1312 print "Source root is : ",source_root
55 phornby 1243 print " Default packages local installation: ", dir_packages
56     print " Default library local installation ", dir_libraries
57     print " Default example local installation: ", dir_examples
58 gross 1133 print "Install prefix is: ", prefix
59 phornby 1243 print " Default packages system installation: ", sys_dir_packages
60     print " Default library system installation ", sys_dir_libraries
61     print " Default example system installation: ", sys_dir_examples
62 gross 806
63 ksteube 1217 #==============================================================================================
64    
65 robwdcock 682 # Default options and options help text
66     # These are defaults and can be overridden using command line arguments or an options file.
67     # if the options_file or ARGUMENTS do not exist then the ones listed as default here are used
68     # DO NOT CHANGE THEM HERE
69 ksteube 1083 # Where to install?
70 gross 1133 #==============================================================================================
71     #
72     # get the options file if present:
73     #
74 phornby 1246 options_file = ARGUMENTS.get('options_file','')
75    
76     if not os.path.isfile(options_file) :
77     options_file = False
78    
79     if not options_file :
80     import socket
81 ksteube 1250 hostname = re.sub("[^0-9a-zA-Z]", "_", socket.gethostname().split('.')[0])
82 phornby 1246 tmp = os.path.join("scons",hostname+"_options.py")
83    
84     if os.path.isfile(tmp) :
85     options_file = tmp
86    
87     IS_WINDOWS_PLATFORM = (os.name== "nt")
88    
89     # If you're not going to tell me then......
90     # FIXME: add one for the altix too.
91     if not options_file :
92     if IS_WINDOWS_PLATFORM :
93     options_file = "scons/windows_mscv71_options.py"
94     else:
95     options_file = "scons/linux_gcc_eg_options.py"
96    
97 gross 1133 # and load it
98     opts = Options(options_file, ARGUMENTS)
99     #================================================================
100     #
101     # check if UMFPACK is installed on the system:
102     #
103 gross 1149 uf_root=None
104     for i in [ 'UMFPACK', 'umfpack', 'ufsparse', 'UFSPARSE']:
105     if os.path.isdir(os.path.join(tools_prefix,'include',i)):
106     uf_root=i
107     print i," is used form ",tools_prefix
108     break
109     if not uf_root==None:
110     umf_path_default=os.path.join(tools_prefix,'include',uf_root)
111     umf_lib_path_default=os.path.join(tools_prefix,'lib')
112     umf_libs_default=['umfpack']
113     amd_path_default=os.path.join(tools_prefix,'include',uf_root)
114     amd_lib_path_default=os.path.join(tools_prefix,'lib')
115     amd_libs_default=['amd']
116     ufc_path_default=os.path.join(tools_prefix,'include',uf_root)
117 gross 1133 else:
118 gross 1149 umf_path_default=None
119     umf_lib_path_default=None
120     umf_libs_default=None
121     amd_path_default=None
122     amd_lib_path_default=None
123     amd_libs_default=None
124     ufc_path_default=None
125     #
126 gross 1133 #==========================================================================
127     #
128     # python installation:
129     #
130 phornby 1232 python_path_default=os.path.join(tools_prefix,'include','python%s.%s'%(sys.version_info[0],sys.version_info[1]))
131     python_lib_path_default=os.path.join(tools_prefix,'lib')
132 phornby 1235 python_lib_default="python%s.%s"%(sys.version_info[0],sys.version_info[1])
133 gross 1149
134 gross 1133 #==========================================================================
135     #
136     # boost installation:
137     #
138 phornby 1232 boost_path_default=os.path.join(tools_prefix,'include')
139 phornby 1235 boost_lib_path_default=os.path.join(tools_prefix,'lib')
140     boost_lib_default=['boost_python']
141 ksteube 1312
142 gross 1133 #==========================================================================
143     #
144     # check if netCDF is installed on the system:
145     #
146 phornby 1232 netCDF_path_default=os.path.join(tools_prefix,'include','netcdf-3')
147 ksteube 1312 netCDF_lib_path_default=os.path.join(tools_prefix,'lib')
148 gross 1149
149     if os.path.isdir(netCDF_path_default) and os.path.isdir(netCDF_lib_path_default):
150     useNetCDF_default='yes'
151     netCDF_libs_default=[ 'netcdf_c++', 'netcdf' ]
152     else:
153     useNetCDF_default='no'
154     netCDF_path_default=None
155     netCDF_lib_path_default=None
156     netCDF_libs_default=None
157    
158 gross 1133 #==========================================================================
159     #
160 ksteube 1312 # MPI:
161     #
162     if IS_WINDOWS_PLATFORM:
163     useMPI_default='no'
164     mpi_path_default=None
165     mpi_lib_path_default=None
166     mpi_libs_default=[]
167     mpi_run_default=None
168     else:
169     useMPI_default='no'
170     mpi_root='/usr/local'
171     mpi_path_default=os.path.join(mpi_root,'include')
172     mpi_lib_path_default=os.path.join(mpi_root,'lib')
173     mpi_libs_default=[ 'mpich' , 'pthread', 'rt' ]
174     mpi_run_default='mpiexec -np 1'
175     #
176     #==========================================================================
177     #
178 gross 1133 # compile:
179     #
180 ksteube 1312 cc_flags_default='-O3 -std=c99 -ffast-math -fpic -Wno-unknown-pragmas -ansi'
181     cc_flags_debug_default='-g -O0 -ffast-math -std=c99 -fpic -Wno-unknown-pragmas -ansi'
182 phornby 1232 cxx_flags_default='--no-warn -ansi'
183     cxx_flags_debug_default='--no-warn -ansi -DDOASSERT'
184 ksteube 1312
185 gross 1133 #==============================================================================================
186     # Default options and options help text
187     # These are defaults and can be overridden using command line arguments or an options file.
188     # if the options_file or ARGUMENTS do not exist then the ones listed as default here are used
189     # DO NOT CHANGE THEM HERE
190 robwdcock 682 opts.AddOptions(
191     # Where to install esys stuff
192 ksteube 1217 ('incinstall', 'where the esys headers will be installed', Dir('#.').abspath+'/include'),
193     ('libinstall', 'where the esys libraries will be installed', dir_libraries),
194     ('pyinstall', 'where the esys python modules will be installed', dir_packages),
195     ('exinstall', 'where the esys examples will be installed', dir_examples),
196 phornby 1243 ('sys_libinstall', 'where the system esys libraries will be installed', sys_dir_libraries),
197     ('sys_pyinstall', 'where the system esys python modules will be installed', sys_dir_packages),
198     ('sys_exinstall', 'where the system esys examples will be installed', sys_dir_examples),
199 ksteube 1217 ('src_zipfile', 'the source zip file will be installed.', Dir('#.').abspath+"/release/escript_src.zip"),
200     ('test_zipfile', 'the test zip file will be installed.', Dir('#.').abspath+"/release/escript_tests.zip"),
201     ('src_tarfile', 'the source tar file will be installed.', Dir('#.').abspath+"/release/escript_src.tar.gz"),
202     ('test_tarfile', 'the test tar file will be installed.', Dir('#.').abspath+"/release/escript_tests.tar.gz"),
203     ('examples_tarfile', 'the examples tar file will be installed.', Dir('#.').abspath+"/release/doc/escript_examples.tar.gz"),
204     ('examples_zipfile', 'the examples zip file will be installed.', Dir('#.').abspath+"/release/doc/escript_examples.zip"),
205     ('guide_pdf', 'name of the user guide in pdf format', Dir('#.').abspath+"/release/doc/user/guide.pdf"),
206     ('api_epydoc', 'name of the epydoc api docs directory', Dir('#.').abspath+"/release/doc/epydoc"),
207     ('guide_html', 'name of the directory for user guide in html format', Dir('#.').abspath+"/release/doc/user/html"),
208 ksteube 1215 ('api_doxygen', 'name of the doxygen api docs directory',prefix+"/release/doc/doxygen"),
209 robwdcock 682 # Compilation options
210 gross 700 BoolOption('dodebug', 'Do you want a debug build?', 'no'),
211 ksteube 1312 BoolOption('bounds_check', 'Do you want extra array bounds checking?', 'no'),
212 gross 1133 ('options_file', "Optional file containing preferred options. Ignored if it doesn't exist (default: scons/<hostname>_options.py)", options_file),
213 robwdcock 682 ('cc_defines','C/C++ defines to use', None),
214 gross 1133 ('cc_flags','C compiler flags to use (Release build)', cc_flags_default),
215     ('cc_flags_debug', 'C compiler flags to use (Debug build)', cc_flags_debug_default),
216     ('cxx_flags', 'C++ compiler flags to use (Release build)', cxx_flags_default),
217     ('cxx_flags_debug', 'C++ compiler flags to use (Debug build)', cxx_flags_debug_default),
218 phornby 1628 ('link_flags', 'Linker flags to use (Release build)', None),
219     ('link_flags_debug', 'Linker flags to use (Debug build)', None),
220    
221 ksteube 1312 ('omp_flags', 'OpenMP compiler flags to use (Release build)', ''),
222     ('omp_flags_debug', 'OpenMP compiler flags to use (Debug build)', ''),
223 robwdcock 682 ('ar_flags', 'Static library archiver flags to use', None),
224     ('sys_libs', 'System libraries to link with', None),
225 gross 700 ('tar_flags','flags for zip files','-c -z'),
226 robwdcock 682 # MKL
227 matt 863 PathOption('mkl_path', 'Path to MKL includes', None),
228     PathOption('mkl_lib_path', 'Path to MKL libs', None),
229 robwdcock 682 ('mkl_libs', 'MKL libraries to link with', None),
230     # SCSL
231 matt 863 PathOption('scsl_path', 'Path to SCSL includes', None),
232     PathOption('scsl_lib_path', 'Path to SCSL libs', None),
233 robwdcock 682 ('scsl_libs', 'SCSL libraries to link with', None),
234 bcumming 759 ('scsl_libs_MPI', 'SCSL libraries to link with for MPI build', None),
235 matt 863 # UMFPACK
236     PathOption('ufc_path', 'Path to UFconfig includes', ufc_path_default),
237     PathOption('umf_path', 'Path to UMFPACK includes', umf_path_default),
238     PathOption('umf_lib_path', 'Path to UMFPACK libs', umf_lib_path_default),
239 gross 806 ('umf_libs', 'UMFPACK libraries to link with', umf_libs_default),
240     # AMD (used by UMFPACK)
241 matt 863 PathOption('amd_path', 'Path to AMD includes', amd_path_default),
242     PathOption('amd_lib_path', 'Path to AMD libs', amd_lib_path_default),
243 gross 806 ('amd_libs', 'AMD libraries to link with', amd_libs_default),
244 ksteube 1459 # ParMETIS
245     ('parmetis_path', 'Path to ParMETIS includes', ''),
246     ('parmetis_lib_path', 'Path to ParMETIS library', ''),
247     ('parmetis_lib', 'ParMETIS library to link with', []),
248 ksteube 1312 # TRILINOS
249     PathOption('trilinos_path', 'Path to TRILINOS includes', None),
250     PathOption('trilinos_lib_path', 'Path to TRILINOS libs', None),
251     ('trilinos_libs', 'TRILINOS libraries to link with', None),
252 gross 805 # BLAS
253 matt 863 PathOption('blas_path', 'Path to BLAS includes', None),
254     PathOption('blas_lib_path', 'Path to BLAS libs', None),
255 gross 806 ('blas_libs', 'BLAS libraries to link with', None),
256 gross 950 # netCDF
257 gross 1133 ('useNetCDF', 'switch on/off the usage of netCDF', useNetCDF_default),
258 gross 1028 PathOption('netCDF_path', 'Path to netCDF includes', netCDF_path_default),
259     PathOption('netCDF_lib_path', 'Path to netCDF libs', netCDF_lib_path_default),
260 gross 1133 ('netCDF_libs', 'netCDF C++ libraries to link with', netCDF_libs_default),
261 robwdcock 682 # Python
262 gross 685 # locations of include files for python
263 phornby 1243 # FIXME: python_path should be python_inc_path and the same for boost etc.
264 gross 1133 PathOption('python_path', 'Path to Python includes', python_path_default),
265     PathOption('python_lib_path', 'Path to Python libs', python_lib_path_default),
266 phornby 1235 ('python_lib', 'Python libraries to link with', python_lib_default),
267 phornby 1243 ('python_cmd', 'Python command', 'python'),
268 robwdcock 682 # Boost
269 gross 1133 PathOption('boost_path', 'Path to Boost includes', boost_path_default),
270 phornby 1235 PathOption('boost_lib_path', 'Path to Boost libs', boost_lib_path_default),
271     ('boost_lib', 'Boost libraries to link with', boost_lib_default),
272 robwdcock 682 # Doc building
273 ksteube 1216 # PathOption('doxygen_path', 'Path to Doxygen executable', None),
274 matt 863 # PathOption('epydoc_path', 'Path to Epydoc executable', None),
275 robwdcock 682 # PAPI
276 matt 863 PathOption('papi_path', 'Path to PAPI includes', None),
277     PathOption('papi_lib_path', 'Path to PAPI libs', None),
278 robwdcock 682 ('papi_libs', 'PAPI libraries to link with', None),
279 ksteube 1312 ('papi_instrument_solver', 'use PAPI in Solver.c to instrument each iteration of the solver', None),
280 bcumming 759 # MPI
281 ksteube 1312 BoolOption('useMPI', 'Compile parallel version using MPI', useMPI_default),
282     ('MPICH_IGNORE_CXX_SEEK', 'name of macro to ignore MPI settings of C++ SEEK macro (for MPICH)' , 'MPICH_IGNORE_CXX_SEEK'),
283     PathOption('mpi_path', 'Path to MPI includes', mpi_path_default),
284     ('mpi_run', 'mpirun name' , mpi_run_default),
285     PathOption('mpi_lib_path', 'Path to MPI libs (needs to be added to the LD_LIBRARY_PATH)',mpi_lib_path_default),
286     ('mpi_libs', 'MPI libraries to link with (needs to be shared!)', mpi_libs_default)
287 robwdcock 682 )
288 gross 1133 #=================================================================================================
289     #
290     # Note: On the Altix the intel compilers are not automatically
291     # detected by scons intelc.py script. The Altix has a different directory
292     # path and in some locations the "modules" facility is used to support
293     # multiple compiler versions. This forces the need to import the users PATH
294     # environment which isn't the "scons way"
295     # This doesn't impact linux and windows which will use the default compiler (g++ or msvc, or the intel compiler if it is installed on both platforms)
296     # FIXME: Perhaps a modification to intelc.py will allow better support for ia64 on altix
297     #
298 phornby 1232
299 gross 1133 if IS_WINDOWS_PLATFORM:
300     env = Environment(tools = ['default', 'msvc'], options = opts)
301 trankine 1428 #env = Environment(tools = ['default', 'intelc'], options = opts)
302 robwdcock 682 else:
303 ksteube 1559 if socket.gethostname().split('.')[0] == 'service0':
304 gross 1133 env = Environment(tools = ['default', 'intelc'], options = opts)
305 ksteube 1559 elif os.uname()[4]=='ia64':
306     env = Environment(tools = ['default', 'intelc'], options = opts)
307 gross 1133 if env['CXX'] == 'icpc':
308     env['LINK'] = env['CXX'] # version >=9 of intel c++ compiler requires use of icpc to link in C++ runtimes (icc does not). FIXME: this behaviour could be directly incorporated into scons intelc.py
309     else:
310     env = Environment(tools = ['default'], options = opts)
311     Help(opts.GenerateHelpText(env))
312 phornby 1232
313 ksteube 1312 if env['bounds_check']:
314     env.Append(CPPDEFINES = [ 'BOUNDS_CHECK' ])
315     env.Append(CXXDEFINES = [ 'BOUNDS_CHECK' ])
316 ksteube 1348 bounds_check = env['bounds_check']
317     else:
318     bounds_check = 0
319 ksteube 1312
320 gross 1133 #=================================================================================================
321     #
322     # Initialise Scons Build Environment
323     # check for user environment variables we are interested in
324 gross 1024 try:
325 phornby 1243 tmp = os.environ['PYTHONPATH']
326     env['ENV']['PYTHONPATH'] = tmp
327 gross 1024 except KeyError:
328 phornby 1243 pass
329 gross 1024
330 phornby 1243 env.PrependENVPath('PYTHONPATH', source_root)
331    
332 gross 1024 try:
333 gross 1160 omp_num_threads = os.environ['OMP_NUM_THREADS']
334     except KeyError:
335     omp_num_threads = 1
336 ksteube 1312 env['ENV']['OMP_NUM_THREADS'] = omp_num_threads
337 phornby 1243
338 ksteube 1312 try:
339     path = os.environ['PATH']
340     env['ENV']['PATH'] = path
341     except KeyError:
342     omp_num_threads = 1
343    
344 gross 1160 env['ENV']['OMP_NUM_THREADS'] = omp_num_threads
345    
346 ksteube 1312
347     # Copy some variables from the system environment to the build environment
348 gross 1160 try:
349 gross 1163 env['ENV']['DISPLAY'] = os.environ['DISPLAY']
350 jongui 1164 env['ENV']['XAUTHORITY'] = os.environ['XAUTHORITY']
351 ksteube 1312 home_temp = os.environ['HOME'] # MPICH2's mpd needs $HOME to find $HOME/.mpd.conf
352     env['ENV']['HOME'] = home_temp
353 gross 1163 except KeyError:
354     pass
355    
356     try:
357 phornby 1243 tmp = os.environ['PATH']
358     env['ENV']['PATH'] = tmp
359 gross 1024 except KeyError:
360 phornby 1243 pass
361    
362 gross 1024 try:
363 phornby 1243 tmp = os.environ['LD_LIBRARY_PATH']
364     env['ENV']['LD_LIBRARY_PATH'] = tmp
365 gross 1024 except KeyError:
366 phornby 1243 pass
367 gross 1133 #==========================================================================
368     #
369     # Add some customer builders
370     #
371 robwdcock 682 py_builder = Builder(action = scons_extensions.build_py, suffix = '.pyc', src_suffix = '.py', single_source=True)
372     env.Append(BUILDERS = {'PyCompile' : py_builder});
373    
374 phornby 1244 runUnitTest_builder = Builder(action = scons_extensions.runUnitTest, suffix = '.passed',
375     src_suffix=env['PROGSUFFIX'], single_source=True)
376    
377 robwdcock 682 env.Append(BUILDERS = {'RunUnitTest' : runUnitTest_builder});
378    
379     runPyUnitTest_builder = Builder(action = scons_extensions.runPyUnitTest, suffix = '.passed', src_suffic='.py', single_source=True)
380     env.Append(BUILDERS = {'RunPyUnitTest' : runPyUnitTest_builder});
381    
382     # Convert the options which are held in environment variable into python variables for ease of handling and configure compilation options
383     try:
384     incinstall = env['incinstall']
385     env.Append(CPPPATH = [incinstall,])
386     except KeyError:
387 matt 863 incinstall = None
388 robwdcock 682 try:
389     libinstall = env['libinstall']
390 ksteube 1215 env.Append(LIBPATH = [libinstall,]) # Adds -L for building of libescript.so libfinley.so escriptcpp.so finleycpp.so
391 robwdcock 682 env.PrependENVPath('LD_LIBRARY_PATH', libinstall)
392 phornby 1248 if IS_WINDOWS_PLATFORM :
393 woo409 757 env.PrependENVPath('PATH', libinstall)
394 ksteube 1312 env.PrependENVPath('PATH', env['boost_lib_path'])
395 robwdcock 682 except KeyError:
396 matt 863 libinstall = None
397 robwdcock 682 try:
398 ksteube 1217 pyinstall = env['pyinstall'] # all targets will install into pyinstall/esys but PYTHONPATH points at straight pyinstall so you go import esys.escript etc
399 robwdcock 682 except KeyError:
400 matt 863 pyinstall = None
401 ksteube 1312
402 robwdcock 682 try:
403 ksteube 1312 cc_defines = env['cc_defines']
404     env.Append(CPPDEFINES = cc_defines)
405     except KeyError:
406     pass
407     try:
408     flags = env['ar_flags']
409     env.Append(ARFLAGS = flags)
410     except KeyError:
411     ar_flags = None
412     try:
413     sys_libs = env['sys_libs']
414     except KeyError:
415     sys_libs = []
416    
417     try:
418     tar_flags = env['tar_flags']
419     env.Replace(TARFLAGS = tar_flags)
420     except KeyError:
421     pass
422    
423     try:
424 ksteube 1217 exinstall = env['exinstall']
425     except KeyError:
426     exinstall = None
427     try:
428 phornby 1243 sys_libinstall = env['sys_libinstall']
429     except KeyError:
430     sys_libinstall = None
431     try:
432     sys_pyinstall = env['sys_pyinstall']
433     except KeyError:
434     sys_pyinstall = None
435     try:
436     sys_exinstall = env['sys_exinstall']
437     except KeyError:
438     sys_exinstall = None
439 ksteube 1312
440     # ====================== debugging ===================================
441 phornby 1243 try:
442 robwdcock 682 dodebug = env['dodebug']
443     except KeyError:
444 matt 863 dodebug = None
445 ksteube 1312
446     # === switch on omp ===================================================
447 robwdcock 682 try:
448 ksteube 1312 omp_flags = env['omp_flags']
449 bcumming 759 except KeyError:
450 ksteube 1312 omp_flags = ''
451    
452 bcumming 759 try:
453 ksteube 1312 omp_flags_debug = env['omp_flags_debug']
454 robwdcock 682 except KeyError:
455 ksteube 1312 omp_flags_debug = ''
456 ksteube 817
457 ksteube 1312 # ========= use mpi? =====================================================
458     try:
459     useMPI = env['useMPI']
460     except KeyError:
461     useMPI = None
462     # ========= set compiler flags ===========================================
463 phornby 1246
464 robwdcock 682 if dodebug:
465 bcumming 759 try:
466 ksteube 1312 flags = env['cc_flags_debug'] + ' ' + omp_flags_debug
467 bcumming 759 env.Append(CCFLAGS = flags)
468     except KeyError:
469     pass
470 robwdcock 682 else:
471     try:
472 ksteube 1312 flags = env['cc_flags'] + ' ' + omp_flags
473 robwdcock 682 env.Append(CCFLAGS = flags)
474     except KeyError:
475     pass
476     if dodebug:
477 bcumming 759 try:
478     flags = env['cxx_flags_debug']
479     env.Append(CXXFLAGS = flags)
480     except KeyError:
481     pass
482 robwdcock 682 else:
483 bcumming 759 try:
484     flags = env['cxx_flags']
485     env.Append(CXXFLAGS = flags)
486     except KeyError:
487     pass
488 phornby 1634
489     # Impassioned plea - please do this sort of thing in the options files.
490 robwdcock 682 try:
491 ksteube 1312 if env['CC'] == 'gcc': env.Append(CCFLAGS = "-pedantic-errors -Wno-long-long")
492     except:
493     pass
494 phornby 1634
495 phornby 1628 if dodebug:
496     try:
497     flags = env['link_flags_debug']
498     env.Append(LINKFLAGS = flags)
499     except KeyError:
500     pass
501     else:
502     try:
503     flags = env['link_flags']
504     env.Append(LINKFLAGS = flags)
505     except KeyError:
506     pass
507 robwdcock 682
508 ksteube 1348 # ============= Remember what options were used in the compile =====================================
509 ksteube 1360 if not IS_WINDOWS_PLATFORM:
510     env.Execute("/bin/rm -f " + libinstall + "/Compiled.with.*")
511     if dodebug: env.Execute("touch " + libinstall + "/Compiled.with.debug")
512     if useMPI: env.Execute("touch " + libinstall + "/Compiled.with.mpi")
513     if omp_flags != '': env.Execute("touch " + libinstall + "/Compiled.with.OpenMP")
514     if bounds_check: env.Execute("touch " + libinstall + "/Compiled.with.bounds_check")
515 ksteube 1348
516 ksteube 1312 # ============= set mkl (but only of no MPI) =====================================
517     if not useMPI:
518     try:
519     includes = env['mkl_path']
520     env.Append(CPPPATH = [includes,])
521     except KeyError:
522     pass
523 gross 700
524 ksteube 1312 try:
525     lib_path = env['mkl_lib_path']
526     env.Append(LIBPATH = [lib_path,])
527 gross 1374 env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
528 ksteube 1312 except KeyError:
529     pass
530 gross 700
531 gross 806 try:
532     mkl_libs = env['mkl_libs']
533     except KeyError:
534 gross 1133 mkl_libs = []
535 ksteube 1312 else:
536     mkl_libs = []
537 gross 806
538 ksteube 1312 # ============= set scsl (but only of no MPI) =====================================
539     if not useMPI:
540     try:
541     includes = env['scsl_path']
542     env.Append(CPPPATH = [includes,])
543     except KeyError:
544     pass
545 gross 806
546 ksteube 1312 try:
547     lib_path = env['scsl_lib_path']
548     env.Append(LIBPATH = [lib_path,])
549 gross 1374 env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
550 ksteube 1312 except KeyError:
551     pass
552    
553     try:
554     scsl_libs = env['scsl_libs']
555     except KeyError:
556     scsl_libs = [ ]
557 gross 806
558 matt 863 else:
559 ksteube 1312 scsl_libs = []
560 gross 805
561 ksteube 1312 # ============= set TRILINOS (but only with MPI) =====================================
562     if useMPI:
563     try:
564     includes = env['trilinos_path']
565     env.Append(CPPPATH = [includes,])
566     except KeyError:
567     pass
568 gross 805
569 ksteube 1312 try:
570     lib_path = env['trilinos_lib_path']
571     env.Append(LIBPATH = [lib_path,])
572     except KeyError:
573     pass
574 gross 805
575 ksteube 1312 try:
576     trilinos_libs = env['trilinos_libs']
577     except KeyError:
578     trilinos_libs = []
579 gross 806 else:
580 ksteube 1312 trilinos_libs = []
581    
582    
583     # ============= set umfpack (but only without MPI) =====================================
584     umf_libs=[ ]
585     if not useMPI:
586 gross 806 try:
587 ksteube 1312 includes = env['umf_path']
588     env.Append(CPPPATH = [includes,])
589     except KeyError:
590     pass
591    
592     try:
593     lib_path = env['umf_lib_path']
594     env.Append(LIBPATH = [lib_path,])
595     except KeyError:
596     pass
597    
598     try:
599 gross 806 umf_libs = env['umf_libs']
600 ksteube 1312 umf_libs+=umf_libs
601 gross 806 except KeyError:
602 ksteube 1312 pass
603 gross 806
604 ksteube 1312 try:
605     includes = env['ufc_path']
606     env.Append(CPPPATH = [includes,])
607     except KeyError:
608     pass
609 gross 805
610 ksteube 1312 try:
611     includes = env['amd_path']
612     env.Append(CPPPATH = [includes,])
613     except KeyError:
614     pass
615 gross 805
616 ksteube 1312 try:
617     lib_path = env['amd_lib_path']
618     env.Append(LIBPATH = [lib_path,])
619     except KeyError:
620     pass
621 gross 806
622     try:
623     amd_libs = env['amd_libs']
624 ksteube 1312 umf_libs+=amd_libs
625 gross 806 except KeyError:
626 ksteube 1312 pass
627 gross 806
628 ksteube 1312 # ============= set TRILINOS (but only with MPI) =====================================
629     if useMPI:
630     try:
631     includes = env['trilinos_path']
632     env.Append(CPPPATH = [includes,])
633     except KeyError:
634     pass
635    
636     try:
637     lib_path = env['trilinos_lib_path']
638     env.Append(LIBPATH = [lib_path,])
639     except KeyError:
640     pass
641    
642     try:
643     trilinos_libs = env['trilinos_libs']
644     except KeyError:
645     trilinos_libs = []
646     else:
647     trilinos_libs = []
648    
649     # ============= set blas =====================================
650 gross 806 try:
651 gross 805 includes = env['blas_path']
652     env.Append(CPPPATH = [includes,])
653     except KeyError:
654     pass
655 gross 806
656 gross 805 try:
657     lib_path = env['blas_lib_path']
658     env.Append(LIBPATH = [lib_path,])
659     except KeyError:
660     pass
661 gross 806
662 gross 805 try:
663     blas_libs = env['blas_libs']
664     except KeyError:
665 ksteube 1312 blas_libs = [ ]
666 gross 805
667 ksteube 1343 # ========== netcdf ====================================
668     try:
669     useNetCDF = env['useNetCDF']
670     except KeyError:
671     useNetCDF = 'yes'
672     pass
673 ksteube 1312
674 gross 1023 if useNetCDF == 'yes':
675     try:
676 phornby 1246 netCDF_libs = env['netCDF_libs']
677     except KeyError:
678     pass
679    
680     env.Append(LIBS = netCDF_libs)
681     env.Append(CPPDEFINES = [ 'USE_NETCDF' ])
682     try:
683 gross 1023 includes = env['netCDF_path']
684     env.Append(CPPPATH = [includes,])
685     except KeyError:
686     pass
687 gross 950
688 gross 1023 try:
689     lib_path = env['netCDF_lib_path']
690 gross 1133 env.Append(LIBPATH = [ lib_path, ])
691 gross 1374 env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
692 phornby 1248 if IS_WINDOWS_PLATFORM :
693     env.PrependENVPath('PATH', lib_path)
694 gross 1023 except KeyError:
695     pass
696     else:
697 phornby 1246 print "Warning: Installation is not configured with netCDF. Some I/O function may not be available."
698 gross 1133 netCDF_libs=[ ]
699 gross 1023
700 ksteube 1312 # ====================== boost ======================================
701 gross 950 try:
702 robwdcock 682 includes = env['boost_path']
703     env.Append(CPPPATH = [includes,])
704     except KeyError:
705     pass
706     try:
707 phornby 1235 lib_path = env['boost_lib_path']
708 robwdcock 682 env.Append(LIBPATH = [lib_path,])
709 gross 1374 env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
710 phornby 1248 if IS_WINDOWS_PLATFORM :
711     env.PrependENVPath('PATH', lib_path)
712 robwdcock 682 except KeyError:
713     pass
714     try:
715 phornby 1235 boost_lib = env['boost_lib']
716 robwdcock 682 except KeyError:
717 phornby 1235 boost_lib = None
718 ksteube 1312 # ====================== python ======================================
719 robwdcock 682 try:
720     includes = env['python_path']
721     env.Append(CPPPATH = [includes,])
722     except KeyError:
723     pass
724     try:
725     lib_path = env['python_lib_path']
726 gross 1374 env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
727 robwdcock 682 env.Append(LIBPATH = [lib_path,])
728     except KeyError:
729     pass
730     try:
731 phornby 1235 python_lib = env['python_lib']
732 robwdcock 682 except KeyError:
733 phornby 1235 python_lib = None
734 ksteube 1312 # =============== documentation =======================================
735 robwdcock 682 try:
736     doxygen_path = env['doxygen_path']
737     except KeyError:
738 matt 863 doxygen_path = None
739 robwdcock 682 try:
740     epydoc_path = env['epydoc_path']
741     except KeyError:
742 matt 863 epydoc_path = None
743 ksteube 1459 # =============== ParMETIS =======================================
744     try:
745     parmetis_path = env['parmetis_path']
746     parmetis_lib_path = env['parmetis_lib_path']
747     parmetis_lib = env['parmetis_lib']
748     except KeyError:
749     parmetis_path = ''
750     parmetis_lib_path = ''
751     parmetis_lib = ''
752    
753     if useMPI and os.path.isdir(parmetis_lib_path):
754     env.Append(CPPDEFINES = [ 'PARMETIS' ])
755     env.Append(CXXDEFINES = [ 'PARMETIS' ])
756     env.Append(CPPPATH = [parmetis_path])
757     env.Append(LIBPATH = [parmetis_lib_path])
758     env.Append(LIBS = parmetis_lib)
759 ksteube 1312 # =============== PAPI =======================================
760 robwdcock 682 try:
761     includes = env['papi_path']
762     env.Append(CPPPATH = [includes,])
763     except KeyError:
764     pass
765     try:
766     lib_path = env['papi_lib_path']
767     env.Append(LIBPATH = [lib_path,])
768     except KeyError:
769     pass
770     try:
771     papi_libs = env['papi_libs']
772     except KeyError:
773 matt 863 papi_libs = None
774 ksteube 1312 # ============= set mpi =====================================
775     if useMPI:
776 ksteube 1560 env.Append(CPPDEFINES=['PASO_MPI', 'MPI_NO_CPPBIND'])
777 ksteube 1312 try:
778     includes = env['mpi_path']
779     env.Append(CPPPATH = [includes,])
780     except KeyError:
781     pass
782     try:
783     lib_path = env['mpi_lib_path']
784     env.Append(LIBPATH = [lib_path,])
785     env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
786     except KeyError:
787     pass
788     try:
789     mpi_libs = env['mpi_libs']
790     except KeyError:
791     mpi_libs = []
792 robwdcock 682
793 ksteube 1312 try:
794     mpi_run = env['mpi_run']
795     except KeyError:
796     mpi_run = ''
797 gross 707
798 ksteube 1312 try:
799     mpich_ignore_cxx_seek=env['MPICH_IGNORE_CXX_SEEK']
800     env.Append(CPPDEFINES = [ mpich_ignore_cxx_seek ] )
801     except KeyError:
802     pass
803     else:
804     mpi_libs=[]
805     mpi_run = mpi_run_default
806     # =========== zip files ===========================================
807 gross 700 try:
808 ksteube 1312 includes = env['papi_path']
809     env.Append(CPPPATH = [includes,])
810     except KeyError:
811     pass
812     try:
813     lib_path = env['papi_lib_path']
814     env.Append(LIBPATH = [lib_path,])
815     except KeyError:
816     pass
817     try:
818     papi_libs = env['papi_libs']
819     except KeyError:
820     papi_libs = None
821     try:
822     papi_instrument_solver = env['papi_instrument_solver']
823     except KeyError:
824     papi_instrument_solver = None
825    
826    
827     # ============= and some helpers =====================================
828     try:
829     doxygen_path = env['doxygen_path']
830     except KeyError:
831     doxygen_path = None
832     try:
833     epydoc_path = env['epydoc_path']
834     except KeyError:
835     epydoc_path = None
836     try:
837 gross 707 src_zipfile = env.File(env['src_zipfile'])
838 gross 700 except KeyError:
839 matt 863 src_zipfile = None
840 gross 700 try:
841 gross 707 test_zipfile = env.File(env['test_zipfile'])
842 gross 700 except KeyError:
843 matt 863 test_zipfile = None
844 gross 707 try:
845     examples_zipfile = env.File(env['examples_zipfile'])
846     except KeyError:
847 matt 863 examples_zipfile = None
848 gross 700
849     try:
850 gross 707 src_tarfile = env.File(env['src_tarfile'])
851 gross 700 except KeyError:
852 matt 863 src_tarfile = None
853 gross 700 try:
854 gross 707 test_tarfile = env.File(env['test_tarfile'])
855 gross 700 except KeyError:
856 matt 863 test_tarfile = None
857 gross 707 try:
858     examples_tarfile = env.File(env['examples_tarfile'])
859     except KeyError:
860 matt 863 examples_tarfile = None
861 gross 700
862     try:
863 gross 707 guide_pdf = env.File(env['guide_pdf'])
864 gross 700 except KeyError:
865 matt 863 guide_pdf = None
866 gross 700
867 gross 707 try:
868     guide_html_index = env.File('index.htm',env['guide_html'])
869     except KeyError:
870 matt 863 guide_html_index = None
871 gross 707
872 elspeth 712 try:
873     api_epydoc = env.Dir(env['api_epydoc'])
874     except KeyError:
875 matt 863 api_epydoc = None
876 elspeth 712
877 ksteube 1215 try:
878     api_doxygen = env.Dir(env['api_doxygen'])
879     except KeyError:
880     api_doxygen = None
881    
882 ksteube 1247 try:
883 ksteube 1312 svn_pipe = os.popen("svnversion -n .")
884 ksteube 1250 global_revision = svn_pipe.readlines()
885 ksteube 1247 svn_pipe.close()
886 gross 1391 global_revision = re.sub(":.*", "", global_revision[0])
887     global_revision = re.sub("[^0-9]", "", global_revision)
888 ksteube 1247 except:
889 gross 1391 global_revision="-1"
890     print "Warning: unable to recover global revsion number."
891 ksteube 1416 if global_revision == "": global_revision="0"
892 gross 1391 print "Revision number is %s."%global_revision
893 ksteube 1312 env.Append(CPPDEFINES = "SVN_VERSION="+global_revision)
894 ksteube 1247
895 phornby 1246 # Python install - esys __init__.py
896     init_target = env.Command(pyinstall+'/__init__.py', None, Touch('$TARGET'))
897 phornby 1243
898     # FIXME: exinstall and friends related to examples are not working.
899 phornby 1246 build_target = env.Alias('build',[libinstall,incinstall,pyinstall,init_target])
900 phornby 1243
901     env.Default(build_target)
902    
903 gross 700 # Zipgets
904 matt 863 env.Alias('release_src',[ src_zipfile, src_tarfile ])
905 gross 700 env.Alias('release_tests',[ test_zipfile, test_tarfile])
906 gross 707 env.Alias('release_examples',[ examples_zipfile, examples_tarfile])
907 ksteube 1215 env.Alias('examples_zipfile',examples_zipfile)
908     env.Alias('examples_tarfile',examples_tarfile)
909 gross 720 env.Alias('api_epydoc',api_epydoc)
910 ksteube 1215 env.Alias('api_doxygen',api_doxygen)
911     env.Alias('guide_html_index',guide_html_index)
912 gross 807 env.Alias('guide_pdf', guide_pdf)
913 ksteube 1216 env.Alias('docs',[ 'release_examples', 'guide_pdf', api_epydoc, api_doxygen, guide_html_index])
914 gross 707 env.Alias('release', ['release_src', 'release_tests', 'docs'])
915 phornby 1243
916 phornby 1246 env.Alias('build_tests',build_target) # target to build all C++ tests
917     env.Alias('build_py_tests',build_target) # target to build all python tests
918 gross 706 env.Alias('build_all_tests', [ 'build_tests', 'build_py_tests' ] ) # target to build all python tests
919     env.Alias('run_tests', 'build_tests') # target to run all C++ test
920     env.Alias('py_tests', 'build_py_tests') # taget to run all released python tests
921 gross 705 env.Alias('all_tests', ['run_tests', 'py_tests']) # target to run all C++ and released python tests
922 robwdcock 682
923    
924     # Allow sconscripts to see the env
925 ksteube 1312 Export(["IS_WINDOWS_PLATFORM", "env", "incinstall", "libinstall", "pyinstall", "dodebug", "mkl_libs", "scsl_libs", "umf_libs", "blas_libs", "netCDF_libs", "useNetCDF", "mpi_run",
926 phornby 1235 "boost_lib", "python_lib", "doxygen_path", "epydoc_path", "papi_libs",
927 ksteube 1312 "sys_libs", "test_zipfile", "src_zipfile", "test_tarfile", "src_tarfile", "examples_tarfile", "examples_zipfile", "trilinos_libs", "mpi_libs", "papi_instrument_solver",
928     "guide_pdf", "guide_html_index", "api_epydoc", "api_doxygen", "useMPI" ])
929 robwdcock 682
930     # End initialisation section
931     # Begin configuration section
932 gross 700 # adds this file and the scons option directore to the source tar
933 ksteube 1339 release_srcfiles=[env.File('SConstruct'),env.Dir('lib'),env.Dir('include'),]+[ env.File(x) for x in glob.glob('scons/*.py') ]
934 gross 700 release_testfiles=[env.File('README_TESTS'),]
935 gross 706 env.Zip(src_zipfile, release_srcfiles)
936 gross 700 env.Zip(test_zipfile, release_testfiles)
937 gross 1133 try:
938     env.Tar(src_tarfile, release_srcfiles)
939     env.Tar(test_tarfile, release_testfiles)
940     except AttributeError:
941     pass
942 robwdcock 682 # Insert new components to be build here
943     # FIXME: might be nice to replace this verbosity with a list of targets and some
944     # FIXME: nifty python to create the lengthy but very similar env.Sconscript lines
945     # Third Party libraries
946     env.SConscript(dirs = ['tools/CppUnitTest/src'], build_dir='build/$PLATFORM/tools/CppUnitTest', duplicate=0)
947     # C/C++ Libraries
948 phornby 1628 env.SConscript(dirs = ['esysUtils/src'], build_dir='build/$PLATFORM/esysUtils', duplicate=0)
949     env.SConscript(dirs = ['escript/src'], build_dir='build/$PLATFORM/escript', duplicate=0)
950 robwdcock 682 env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)
951 gross 958 # bruce is removed for now as it doesn't really do anything
952     # env.SConscript(dirs = ['bruce/src'], build_dir='build/$PLATFORM/bruce', duplicate=0)
953 robwdcock 682 env.SConscript(dirs = ['finley/src'], build_dir='build/$PLATFORM/finley', duplicate=0)
954     env.SConscript(dirs = ['modellib/py_src'], build_dir='build/$PLATFORM/modellib', duplicate=0)
955 gross 707 env.SConscript(dirs = ['doc'], build_dir='build/$PLATFORM/doc', duplicate=0)
956 matt 863 env.SConscript(dirs = ['pyvisi/py_src'], build_dir='build/$PLATFORM/pyvisi', duplicate=0)
957 gross 898 env.SConscript(dirs = ['pycad/py_src'], build_dir='build/$PLATFORM/pycad', duplicate=0)
958 matt 863 env.SConscript(dirs = ['pythonMPI/src'], build_dir='build/$PLATFORM/pythonMPI', duplicate=0)
959 bcumming 784 #env.SConscript(dirs = ['../test'], build_dir='../test/build', duplicate=0)
960 phornby 1243
961    
962     syslib_install_target = env.installDirectory(sys_libinstall,libinstall)
963     syspy_install_target = env.installDirectory(sys_pyinstall,pyinstall,recursive=True)
964    
965     install_target = env.Alias("install", env.Flatten([syslib_install_target, syspy_install_target]) )

  ViewVC Help
Powered by ViewVC 1.1.26