/[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 1634 by phornby, Sat Jul 12 09:08:33 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 470  else: Line 485  else:
485          env.Append(CXXFLAGS = flags)          env.Append(CXXFLAGS = flags)
486       except KeyError:       except KeyError:
487          pass          pass
488    
489    # Impassioned plea - please do this sort of thing in the options files.
490  try:  try:
491       if env['CC'] == 'gcc': env.Append(CCFLAGS = "-pedantic-errors -Wno-long-long")       if env['CC'] == 'gcc': env.Append(CCFLAGS = "-pedantic-errors -Wno-long-long")
492  except:  except:
493       pass       pass
494    
495    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    
508    # ============= Remember what options were used in the compile =====================================
509    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    
516  # ============= set mkl (but only of no MPI) =====================================  # ============= set mkl (but only of no MPI) =====================================
517  if not useMPI:  if not useMPI:
518     try:     try:
# Line 486  if not useMPI: Line 524  if not useMPI:
524     try:     try:
525        lib_path = env['mkl_lib_path']        lib_path = env['mkl_lib_path']
526        env.Append(LIBPATH = [lib_path,])        env.Append(LIBPATH = [lib_path,])
527          env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
528     except KeyError:     except KeyError:
529        pass        pass
530    
# Line 507  if not useMPI: Line 546  if not useMPI:
546     try:     try:
547        lib_path = env['scsl_lib_path']        lib_path = env['scsl_lib_path']
548        env.Append(LIBPATH = [lib_path,])        env.Append(LIBPATH = [lib_path,])
549          env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
550     except KeyError:     except KeyError:
551        pass        pass
552        
# Line 648  if useNetCDF == 'yes': Line 688  if useNetCDF == 'yes':
688     try:     try:
689        lib_path = env['netCDF_lib_path']        lib_path = env['netCDF_lib_path']
690        env.Append(LIBPATH = [ lib_path, ])        env.Append(LIBPATH = [ lib_path, ])
691          env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
692        if IS_WINDOWS_PLATFORM :        if IS_WINDOWS_PLATFORM :
693           env.PrependENVPath('PATH', lib_path)           env.PrependENVPath('PATH', lib_path)
694     except KeyError:     except KeyError:
# Line 665  except KeyError: Line 706  except KeyError:
706  try:  try:
707     lib_path = env['boost_lib_path']     lib_path = env['boost_lib_path']
708     env.Append(LIBPATH = [lib_path,])     env.Append(LIBPATH = [lib_path,])
709       env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
710     if IS_WINDOWS_PLATFORM :     if IS_WINDOWS_PLATFORM :
711        env.PrependENVPath('PATH', lib_path)        env.PrependENVPath('PATH', lib_path)
712  except KeyError:  except KeyError:
# Line 681  except KeyError: Line 723  except KeyError:
723     pass     pass
724  try:  try:
725     lib_path = env['python_lib_path']     lib_path = env['python_lib_path']
726       env['ENV']['LD_LIBRARY_PATH']+=":"+lib_path
727     env.Append(LIBPATH = [lib_path,])     env.Append(LIBPATH = [lib_path,])
728  except KeyError:  except KeyError:
729     pass     pass
# Line 697  try: Line 740  try:
740     epydoc_path = env['epydoc_path']     epydoc_path = env['epydoc_path']
741  except KeyError:  except KeyError:
742     epydoc_path = None     epydoc_path = None
743    # =============== 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  # =============== PAPI =======================================  # =============== PAPI =======================================
760  try:  try:
761     includes = env['papi_path']     includes = env['papi_path']
# Line 714  except KeyError: Line 773  except KeyError:
773     papi_libs = None     papi_libs = None
774  # ============= set mpi =====================================  # ============= set mpi =====================================
775  if useMPI:  if useMPI:
776     env.Append(CPPDEFINES=['PASO_MPI',])     env.Append(CPPDEFINES=['PASO_MPI', 'MPI_NO_CPPBIND'])
777     try:     try:
778        includes = env['mpi_path']        includes = env['mpi_path']
779        env.Append(CPPPATH = [includes,])        env.Append(CPPPATH = [includes,])
# Line 827  try: Line 886  try:
886     global_revision = re.sub(":.*", "", global_revision[0])     global_revision = re.sub(":.*", "", global_revision[0])
887     global_revision = re.sub("[^0-9]", "", global_revision)     global_revision = re.sub("[^0-9]", "", global_revision)
888  except:  except:
889     global_revision = "0"     global_revision="-1"
890       print "Warning: unable to recover global revsion number."
891    if global_revision == "": global_revision="0"
892    print "Revision number is %s."%global_revision
893  env.Append(CPPDEFINES = "SVN_VERSION="+global_revision)  env.Append(CPPDEFINES = "SVN_VERSION="+global_revision)
894    
895  # Python install - esys __init__.py  # Python install - esys __init__.py
# Line 883  except AttributeError: Line 945  except AttributeError:
945  # Third Party libraries  # Third Party libraries
946  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)
947  # C/C++ Libraries  # C/C++ Libraries
948    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  env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)  env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)
951  # bruce is removed for now as it doesn't really do anything  # 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)  # 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)  
953  env.SConscript(dirs = ['finley/src'], build_dir='build/$PLATFORM/finley', duplicate=0)  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)  env.SConscript(dirs = ['modellib/py_src'], build_dir='build/$PLATFORM/modellib', duplicate=0)
955  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.1634

  ViewVC Help
Powered by ViewVC 1.1.26