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

Diff of /branches/inv2jf/SConstruct

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

revision 1245 by phornby, Mon Aug 13 07:13:17 2007 UTC revision 1246 by phornby, Mon Aug 13 22:09:00 2007 UTC
# Line 16  EnsurePythonVersion(2,3) Line 16  EnsurePythonVersion(2,3)
16  #   import tools:  #   import tools:
17  import glob  import glob
18  import sys, os  import sys, os
 import socket  
19  # Add our extensions  # Add our extensions
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
# Line 69  print "    Default example system installat Line 68  print "    Default example system installat
68  #      #    
69  #    get the options file if present:  #    get the options file if present:
70  #  #
71  if ARGUMENTS.get('options_file',0):  options_file = ARGUMENTS.get('options_file','')
72     options_file = ARGUMENTS.get('options_file',0)  
73  else:  if not os.path.isfile(options_file) :
74        options_file = False
75    
76    if not options_file :
77       import socket
78     from string import ascii_letters,digits     from string import ascii_letters,digits
79     hostname=""     hostname=""
80     for s in socket.gethostname().split('.')[0]:     for s in socket.gethostname().split('.')[0]:
# Line 79  else: Line 82  else:
82           hostname+=s           hostname+=s
83        else:        else:
84           hostname+="_"           hostname+="_"
85     options_file = os.path.join("scons",hostname+"_options.py")     tmp = os.path.join("scons",hostname+"_options.py")
86      
87  if os.path.isfile(options_file):     if os.path.isfile(tmp) :
88     print "option file is ",options_file,"."        options_file = tmp
89  else:  
90     print "option file is ",options_file, "(not present)."  IS_WINDOWS_PLATFORM = (os.name== "nt")
91    
92    # If you're not going to tell me then......
93    # FIXME: add one for the altix too.
94    if not options_file :
95       if IS_WINDOWS_PLATFORM :
96          options_file = "scons/windows_mscv71_options.py"
97       else:
98          options_file = "scons/linux_gcc_eg_options.py"
99    
100  # and load it  # and load it
101  opts = Options(options_file, ARGUMENTS)  opts = Options(options_file, ARGUMENTS)
102  #================================================================  #================================================================
# Line 246  opts.AddOptions( Line 258  opts.AddOptions(
258  #   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)  #   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)
259  #   FIXME: Perhaps a modification to intelc.py will allow better support for ia64 on altix  #   FIXME: Perhaps a modification to intelc.py will allow better support for ia64 on altix
260  #  #
 IS_WINDOWS_PLATFORM = (os.name== "nt")  
261    
262  if IS_WINDOWS_PLATFORM:  if IS_WINDOWS_PLATFORM:
263        env = Environment(tools = ['default', 'msvc'], options = opts)        env = Environment(tools = ['default', 'msvc'], options = opts)
# Line 359  try: Line 370  try:
370  except KeyError:  except KeyError:
371     pass     pass
372    
373    
374  if dodebug:  if dodebug:
375    if useMPI:    if useMPI:
376      try:      try:
# Line 539  except KeyError: Line 551  except KeyError:
551     useNetCDF = 'yes'     useNetCDF = 'yes'
552     pass     pass
553    
 if not useNetCDF == 'yes':  
    print "Warning: Installation is not configured with netCDF. Some I/O function may not be available."  
     
554  if useNetCDF == 'yes':  if useNetCDF == 'yes':
555     try:     try:
556          netCDF_libs = env['netCDF_libs']
557       except KeyError:
558          pass
559    
560       env.Append(LIBS = netCDF_libs)
561       env.Append(CPPDEFINES = [ 'USE_NETCDF' ])
562       try:
563        includes = env['netCDF_path']        includes = env['netCDF_path']
564        env.Append(CPPPATH = [includes,])        env.Append(CPPPATH = [includes,])
565     except KeyError:     except KeyError:
# Line 555  if useNetCDF == 'yes': Line 571  if useNetCDF == 'yes':
571        env.Append(LIBPATH = [ lib_path, ])        env.Append(LIBPATH = [ lib_path, ])
572     except KeyError:     except KeyError:
573        pass        pass
   
    try:  
       netCDF_libs = env['netCDF_libs']  
    except KeyError:  
       netCDF_libs = [ ]  
