/[escript]/trunk/SConstruct
ViewVC logotype

Diff of /trunk/SConstruct

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1343 by ksteube, Wed Nov 14 02:48:02 2007 UTC revision 1628 by phornby, Fri Jul 11 13:12:46 2008 UTC
# Line 20  import sys, os, re Line 20  import sys, os, re
20  if sys.path.count('scons')==0: sys.path.append('scons')  if sys.path.count('scons')==0: sys.path.append('scons')
21  import scons_extensions  import scons_extensions
22    
23    # 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  #===============================================================  #===============================================================
27    
28  tools_prefix="/usr"  tools_prefix="/usr"
# Line 28  tools_prefix="/usr" Line 31  tools_prefix="/usr"
31  #      #    
32  #    get the installation prefix  #    get the installation prefix
33  #  #
34  prefix = ARGUMENTS.get('prefix', '/usr')  prefix = ARGUMENTS.get('prefix', sys.prefix )
35    
36  # We may also need to know where python's site-packages subdirectory lives  # 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])  python_version = 'python%s.%s'%(sys.version_info[0],sys.version_info[1])
   
38  # Install as a standard python package in /usr/lib64 if available, else in /usr/lib  # 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"):  if os.path.isdir(  prefix+"/lib64/"+python_version+"/site-packages"):
40     sys_dir_packages =  prefix+"/lib64/"+python_version+"/site-packages/esys"     sys_dir_packages =  prefix+"/lib64/"+python_version+"/site-packages/esys"
# Line 213  opts.AddOptions( Line 215  opts.AddOptions(
215    ('cc_flags_debug', 'C compiler flags to use (Debug build)', cc_flags_debug_default),    ('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),    ('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),    ('cxx_flags_debug', 'C++ compiler flags to use (Debug build)', cxx_flags_debug_default),
218      ('link_flags', 'Linker flags to use (Release build)', None),
219      ('link_flags_debug', 'Linker flags to use (Debug build)', None),
220    
221    ('omp_flags', 'OpenMP compiler flags to use (Release build)', ''),    ('omp_flags', 'OpenMP compiler flags to use (Release build)', ''),
222    ('omp_flags_debug', 'OpenMP compiler flags to use (Debug build)', ''),    ('omp_flags_debug', 'OpenMP compiler flags to use (Debug build)', ''),
223    ('ar_flags', 'Static library archiver flags to use', None),    ('ar_flags', 'Static library archiver flags to use', None),
# Line 236  opts.AddOptions( Line 241  opts.AddOptions(
241    PathOption('amd_path', 'Path to AMD includes', amd_path_default),    PathOption('amd_path', 'Path to AMD includes', amd_path_default),
242    PathOption('amd_lib_path', 'Path to AMD libs', amd_lib_path_default),    PathOption('amd_lib_path', 'Path to AMD libs', amd_lib_path_default),
243    ('amd_libs', 'AMD libraries to link with', amd_libs_default),    ('amd_libs', 'AMD libraries to link with', amd_libs_default),
244    # 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  # TRILINOS  # TRILINOS
249    PathOption('trilinos_path', 'Path to TRILINOS includes', None),    PathOption('trilinos_path', 'Path to TRILINOS includes', None),
250    PathOption('trilinos_lib_path', 'Path to TRILINOS libs', None),    PathOption('trilinos_lib_path', 'Path to TRILINOS libs', None),
# Line 289  opts.AddOptions( Line 298  opts.AddOptions(
298    
299  if IS_WINDOWS_PLATFORM:  if IS_WINDOWS_PLATFORM:
300        env = Environment(tools = ['default', 'msvc'], options = opts)        env = Environment(tools = ['default', 'msvc'], options = opts)
301          #env = Environment(tools = ['default', 'intelc'], options = opts)
302  else:  else:
303     if os.uname()[4]=='ia64':     if socket.gethostname().split('.')[0] == 'service0':
304          env = Environment(tools = ['default', 'intelc'], options = opts)
305       elif os.uname()[4]=='ia64':
306        env = Environment(tools = ['default', 'intelc'], options = opts)        env = Environment(tools = ['default', 'intelc'], options = opts)
307        if env['CXX'] == 'icpc':        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           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
# Line 301  Help(opts.GenerateHelpText(env)) Line 313  Help(opts.GenerateHelpText(env))
313  if env['bounds_check']:  if env['bounds_check']:
314     env.Append(CPPDEFINES = [ 'BOUNDS_CHECK' ])     env.Append(CPPDEFINES = [ 'BOUNDS_CHECK' ])
315     env.Append(CXXDEFINES = [ 'BOUNDS_CHECK' ])     env.Append(CXXDEFINES = [ 'BOUNDS_CHECK' ])
316       bounds_check = env['bounds_check']
317    else:
318       bounds_check = 0
319    
320  #=================================================================================================  #=================================================================================================
321  #  #
# Line 474  try: Line 489  try:
489       if env['CC'] == 'gcc': env.Append(CCFLAGS = "-pedantic-errors -Wno-long-long")       if env['CC'] == 'gcc': env.Append(CCFLAGS = "-pedantic-errors -Wno-long-long")
490  except:  except:
491       pass       pass
492    if dodebug:
493         try:
494            flags = env['link_flags_debug']
495            env.Append(LINKFLAGS = flags)
496         except KeyError:
497            pass
498    else:
499         try:
500            flags = env['link_flags']
501            env.Append(LINKFLAGS = flags)
502         except KeyError:
503            pass
504    
505    # ============= Remember what options were used in the compile =====================================
506    if not IS_WINDOWS_PLATFORM:
507      env.Execute("/bin/rm -f " + libinstall + "/Compiled.with.*")
508      if dodebug:       env.Execute("touch " + libinstall + "/Compiled.with.debug")
509      if useMPI:        env.Execute("touch " + libinstall + "/Compiled.with.mpi")
510      if omp_flags != '':   env.Execute("touch " + libinstall + "/Compiled.with.OpenMP")
511      if bounds_check:  env.Execute("touch " + libinstall + "/Compiled.with.bounds_check")
512    
513  # ============= set mkl (but only of no MPI) =====================================  # ============= set mkl (but only of no MPI) =====================================
514  if not useMPI:  if not useMPI:
# Line 486  if not useMPI: Line 521  if not useMPI:
521     try:     try:
522        lib_path = env['mkl_lib_path']        lib_path = env['mkl_lib_path']
523        env.Append(LIBPATH = [lib_path,])        env.Append(LIBPATH = [lib_path,])
524          env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
525     except KeyError:     except KeyError:
526        pass        pass
527    
# Line 507  if not useMPI: Line 543  if not useMPI:
543     try:     try:
544        lib_path = env['scsl_lib_path']        lib_path = env['scsl_lib_path']
545        env.Append(LIBPATH = [lib_path,])        env.Append(LIBPATH = [lib_path,])
546          env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
547     except KeyError:     except KeyError:
548        pass        pass
549        
# Line 648  if useNetCDF == 'yes': Line 685  if useNetCDF == 'yes':
685     try:     try:
686        lib_path = env['netCDF_lib_path']        lib_path = env['netCDF_lib_path']
687        env.Append(LIBPATH = [ lib_path, ])        env.Append(LIBPATH = [ lib_path, ])
688          env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
689        if IS_WINDOWS_PLATFORM :        if IS_WINDOWS_PLATFORM :
690           env.PrependENVPath('PATH', lib_path)           env.PrependENVPath('PATH', lib_path)
691     except KeyError:     except KeyError:
# Line 665  except KeyError: Line 703  except KeyError:
703  try:  try:
704     lib_path = env['boost_lib_path']     lib_path = env['boost_lib_path']
705     env.Append(LIBPATH = [lib_path,])     env.Append(LIBPATH = [lib_path,])
706       env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
707     if IS_WINDOWS_PLATFORM :     if IS_WINDOWS_PLATFORM :
708        env.PrependENVPath('PATH', lib_path)        env.PrependENVPath('PATH', lib_path)
709  except KeyError:  except KeyError:
# Line 681  except KeyError: Line 720  except KeyError:
720     pass     pass
721  try:  try:
722     lib_path = env['python_lib_path']     lib_path = env['python_lib_path']
723       env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
724     env.Append(LIBPATH = [lib_path,])     env.Append(LIBPATH = [lib_path,])
725  except KeyError:  except KeyError:
726     pass     pass
# Line 697  try: Line 737  try:
737     epydoc_path = env['epydoc_path']     epydoc_path = env['epydoc_path']
738  except KeyError:  except KeyError:
739     epydoc_path = None     epydoc_path = None
740    # =============== ParMETIS =======================================
741    try:
742       parmetis_path = env['parmetis_path']
743       parmetis_lib_path = env['parmetis_lib_path']
744       parmetis_lib = env['parmetis_lib']
745    except KeyError:
746       parmetis_path = ''
747       parmetis_lib_path = ''
748       parmetis_lib = ''
749    
750    if useMPI and os.path.isdir(parmetis_lib_path):
751       env.Append(CPPDEFINES = [ 'PARMETIS' ])
752       env.Append(CXXDEFINES = [ 'PARMETIS' ])
753       env.Append(CPPPATH = [parmetis_path])
754       env.Append(LIBPATH = [parmetis_lib_path])
755       env.Append(LIBS = parmetis_lib)
756  # =============== PAPI =======================================  # =============== PAPI =======================================
757  try:  try:
758     includes = env['papi_path']     includes = env['papi_path']
# Line 714  except KeyError: Line 770  except KeyError:
770     papi_libs = None     papi_libs = None
771  # ============= set mpi =====================================  # ============= set mpi =====================================
772  if useMPI:  if useMPI:
773     env.Append(CPPDEFINES=['PASO_MPI',])     env.Append(CPPDEFINES=['PASO_MPI', 'MPI_NO_CPPBIND'])
774     try:     try:
775        includes = env['mpi_path']        includes = env['mpi_path']
776        env.Append(CPPPATH = [includes,])        env.Append(CPPPATH = [includes,])
# Line 827  try: Line 883  try:
883     global_revision = re.sub(":.*", "", global_revision[0])     global_revision = re.sub(":.*", "", global_revision[0])
884     global_revision = re.sub("[^0-9]", "", global_revision)     global_revision = re.sub("[^0-9]", "", global_revision)
885  except:  except:
886     global_revision = "0"     global_revision="-1"
887       print "Warning: unable to recover global revsion number."
888    if global_revision == "": global_revision="0"
889    print "Revision number is %s."%global_revision
890  env.Append(CPPDEFINES = "SVN_VERSION="+global_revision)  env.Append(CPPDEFINES = "SVN_VERSION="+global_revision)
891    
892  # Python install - esys __init__.py  # Python install - esys __init__.py
# Line 883  except AttributeError: Line 942  except AttributeError:
942  # Third Party libraries  # Third Party libraries
943  env.SConscript(dirs = ['tools/CppUnitTest/src'], build_dir='build/$PLATFORM/tools/CppUnitTest', duplicate=0)  env.SConscript(dirs = ['tools/CppUnitTest/src'], build_dir='build/$PLATFORM/tools/CppUnitTest', duplicate=0)
944  # C/C++ Libraries  # C/C++ Libraries
945    env.SConscript(dirs = ['esysUtils/src'], build_dir='build/$PLATFORM/esysUtils', duplicate=0)
946    env.SConscript(dirs = ['escript/src'], build_dir='build/$PLATFORM/escript', duplicate=0)
947  env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)  env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)
948  # bruce is removed for now as it doesn't really do anything  # bruce is removed for now as it doesn't really do anything
949  # env.SConscript(dirs = ['bruce/src'], build_dir='build/$PLATFORM/bruce', duplicate=0)  # env.SConscript(dirs = ['bruce/src'], build_dir='build/$PLATFORM/bruce', duplicate=0)
 env.SConscript(dirs = ['escript/src'], build_dir='build/$PLATFORM/escript', duplicate=0)  
 env.SConscript(dirs = ['esysUtils/src'], build_dir='build/$PLATFORM/esysUtils', duplicate=0)  
950  env.SConscript(dirs = ['finley/src'], build_dir='build/$PLATFORM/finley', duplicate=0)  env.SConscript(dirs = ['finley/src'], build_dir='build/$PLATFORM/finley', duplicate=0)
951  env.SConscript(dirs = ['modellib/py_src'], build_dir='build/$PLATFORM/modellib', duplicate=0)  env.SConscript(dirs = ['modellib/py_src'], build_dir='build/$PLATFORM/modellib', duplicate=0)
952  env.SConscript(dirs = ['doc'], build_dir='build/$PLATFORM/doc', duplicate=0)  env.SConscript(dirs = ['doc'], build_dir='build/$PLATFORM/doc', duplicate=0)

Legend:
Removed from v.1343  
changed lines
  Added in v.1628

  ViewVC Help
Powered by ViewVC 1.1.26