CPack/DEB component dependency auto-discovery
Dependency auto-discovery can now be set per component
This commit is contained in:
parent
22a707e861
commit
4588a1697f
|
@ -0,0 +1,6 @@
|
||||||
|
cpack-deb-component-auto-discovery
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
* The :module:`CPackDeb` module learned a new
|
||||||
|
:variable:`CPACK_DEBIAN_<COMPONENT>_PACKAGE_SHLIBDEPS`
|
||||||
|
variable to specify per-component use of ``dpkg-shlibdeps``.
|
|
@ -103,14 +103,21 @@
|
||||||
# characters such as <>.
|
# characters such as <>.
|
||||||
#
|
#
|
||||||
# .. variable:: CPACK_DEBIAN_PACKAGE_SHLIBDEPS
|
# .. variable:: CPACK_DEBIAN_PACKAGE_SHLIBDEPS
|
||||||
#
|
# CPACK_DEBIAN_<COMPONENT>_PACKAGE_SHLIBDEPS
|
||||||
# * Mandatory : NO
|
|
||||||
# * Default : OFF
|
|
||||||
#
|
#
|
||||||
# May be set to ON in order to use dpkg-shlibdeps to generate
|
# May be set to ON in order to use dpkg-shlibdeps to generate
|
||||||
# better package dependency list.
|
# better package dependency list.
|
||||||
# You may need set CMAKE_INSTALL_RPATH toi appropriate value
|
#
|
||||||
# if you use this feature, because if you don't dpkg-shlibdeps
|
# * Mandatory : NO
|
||||||
|
# * Default :
|
||||||
|
#
|
||||||
|
# - :variable:`CPACK_DEBIAN_PACKAGE_SHLIBDEPS` if set or
|
||||||
|
# - OFF
|
||||||
|
#
|
||||||
|
# .. note::
|
||||||
|
#
|
||||||
|
# You may need set :variable:`CMAKE_INSTALL_RPATH` to an appropriate value
|
||||||
|
# if you use this feature, because if you don't :code:`dpkg-shlibdeps`
|
||||||
# may fail to find your own shared libs.
|
# may fail to find your own shared libs.
|
||||||
# See http://www.cmake.org/Wiki/CMake_RPATH_handling.
|
# See http://www.cmake.org/Wiki/CMake_RPATH_handling.
|
||||||
#
|
#
|
||||||
|
@ -245,42 +252,71 @@ function(cpack_deb_prepare_package_vars)
|
||||||
set(CPACK_DEBIAN_FAKEROOT_EXECUTABLE ${FAKEROOT_EXECUTABLE})
|
set(CPACK_DEBIAN_FAKEROOT_EXECUTABLE ${FAKEROOT_EXECUTABLE})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
set(WDIR "${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}${CPACK_DEB_PACKAGE_COMPONENT_PART_PATH}")
|
||||||
|
|
||||||
|
# per component automatic discover: some of the component might not have
|
||||||
|
# binaries.
|
||||||
|
if(CPACK_DEB_PACKAGE_COMPONENT)
|
||||||
|
string(TOUPPER "${CPACK_DEB_PACKAGE_COMPONENT}" _local_component_name)
|
||||||
|
set(_component_shlibdeps_var "CPACK_DEBIAN_${_local_component_name}_PACKAGE_SHLIBDEPS")
|
||||||
|
|
||||||
|
# if set, overrides the global configuration
|
||||||
|
if(DEFINED ${_component_shlibdeps_var})
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS "${${_component_shlibdeps_var}}")
|
||||||
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
|
message("CPackDeb Debug: component '${CPACK_DEB_PACKAGE_COMPONENT}' dpkg-shlibdeps set to ${CPACK_DEBIAN_PACKAGE_SHLIBDEPS}")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CPACK_DEBIAN_PACKAGE_SHLIBDEPS)
|
if(CPACK_DEBIAN_PACKAGE_SHLIBDEPS)
|
||||||
# dpkg-shlibdeps is a Debian utility for generating dependency list
|
# dpkg-shlibdeps is a Debian utility for generating dependency list
|
||||||
find_program(SHLIBDEPS_EXECUTABLE dpkg-shlibdeps)
|
find_program(SHLIBDEPS_EXECUTABLE dpkg-shlibdeps)
|
||||||
|
|
||||||
# Check version of the dpkg-shlibdeps tool using CPackRPM method
|
|
||||||
if(SHLIBDEPS_EXECUTABLE)
|
if(SHLIBDEPS_EXECUTABLE)
|
||||||
|
# Check version of the dpkg-shlibdeps tool using CPackRPM method
|
||||||
execute_process(COMMAND env LC_ALL=C ${SHLIBDEPS_EXECUTABLE} --version
|
execute_process(COMMAND env LC_ALL=C ${SHLIBDEPS_EXECUTABLE} --version
|
||||||
OUTPUT_VARIABLE _TMP_VERSION
|
OUTPUT_VARIABLE _TMP_VERSION
|
||||||
ERROR_QUIET
|
ERROR_QUIET
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||||
string(REGEX MATCH "dpkg-shlibdeps version ([0-9]+\\.[0-9]+\\.[0-9]+)"
|
string(REGEX MATCH "dpkg-shlibdeps version ([0-9]+\\.[0-9]+\\.[0-9]+)"
|
||||||
SHLIBDEPS_EXECUTABLE_VERSION
|
SHLIBDEPS_EXECUTABLE_VERSION
|
||||||
${_TMP_VERSION})
|
"${_TMP_VERSION}")
|
||||||
set(SHLIBDEPS_EXECUTABLE_VERSION "${CMAKE_MATCH_1}")
|
set(SHLIBDEPS_EXECUTABLE_VERSION "${CMAKE_MATCH_1}")
|
||||||
|
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
|
message("CPackDeb Debug: dpkg-shlibdeps --version output is '${_TMP_VERSION}'")
|
||||||
message("CPackDeb Debug: dpkg-shlibdeps version is <${SHLIBDEPS_EXECUTABLE_VERSION}>")
|
message("CPackDeb Debug: dpkg-shlibdeps version is <${SHLIBDEPS_EXECUTABLE_VERSION}>")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Generating binary list - Get type of all install files
|
# Generating binary list - Get type of all install files
|
||||||
execute_process(COMMAND find -type f
|
cmake_policy(PUSH)
|
||||||
COMMAND xargs file
|
# Tell file(GLOB_RECURSE) not to follow directory symlinks
|
||||||
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
# even if the project does not set this policy to NEW.
|
||||||
OUTPUT_VARIABLE CPACK_DEB_INSTALL_FILES)
|
cmake_policy(SET CMP0009 NEW)
|
||||||
|
file(GLOB_RECURSE FILE_PATHS_ LIST_DIRECTORIES false RELATIVE "${WDIR}" "${WDIR}/*")
|
||||||
|
cmake_policy(POP)
|
||||||
|
|
||||||
# Convert to CMake list
|
# get file info so that we can determine if file is executable or not
|
||||||
string(REPLACE "\n" ";" CPACK_DEB_INSTALL_FILES ${CPACK_DEB_INSTALL_FILES})
|
unset(CPACK_DEB_INSTALL_FILES)
|
||||||
|
foreach(FILE_ IN LISTS FILE_PATHS_)
|
||||||
|
execute_process(COMMAND file "./${FILE_}"
|
||||||
|
WORKING_DIRECTORY "${WDIR}"
|
||||||
|
OUTPUT_VARIABLE INSTALL_FILE_)
|
||||||
|
list(APPEND CPACK_DEB_INSTALL_FILES "${INSTALL_FILE_}")
|
||||||
|
endforeach()
|
||||||
|
|
||||||
# Only dynamically linked ELF files are included
|
# Only dynamically linked ELF files are included
|
||||||
# Extract only file name infront of ":"
|
# Extract only file name infront of ":"
|
||||||
foreach(_FILE ${CPACK_DEB_INSTALL_FILES})
|
foreach(_FILE ${CPACK_DEB_INSTALL_FILES})
|
||||||
if( ${_FILE} MATCHES "ELF.*dynamically linked")
|
if( ${_FILE} MATCHES "ELF.*dynamically linked")
|
||||||
string(REGEX MATCH "(^.*):" _FILE_NAME ${_FILE})
|
string(REGEX MATCH "(^.*):" _FILE_NAME "${_FILE}")
|
||||||
list(APPEND CPACK_DEB_BINARY_FILES ${CMAKE_MATCH_1})
|
list(APPEND CPACK_DEB_BINARY_FILES "${CMAKE_MATCH_1}")
|
||||||
|
set(CONTAINS_EXECUTABLE_FILES_ TRUE)
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
|
if(CONTAINS_EXECUTABLE_FILES_)
|
||||||
message("CPackDeb: - Generating dependency list")
|
message("CPackDeb: - Generating dependency list")
|
||||||
|
|
||||||
# Create blank control file for running dpkg-shlibdeps
|
# Create blank control file for running dpkg-shlibdeps
|
||||||
|
@ -289,10 +325,16 @@ function(cpack_deb_prepare_package_vars)
|
||||||
file(MAKE_DIRECTORY ${CPACK_TEMPORARY_DIRECTORY}/debian)
|
file(MAKE_DIRECTORY ${CPACK_TEMPORARY_DIRECTORY}/debian)
|
||||||
file(WRITE ${CPACK_TEMPORARY_DIRECTORY}/debian/control "")
|
file(WRITE ${CPACK_TEMPORARY_DIRECTORY}/debian/control "")
|
||||||
|
|
||||||
|
# only set ignore-missing-info flag for dpkg-shlibdeps that have --version option
|
||||||
|
# (those are newer and also have --ignore-missing-info flag)
|
||||||
|
if(SHLIBDEPS_EXECUTABLE_VERSION)
|
||||||
|
set(IGNORE_MISSING_INFO_FLAG "--ignore-missing-info")
|
||||||
|
endif()
|
||||||
|
|
||||||
# Execute dpkg-shlibdeps
|
# Execute dpkg-shlibdeps
|
||||||
# --ignore-missing-info : allow dpkg-shlibdeps to run even if some libs do not belong to a package
|
# --ignore-missing-info : allow dpkg-shlibdeps to run even if some libs do not belong to a package
|
||||||
# -O : print to STDOUT
|
# -O : print to STDOUT
|
||||||
execute_process(COMMAND ${SHLIBDEPS_EXECUTABLE} --ignore-missing-info -O ${CPACK_DEB_BINARY_FILES}
|
execute_process(COMMAND ${SHLIBDEPS_EXECUTABLE} ${IGNORE_MISSING_INFO_FLAG} -O ${CPACK_DEB_BINARY_FILES}
|
||||||
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
||||||
OUTPUT_VARIABLE SHLIBDEPS_OUTPUT
|
OUTPUT_VARIABLE SHLIBDEPS_OUTPUT
|
||||||
RESULT_VARIABLE SHLIBDEPS_RESULT
|
RESULT_VARIABLE SHLIBDEPS_RESULT
|
||||||
|
@ -303,11 +345,15 @@ function(cpack_deb_prepare_package_vars)
|
||||||
message( "CPackDeb Debug: dpkg-shlibdeps warnings \n${SHLIBDEPS_ERROR}")
|
message( "CPackDeb Debug: dpkg-shlibdeps warnings \n${SHLIBDEPS_ERROR}")
|
||||||
endif()
|
endif()
|
||||||
if(NOT SHLIBDEPS_RESULT EQUAL 0)
|
if(NOT SHLIBDEPS_RESULT EQUAL 0)
|
||||||
message (FATAL_ERROR "CPackDeb: dpkg-shlibdeps: ${SHLIBDEPS_ERROR}")
|
message (FATAL_ERROR "CPackDeb: dpkg-shlibdeps: '${SHLIBDEPS_ERROR}';\n"
|
||||||
|
"executed command: '${SHLIBDEPS_EXECUTABLE} ${IGNORE_MISSING_INFO_FLAG} -O ${CPACK_DEB_BINARY_FILES}';\n"
|
||||||
|
"found files: '${INSTALL_FILE_}';\n"
|
||||||
|
"files info: '${CPACK_DEB_INSTALL_FILES}';\n"
|
||||||
|
"binary files: '${CPACK_DEB_BINARY_FILES}'")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
#Get rid of prefix generated by dpkg-shlibdeps
|
#Get rid of prefix generated by dpkg-shlibdeps
|
||||||
string (REGEX REPLACE "^.*Depends=" "" CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS ${SHLIBDEPS_OUTPUT})
|
string(REGEX REPLACE "^.*Depends=" "" CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS "${SHLIBDEPS_OUTPUT}")
|
||||||
|
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
message( "CPackDeb Debug: Found dependency: ${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
message( "CPackDeb Debug: Found dependency: ${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
||||||
|
@ -323,7 +369,11 @@ function(cpack_deb_prepare_package_vars)
|
||||||
else()
|
else()
|
||||||
set(CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
set(CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
||||||
endif()
|
endif()
|
||||||
|
else()
|
||||||
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
|
message( "CPackDeb Debug: Using only user-provided depends because package does not contain executable files that contain dynamically linked libraries.")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
message( "CPackDeb Debug: Using only user-provided depends because dpkg-shlibdeps is not found.")
|
message( "CPackDeb Debug: Using only user-provided depends because dpkg-shlibdeps is not found.")
|
||||||
|
@ -452,8 +502,6 @@ function(cpack_deb_prepare_package_vars)
|
||||||
set(CPACK_DEB_PACKAGE_COMPONENT_PART_NAME "")
|
set(CPACK_DEB_PACKAGE_COMPONENT_PART_NAME "")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(WDIR "${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}${CPACK_DEB_PACKAGE_COMPONENT_PART_PATH}")
|
|
||||||
|
|
||||||
# Print out some debug information if we were asked for that
|
# Print out some debug information if we were asked for that
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
message("CPackDeb:Debug: CPACK_TOPLEVEL_DIRECTORY = ${CPACK_TOPLEVEL_DIRECTORY}")
|
message("CPackDeb:Debug: CPACK_TOPLEVEL_DIRECTORY = ${CPACK_TOPLEVEL_DIRECTORY}")
|
||||||
|
|
|
@ -1010,7 +1010,8 @@ ${CMake_BINARY_DIR}/bin/cmake -DDIR=dev -P ${CMake_SOURCE_DIR}/Utilities/Release
|
||||||
set(DEB_TEST_NAMES "CPackComponentsDEB")
|
set(DEB_TEST_NAMES "CPackComponentsDEB")
|
||||||
set(DEB_CONFIGURATIONS_TO_TEST "components-lintian-dpkgdeb-checks"
|
set(DEB_CONFIGURATIONS_TO_TEST "components-lintian-dpkgdeb-checks"
|
||||||
"components-description1"
|
"components-description1"
|
||||||
"components-description2")
|
"components-description2"
|
||||||
|
"components-shlibdeps1")
|
||||||
set(CPackGen "DEB")
|
set(CPackGen "DEB")
|
||||||
set(CPackRun_CPackGen "-DCPackGen=${CPackGen}")
|
set(CPackRun_CPackGen "-DCPackGen=${CPackGen}")
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,24 @@
|
||||||
|
#
|
||||||
|
# Activate component packaging
|
||||||
|
#
|
||||||
|
|
||||||
|
if(CPACK_GENERATOR MATCHES "DEB")
|
||||||
|
set(CPACK_DEB_COMPONENT_INSTALL "ON")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
#
|
||||||
|
# Choose grouping way
|
||||||
|
#
|
||||||
|
#set(CPACK_COMPONENTS_ALL_GROUPS_IN_ONE_PACKAGE)
|
||||||
|
#set(CPACK_COMPONENTS_GROUPING)
|
||||||
|
set(CPACK_COMPONENTS_IGNORE_GROUPS 1)
|
||||||
|
#set(CPACK_COMPONENTS_ALL_IN_ONE_PACKAGE 1)
|
||||||
|
|
||||||
|
# we set shlibdeps to on
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS ON)
|
||||||
|
# except for the component "headers" that do not contain any binary.
|
||||||
|
# the packaging will just fail if this does not work
|
||||||
|
set(CPACK_DEBIAN_HEADERS_PACKAGE_SHLIBDEPS OFF)
|
||||||
|
|
||||||
|
# Also libraries contains only a static library.
|
||||||
|
set(CPACK_DEBIAN_LIBRARIES_PACKAGE_SHLIBDEPS OFF)
|
|
@ -0,0 +1,75 @@
|
||||||
|
if(NOT CPackComponentsDEB_SOURCE_DIR)
|
||||||
|
message(FATAL_ERROR "CPackComponentsDEB_SOURCE_DIR not set")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include(${CPackComponentsDEB_SOURCE_DIR}/RunCPackVerifyResult.cmake)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# requirements
|
||||||
|
|
||||||
|
# debian now produces lower case names
|
||||||
|
set(expected_file_mask "${CPackComponentsDEB_BINARY_DIR}/MyLib-*.deb")
|
||||||
|
set(expected_count 3)
|
||||||
|
|
||||||
|
|
||||||
|
set(actual_output)
|
||||||
|
run_cpack(actual_output
|
||||||
|
CPack_output
|
||||||
|
CPack_error
|
||||||
|
EXPECTED_FILE_MASK "${expected_file_mask}"
|
||||||
|
CONFIG_ARGS ${config_args}
|
||||||
|
CONFIG_VERBOSE ${config_verbose})
|
||||||
|
|
||||||
|
message(STATUS "expected_count='${expected_count}'")
|
||||||
|
message(STATUS "expected_file_mask='${expected_file_mask}'")
|
||||||
|
message(STATUS "actual_output_files='${actual_output}'")
|
||||||
|
|
||||||
|
if(NOT actual_output)
|
||||||
|
message(FATAL_ERROR "error: expected_files do not exist: CPackComponentsDEB test fails. (CPack_output=${CPack_output}, CPack_error=${CPack_error}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
list(LENGTH actual_output actual_count)
|
||||||
|
message(STATUS "actual_count='${actual_count}'")
|
||||||
|
if(NOT actual_count EQUAL expected_count)
|
||||||
|
message(FATAL_ERROR "error: expected_count=${expected_count} does not match actual_count=${actual_count}: CPackComponents test fails. (CPack_output=${CPack_output}, CPack_error=${CPack_error})")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
# dpkg-deb checks for the summary of the packages
|
||||||
|
find_program(DPKGDEB_EXECUTABLE dpkg-deb)
|
||||||
|
if(DPKGDEB_EXECUTABLE)
|
||||||
|
set(dpkgdeb_output_errors_all)
|
||||||
|
foreach(_f IN LISTS actual_output)
|
||||||
|
|
||||||
|
# extracts the metadata from the package
|
||||||
|
run_dpkgdeb(dpkg_output
|
||||||
|
FILENAME ${_f}
|
||||||
|
)
|
||||||
|
|
||||||
|
dpkgdeb_return_specific_metaentry(dpkg_package_name
|
||||||
|
DPKGDEB_OUTPUT "${dpkg_output}"
|
||||||
|
METAENTRY "Package:")
|
||||||
|
|
||||||
|
message(STATUS "package='${dpkg_package_name}'")
|
||||||
|
|
||||||
|
if("${dpkg_package_name}" STREQUAL "mylib-applications")
|
||||||
|
# pass
|
||||||
|
elseif("${dpkg_package_name}" STREQUAL "mylib-headers")
|
||||||
|
# pass
|
||||||
|
elseif("${dpkg_package_name}" STREQUAL "mylib-libraries")
|
||||||
|
# pass
|
||||||
|
else()
|
||||||
|
set(dpkgdeb_output_errors_all ${dpkgdeb_output_errors_all}
|
||||||
|
"dpkg-deb: ${_f}: component name not found: ${dpkg_package_name}\n")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
|
||||||
|
if(NOT "${dpkgdeb_output_errors_all}" STREQUAL "")
|
||||||
|
message(FATAL_ERROR "dpkg-deb checks failed:\n${dpkgdeb_output_errors_all}")
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
message("dpkg-deb executable not found - skipping dpkg-deb test")
|
||||||
|
endif()
|
Loading…
Reference in New Issue