574  else:  else:
575       print "Warning: Installation is not configured with netCDF. Some I/O function may not be available."
576     netCDF_libs=[ ]     netCDF_libs=[ ]
577    
578  try:  try:
# Line 661  try: Line 673  try:
673  except KeyError:  except KeyError:
674     api_doxygen = None     api_doxygen = None
675    
676    # Python install - esys __init__.py
677    init_target = env.Command(pyinstall+'/__init__.py', None, Touch('$TARGET'))
678    
679  # FIXME: exinstall and friends related to examples are not working.  # FIXME: exinstall and friends related to examples are not working.
680  build_target = env.Alias('build',[libinstall,incinstall,pyinstall])  build_target = env.Alias('build',[libinstall,incinstall,pyinstall,init_target])
681    
682  env.Default(build_target)  env.Default(build_target)
683    
# Line 680  env.Alias('guide_pdf', guide_pdf) Line 694  env.Alias('guide_pdf', guide_pdf)
694  env.Alias('docs',[ 'release_examples', 'guide_pdf', api_epydoc, api_doxygen, guide_html_index])  env.Alias('docs',[ 'release_examples', 'guide_pdf', api_epydoc, api_doxygen, guide_html_index])
695  env.Alias('release', ['release_src', 'release_tests', 'docs'])  env.Alias('release', ['release_src', 'release_tests', 'docs'])
696    
697  env.Alias('build_tests')    # target to build all C++ tests  env.Alias('build_tests',build_target)    # target to build all C++ tests
698  env.Alias('build_py_tests') # target to build all python tests  env.Alias('build_py_tests',build_target) # target to build all python tests
699  env.Alias('build_all_tests', [ 'build_tests', 'build_py_tests' ] ) # target to build all python tests  env.Alias('build_all_tests', [ 'build_tests', 'build_py_tests' ] ) # target to build all python tests
700  env.Alias('run_tests', 'build_tests')   # target to run all C++ test  env.Alias('run_tests', 'build_tests')   # target to run all C++ test
701  env.Alias('py_tests', 'build_py_tests') # taget to run all released python tests  env.Alias('py_tests', 'build_py_tests') # taget to run all released python tests
702  env.Alias('all_tests', ['run_tests', 'py_tests']) # target to run all C++ and released python tests  env.Alias('all_tests', ['run_tests', 'py_tests']) # target to run all C++ and released python tests
703    
 # Python install - esys __init__.py  
 init_target = env.Command(pyinstall+'/__init__.py', None, Touch('$TARGET'))  
 env.Alias(init_target)  
704    
705  # Allow sconscripts to see the env  # Allow sconscripts to see the env
706  Export(["IS_WINDOWS_PLATFORM", "env", "incinstall", "libinstall", "pyinstall", "exinstall", "dodebug", "mkl_libs", "scsl_libs", "umf_libs", "amd_libs", "blas_libs", "netCDF_libs", "useNetCDF",  Export(["env", "incinstall", "libinstall", "pyinstall", "exinstall", "dodebug",
707            "mkl_libs", "scsl_libs", "umf_libs", "amd_libs", "blas_libs",
708            "netCDF_libs",
709      "boost_lib", "python_lib", "doxygen_path", "epydoc_path", "papi_libs",      "boost_lib", "python_lib", "doxygen_path", "epydoc_path", "papi_libs",
710          "sys_libs", "test_zipfile", "src_zipfile", "test_tarfile", "src_tarfile", "examples_tarfile", "examples_zipfile",          "sys_libs", "test_zipfile", "src_zipfile", "test_tarfile",
711          "guide_pdf", "guide_html_index", "api_epydoc", "api_doxygen", "useMPI" ])          "src_tarfile", "examples_tarfile", "examples_zipfile",
712            "guide_pdf", "guide_html_index", "api_epydoc", "api_doxygen", "useMPI"
713            ])
714    
715  # End initialisation section  # End initialisation section
716  # Begin configuration section  # Begin configuration section

Legend:
Removed from v.1245  
changed lines
  Added in v.1246

  ViewVC Help
Powered by ViewVC 1.1.26