/[escript]/trunk/SConstruct
ViewVC logotype

Diff of /trunk/SConstruct

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

revision 2012 by phornby, Mon Nov 10 12:13:45 2008 UTC revision 2040 by phornby, Sat Nov 15 12:43:11 2008 UTC
# Line 73  opts.AddOptions( Line 73  opts.AddOptions(
73    ('sys_libs', 'System libraries to link with', []),    ('sys_libs', 'System libraries to link with', []),
74    ('ar_flags', 'Static library archiver flags to use', ''),    ('ar_flags', 'Static library archiver flags to use', ''),
75    BoolOption('useopenmp', 'Compile parallel version using OpenMP', 'yes'),    BoolOption('useopenmp', 'Compile parallel version using OpenMP', 'yes'),
76    BoolOption('usepedantic', 'Compile with -pedantic if using gcc', 'yes'),    BoolOption('usepedantic', 'Compile with -pedantic if using gcc', 'no'),
77      BoolOption('usewarnings','Compile with warnings as errors if using gcc','yes'),
78  # Python  # Python
79    ('python_path', 'Path to Python includes', '/usr/include/'+python_version),    ('python_path', 'Path to Python includes', '/usr/include/'+python_version),
80    ('python_lib_path', 'Path to Python libs', usr_lib),    ('python_lib_path', 'Path to Python libs', usr_lib),
# Line 168  if env["CC"] == "icc": Line 169  if env["CC"] == "icc":
169    omp_debug     = "-openmp -openmp_report0"    omp_debug     = "-openmp -openmp_report0"
170    omp_libs      = ['guide', 'pthread']    omp_libs      = ['guide', 'pthread']
171    pedantic      = ""    pedantic      = ""
172      fatalwarning      = ""        # Switch to turn warnings into errors
173  elif env["CC"] == "gcc":  elif env["CC"] == "gcc":
174    # GNU C on any system    # GNU C on any system
175    cc_flags      = "-fPIC -ansi -ffast-math -Wno-unknown-pragmas -DBLOCKTIMER"    cc_flags      = "-pedantic -Wall -fPIC -ansi -ffast-math -Wno-unknown-pragmas -DBLOCKTIMER -isystem " + env['boost_path'] + " -isystem " + env['python_path'] + " -Wno-sign-compare -Wno-system-headers -Wno-strict-aliasing"
176    #the strict aliasing warning is triggered by some type punning in the boost headers for version 1.34
177    #isystem does not seem to prevent this
178    cc_optim      = "-O3"    cc_optim      = "-O3"
179    cc_debug      = "-g -O0 -DDOASSERT -DDOPROF -DBOUNDS_CHECK"    cc_debug      = "-g -O0 -DDOASSERT -DDOPROF -DBOUNDS_CHECK"
180    omp_optim     = ""    omp_optim     = ""
181    omp_debug     = ""    omp_debug     = ""
182    omp_libs      = []    omp_libs      = []
183    pedantic      = "-pedantic-errors -Wno-long-long"    pedantic      = "-pedantic-errors -Wno-long-long"
184      fatalwarning      = "-Werror"
185  elif env["CC"] == "cl":  elif env["CC"] == "cl":
186    # Microsoft Visual C on Windows    # Microsoft Visual C on Windows
187    cc_flags      = "/FD /EHsc /GR /wd4068 -D_USE_MATH_DEFINES -DDLL_NETCDF"    cc_flags      = "/FD /EHsc /GR /wd4068 -D_USE_MATH_DEFINES -DDLL_NETCDF"
# Line 186  elif env["CC"] == "cl": Line 191  elif env["CC"] == "cl":
191    omp_debug     = ""    omp_debug     = ""
192    omp_libs      = []    omp_libs      = []
193    pedantic      = ""    pedantic      = ""
194      fatalwarning      = ""
195  elif env["CC"] == "icl":  elif env["CC"] == "icl":
196    # intel C on Windows, see windows_msvc71_options.py for a start    # intel C on Windows, see windows_intelc_options.py for a start
197    pedantic      = ""    pedantic      = ""
198      fatalwarning      = ""
199    
200  # If not specified in hostname_options.py then set them here  # If not specified in hostname_options.py then set them here
201  if env["cc_flags"]  == "-DEFAULT_1": env['cc_flags'] = cc_flags  if env["cc_flags"]  == "-DEFAULT_1": env['cc_flags'] = cc_flags
# Line 258  env.Append(CPPPATH     = [Dir('include')]) Line 265  env.Append(CPPPATH     = [Dir('include')])
265  # Add cc option -L<Escript>/trunk/lib  # Add cc option -L<Escript>/trunk/lib
266  env.Append(LIBPATH      = [Dir(env['libinstall'])])  env.Append(LIBPATH      = [Dir(env['libinstall'])])
267    
 env.Append(CPPDEFINES = ['ESCRIPT_EXPORTS', 'FINLEY_EXPORTS'])  
   
