/[escript]/trunk/SConstruct
ViewVC logotype

Diff of /trunk/SConstruct

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

revision 3585 by caltinay, Wed Sep 7 06:16:08 2011 UTC revision 3604 by caltinay, Mon Sep 19 04:47:53 2011 UTC
# Line 19  from site_init import * Line 19  from site_init import *
19    
20  # Version number to check for in options file. Increment when new features are  # Version number to check for in options file. Increment when new features are
21  # added or existing options changed.  # added or existing options changed.
22  REQUIRED_OPTS_VERSION=200  REQUIRED_OPTS_VERSION=201
23    
24  # MS Windows support, many thanks to PH  # MS Windows support, many thanks to PH
25  IS_WINDOWS = (os.name == 'nt')  IS_WINDOWS = (os.name == 'nt')
# Line 73  vars.AddVariables( Line 73  vars.AddVariables(
73  # Mandatory libraries  # Mandatory libraries
74    ('boost_prefix', 'Prefix/Paths of boost installation', default_prefix),    ('boost_prefix', 'Prefix/Paths of boost installation', default_prefix),
75    ('boost_libs', 'Boost libraries to link with', ['boost_python-mt']),    ('boost_libs', 'Boost libraries to link with', ['boost_python-mt']),
76    # Mandatory for tests
77      ('cppunit_prefix', 'Prefix/Paths of CppUnit installation', default_prefix),
78      ('cppunit_libs', 'CppUnit libraries to link with', ['cppunit']),
79  # Optional libraries and options  # Optional libraries and options
80    EnumVariable('mpi', 'Compile parallel version using MPI flavour', 'none', allowed_values=mpi_flavours),    EnumVariable('mpi', 'Compile parallel version using MPI flavour', 'none', allowed_values=mpi_flavours),
81    ('mpi_prefix', 'Prefix/Paths of MPI installation', default_prefix),    ('mpi_prefix', 'Prefix/Paths of MPI installation', default_prefix),
# Line 119  vars.AddVariables( Line 122  vars.AddVariables(
122    EnumVariable('forcecollres', 'For testing use only - set the default value for force resolving collective ops', 'leave_alone', allowed_values=('leave_alone', 'on', 'off')),    EnumVariable('forcecollres', 'For testing use only - set the default value for force resolving collective ops', 'leave_alone', allowed_values=('leave_alone', 'on', 'off')),
123    # finer control over library building, intel aggressive global optimisation    # finer control over library building, intel aggressive global optimisation
124    # works with dynamic libraries on windows.    # works with dynamic libraries on windows.
125    ('share_esysutils', 'Build a dynamic esysUtils library', False),    ('build_shared', 'Build dynamic libraries only', False),
   ('share_paso', 'Build a dynamic paso library', False),  
126    ('sys_libs', 'Extra libraries to link with', []),    ('sys_libs', 'Extra libraries to link with', []),
127    ('escript_opts_version', 'Version of options file (do not specify on command line)'),    ('escript_opts_version', 'Version of options file (do not specify on command line)'),
128  )  )
# Line 293  env['svn_revision']=global_revision Line 295  env['svn_revision']=global_revision
295  env.Append(CPPDEFINES=['SVN_VERSION='+global_revision])  env.Append(CPPDEFINES=['SVN_VERSION='+global_revision])
296    
297  if IS_WINDOWS:  if IS_WINDOWS:
298      if not env['share_esysutils']:      if not env['build_shared']:
299          env.Append(CPPDEFINES = ['ESYSUTILS_STATIC_LIB'])          env.Append(CPPDEFINES = ['ESYSUTILS_STATIC_LIB'])
     if not env['share_paso']:  
