Create a base options function for common openspeedshop base cmake options to reduce redundencies.

This commit is contained in:
Jim Galarowicz 2016-10-14 21:44:55 -07:00
parent 1eb2b445aa
commit 233479c988

View File

@ -161,6 +161,37 @@ def adjustBuildTypeParams_cmakeOptions(self, spec, cmakeOptions):
cmakeOptions.extend(BuildTypeOptions) cmakeOptions.extend(BuildTypeOptions)
def set_defaultbase_cmakeOptions(self, spec, cmakeOptions):
# Appends to cmakeOptions the options that will enable
# the appropriate base level options to the openspeedshop
# cmake build.
python_vers = format(spec['python'].version.up_to(2))
python_pv = '/python' + python_vers
python_pvs = '/libpython' + python_vers + '.' + format(dso_suffix)
BaseOptions = []
BaseOptions.append('-DBINUTILS_DIR=%s' % spec['binutils'].prefix)
BaseOptions.append('-DLIBELF_DIR=%s' % spec['libelf'].prefix)
BaseOptions.append('-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix)
BaseOptions.append(
'-DPYTHON_EXECUTABLE=%s'
% join_path(spec['python'].prefix + '/bin/python'))
BaseOptions.append(
'-DPYTHON_INCLUDE_DIR=%s'
% join_path(spec['python'].prefix.include) + python_pv)
BaseOptions.append(
'-DPYTHON_LIBRARY=%s'
% join_path(spec['python'].prefix.lib) + python_pvs)
BaseOptions.append('-DBoost_NO_SYSTEM_PATHS=TRUE')
BaseOptions.append('-DBoost_NO_BOOST_CMAKE=TRUE')
BaseOptions.append('-DBOOST_ROOT=%s' % spec['boost'].prefix)
BaseOptions.append('-DBoost_DIR=%s' % spec['boost'].prefix)
BaseOptions.append('-DBOOST_LIBRARYDIR=%s' % spec['boost'].prefix.lib)
BaseOptions.append('-DDYNINST_DIR=%s' % spec['dyninst'].prefix)
cmakeOptions.extend(BaseOptions)
def set_mpi_cmakeOptions(self, spec, cmakeOptions): def set_mpi_cmakeOptions(self, spec, cmakeOptions):
# Appends to cmakeOptions the options that will enable # Appends to cmakeOptions the options that will enable
# the appropriate MPI implementations # the appropriate MPI implementations
@ -278,11 +309,11 @@ def install(self, spec, prefix):
else: else:
cmake_prefix_path = join_path(spec['dyninst'].prefix) cmake_prefix_path = join_path(spec['dyninst'].prefix)
with working_dir('build', create=True): with working_dir('build', create=True):
python_vers = format(spec['python'].version.up_to(2))
python_pv = '/python' + python_vers
python_pvs = \
'/libpython' + python_vers + '.' + format(dso_suffix)
cmakeOptions = [] cmakeOptions = []
# Appends base options to cmakeOptions
self.set_defaultbase_cmakeOptions(spec, cmakeOptions)
cmakeOptions.extend( cmakeOptions.extend(
['-DCMAKE_INSTALL_PREFIX=%s' ['-DCMAKE_INSTALL_PREFIX=%s'
% prefix, % prefix,
@ -290,12 +321,6 @@ def install(self, spec, prefix):
% cmake_prefix_path, % cmake_prefix_path,
'-DINSTRUMENTOR=%s' '-DINSTRUMENTOR=%s'
% instrumentor_setting, % instrumentor_setting,
'-DBINUTILS_DIR=%s'
% spec['binutils'].prefix,
'-DLIBELF_DIR=%s'
% spec['libelf'].prefix,
'-DLIBDWARF_DIR=%s'
% spec['libdwarf'].prefix,
'-DLIBMONITOR_DIR=%s' '-DLIBMONITOR_DIR=%s'
% spec['libmonitor'].prefix, % spec['libmonitor'].prefix,
'-DLIBUNWIND_DIR=%s' '-DLIBUNWIND_DIR=%s'
@ -305,25 +330,7 @@ def install(self, spec, prefix):
'-DSQLITE3_DIR=%s' '-DSQLITE3_DIR=%s'
% spec['sqlite'].prefix, % spec['sqlite'].prefix,
'-DQTLIB_DIR=%s' '-DQTLIB_DIR=%s'
% spec['qt'].prefix, % spec['qt'].prefix])
'-DPYTHON_EXECUTABLE=%s'
% join_path(spec['python'].prefix + '/bin/python'),
'-DPYTHON_INCLUDE_DIR=%s'
% join_path(
spec['python'].prefix.include) + python_pv,
'-DPYTHON_LIBRARY=%s'
% join_path(
spec['python'].prefix.lib) + python_pvs,
'-DBoost_NO_SYSTEM_PATHS=TRUE',
'-DBoost_NO_BOOST_CMAKE=TRUE',
'-DBOOST_ROOT=%s'
% spec['boost'].prefix,
'-DBoost_DIR=%s'
% spec['boost'].prefix,
'-DBOOST_LIBRARYDIR=%s'
% spec['boost'].prefix.lib,
'-DDYNINST_DIR=%s'
% spec['dyninst'].prefix])
# Add any MPI implementations coming from variant settings # Add any MPI implementations coming from variant settings
self.set_mpi_cmakeOptions(spec, cmakeOptions) self.set_mpi_cmakeOptions(spec, cmakeOptions)
@ -348,11 +355,11 @@ def install(self, spec, prefix):
if '+runtime' in spec: if '+runtime' in spec:
with working_dir('build_cbtf_runtime', create=True): with working_dir('build_cbtf_runtime', create=True):
python_vers = '%d.%d' % spec['python'].version[:2]
python_pv = '/python' + python_vers
python_pvs = \
'/libpython' + python_vers + '.' + format(dso_suffix)
cmakeOptions = [] cmakeOptions = []
# Appends base options to cmakeOptions
self.set_defaultbase_cmakeOptions(spec, cmakeOptions)
cmakeOptions.extend( cmakeOptions.extend(
['-DCMAKE_INSTALL_PREFIX=%s' ['-DCMAKE_INSTALL_PREFIX=%s'
% prefix, % prefix,
@ -360,38 +367,10 @@ def install(self, spec, prefix):
% cmake_prefix_path, % cmake_prefix_path,
'-DINSTRUMENTOR=%s' '-DINSTRUMENTOR=%s'
% instrumentor_setting, % instrumentor_setting,
'-DBINUTILS_DIR=%s'
% spec['binutils'].prefix,
'-DLIBELF_DIR=%s'
% spec['libelf'].prefix,
'-DLIBDWARF_DIR=%s'
% spec['libdwarf'].prefix,
'-DCBTF_DIR=%s' '-DCBTF_DIR=%s'
% spec['cbtf'].prefix, % spec['cbtf'].prefix,
'-DCBTF_KRELL_DIR=%s' '-DCBTF_KRELL_DIR=%s'
% spec['cbtf-krell'].prefix, % spec['cbtf-krell'].prefix,
'-DPYTHON_EXECUTABLE=%s'
% join_path(spec['python'].prefix + '/bin/python'),
'-DPYTHON_INCLUDE_DIR=%s'
% join_path(
spec['python'].prefix.include) + python_pv,
'-DPYTHON_LIBRARY=%s'
% join_path(
spec['python'].prefix.lib) + python_pvs,
'-DBoost_NO_SYSTEM_PATHS=TRUE',
'-DBoost_NO_BOOST_CMAKE=TRUE',
'-DBOOST_ROOT=%s'
% spec['boost'].prefix,
'-DBoost_DIR=%s'
% spec['boost'].prefix,
'-DBOOST_LIBRARYDIR=%s'
% spec['boost'].prefix.lib,
'-DBoost_INCLUDE_DIRS:PATH=%s'
% spec['boost'].prefix.include,
'-DBoost_LIBRARY_DIRS:PATH=%s'
% spec['boost'].prefix.lib,
'-DDYNINST_DIR=%s'
% spec['dyninst'].prefix,
'-DMRNET_DIR=%s' '-DMRNET_DIR=%s'
% spec['mrnet'].prefix]) % spec['mrnet'].prefix])
@ -407,11 +386,11 @@ def install(self, spec, prefix):
else: else:
with working_dir('build_cbtf', create=True): with working_dir('build_cbtf', create=True):
python_vers = format(spec['python'].version.up_to(2))
python_pv = '/python' + python_vers
python_pvs = \
'/libpython' + python_vers + '.' + format(dso_suffix)
cmakeOptions = [] cmakeOptions = []
# Appends base options to cmakeOptions
self.set_defaultbase_cmakeOptions(spec, cmakeOptions)
cmakeOptions.extend( cmakeOptions.extend(
['-DCMAKE_INSTALL_PREFIX=%s' ['-DCMAKE_INSTALL_PREFIX=%s'
% prefix, % prefix,
@ -419,12 +398,6 @@ def install(self, spec, prefix):
% cmake_prefix_path, % cmake_prefix_path,
'-DINSTRUMENTOR=%s' '-DINSTRUMENTOR=%s'
% instrumentor_setting, % instrumentor_setting,
'-DBINUTILS_DIR=%s'
% spec['binutils'].prefix,
'-DLIBELF_DIR=%s'
% spec['libelf'].prefix,
'-DLIBDWARF_DIR=%s'
% spec['libdwarf'].prefix,
'-DSQLITE3_DIR=%s' '-DSQLITE3_DIR=%s'
% spec['sqlite'].prefix, % spec['sqlite'].prefix,
'-DCBTF_DIR=%s' '-DCBTF_DIR=%s'
@ -433,29 +406,6 @@ def install(self, spec, prefix):
% spec['cbtf-krell'].prefix, % spec['cbtf-krell'].prefix,
'-DQTLIB_DIR=%s' '-DQTLIB_DIR=%s'
% spec['qt'].prefix, % spec['qt'].prefix,
'-DPYTHON_EXECUTABLE=%s'
% join_path(
spec['python'].prefix + '/bin/python'),
'-DPYTHON_INCLUDE_DIR=%s'
% join_path(
spec['python'].prefix.include) + python_pv,
'-DPYTHON_LIBRARY=%s'
% join_path(
spec['python'].prefix.lib) + python_pvs,
'-DBoost_NO_SYSTEM_PATHS=TRUE',
'-DBoost_NO_BOOST_CMAKE=TRUE',
'-DBOOST_ROOT=%s'
% spec['boost'].prefix,
'-DBoost_DIR=%s'
% spec['boost'].prefix,
'-DBOOST_LIBRARYDIR=%s'
% spec['boost'].prefix.lib,
'-DBoost_INCLUDE_DIRS:PATH=%s'
% spec['boost'].prefix.include,
'-DBoost_LIBRARY_DIRS:PATH=%s'
% spec['boost'].prefix.lib,
'-DDYNINST_DIR=%s'
% spec['dyninst'].prefix,
'-DMRNET_DIR=%s' '-DMRNET_DIR=%s'
% spec['mrnet'].prefix]) % spec['mrnet'].prefix])