268  if env['cc_extra'] != '': env.Append(CCFLAGS = env['cc_extra'])  if env['cc_extra'] != '': env.Append(CCFLAGS = env['cc_extra'])
269  if env['ld_extra'] != '': env.Append(LINKFLAGS = env['ld_extra'])  if env['ld_extra'] != '': env.Append(LINKFLAGS = env['ld_extra'])
270    
# Line 269  if env['usepedantic']: env.Append(CCFLAG Line 274  if env['usepedantic']: env.Append(CCFLAG
274  if IS_WINDOWS_PLATFORM:  if IS_WINDOWS_PLATFORM:
275    env.PrependENVPath('PATH',    [env['boost_lib_path']])    env.PrependENVPath('PATH',    [env['boost_lib_path']])
276    env.PrependENVPath('PATH',    [env['libinstall']])    env.PrependENVPath('PATH',    [env['libinstall']])
277      env.Append(CPPDEFINES = ['ESYSUTILS_STATIC_LIB'])
278    
279    if env['usenetcdf']:    if env['usenetcdf']:
280      env.PrependENVPath('PATH',  [env['netCDF_lib_path']])      env.PrependENVPath('PATH',  [env['netCDF_lib_path']])
281    
# Line 508  else: Line 515  else:
515    
516  env['useparmetis'] = env_mpi['useparmetis']  env['useparmetis'] = env_mpi['useparmetis']
517    
518    ############ Now we switch on Warnings as errors ###############
519    
520    #this needs to be done after configuration because the scons test files have warnings in them
521    
522    if ((fatalwarning != "") and (env['usewarnings'])):
523      env.Append(CCFLAGS        = fatalwarning)
524      env_mpi.Append(CCFLAGS        = fatalwarning)
525    
526  ############ Summarize our environment #########################  ############ Summarize our environment #########################
527    
528  print ""  print ""
# Line 534  else: print "  Not using PAPI" Line 549  else: print "  Not using PAPI"
549  if env['usedebug']: print " Compiling for debug"  if env['usedebug']: print " Compiling for debug"
550  else: print "   Not compiling for debug"  else: print "   Not compiling for debug"
551  print " Installing in", prefix  print " Installing in", prefix
552    if ((fatalwarning != "") and (env['usewarnings'])): print " Treating warnings as errors"
553    else: print "   Not treating warnings as errors"
554  print ""  print ""
555    
556  ############ Delete option-dependent files #####################  ############ Delete option-dependent files #####################
# Line 556  env.Append(BUILDERS = {'RunPyUnitTest' : Line 573  env.Append(BUILDERS = {'RunPyUnitTest' :
573    
574  ############ Build the subdirectories ##########################  ############ Build the subdirectories ##########################
575    
576  Export(["env", "env_mpi", "clone_env"])  Export(
577      ["env",
578       "env_mpi",
579       "clone_env",
580       "IS_WINDOWS_PLATFORM"
581       ]
582      )
583    
584  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)
585  env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)  env.SConscript(dirs = ['paso/src'], build_dir='build/$PLATFORM/paso', duplicate=0)

Legend:
Removed from v.2012  
changed lines
  Added in v.2040

  ViewVC Help
Powered by ViewVC 1.1.26