Merge topic 'cpack-deb-component-vars-prepare'
c8375e15
CPackDeb: Refactor package variable lookup by generator
This commit is contained in:
commit
0d852d4c65
|
@ -223,233 +223,260 @@ if(NOT UNIX)
|
||||||
message(FATAL_ERROR "CPackDeb.cmake may only be used under UNIX.")
|
message(FATAL_ERROR "CPackDeb.cmake may only be used under UNIX.")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# CPACK_DEBIAN_PACKAGE_SHLIBDEPS
|
function(cpack_deb_prepare_package_vars)
|
||||||
# If specify OFF, only user depends are used
|
# CPACK_DEBIAN_PACKAGE_SHLIBDEPS
|
||||||
if(NOT DEFINED CPACK_DEBIAN_PACKAGE_SHLIBDEPS)
|
# If specify OFF, only user depends are used
|
||||||
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS OFF)
|
if(NOT DEFINED CPACK_DEBIAN_PACKAGE_SHLIBDEPS)
|
||||||
endif()
|
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
find_program(FAKEROOT_EXECUTABLE fakeroot)
|
find_program(FAKEROOT_EXECUTABLE fakeroot)
|
||||||
if(FAKEROOT_EXECUTABLE)
|
if(FAKEROOT_EXECUTABLE)
|
||||||
set(CPACK_DEBIAN_FAKEROOT_EXECUTABLE ${FAKEROOT_EXECUTABLE})
|
set(CPACK_DEBIAN_FAKEROOT_EXECUTABLE ${FAKEROOT_EXECUTABLE})
|
||||||
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
|
# Check version of the dpkg-shlibdeps tool using CPackRPM method
|
||||||
if(SHLIBDEPS_EXECUTABLE)
|
if(SHLIBDEPS_EXECUTABLE)
|
||||||
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 is <${SHLIBDEPS_EXECUTABLE_VERSION}>")
|
message( "CPackDeb Debug: dpkg-shlibdeps version is <${SHLIBDEPS_EXECUTABLE_VERSION}>")
|
||||||
endif()
|
|
||||||
|
|
||||||
# Generating binary list - Get type of all install files
|
|
||||||
execute_process(COMMAND find -type f
|
|
||||||
COMMAND xargs file
|
|
||||||
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
|
||||||
OUTPUT_VARIABLE CPACK_DEB_INSTALL_FILES)
|
|
||||||
|
|
||||||
# Convert to CMake list
|
|
||||||
string(REPLACE "\n" ";" CPACK_DEB_INSTALL_FILES ${CPACK_DEB_INSTALL_FILES})
|
|
||||||
|
|
||||||
# Only dynamically linked ELF files are included
|
|
||||||
# Extract only file name infront of ":"
|
|
||||||
foreach ( _FILE ${CPACK_DEB_INSTALL_FILES})
|
|
||||||
if ( ${_FILE} MATCHES "ELF.*dynamically linked")
|
|
||||||
string(REGEX MATCH "(^.*):" _FILE_NAME ${_FILE})
|
|
||||||
list(APPEND CPACK_DEB_BINARY_FILES ${CMAKE_MATCH_1})
|
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
|
||||||
|
|
||||||
message( "CPackDeb: - Generating dependency list")
|
# Generating binary list - Get type of all install files
|
||||||
|
execute_process(COMMAND find -type f
|
||||||
|
COMMAND xargs file
|
||||||
|
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
||||||
|
OUTPUT_VARIABLE CPACK_DEB_INSTALL_FILES)
|
||||||
|
|
||||||
# Create blank control file for running dpkg-shlibdeps
|
# Convert to CMake list
|
||||||
# There might be some other way to invoke dpkg-shlibdeps without creating this file
|
string(REPLACE "\n" ";" CPACK_DEB_INSTALL_FILES ${CPACK_DEB_INSTALL_FILES})
|
||||||
# but standard debian package should not have anything that can collide with this file or directory
|
|
||||||
file(MAKE_DIRECTORY ${CPACK_TEMPORARY_DIRECTORY}/debian)
|
|
||||||
file(WRITE ${CPACK_TEMPORARY_DIRECTORY}/debian/control "")
|
|
||||||
|
|
||||||
# Execute dpkg-shlibdeps
|
# Only dynamically linked ELF files are included
|
||||||
# --ignore-missing-info : allow dpkg-shlibdeps to run even if some libs do not belong to a package
|
# Extract only file name infront of ":"
|
||||||
# -O : print to STDOUT
|
foreach ( _FILE ${CPACK_DEB_INSTALL_FILES})
|
||||||
execute_process(COMMAND ${SHLIBDEPS_EXECUTABLE} --ignore-missing-info -O ${CPACK_DEB_BINARY_FILES}
|
if ( ${_FILE} MATCHES "ELF.*dynamically linked")
|
||||||
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
string(REGEX MATCH "(^.*):" _FILE_NAME ${_FILE})
|
||||||
OUTPUT_VARIABLE SHLIBDEPS_OUTPUT
|
list(APPEND CPACK_DEB_BINARY_FILES ${CMAKE_MATCH_1})
|
||||||
RESULT_VARIABLE SHLIBDEPS_RESULT
|
endif()
|
||||||
ERROR_VARIABLE SHLIBDEPS_ERROR
|
endforeach()
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE )
|
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
|
||||||
# dpkg-shlibdeps will throw some warnings if some input files are not binary
|
|
||||||
message( "CPackDeb Debug: dpkg-shlibdeps warnings \n${SHLIBDEPS_ERROR}")
|
|
||||||
endif()
|
|
||||||
if (NOT SHLIBDEPS_RESULT EQUAL 0)
|
|
||||||
message (FATAL_ERROR "CPackDeb: dpkg-shlibdeps: ${SHLIBDEPS_ERROR}")
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
#Get rid of prefix generated by dpkg-shlibdeps
|
message( "CPackDeb: - Generating dependency list")
|
||||||
string (REGEX REPLACE "^.*Depends=" "" CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS ${SHLIBDEPS_OUTPUT})
|
|
||||||
|
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
# Create blank control file for running dpkg-shlibdeps
|
||||||
message( "CPackDeb Debug: Found dependency: ${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
# There might be some other way to invoke dpkg-shlibdeps without creating this file
|
||||||
endif()
|
# but standard debian package should not have anything that can collide with this file or directory
|
||||||
|
file(MAKE_DIRECTORY ${CPACK_TEMPORARY_DIRECTORY}/debian)
|
||||||
|
file(WRITE ${CPACK_TEMPORARY_DIRECTORY}/debian/control "")
|
||||||
|
|
||||||
# Remove blank control file
|
# Execute dpkg-shlibdeps
|
||||||
# Might not be safe if package actual contain file or directory named debian
|
# --ignore-missing-info : allow dpkg-shlibdeps to run even if some libs do not belong to a package
|
||||||
file(REMOVE_RECURSE "${CPACK_TEMPORARY_DIRECTORY}/debian")
|
# -O : print to STDOUT
|
||||||
|
execute_process(COMMAND ${SHLIBDEPS_EXECUTABLE} --ignore-missing-info -O ${CPACK_DEB_BINARY_FILES}
|
||||||
|
WORKING_DIRECTORY "${CPACK_TEMPORARY_DIRECTORY}"
|
||||||
|
OUTPUT_VARIABLE SHLIBDEPS_OUTPUT
|
||||||
|
RESULT_VARIABLE SHLIBDEPS_RESULT
|
||||||
|
ERROR_VARIABLE SHLIBDEPS_ERROR
|
||||||
|
OUTPUT_STRIP_TRAILING_WHITESPACE )
|
||||||
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
|
# dpkg-shlibdeps will throw some warnings if some input files are not binary
|
||||||
|
message( "CPackDeb Debug: dpkg-shlibdeps warnings \n${SHLIBDEPS_ERROR}")
|
||||||
|
endif()
|
||||||
|
if (NOT SHLIBDEPS_RESULT EQUAL 0)
|
||||||
|
message (FATAL_ERROR "CPackDeb: dpkg-shlibdeps: ${SHLIBDEPS_ERROR}")
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
#Get rid of prefix generated by dpkg-shlibdeps
|
||||||
|
string (REGEX REPLACE "^.*Depends=" "" CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS ${SHLIBDEPS_OUTPUT})
|
||||||
|
|
||||||
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
|
message( "CPackDeb Debug: Found dependency: ${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Remove blank control file
|
||||||
|
# Might not be safe if package actual contain file or directory named debian
|
||||||
|
file(REMOVE_RECURSE "${CPACK_TEMPORARY_DIRECTORY}/debian")
|
||||||
|
|
||||||
|
# Append user depend if set
|
||||||
|
if (CPACK_DEBIAN_PACKAGE_DEPENDS)
|
||||||
|
set (CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}, ${CPACK_DEBIAN_PACKAGE_DEPENDS}")
|
||||||
|
else ()
|
||||||
|
set (CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
||||||
|
endif ()
|
||||||
|
|
||||||
# Append user depend if set
|
|
||||||
if (CPACK_DEBIAN_PACKAGE_DEPENDS)
|
|
||||||
set (CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}, ${CPACK_DEBIAN_PACKAGE_DEPENDS}")
|
|
||||||
else ()
|
else ()
|
||||||
set (CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_AUTO_DEPENDS}")
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
endif ()
|
message( "CPackDeb Debug: Using only user-provided depends because dpkg-shlibdeps is not found.")
|
||||||
|
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")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
else ()
|
# Let's define the control file found in debian package:
|
||||||
|
|
||||||
|
# Binary package:
|
||||||
|
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-binarycontrolfiles
|
||||||
|
|
||||||
|
# DEBIAN/control
|
||||||
|
# debian policy enforce lower case for package name
|
||||||
|
# Package: (mandatory)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_NAME)
|
||||||
|
string(TOLOWER "${CPACK_PACKAGE_NAME}" CPACK_DEBIAN_PACKAGE_NAME)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Version: (mandatory)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_VERSION)
|
||||||
|
if(NOT CPACK_PACKAGE_VERSION)
|
||||||
|
message(FATAL_ERROR "CPackDeb: Debian package requires a package version")
|
||||||
|
endif()
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_VERSION ${CPACK_PACKAGE_VERSION})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Architecture: (mandatory)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_ARCHITECTURE)
|
||||||
|
# There is no such thing as i686 architecture on debian, you should use i386 instead
|
||||||
|
# $ dpkg --print-architecture
|
||||||
|
find_program(DPKG_CMD dpkg)
|
||||||
|
if(NOT DPKG_CMD)
|
||||||
|
message(STATUS "CPackDeb: Can not find dpkg in your path, default to i386.")
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_ARCHITECTURE i386)
|
||||||
|
endif()
|
||||||
|
execute_process(COMMAND "${DPKG_CMD}" --print-architecture
|
||||||
|
OUTPUT_VARIABLE CPACK_DEBIAN_PACKAGE_ARCHITECTURE
|
||||||
|
OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# have a look at get_property(result GLOBAL PROPERTY ENABLED_FEATURES),
|
||||||
|
# this returns the successful find_package() calls, maybe this can help
|
||||||
|
# Depends:
|
||||||
|
# You should set: DEBIAN_PACKAGE_DEPENDS
|
||||||
|
# TODO: automate 'objdump -p | grep NEEDED'
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_DEPENDS)
|
||||||
|
message(STATUS "CPACK_DEBIAN_PACKAGE_DEPENDS not set, the package will have no dependencies.")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Maintainer: (mandatory)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_MAINTAINER)
|
||||||
|
if(NOT CPACK_PACKAGE_CONTACT)
|
||||||
|
message(FATAL_ERROR "CPackDeb: Debian package requires a maintainer for a package, set CPACK_PACKAGE_CONTACT or CPACK_DEBIAN_PACKAGE_MAINTAINER")
|
||||||
|
endif()
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_MAINTAINER ${CPACK_PACKAGE_CONTACT})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Description: (mandatory)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_DESCRIPTION)
|
||||||
|
if(NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY)
|
||||||
|
message(FATAL_ERROR "CPackDeb: Debian package requires a summary for a package, set CPACK_PACKAGE_DESCRIPTION_SUMMARY or CPACK_DEBIAN_PACKAGE_DESCRIPTION")
|
||||||
|
endif()
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_DESCRIPTION ${CPACK_PACKAGE_DESCRIPTION_SUMMARY})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Section: (recommended)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_SECTION)
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_SECTION "devel")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Priority: (recommended)
|
||||||
|
if(NOT CPACK_DEBIAN_PACKAGE_PRIORITY)
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_PRIORITY "optional")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Compression: (recommended)
|
||||||
|
if(NOT CPACK_DEBIAN_COMPRESSION_TYPE)
|
||||||
|
set(CPACK_DEBIAN_COMPRESSION_TYPE "gzip")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
|
||||||
|
# Recommends:
|
||||||
|
# You should set: CPACK_DEBIAN_PACKAGE_RECOMMENDS
|
||||||
|
|
||||||
|
# Suggests:
|
||||||
|
# You should set: CPACK_DEBIAN_PACKAGE_SUGGESTS
|
||||||
|
|
||||||
|
# CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA
|
||||||
|
# This variable allow advanced user to add custom script to the control.tar.gz (inside the .deb archive)
|
||||||
|
# Typical examples are:
|
||||||
|
# - conffiles
|
||||||
|
# - postinst
|
||||||
|
# - postrm
|
||||||
|
# - prerm"
|
||||||
|
# Usage:
|
||||||
|
# set(CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA
|
||||||
|
# "${CMAKE_CURRENT_SOURCE_DIR/prerm;${CMAKE_CURRENT_SOURCE_DIR}/postrm")
|
||||||
|
|
||||||
|
# Are we packaging components ?
|
||||||
|
if(CPACK_DEB_PACKAGE_COMPONENT)
|
||||||
|
set(CPACK_DEB_PACKAGE_COMPONENT_PART_NAME "-${CPACK_DEB_PACKAGE_COMPONENT}")
|
||||||
|
string(TOLOWER "${CPACK_PACKAGE_NAME}${CPACK_DEB_PACKAGE_COMPONENT_PART_NAME}" CPACK_DEBIAN_PACKAGE_NAME)
|
||||||
|
else()
|
||||||
|
set(CPACK_DEB_PACKAGE_COMPONENT_PART_NAME "")
|
||||||
|
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
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
||||||
message( "CPackDeb Debug: Using only user-provided depends")
|
message("CPackDeb:Debug: CPACK_TOPLEVEL_DIRECTORY = ${CPACK_TOPLEVEL_DIRECTORY}")
|
||||||
|
message("CPackDeb:Debug: CPACK_TOPLEVEL_TAG = ${CPACK_TOPLEVEL_TAG}")
|
||||||
|
message("CPackDeb:Debug: CPACK_TEMPORARY_DIRECTORY = ${CPACK_TEMPORARY_DIRECTORY}")
|
||||||
|
message("CPackDeb:Debug: CPACK_OUTPUT_FILE_NAME = ${CPACK_OUTPUT_FILE_NAME}")
|
||||||
|
message("CPackDeb:Debug: CPACK_OUTPUT_FILE_PATH = ${CPACK_OUTPUT_FILE_PATH}")
|
||||||
|
message("CPackDeb:Debug: CPACK_PACKAGE_FILE_NAME = ${CPACK_PACKAGE_FILE_NAME}")
|
||||||
|
message("CPackDeb:Debug: CPACK_PACKAGE_INSTALL_DIRECTORY = ${CPACK_PACKAGE_INSTALL_DIRECTORY}")
|
||||||
|
message("CPackDeb:Debug: CPACK_TEMPORARY_PACKAGE_FILE_NAME = ${CPACK_TEMPORARY_PACKAGE_FILE_NAME}")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
|
||||||
|
|
||||||
# Let's define the control file found in debian package:
|
# For debian source packages:
|
||||||
|
# debian/control
|
||||||
|
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-sourcecontrolfiles
|
||||||
|
|
||||||
# Binary package:
|
# .dsc
|
||||||
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-binarycontrolfiles
|
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-debiansourcecontrolfiles
|
||||||
|
|
||||||
# DEBIAN/control
|
# Builds-Depends:
|
||||||
# debian policy enforce lower case for package name
|
#if(NOT CPACK_DEBIAN_PACKAGE_BUILDS_DEPENDS)
|
||||||
# Package: (mandatory)
|
# set(CPACK_DEBIAN_PACKAGE_BUILDS_DEPENDS
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_NAME)
|
# "debhelper (>> 5.0.0), libncurses5-dev, tcl8.4"
|
||||||
string(TOLOWER "${CPACK_PACKAGE_NAME}" CPACK_DEBIAN_PACKAGE_NAME)
|
# )
|
||||||
endif()
|
#endif()
|
||||||
|
|
||||||
# Version: (mandatory)
|
# move variables to parent scope so that they may be used to create debian package
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_VERSION)
|
set(GEN_CPACK_DEBIAN_PACKAGE_NAME "${CPACK_DEBIAN_PACKAGE_NAME}" PARENT_SCOPE)
|
||||||
if(NOT CPACK_PACKAGE_VERSION)
|
set(GEN_CPACK_DEBIAN_PACKAGE_VERSION "${CPACK_DEBIAN_PACKAGE_VERSION}" PARENT_SCOPE)
|
||||||
message(FATAL_ERROR "CPackDeb: Debian package requires a package version")
|
set(GEN_CPACK_DEBIAN_PACKAGE_SECTION "${CPACK_DEBIAN_PACKAGE_SECTION}" PARENT_SCOPE)
|
||||||
endif()
|
set(GEN_CPACK_DEBIAN_PACKAGE_PRIORITY "${CPACK_DEBIAN_PACKAGE_PRIORITY}" PARENT_SCOPE)
|
||||||
set(CPACK_DEBIAN_PACKAGE_VERSION ${CPACK_PACKAGE_VERSION})
|
set(GEN_CPACK_DEBIAN_PACKAGE_ARCHITECTURE "${CPACK_DEBIAN_PACKAGE_ARCHITECTURE}" PARENT_SCOPE)
|
||||||
endif()
|
set(GEN_CPACK_DEBIAN_PACKAGE_MAINTAINER "${CPACK_DEBIAN_PACKAGE_MAINTAINER}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_DESCRIPTION "${CPACK_DEBIAN_PACKAGE_DESCRIPTION}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_DEPENDS "${CPACK_DEBIAN_PACKAGE_DEPENDS}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_FAKEROOT_EXECUTABLE "${CPACK_DEBIAN_FAKEROOT_EXECUTABLE}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_COMPRESSION_TYPE "${CPACK_DEBIAN_COMPRESSION_TYPE}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_RECOMMENDS "${CPACK_DEBIAN_PACKAGE_RECOMMENDS}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_SUGGESTS "${CPACK_DEBIAN_PACKAGE_SUGGESTS}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_HOMEPAGE "${CPACK_DEBIAN_PACKAGE_HOMEPAGE}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_PREDEPENDS "${CPACK_DEBIAN_PACKAGE_PREDEPENDS}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_ENHANCES "${CPACK_DEBIAN_PACKAGE_ENHANCES}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_BREAKS "${CPACK_DEBIAN_PACKAGE_BREAKS}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_CONFLICTS "${CPACK_DEBIAN_PACKAGE_CONFLICTS}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_PROVIDES "${CPACK_DEBIAN_PACKAGE_PROVIDES}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_REPLACES "${CPACK_DEBIAN_PACKAGE_REPLACES}" PARENT_SCOPE)
|
||||||
|
set(GEN_CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA "${CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA}" PARENT_SCOPE)
|
||||||
|
set(GEN_WDIR "${WDIR}" PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
# Architecture: (mandatory)
|
cpack_deb_prepare_package_vars()
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_ARCHITECTURE)
|
|
||||||
# There is no such thing as i686 architecture on debian, you should use i386 instead
|
|
||||||
# $ dpkg --print-architecture
|
|
||||||
find_program(DPKG_CMD dpkg)
|
|
||||||
if(NOT DPKG_CMD)
|
|
||||||
message(STATUS "CPackDeb: Can not find dpkg in your path, default to i386.")
|
|
||||||
set(CPACK_DEBIAN_PACKAGE_ARCHITECTURE i386)
|
|
||||||
endif()
|
|
||||||
execute_process(COMMAND "${DPKG_CMD}" --print-architecture
|
|
||||||
OUTPUT_VARIABLE CPACK_DEBIAN_PACKAGE_ARCHITECTURE
|
|
||||||
OUTPUT_STRIP_TRAILING_WHITESPACE
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# have a look at get_property(result GLOBAL PROPERTY ENABLED_FEATURES),
|
|
||||||
# this returns the successful find_package() calls, maybe this can help
|
|
||||||
# Depends:
|
|
||||||
# You should set: DEBIAN_PACKAGE_DEPENDS
|
|
||||||
# TODO: automate 'objdump -p | grep NEEDED'
|
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_DEPENDS)
|
|
||||||
message(STATUS "CPACK_DEBIAN_PACKAGE_DEPENDS not set, the package will have no dependencies.")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Maintainer: (mandatory)
|
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_MAINTAINER)
|
|
||||||
if(NOT CPACK_PACKAGE_CONTACT)
|
|
||||||
message(FATAL_ERROR "CPackDeb: Debian package requires a maintainer for a package, set CPACK_PACKAGE_CONTACT or CPACK_DEBIAN_PACKAGE_MAINTAINER")
|
|
||||||
endif()
|
|
||||||
set(CPACK_DEBIAN_PACKAGE_MAINTAINER ${CPACK_PACKAGE_CONTACT})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Description: (mandatory)
|
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_DESCRIPTION)
|
|
||||||
if(NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY)
|
|
||||||
message(FATAL_ERROR "CPackDeb: Debian package requires a summary for a package, set CPACK_PACKAGE_DESCRIPTION_SUMMARY or CPACK_DEBIAN_PACKAGE_DESCRIPTION")
|
|
||||||
endif()
|
|
||||||
set(CPACK_DEBIAN_PACKAGE_DESCRIPTION ${CPACK_PACKAGE_DESCRIPTION_SUMMARY})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Section: (recommended)
|
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_SECTION)
|
|
||||||
set(CPACK_DEBIAN_PACKAGE_SECTION "devel")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Priority: (recommended)
|
|
||||||
if(NOT CPACK_DEBIAN_PACKAGE_PRIORITY)
|
|
||||||
set(CPACK_DEBIAN_PACKAGE_PRIORITY "optional")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Compression: (recommended)
|
|
||||||
if(NOT CPACK_DEBIAN_COMPRESSION_TYPE)
|
|
||||||
set(CPACK_DEBIAN_COMPRESSION_TYPE "gzip")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
# Recommends:
|
|
||||||
# You should set: CPACK_DEBIAN_PACKAGE_RECOMMENDS
|
|
||||||
|
|
||||||
# Suggests:
|
|
||||||
# You should set: CPACK_DEBIAN_PACKAGE_SUGGESTS
|
|
||||||
|
|
||||||
# CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA
|
|
||||||
# This variable allow advanced user to add custom script to the control.tar.gz (inside the .deb archive)
|
|
||||||
# Typical examples are:
|
|
||||||
# - conffiles
|
|
||||||
# - postinst
|
|
||||||
# - postrm
|
|
||||||
# - prerm"
|
|
||||||
# Usage:
|
|
||||||
# set(CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA
|
|
||||||
# "${CMAKE_CURRENT_SOURCE_DIR/prerm;${CMAKE_CURRENT_SOURCE_DIR}/postrm")
|
|
||||||
|
|
||||||
# Are we packaging components ?
|
|
||||||
if(CPACK_DEB_PACKAGE_COMPONENT)
|
|
||||||
set(CPACK_DEB_PACKAGE_COMPONENT_PART_NAME "-${CPACK_DEB_PACKAGE_COMPONENT}")
|
|
||||||
string(TOLOWER "${CPACK_PACKAGE_NAME}${CPACK_DEB_PACKAGE_COMPONENT_PART_NAME}" CPACK_DEBIAN_PACKAGE_NAME)
|
|
||||||
else()
|
|
||||||
set(CPACK_DEB_PACKAGE_COMPONENT_PART_NAME "")
|
|
||||||
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
|
|
||||||
if(CPACK_DEBIAN_PACKAGE_DEBUG)
|
|
||||||
message("CPackDeb:Debug: CPACK_TOPLEVEL_DIRECTORY = ${CPACK_TOPLEVEL_DIRECTORY}")
|
|
||||||
message("CPackDeb:Debug: CPACK_TOPLEVEL_TAG = ${CPACK_TOPLEVEL_TAG}")
|
|
||||||
message("CPackDeb:Debug: CPACK_TEMPORARY_DIRECTORY = ${CPACK_TEMPORARY_DIRECTORY}")
|
|
||||||
message("CPackDeb:Debug: CPACK_OUTPUT_FILE_NAME = ${CPACK_OUTPUT_FILE_NAME}")
|
|
||||||
message("CPackDeb:Debug: CPACK_OUTPUT_FILE_PATH = ${CPACK_OUTPUT_FILE_PATH}")
|
|
||||||
message("CPackDeb:Debug: CPACK_PACKAGE_FILE_NAME = ${CPACK_PACKAGE_FILE_NAME}")
|
|
||||||
message("CPackDeb:Debug: CPACK_PACKAGE_INSTALL_DIRECTORY = ${CPACK_PACKAGE_INSTALL_DIRECTORY}")
|
|
||||||
message("CPackDeb:Debug: CPACK_TEMPORARY_PACKAGE_FILE_NAME = ${CPACK_TEMPORARY_PACKAGE_FILE_NAME}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# For debian source packages:
|
|
||||||
# debian/control
|
|
||||||
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-sourcecontrolfiles
|
|
||||||
|
|
||||||
# .dsc
|
|
||||||
# http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-debiansourcecontrolfiles
|
|
||||||
|
|
||||||
# Builds-Depends:
|
|
||||||
#if(NOT CPACK_DEBIAN_PACKAGE_BUILDS_DEPENDS)
|
|
||||||
# set(CPACK_DEBIAN_PACKAGE_BUILDS_DEPENDS
|
|
||||||
# "debhelper (>> 5.0.0), libncurses5-dev, tcl8.4"
|
|
||||||
# )
|
|
||||||
#endif()
|
|
||||||
|
|
|
@ -90,7 +90,7 @@ int cmCPackDebGenerator::PackageOnePack(std::string initialTopLevel,
|
||||||
}
|
}
|
||||||
|
|
||||||
cmsys::Glob gl;
|
cmsys::Glob gl;
|
||||||
std::string findExpr(this->GetOption("WDIR"));
|
std::string findExpr(this->GetOption("GEN_WDIR"));
|
||||||
findExpr += "/*";
|
findExpr += "/*";
|
||||||
gl.RecurseOn();
|
gl.RecurseOn();
|
||||||
if ( !gl.FindFiles(findExpr) )
|
if ( !gl.FindFiles(findExpr) )
|
||||||
|
@ -217,7 +217,7 @@ int cmCPackDebGenerator::PackageComponentsAllInOne()
|
||||||
}
|
}
|
||||||
|
|
||||||
cmsys::Glob gl;
|
cmsys::Glob gl;
|
||||||
std::string findExpr(this->GetOption("WDIR"));
|
std::string findExpr(this->GetOption("GEN_WDIR"));
|
||||||
findExpr += "/*";
|
findExpr += "/*";
|
||||||
gl.RecurseOn();
|
gl.RecurseOn();
|
||||||
if ( !gl.FindFiles(findExpr) )
|
if ( !gl.FindFiles(findExpr) )
|
||||||
|
@ -286,7 +286,7 @@ int cmCPackDebGenerator::createDeb()
|
||||||
|
|
||||||
// debian-binary file
|
// debian-binary file
|
||||||
std::string dbfilename;
|
std::string dbfilename;
|
||||||
dbfilename += this->GetOption("WDIR");
|
dbfilename += this->GetOption("GEN_WDIR");
|
||||||
dbfilename += "/debian-binary";
|
dbfilename += "/debian-binary";
|
||||||
{ // the scope is needed for cmGeneratedFileStream
|
{ // the scope is needed for cmGeneratedFileStream
|
||||||
cmGeneratedFileStream out(dbfilename.c_str());
|
cmGeneratedFileStream out(dbfilename.c_str());
|
||||||
|
@ -296,44 +296,47 @@ int cmCPackDebGenerator::createDeb()
|
||||||
|
|
||||||
// control file
|
// control file
|
||||||
std::string ctlfilename;
|
std::string ctlfilename;
|
||||||
ctlfilename = this->GetOption("WDIR");
|
ctlfilename = this->GetOption("GEN_WDIR");
|
||||||
ctlfilename += "/control";
|
ctlfilename += "/control";
|
||||||
|
|
||||||
// debian policy enforce lower case for package name
|
// debian policy enforce lower case for package name
|
||||||
// mandatory entries:
|
// mandatory entries:
|
||||||
std::string debian_pkg_name = cmsys::SystemTools::LowerCase(
|
std::string debian_pkg_name = cmsys::SystemTools::LowerCase(
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_NAME") );
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_NAME") );
|
||||||
const char* debian_pkg_version =
|
const char* debian_pkg_version =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_VERSION");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_VERSION");
|
||||||
const char* debian_pkg_section =
|
const char* debian_pkg_section =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_SECTION");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_SECTION");
|
||||||
const char* debian_pkg_priority =
|
const char* debian_pkg_priority =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_PRIORITY");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_PRIORITY");
|
||||||
const char* debian_pkg_arch =
|
const char* debian_pkg_arch =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_ARCHITECTURE");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_ARCHITECTURE");
|
||||||
const char* maintainer = this->GetOption("CPACK_DEBIAN_PACKAGE_MAINTAINER");
|
const char* maintainer =
|
||||||
const char* desc = this->GetOption("CPACK_DEBIAN_PACKAGE_DESCRIPTION");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_MAINTAINER");
|
||||||
|
const char* desc =
|
||||||
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_DESCRIPTION");
|
||||||
|
|
||||||
// optional entries
|
// optional entries
|
||||||
const char* debian_pkg_dep = this->GetOption("CPACK_DEBIAN_PACKAGE_DEPENDS");
|
const char* debian_pkg_dep =
|
||||||
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_DEPENDS");
|
||||||
const char* debian_pkg_rec =
|
const char* debian_pkg_rec =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_RECOMMENDS");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_RECOMMENDS");
|
||||||
const char* debian_pkg_sug =
|
const char* debian_pkg_sug =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_SUGGESTS");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_SUGGESTS");
|
||||||
const char* debian_pkg_url =
|
const char* debian_pkg_url =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_HOMEPAGE");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_HOMEPAGE");
|
||||||
const char* debian_pkg_predep =
|
const char* debian_pkg_predep =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_PREDEPENDS");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_PREDEPENDS");
|
||||||
const char* debian_pkg_enhances =
|
const char* debian_pkg_enhances =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_ENHANCES");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_ENHANCES");
|
||||||
const char* debian_pkg_breaks =
|
const char* debian_pkg_breaks =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_BREAKS");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_BREAKS");
|
||||||
const char* debian_pkg_conflicts =
|
const char* debian_pkg_conflicts =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_CONFLICTS");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_CONFLICTS");
|
||||||
const char* debian_pkg_provides =
|
const char* debian_pkg_provides =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_PROVIDES");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_PROVIDES");
|
||||||
const char* debian_pkg_replaces =
|
const char* debian_pkg_replaces =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_REPLACES");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_REPLACES");
|
||||||
|
|
||||||
{ // the scope is needed for cmGeneratedFileStream
|
{ // the scope is needed for cmGeneratedFileStream
|
||||||
cmGeneratedFileStream out(ctlfilename.c_str());
|
cmGeneratedFileStream out(ctlfilename.c_str());
|
||||||
|
@ -399,13 +402,10 @@ int cmCPackDebGenerator::createDeb()
|
||||||
out << std::endl;
|
out << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string cmd;
|
std::string cmd(this->GetOption("GEN_CPACK_DEBIAN_FAKEROOT_EXECUTABLE"));
|
||||||
if (NULL != this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE")) {
|
|
||||||
cmd += this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE");
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* debian_compression_type =
|
const char* debian_compression_type =
|
||||||
this->GetOption("CPACK_DEBIAN_COMPRESSION_TYPE");
|
this->GetOption("GEN_CPACK_DEBIAN_COMPRESSION_TYPE");
|
||||||
if(!debian_compression_type)
|
if(!debian_compression_type)
|
||||||
{
|
{
|
||||||
debian_compression_type = "gzip";
|
debian_compression_type = "gzip";
|
||||||
|
@ -440,8 +440,9 @@ int cmCPackDebGenerator::createDeb()
|
||||||
// now add all directories which have to be compressed
|
// now add all directories which have to be compressed
|
||||||
// collect all top level install dirs for that
|
// collect all top level install dirs for that
|
||||||
// e.g. /opt/bin/foo, /usr/bin/bar and /usr/bin/baz would give /usr and /opt
|
// e.g. /opt/bin/foo, /usr/bin/bar and /usr/bin/baz would give /usr and /opt
|
||||||
size_t topLevelLength = std::string(this->GetOption("WDIR")).length();
|
size_t topLevelLength = std::string(this->GetOption("GEN_WDIR")).length();
|
||||||
cmCPackLogger(cmCPackLog::LOG_DEBUG, "WDIR: \"" << this->GetOption("WDIR")
|
cmCPackLogger(cmCPackLog::LOG_DEBUG, "WDIR: \""
|
||||||
|
<< this->GetOption("GEN_WDIR")
|
||||||
<< "\", length = " << topLevelLength
|
<< "\", length = " << topLevelLength
|
||||||
<< std::endl);
|
<< std::endl);
|
||||||
std::set<std::string> installDirs;
|
std::set<std::string> installDirs;
|
||||||
|
@ -467,7 +468,7 @@ int cmCPackDebGenerator::createDeb()
|
||||||
std::string output;
|
std::string output;
|
||||||
int retval = -1;
|
int retval = -1;
|
||||||
int res = cmSystemTools::RunSingleCommand(cmd.c_str(), &output, &output,
|
int res = cmSystemTools::RunSingleCommand(cmd.c_str(), &output, &output,
|
||||||
&retval, this->GetOption("WDIR"), this->GeneratorVerbose, 0);
|
&retval, this->GetOption("GEN_WDIR"), this->GeneratorVerbose, 0);
|
||||||
|
|
||||||
if ( !res || retval )
|
if ( !res || retval )
|
||||||
{
|
{
|
||||||
|
@ -485,7 +486,7 @@ int cmCPackDebGenerator::createDeb()
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string md5filename;
|
std::string md5filename;
|
||||||
md5filename = this->GetOption("WDIR");
|
md5filename = this->GetOption("GEN_WDIR");
|
||||||
md5filename += "/md5sums";
|
md5filename += "/md5sums";
|
||||||
|
|
||||||
{ // the scope is needed for cmGeneratedFileStream
|
{ // the scope is needed for cmGeneratedFileStream
|
||||||
|
@ -523,14 +524,10 @@ int cmCPackDebGenerator::createDeb()
|
||||||
// Do not end the md5sum file with yet another (invalid)
|
// Do not end the md5sum file with yet another (invalid)
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd = "";
|
cmd = this->GetOption("GEN_CPACK_DEBIAN_FAKEROOT_EXECUTABLE");
|
||||||
if (NULL != this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE"))
|
|
||||||
{
|
|
||||||
cmd = this->GetOption("CPACK_DEBIAN_FAKEROOT_EXECUTABLE");
|
|
||||||
}
|
|
||||||
cmd += cmake_tar + "tar czf control.tar.gz ./control ./md5sums";
|
cmd += cmake_tar + "tar czf control.tar.gz ./control ./md5sums";
|
||||||
const char* controlExtra =
|
const char* controlExtra =
|
||||||
this->GetOption("CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA");
|
this->GetOption("GEN_CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA");
|
||||||
if( controlExtra )
|
if( controlExtra )
|
||||||
{
|
{
|
||||||
std::vector<std::string> controlExtraList;
|
std::vector<std::string> controlExtraList;
|
||||||
|
@ -540,7 +537,7 @@ int cmCPackDebGenerator::createDeb()
|
||||||
{
|
{
|
||||||
std::string filenamename =
|
std::string filenamename =
|
||||||
cmsys::SystemTools::GetFilenameName(*i);
|
cmsys::SystemTools::GetFilenameName(*i);
|
||||||
std::string localcopy = this->GetOption("WDIR");
|
std::string localcopy = this->GetOption("GEN_WDIR");
|
||||||
localcopy += "/";
|
localcopy += "/";
|
||||||
localcopy += filenamename;
|
localcopy += filenamename;
|
||||||
// if we can copy the file, it means it does exist, let's add it:
|
// if we can copy the file, it means it does exist, let's add it:
|
||||||
|
@ -554,7 +551,7 @@ int cmCPackDebGenerator::createDeb()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
res = cmSystemTools::RunSingleCommand(cmd.c_str(), &output, &output,
|
res = cmSystemTools::RunSingleCommand(cmd.c_str(), &output, &output,
|
||||||
&retval, this->GetOption("WDIR"), this->GeneratorVerbose, 0);
|
&retval, this->GetOption("GEN_WDIR"), this->GeneratorVerbose, 0);
|
||||||
|
|
||||||
if ( !res || retval )
|
if ( !res || retval )
|
||||||
{
|
{
|
||||||
|
@ -575,7 +572,7 @@ int cmCPackDebGenerator::createDeb()
|
||||||
// since debian packages require BSD ar (most Linux distros and even
|
// since debian packages require BSD ar (most Linux distros and even
|
||||||
// FreeBSD and NetBSD ship GNU ar) we use a copy of OpenBSD ar here.
|
// FreeBSD and NetBSD ship GNU ar) we use a copy of OpenBSD ar here.
|
||||||
std::vector<std::string> arFiles;
|
std::vector<std::string> arFiles;
|
||||||
std::string topLevelString = this->GetOption("WDIR");
|
std::string topLevelString = this->GetOption("GEN_WDIR");
|
||||||
topLevelString += "/";
|
topLevelString += "/";
|
||||||
arFiles.push_back(topLevelString + "debian-binary");
|
arFiles.push_back(topLevelString + "debian-binary");
|
||||||
arFiles.push_back(topLevelString + "control.tar.gz");
|
arFiles.push_back(topLevelString + "control.tar.gz");
|
||||||
|
|
Loading…
Reference in New Issue