300          env.Append(CPPDEFINES = ['PASO_STATIC_LIB'])          env.Append(CPPDEFINES = ['PASO_STATIC_LIB'])
301    
302  ###################### Copy required environment vars ########################  ###################### Copy required environment vars ########################
# Line 440  except ImportError: Line 441  except ImportError:
441      print("Cannot import numpy, you need to set your PYTHONPATH and probably %s"%LD_LIBRARY_PATH_KEY)      print("Cannot import numpy, you need to set your PYTHONPATH and probably %s"%LD_LIBRARY_PATH_KEY)
442      Exit(1)      Exit(1)
443    
444    ######## CppUnit (required for tests)
445    
446    try:
447        cppunit_inc_path,cppunit_lib_path=findLibWithHeader(env, env['cppunit_libs'], 'cppunit/TestFixture.h', env['cppunit_prefix'], lang='c++')
448        env.AppendUnique(CPPPATH = [cppunit_inc_path])
449        env.AppendUnique(LIBPATH = [cppunit_lib_path])
450        env.PrependENVPath(LD_LIBRARY_PATH_KEY, cppunit_lib_path)
451        env['cppunit']=True
452    except:
453        env['cppunit']=False
454    
455  ######## VTK (optional)  ######## VTK (optional)
456    
457  if env['pyvisi']:  if env['pyvisi']:
# Line 563  if env['usempi']: Line 575  if env['usempi']:
575    
576  ######## BOOMERAMG (optional)  ######## BOOMERAMG (optional)
577    
 #if env['boomeramg'] and env['mpi'] == 'none':  
 #    print("boomeramg requires mpi!")  
 #    Exit(1)  
578  if env['mpi'] == 'none': env['boomeramg'] = False  if env['mpi'] == 'none': env['boomeramg'] = False
579    
580  boomeramg_inc_path=''  boomeramg_inc_path=''
# Line 574  if env['boomeramg']: Line 583  if env['boomeramg']:
583      boomeramg_inc_path,boomeramg_lib_path=findLibWithHeader(env, env['boomeramg_libs'], 'HYPRE.h', env['boomeramg_prefix'], lang='c')      boomeramg_inc_path,boomeramg_lib_path=findLibWithHeader(env, env['boomeramg_libs'], 'HYPRE.h', env['boomeramg_prefix'], lang='c')
584      env.AppendUnique(CPPPATH = [boomeramg_inc_path])      env.AppendUnique(CPPPATH = [boomeramg_inc_path])
585      env.AppendUnique(LIBPATH = [boomeramg_lib_path])      env.AppendUnique(LIBPATH = [boomeramg_lib_path])
     # Note that we do not add the libs since they are only needed for the  
     # weipa library and tools.  
586      env.AppendUnique(LIBS = env['boomeramg_libs'])      env.AppendUnique(LIBS = env['boomeramg_libs'])
587      env.PrependENVPath(LD_LIBRARY_PATH_KEY, boomeramg_lib_path)      env.PrependENVPath(LD_LIBRARY_PATH_KEY, boomeramg_lib_path)
588      env.Append(CPPDEFINES = ['BOOMERAMG'])      env.Append(CPPDEFINES = ['BOOMERAMG'])
# Line 607  try: Line 614  try:
614  except OSError:  except OSError:
615      env['gmsh']=False      env['gmsh']=False
616    
617    ######## PDFLaTeX (for documentation)
618    if 'PDF' in dir(env) and '.tex' in env.PDF.builder.src_suffixes(env):
619        env['pdflatex']=True
620    else:
621        env['pdflatex']=False
622    
623  ######################## Summarize our environment ###########################  ######################## Summarize our environment ###########################
624    
625  # keep some of our install paths first in the list for the unit tests  # keep some of our install paths first in the list for the unit tests
# Line 652  for i in e_list: Line 665  for i in e_list:
665      print("%16s:  YES"%i)      print("%16s:  YES"%i)
666  for i in d_list:  for i in d_list:
667      print("%16s:  DISABLED"%i)      print("%16s:  DISABLED"%i)
668    if env['cppunit']:
669        print("         CppUnit:  FOUND")
670    else:
671        print("         CppUnit:  NOT FOUND")
672  if env['gmsh']=='m':  if env['gmsh']=='m':
673      print("            gmsh:  FOUND, MPI-ENABLED")      print("            gmsh:  FOUND, MPI-ENABLED")
674  elif env['gmsh']=='s':  elif env['gmsh']=='s':
# Line 688  Export( Line 705  Export(
705    ]    ]
706  )  )
707    
 env.SConscript(dirs = ['tools/CppUnitTest/src'], variant_dir='$BUILD_DIR/$PLATFORM/tools/CppUnitTest', duplicate=0)  
