2016-06-01 17:50:21 +00:00
|
|
|
include(CMakeParseArguments)
|
2016-05-28 07:44:36 +00:00
|
|
|
|
2016-06-01 17:50:21 +00:00
|
|
|
function(distutils_install_module name)
|
2017-07-20 20:54:37 +00:00
|
|
|
set(py_srcs setup.py README.rst requirements.txt test-requirements.txt bin ${name})
|
2016-05-28 07:44:36 +00:00
|
|
|
foreach(src ${py_srcs})
|
2017-07-20 20:54:37 +00:00
|
|
|
if(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/${src})
|
|
|
|
list(APPEND py_clone ${CMAKE_CURRENT_BINARY_DIR}/${src})
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT ${src}
|
|
|
|
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${src}
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E create_symlink ${CMAKE_CURRENT_SOURCE_DIR}/${src} ${src})
|
|
|
|
endif()
|
2016-05-28 07:44:36 +00:00
|
|
|
endforeach()
|
|
|
|
add_custom_target(${name}-clone ALL
|
|
|
|
DEPENDS ${py_clone})
|
2019-07-18 01:46:51 +00:00
|
|
|
cmake_parse_arguments(DU "" "INSTALL_SCRIPT;PYTHON_VERSION" "" ${ARGN})
|
|
|
|
if(DU_PYTHON_VERSION)
|
|
|
|
set(python_version ${DU_PYTHON_VERSION})
|
|
|
|
else()
|
|
|
|
set(python_version 3)
|
|
|
|
endif()
|
2016-06-01 17:50:21 +00:00
|
|
|
install(CODE "
|
2016-07-04 03:10:49 +00:00
|
|
|
set(options --prefix=${CMAKE_INSTALL_PREFIX})
|
2016-06-01 17:50:21 +00:00
|
|
|
if(DEFINED ENV{DESTDIR})
|
|
|
|
if(EXISTS /etc/debian_version)
|
|
|
|
list(APPEND options --install-layout=deb)
|
|
|
|
endif()
|
2018-11-20 14:13:35 +00:00
|
|
|
list(APPEND options
|
|
|
|
--root=\$ENV{DESTDIR}
|
|
|
|
--single-version-externally-managed)
|
2016-06-01 17:50:21 +00:00
|
|
|
if(NOT \"${DU_INSTALL_SCRIPT}\" STREQUAL \"\")
|
|
|
|
list(APPEND options --install-script=${DU_INSTALL_SCRIPT})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
execute_process(
|
2019-07-18 01:46:51 +00:00
|
|
|
COMMAND ${Python${python_version}_EXECUTABLE}
|
2018-11-20 14:13:35 +00:00
|
|
|
setup.py install \${options}
|
2016-06-01 17:50:21 +00:00
|
|
|
WORKING_DIRECTORY \"${CMAKE_CURRENT_BINARY_DIR}\")")
|
2016-05-28 07:44:36 +00:00
|
|
|
endfunction(distutils_install_module)
|
2016-06-01 05:38:05 +00:00
|
|
|
|
2019-07-18 01:46:51 +00:00
|
|
|
function(distutils_add_cython_module target name src python_version)
|
2016-06-01 05:38:05 +00:00
|
|
|
get_property(compiler_launcher GLOBAL PROPERTY RULE_LAUNCH_COMPILE)
|
|
|
|
get_property(link_launcher GLOBAL PROPERTY RULE_LAUNCH_LINK)
|
2016-09-29 15:25:04 +00:00
|
|
|
# When using ccache, CMAKE_C_COMPILER is ccache executable absolute path
|
|
|
|
# and the actual C compiler is CMAKE_C_COMPILER_ARG1.
|
|
|
|
# However with a naive
|
|
|
|
# set(PY_CC ${compiler_launcher} ${CMAKE_C_COMPILER} ${CMAKE_C_COMPILER_ARG1})
|
|
|
|
# distutils tries to execve something like "/usr/bin/cmake gcc" and fails.
|
|
|
|
# Removing the leading whitespace from CMAKE_C_COMPILER_ARG1 helps to avoid
|
|
|
|
# the failure.
|
|
|
|
string(STRIP "${CMAKE_C_COMPILER_ARG1}" c_compiler_arg1)
|
|
|
|
string(STRIP "${CMAKE_CXX_COMPILER_ARG1}" cxx_compiler_arg1)
|
|
|
|
# Note: no quotes, otherwise distutils will execute "/usr/bin/ccache gcc"
|
|
|
|
# CMake's implicit conversion between strings and lists is wonderful, isn't it?
|
2018-10-22 04:28:01 +00:00
|
|
|
string(REPLACE " " ";" cflags ${CMAKE_C_FLAGS})
|
|
|
|
list(APPEND cflags -iquote${CMAKE_SOURCE_DIR}/src/include -w)
|
2018-12-17 11:01:25 +00:00
|
|
|
# This little bit of magic wipes out __Pyx_check_single_interpreter()
|
2019-03-20 07:52:14 +00:00
|
|
|
# Note: this is reproduced in distutils_install_cython_module
|
2018-12-17 11:01:25 +00:00
|
|
|
list(APPEND cflags -D'void0=dead_function\(void\)')
|
|
|
|
list(APPEND cflags -D'__Pyx_check_single_interpreter\(ARG\)=ARG \#\# 0')
|
2018-10-22 04:28:01 +00:00
|
|
|
set(PY_CC ${compiler_launcher} ${CMAKE_C_COMPILER} ${c_compiler_arg1} ${cflags})
|
2016-09-29 15:25:04 +00:00
|
|
|
set(PY_CXX ${compiler_launcher} ${CMAKE_CXX_COMPILER} ${cxx_compiler_arg1})
|
|
|
|
set(PY_LDSHARED ${link_launcher} ${CMAKE_C_COMPILER} ${c_compiler_arg1} "-shared")
|
2019-07-08 11:27:37 +00:00
|
|
|
|
2019-07-18 01:46:51 +00:00
|
|
|
if(${Python${python_version}_VERSION_MAJOR} STREQUAL "2")
|
2019-07-08 11:27:37 +00:00
|
|
|
set(suffix_var "SO")
|
|
|
|
else()
|
|
|
|
set(suffix_var "EXT_SUFFIX")
|
|
|
|
endif()
|
2019-07-18 01:46:51 +00:00
|
|
|
execute_process(COMMAND "${Python${python_version}_EXECUTABLE}" -c
|
2019-07-08 11:27:37 +00:00
|
|
|
"from distutils import sysconfig; print(sysconfig.get_config_var('${suffix_var}'))"
|
|
|
|
RESULT_VARIABLE result
|
|
|
|
OUTPUT_VARIABLE ext_suffix
|
|
|
|
ERROR_VARIABLE error
|
|
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
if(NOT result EQUAL 0)
|
|
|
|
message(FATAL_ERROR "Unable to tell python extension's suffix: ${error}")
|
|
|
|
endif()
|
2019-07-18 01:46:51 +00:00
|
|
|
set(output_dir "${CYTHON_MODULE_DIR}/lib.${Python${python_version}_VERSION_MAJOR}")
|
2019-07-08 12:15:39 +00:00
|
|
|
set(setup_py ${CMAKE_CURRENT_SOURCE_DIR}/setup.py)
|
2019-07-08 12:06:06 +00:00
|
|
|
add_custom_command(
|
|
|
|
OUTPUT ${output_dir}/${name}${ext_suffix}
|
2016-06-01 05:38:05 +00:00
|
|
|
COMMAND
|
|
|
|
env
|
2016-09-29 15:25:04 +00:00
|
|
|
CC="${PY_CC}"
|
|
|
|
CXX="${PY_CXX}"
|
|
|
|
LDSHARED="${PY_LDSHARED}"
|
2016-11-08 20:43:26 +00:00
|
|
|
OPT=\"-DNDEBUG -g -fwrapv -O2 -w\"
|
2016-06-01 05:38:05 +00:00
|
|
|
LDFLAGS=-L${CMAKE_LIBRARY_OUTPUT_DIRECTORY}
|
|
|
|
CYTHON_BUILD_DIR=${CMAKE_CURRENT_BINARY_DIR}
|
2016-06-13 18:17:09 +00:00
|
|
|
CEPH_LIBDIR=${CMAKE_LIBRARY_OUTPUT_DIRECTORY}
|
2019-07-18 01:46:51 +00:00
|
|
|
${Python${python_version}_EXECUTABLE} ${setup_py}
|
2016-07-13 12:57:30 +00:00
|
|
|
build --verbose --build-base ${CYTHON_MODULE_DIR}
|
2019-07-08 11:27:37 +00:00
|
|
|
--build-platlib ${output_dir}
|
2019-07-08 12:15:39 +00:00
|
|
|
MAIN_DEPENDENCY ${src}
|
|
|
|
DEPENDS ${setup_py}
|
2019-07-08 12:06:06 +00:00
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR})
|
|
|
|
add_custom_target(${target} ALL
|
|
|
|
DEPENDS ${output_dir}/${name}${ext_suffix})
|
2016-06-01 05:38:05 +00:00
|
|
|
endfunction(distutils_add_cython_module)
|
|
|
|
|
2019-07-18 01:46:51 +00:00
|
|
|
function(distutils_install_cython_module name python_version)
|
cmake: pass LDSHARED env var to distutils
otherwise, the default gcc will be used, and the $CMAKE_C_COMPILER
passed to the outer CMakeLists.txt won't kick in. moreover, if the
building script (ceph.spec for instance) could set the $PATH, and
expect that the CMakeLists.txt will use the toolchain executables
in the $PATH to build Ceph, distutils will continue using the default
$CC for linking the python bindings, on UNIX it will be gcc in the
new shell's $PATH, because we are using `install(CODE "... execute_process(
...))` for installing the python bindings. apparently, this is not
expected. because the new shell's $PATH is very likely different
from the one changed by the building script. to address this, we
should always specify the `$LDSHARED` env var explicitly.
also, pass env vars using `ENV{}` instead of the `env` command to
workaround the issue of https://cmake.org/pipermail/cmake/2015-December/062216.html,
because it's not straightforward to set environment variables with
spaces in the them using cmake. and because one cannot use add_custom_target()
in the script mode of cmake. this leave me only limited options to
fix this issue.
Signed-off-by: Kefu Chai <kchai@redhat.com>
2017-11-11 17:50:42 +00:00
|
|
|
get_property(compiler_launcher GLOBAL PROPERTY RULE_LAUNCH_COMPILE)
|
|
|
|
get_property(link_launcher GLOBAL PROPERTY RULE_LAUNCH_LINK)
|
|
|
|
set(PY_CC "${compiler_launcher} ${CMAKE_C_COMPILER}")
|
|
|
|
set(PY_LDSHARED "${link_launcher} ${CMAKE_C_COMPILER} -shared")
|
2016-06-01 05:38:05 +00:00
|
|
|
install(CODE "
|
cmake: pass LDSHARED env var to distutils
otherwise, the default gcc will be used, and the $CMAKE_C_COMPILER
passed to the outer CMakeLists.txt won't kick in. moreover, if the
building script (ceph.spec for instance) could set the $PATH, and
expect that the CMakeLists.txt will use the toolchain executables
in the $PATH to build Ceph, distutils will continue using the default
$CC for linking the python bindings, on UNIX it will be gcc in the
new shell's $PATH, because we are using `install(CODE "... execute_process(
...))` for installing the python bindings. apparently, this is not
expected. because the new shell's $PATH is very likely different
from the one changed by the building script. to address this, we
should always specify the `$LDSHARED` env var explicitly.
also, pass env vars using `ENV{}` instead of the `env` command to
workaround the issue of https://cmake.org/pipermail/cmake/2015-December/062216.html,
because it's not straightforward to set environment variables with
spaces in the them using cmake. and because one cannot use add_custom_target()
in the script mode of cmake. this leave me only limited options to
fix this issue.
Signed-off-by: Kefu Chai <kchai@redhat.com>
2017-11-11 17:50:42 +00:00
|
|
|
set(ENV{CC} \"${PY_CC}\")
|
|
|
|
set(ENV{LDSHARED} \"${PY_LDSHARED}\")
|
2019-03-20 07:52:14 +00:00
|
|
|
set(ENV{CPPFLAGS} \"-iquote${CMAKE_SOURCE_DIR}/src/include
|
|
|
|
-D'void0=dead_function\(void\)' \
|
|
|
|
-D'__Pyx_check_single_interpreter\(ARG\)=ARG \#\# 0'\")
|
cmake: pass LDSHARED env var to distutils
otherwise, the default gcc will be used, and the $CMAKE_C_COMPILER
passed to the outer CMakeLists.txt won't kick in. moreover, if the
building script (ceph.spec for instance) could set the $PATH, and
expect that the CMakeLists.txt will use the toolchain executables
in the $PATH to build Ceph, distutils will continue using the default
$CC for linking the python bindings, on UNIX it will be gcc in the
new shell's $PATH, because we are using `install(CODE "... execute_process(
...))` for installing the python bindings. apparently, this is not
expected. because the new shell's $PATH is very likely different
from the one changed by the building script. to address this, we
should always specify the `$LDSHARED` env var explicitly.
also, pass env vars using `ENV{}` instead of the `env` command to
workaround the issue of https://cmake.org/pipermail/cmake/2015-December/062216.html,
because it's not straightforward to set environment variables with
spaces in the them using cmake. and because one cannot use add_custom_target()
in the script mode of cmake. this leave me only limited options to
fix this issue.
Signed-off-by: Kefu Chai <kchai@redhat.com>
2017-11-11 17:50:42 +00:00
|
|
|
set(ENV{LDFLAGS} \"-L${CMAKE_LIBRARY_OUTPUT_DIRECTORY}\")
|
|
|
|
set(ENV{CYTHON_BUILD_DIR} \"${CMAKE_CURRENT_BINARY_DIR}\")
|
|
|
|
set(ENV{CEPH_LIBDIR} \"${CMAKE_LIBRARY_OUTPUT_DIRECTORY}\")
|
|
|
|
|
2016-07-04 03:26:28 +00:00
|
|
|
set(options --prefix=${CMAKE_INSTALL_PREFIX})
|
2016-06-01 05:38:05 +00:00
|
|
|
if(DEFINED ENV{DESTDIR})
|
|
|
|
if(EXISTS /etc/debian_version)
|
2016-07-04 03:26:28 +00:00
|
|
|
list(APPEND options --install-layout=deb)
|
2016-06-01 05:38:05 +00:00
|
|
|
endif()
|
2016-07-04 03:26:28 +00:00
|
|
|
list(APPEND options --root=\$ENV{DESTDIR})
|
2016-06-01 05:38:05 +00:00
|
|
|
else()
|
2016-07-04 03:26:28 +00:00
|
|
|
list(APPEND options --root=/)
|
2016-06-01 05:38:05 +00:00
|
|
|
endif()
|
|
|
|
execute_process(
|
cmake: pass LDSHARED env var to distutils
otherwise, the default gcc will be used, and the $CMAKE_C_COMPILER
passed to the outer CMakeLists.txt won't kick in. moreover, if the
building script (ceph.spec for instance) could set the $PATH, and
expect that the CMakeLists.txt will use the toolchain executables
in the $PATH to build Ceph, distutils will continue using the default
$CC for linking the python bindings, on UNIX it will be gcc in the
new shell's $PATH, because we are using `install(CODE "... execute_process(
...))` for installing the python bindings. apparently, this is not
expected. because the new shell's $PATH is very likely different
from the one changed by the building script. to address this, we
should always specify the `$LDSHARED` env var explicitly.
also, pass env vars using `ENV{}` instead of the `env` command to
workaround the issue of https://cmake.org/pipermail/cmake/2015-December/062216.html,
because it's not straightforward to set environment variables with
spaces in the them using cmake. and because one cannot use add_custom_target()
in the script mode of cmake. this leave me only limited options to
fix this issue.
Signed-off-by: Kefu Chai <kchai@redhat.com>
2017-11-11 17:50:42 +00:00
|
|
|
COMMAND
|
2019-07-18 01:46:51 +00:00
|
|
|
${Python${python_version}_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/setup.py
|
2016-07-13 12:57:30 +00:00
|
|
|
build --verbose --build-base ${CYTHON_MODULE_DIR}
|
2019-07-18 01:46:51 +00:00
|
|
|
--build-platlib ${CYTHON_MODULE_DIR}/lib.${Python${python_version}_VERSION_MAJOR}
|
2016-07-09 04:58:33 +00:00
|
|
|
build_ext --cython-c-in-temp --build-temp ${CMAKE_CURRENT_BINARY_DIR} --cython-include-dirs ${PROJECT_SOURCE_DIR}/src/pybind/rados
|
2016-07-08 06:57:41 +00:00
|
|
|
install \${options} --single-version-externally-managed --record /dev/null
|
|
|
|
egg_info --egg-base ${CMAKE_CURRENT_BINARY_DIR}
|
|
|
|
--verbose
|
2016-06-01 05:38:05 +00:00
|
|
|
WORKING_DIRECTORY \"${CMAKE_CURRENT_SOURCE_DIR}\"
|
|
|
|
RESULT_VARIABLE install_res)
|
|
|
|
if(NOT \"\${install_res}\" STREQUAL 0)
|
|
|
|
message(FATAL_ERROR \"Failed to build and install ${name} python module\")
|
|
|
|
endif()
|
|
|
|
")
|
|
|
|
endfunction(distutils_install_cython_module)
|