/[escript]/trunk/escript/src/SConscript
ViewVC logotype

Annotation of /trunk/escript/src/SConscript

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1387 - (hide annotations)
Fri Jan 11 07:45:26 2008 UTC (11 years, 9 months ago) by trankine
Original Path: temp/escript/src/SConscript
File size: 2632 byte(s)
Restore the trunk that existed before the windows changes were committed to the (now moved to branches) old trunk.
1 gross 700 import os
2 jgs 181 Import('*')
3    
4 robwdcock 682 local_env=env.Copy()
5     py_wrapper_local_env=env.Copy()
6     # Remove the sharedlibrary prefix on all platform - we don't want 'lib' mucking with our python modules
7     del py_wrapper_local_env['SHLIBPREFIX']
8 jgs 181
9 robwdcock 682 lib_name = 'escript'
10     py_wrapper_name = lib_name+'cpp'
11     py_wrapper_source = py_wrapper_name+'.cpp'
12     py_wrapper_lib_name = py_wrapper_name
13 jgs 277
14 gross 700 # get the relevant file names:
15 robwdcock 682 src_dir = local_env.Dir('.').srcnode().abspath
16 gross 700 filenames = [ x for x in os.listdir(src_dir) if os.path.splitext(x)[1] in [".h", ".c", ".cpp"] ]
17 jgs 181
18 robwdcock 682 sources = [x for x in filenames if os.path.splitext(x)[1] in ['.cpp', '.c']]
19     headers = [x for x in filenames if os.path.splitext(x)[1] in ['.h']]
20 gross 700
21 robwdcock 682 # Filter out sources that should not be in the list automatically
22     sources.remove(py_wrapper_source) # FIXME: should probably refactor the source tree so the python wrapper isn't colocated with c++ sources
23 jgs 277
24 ksteube 1312 local_env.Append(LIBS = [boost_lib] + [ 'esysUtils'] + sys_libs + netCDF_libs + mpi_libs)
25     py_wrapper_local_env.Append(LIBS = [boost_lib] + [ lib_name, 'esysUtils'] + sys_libs + netCDF_libs)
26     if useNetCDF == 'yes':
27     local_env.Append(LIBS = netCDF_libs)
28     local_env.Append(CPPDEFINES = [ 'USE_NETCDF' ])
29     py_wrapper_local_env.Append(LIBS = netCDF_libs)
30     py_wrapper_local_env.Append(CPPDEFINES = [ 'USE_NETCDF' ])
31 jgs 190
32 ksteube 1312 if papi_instrument_solver:
33     local_env.Append(CPPDEFINES=['PAPI',])
34     if papi_libs:
35     local_env.Append(LIBS = papi_libs)
36     local_env.Append(CPPDEFINES=['BLOCKPAPI',])
37    
38 gross 1023 local_env.Append(CPPDEFINES = [ 'ESCRIPT_EXPORTS'] )
39 woo409 757
40 robwdcock 682 lib = local_env.SharedLibrary(lib_name, sources)
41     py_wrapper_lib = py_wrapper_local_env.SharedLibrary( py_wrapper_lib_name, py_wrapper_source)
42 jgs 481
43 robwdcock 682 include_path = Dir(lib_name, incinstall)
44 jgs 181
45 robwdcock 682 local_env.Install(include_path, headers )
46     local_env.Install(libinstall, lib)
47     py_wrapper_local_env.Install(pyinstall+'/escript', py_wrapper_lib)
48 jgs 277
49 robwdcock 682 # export the lib target since tests will depend on it
50     # the lib target is a list of file nodes (why? win32 produces more than one output file: .lib, .dll, .pdb)
51     # FIXME: This list handling produces the desired result but can this be done directly with scons File nodes?
52     dep_lib = [libinstall+'/'+str(x) for x in lib]
53     Export('dep_lib')
54 jgs 277
55 gross 700
56    
57     # add source files to release
58     release_srcfiles = [ env.File(x) for x in filenames ] + [env.File("SConscript"), ]
59     env.Zip(src_zipfile, release_srcfiles)
60 ksteube 1312 env.Tar(src_tarfile, release_srcfiles)
61    
62 robwdcock 682 # Call the python sconscript
63     env.SConscript(dirs = ['#/escript/py_src'], build_dir='py', duplicate=0)
64 jgs 277
65 robwdcock 682 # Call the unit tests SConscript
66     local_env.SConscript(dirs = ['#/escript/test'], build_dir='#/build/$PLATFORM/escript/test', duplicate=0)

  ViewVC Help
Powered by ViewVC 1.1.26