708  env.SConscript(dirs = ['tools/escriptconvert'], variant_dir='$BUILD_DIR/$PLATFORM/tools/escriptconvert', duplicate=0)  env.SConscript(dirs = ['tools/escriptconvert'], variant_dir='$BUILD_DIR/$PLATFORM/tools/escriptconvert', duplicate=0)
709  env.SConscript(dirs = ['paso/src'], variant_dir='$BUILD_DIR/$PLATFORM/paso', duplicate=0)  env.SConscript(dirs = ['paso/src'], variant_dir='$BUILD_DIR/$PLATFORM/paso', duplicate=0)
710  env.SConscript(dirs = ['weipa/src'], variant_dir='$BUILD_DIR/$PLATFORM/weipa', duplicate=0)  env.SConscript(dirs = ['weipa/src'], variant_dir='$BUILD_DIR/$PLATFORM/weipa', duplicate=0)
# Line 749  buildvars.close() Line 765  buildvars.close()
765    
766  ################### Targets to build and install libraries ###################  ################### Targets to build and install libraries ###################
767    
768  target_init = env.Command(env['pyinstall']+'/__init__.py', None, Touch('$TARGET'))  target_init = env.Command(os.path.join(env['pyinstall'],'__init__.py'), None, Touch('$TARGET'))
769  env.Alias('target_init', [target_init])  env.Alias('target_init', [target_init])
770    # delete buildvars upon cleanup
771    env.Clean('target_init', os.path.join(env['libinstall'], 'buildvars'))
772    
773  # The headers have to be installed prior to build in order to satisfy  # The headers have to be installed prior to build in order to satisfy
774  # #include <paso/Common.h>  # #include <paso/Common.h>
# Line 809  env.Default('install_all') Line 827  env.Default('install_all')
827    
828  ################## Targets to build and run the test suite ###################  ################## Targets to build and run the test suite ###################
829    
830  env.Alias('build_cppunittest', ['install_cppunittest_headers', 'build_cppunittest_lib'])  test_msg = env.Command('.dummy.', None, '@echo "Cannot run C/C++ unit tests, CppUnit not found!";exit 1')
831  env.Alias('install_cppunittest', ['build_cppunittest', 'install_cppunittest_lib'])  if not env['cppunit']:
832  env.Alias('run_tests', ['install_all', 'install_cppunittest_lib'])      env.Alias('run_tests', test_msg)
833  env.Alias('all_tests', ['install_all', 'install_cppunittest_lib', 'run_tests', 'py_tests'])  env.Alias('run_tests', ['install_all'])
834    env.Alias('all_tests', ['install_all', 'run_tests', 'py_tests'])
835  env.Alias('build_full',['install_all','build_tests','build_py_tests'])  env.Alias('build_full',['install_all','build_tests','build_py_tests'])
836  env.Alias('build_PasoTests','$BUILD_DIR/$PLATFORM/paso/profiling/PasoTests')  env.Alias('build_PasoTests','$BUILD_DIR/$PLATFORM/paso/profiling/PasoTests')
837    
# Line 835  if not IS_WINDOWS: Line 854  if not IS_WINDOWS:
854          print("Error attempting to write unittests file.")          print("Error attempting to write unittests file.")
855          Exit(1)          Exit(1)
856    
857        # delete utest.sh upon cleanup
858        env.Clean('target_init', 'utest.sh')
859    
860      # Make sure that the escript wrapper is in place      # Make sure that the escript wrapper is in place
861      if not os.path.isfile(os.path.join(env['bininstall'], 'run-escript')):      if not os.path.isfile(os.path.join(env['bininstall'], 'run-escript')):
862          print("Copying escript wrapper.")          print("Copying escript wrapper.")

Legend:
Removed from v.3585  
changed lines
  Added in v.3604

  ViewVC Help
Powered by ViewVC 1.1.26