# - The builtin (binary) CPack RPM generator (Unix only)
# CPackRPM may be used to create RPM package using CPack.
# CPackRPM is a CPack generator thus it uses the CPACK_XXX variables
# used by CPack : http://www.cmake.org/Wiki/CMake:CPackConfiguration
#
# However CPackRPM has specific features which are controlled by
# the specifics CPACK_RPM_XXX variables.
# Usually those vars correspond to RPM spec file entities, one may find
# information about spec files here http://www.rpm.org/wiki/Docs.
# You'll find a detailed usage of CPackRPM on the wiki:
# http://www.cmake.org/Wiki/CMake:CPackPackageGenerators#RPM_.28Unix_Only.29
# However as a handy reminder here comes the list of specific variables:
#
# CPACK_RPM_PACKAGE_SUMMARY
# Mandatory : YES
# Default : CPACK_PACKAGE_DESCRIPTION_SUMMARY
# The RPM package summary
# CPACK_RPM_PACKAGE_NAME
# Mandatory : YES
# Default : CPACK_PACKAGE_NAME
# The RPM package name
# CPACK_RPM_PACKAGE_VERSION
# Mandatory : YES
# Default : CPACK_PACKAGE_VERSION
# The RPM package version
# CPACK_RPM_PACKAGE_ARCHITECTURE
# Mandatory : NO
# Default : -
# The RPM package architecture. This may be set to "noarch" if you
# know you are building a noarch package.
# CPACK_RPM_PACKAGE_RELEASE
# Mandatory : YES
# Default : 1
# The RPM package release. This is the numbering of the RPM package
# itself, i.e. the version of the packaging and not the version of the
# content (see CPACK_RPM_PACKAGE_VERSION). One may change the default
# value if the previous packaging was buggy and/or you want to put here
# a fancy Linux distro specific numbering.
# CPACK_RPM_PACKAGE_LICENSE
# Mandatory : YES
# Default : "unknown"
# The RPM package license policy.
# CPACK_RPM_PACKAGE_GROUP
# Mandatory : YES
# Default : "unknown"
# The RPM package group.
# CPACK_RPM_PACKAGE_VENDOR
# Mandatory : YES
# Default : CPACK_PACKAGE_VENDOR if set or "unknown"
# The RPM package vendor.
# CPACK_RPM_PACKAGE_URL
# Mandatory : NO
# Default : -
# The projects URL.
# CPACK_RPM_PACKAGE_DESCRIPTION
# Mandatory : YES
# Default : CPACK_PACKAGE_DESCRIPTION_FILE if set or "no package description available"
# CPACK_RPM_COMPRESSION_TYPE
# Mandatory : NO
# Default : -
# May be used to override RPM compression type to be used
# to build the RPM. For example some Linux distribution now default
# to lzma or xz compression whereas older cannot use such RPM.
# Using this one can enforce compression type to be used.
# Possible value are: lzma, xz, bzip2 and gzip.
# CPACK_RPM_PACKAGE_REQUIRES
# Mandatory : NO
# Default : -
# May be used to set RPM dependencies (requires).
# Note that you must enclose the complete requires string between quotes,
# for example:
# set(CPACK_RPM_PACKAGE_REQUIRES "python >= 2.5.0, cmake >= 2.8")
# The required package list of an RPM file could be printed with
# rpm -qp --requires file.rpm
# CPACK_RPM_PACKAGE_SUGGESTS
# Mandatory : NO
# Default : -
# May be used to set weak RPM dependencies (suggests).
# Note that you must enclose the complete requires string between quotes.
# CPACK_RPM_PACKAGE_PROVIDES
# Mandatory : NO
# Default : -
# May be used to set RPM dependencies (provides).
# The provided package list of an RPM file could be printed with
# rpm -qp --provides file.rpm
# CPACK_RPM_PACKAGE_OBSOLETES
# Mandatory : NO
# Default : -
# May be used to set RPM packages that are obsoleted by this one.
# CPACK_RPM_PACKAGE_RELOCATABLE
# Mandatory : NO
# Default : CPACK_PACKAGE_RELOCATABLE
# If this variable is set to TRUE or ON CPackRPM will try
# to build a relocatable RPM package. A relocatable RPM may
# be installed using rpm --prefix or --relocate in order to
# install it at an alternate place see rpm(8).
# Note that currently this may fail if CPACK_SET_DESTDIR is set to ON.
# If CPACK_SET_DESTDIR is set then you will get a warning message
# but if there is file installed with absolute path you'll get
# unexpected behavior.
# CPACK_RPM_SPEC_INSTALL_POST
# Mandatory : NO
# Default : -
# May be used to set an RPM post-install command inside the spec file.
# For example setting it to "/bin/true" may be used to prevent
# rpmbuild to strip binaries.
# CPACK_RPM_SPEC_MORE_DEFINE
# Mandatory : NO
# Default : -
# May be used to add any %define lines to the generated spec file.
# CPACK_RPM_PACKAGE_DEBUG
# Mandatory : NO
# Default : -
# May be set when invoking cpack in order to trace debug information
# during CPack RPM run. For example you may launch CPack like this
# cpack -D CPACK_RPM_PACKAGE_DEBUG=1 -G RPM
# CPACK_RPM_USER_BINARY_SPECFILE
# Mandatory : NO
# Default : -
# May be set by the user in order to specify a USER binary spec file
# to be used by CPackRPM instead of generating the file.
# The specified file will be processed by CONFIGURE_FILE( @ONLY).
# CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE
# Mandatory : NO
# Default : -
# If set CPack will generate a template for USER specified binary
# spec file and stop with an error. For example launch CPack like this
# cpack -D CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE=1 -G RPM
# The user may then use this file in order to hand-craft is own
# binary spec file which may be used with CPACK_RPM_USER_BINARY_SPECFILE.
# CPACK_RPM_PRE_INSTALL_SCRIPT_FILE
# CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE
# Mandatory : NO
# Default : -
# May be used to embbed a pre (un)installation script in the spec file.
# The refered script file(s) will be read and directly
# put after the %pre or %preun section
# One may verify which scriptlet has been included with
# rpm -qp --scripts package.rpm
# CPACK_RPM_POST_INSTALL_SCRIPT_FILE
# CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE
# Mandatory : NO
# Default : -
# May be used to embbed a post (un)installation script in the spec file.
# The refered script file(s) will be read and directly
# put after the %post or %postun section
# One may verify which scriptlet has been included with
# rpm -qp --scripts package.rpm
# CPACK_RPM_CHANGELOG_FILE
# Mandatory : NO
# Default : -
# May be used to embbed a changelog in the spec file.
# The refered file will be read and directly put after the %changelog
# section.
#=============================================================================
# Copyright 2007-2009 Kitware, Inc.
#
# Distributed under the OSI-approved BSD License (the "License");
# see accompanying file Copyright.txt for details.
#
# This software is distributed WITHOUT ANY WARRANTY; without even the
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the License for more information.
#=============================================================================
# (To distribute this file outside of CMake, substitute the full
# License text for the above reference.)
# Author: Eric Noulard with the help of Alexander Neundorf.
IF ( CMAKE_BINARY_DIR )
MESSAGE ( FATAL_ERROR "CPackRPM.cmake may only be used by CPack internally." )
ENDIF ( CMAKE_BINARY_DIR )
IF ( NOT UNIX )
MESSAGE ( FATAL_ERROR "CPackRPM.cmake may only be used under UNIX." )
ENDIF ( NOT UNIX )
# rpmbuild is the basic command for building RPM package
# it may be a simple (symbolic) link to rpm command.
FIND_PROGRAM ( RPMBUILD_EXECUTABLE rpmbuild )
# Check version of the rpmbuild tool this would be easier to
# track bugs with users and CPackRPM debug mode.
# We may use RPM version in order to check for available version dependent features
IF ( RPMBUILD_EXECUTABLE )
execute_process ( COMMAND ${ RPMBUILD_EXECUTABLE } --version
O U T P U T _ V A R I A B L E _ T M P _ V E R S I O N
E R R O R _ Q U I E T
O U T P U T _ S T R I P _ T R A I L I N G _ W H I T E S P A C E )
string ( REGEX REPLACE "^.*\ " ""
R P M B U I L D _ E X E C U T A B L E _ V E R S I O N
$ { _ T M P _ V E R S I O N } )
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: rpmbuild version is <${RPMBUILD_EXECUTABLE_VERSION}>" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
ENDIF ( RPMBUILD_EXECUTABLE )
IF ( NOT RPMBUILD_EXECUTABLE )
MESSAGE ( FATAL_ERROR "RPM package requires rpmbuild executable" )
ENDIF ( NOT RPMBUILD_EXECUTABLE )
# Display lsb_release output if DEBUG mode enable
# This will help to diagnose problem with CPackRPM
# because we will know on which kind of Linux we are
IF ( CPACK_RPM_PACKAGE_DEBUG )
find_program ( LSB_RELEASE_EXECUTABLE lsb_release )
if ( LSB_RELEASE_EXECUTABLE )
execute_process ( COMMAND ${ LSB_RELEASE_EXECUTABLE } -a
O U T P U T _ V A R I A B L E _ T M P _ L S B _ R E L E A S E _ O U T P U T
E R R O R _ Q U I E T
O U T P U T _ S T R I P _ T R A I L I N G _ W H I T E S P A C E )
string ( REGEX REPLACE "\n" ", "
L S B _ R E L E A S E _ O U T P U T
$ { _ T M P _ L S B _ R E L E A S E _ O U T P U T } )
else ( LSB_RELEASE_EXECUTABLE )
set ( LSB_RELEASE_OUTPUT "lsb_release not installed/found!" )
endif ( LSB_RELEASE_EXECUTABLE )
MESSAGE ( "CPackRPM:Debug: LSB_RELEASE = ${LSB_RELEASE_OUTPUT}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
# We may use RPM version in the future in order
# to shut down warning about space in buildtree
# some recent RPM version should support space in different places.
# not checked [yet].
IF ( CPACK_TOPLEVEL_DIRECTORY MATCHES ".* .*" )
MESSAGE ( FATAL_ERROR "${RPMBUILD_EXECUTABLE} can't handle paths with spaces, use a build directory without spaces for building RPMs." )
ENDIF ( CPACK_TOPLEVEL_DIRECTORY MATCHES ".* .*" )
# If rpmbuild is found
# we try to discover alien since we may be on non RPM distro like Debian.
# In this case we may try to to use more advanced features
# like generating RPM directly from DEB using alien.
# FIXME feature not finished (yet)
FIND_PROGRAM ( ALIEN_EXECUTABLE alien )
IF ( ALIEN_EXECUTABLE )
MESSAGE ( STATUS "alien found, we may be on a Debian based distro." )
ENDIF ( ALIEN_EXECUTABLE )
#
# Use user-defined RPM specific variables value
# or generate reasonable default value from
# CPACK_xxx generic values.
# The variables comes from the needed (mandatory or not)
# values found in the RPM specification file aka ".spec" file.
# The variables which may/should be defined are:
#
# CPACK_RPM_PACKAGE_SUMMARY (mandatory)
IF ( NOT CPACK_RPM_PACKAGE_SUMMARY )
# if neither var is defined lets use the name as summary
IF ( NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY )
STRING ( TOLOWER "${CPACK_PACKAGE_NAME}" CPACK_RPM_PACKAGE_SUMMARY )
ELSE ( NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY )
SET ( CPACK_RPM_PACKAGE_SUMMARY ${ CPACK_PACKAGE_DESCRIPTION_SUMMARY } )
ENDIF ( NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY )
ENDIF ( NOT CPACK_RPM_PACKAGE_SUMMARY )
# CPACK_RPM_PACKAGE_NAME (mandatory)
IF ( NOT CPACK_RPM_PACKAGE_NAME )
STRING ( TOLOWER "${CPACK_PACKAGE_NAME}" CPACK_RPM_PACKAGE_NAME )
ENDIF ( NOT CPACK_RPM_PACKAGE_NAME )
# CPACK_RPM_PACKAGE_VERSION (mandatory)
IF ( NOT CPACK_RPM_PACKAGE_VERSION )
IF ( NOT CPACK_PACKAGE_VERSION )
MESSAGE ( FATAL_ERROR "RPM package requires a package version" )
ENDIF ( NOT CPACK_PACKAGE_VERSION )
SET ( CPACK_RPM_PACKAGE_VERSION ${ CPACK_PACKAGE_VERSION } )
ENDIF ( NOT CPACK_RPM_PACKAGE_VERSION )
# Replace '-' in version with '_'
# '-' character is an Illegal RPM version character
# it is illegal because it is used to separate
# RPM "Version" from RPM "Release"
STRING ( REPLACE "-" "_" CPACK_RPM_PACKAGE_VERSION ${ CPACK_RPM_PACKAGE_VERSION } )
# CPACK_RPM_PACKAGE_ARCHITECTURE (optional)
IF ( CPACK_RPM_PACKAGE_ARCHITECTURE )
SET ( TMP_RPM_BUILDARCH "Buildarch: ${CPACK_RPM_PACKAGE_ARCHITECTURE}" )
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: using user-specified build arch = ${CPACK_RPM_PACKAGE_ARCHITECTURE}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
ELSE ( CPACK_RPM_PACKAGE_ARCHITECTURE )
SET ( TMP_RPM_BUILDARCH "" )
ENDIF ( CPACK_RPM_PACKAGE_ARCHITECTURE )
# CPACK_RPM_PACKAGE_RELEASE
# The RPM release is the numbering of the RPM package ITSELF
# this is the version of the PACKAGING and NOT the version
# of the CONTENT of the package.
# You may well need to generate a new RPM package release
# without changing the version of the packaged software.
# This is the case when the packaging is buggy (not) the software :=)
# If not set, 1 is a good candidate
IF ( NOT CPACK_RPM_PACKAGE_RELEASE )
SET ( CPACK_RPM_PACKAGE_RELEASE 1 )
ENDIF ( NOT CPACK_RPM_PACKAGE_RELEASE )
# CPACK_RPM_PACKAGE_LICENSE
IF ( NOT CPACK_RPM_PACKAGE_LICENSE )
SET ( CPACK_RPM_PACKAGE_LICENSE "unknown" )
ENDIF ( NOT CPACK_RPM_PACKAGE_LICENSE )
# CPACK_RPM_PACKAGE_GROUP
IF ( NOT CPACK_RPM_PACKAGE_GROUP )
SET ( CPACK_RPM_PACKAGE_GROUP "unknown" )
ENDIF ( NOT CPACK_RPM_PACKAGE_GROUP )
# CPACK_RPM_PACKAGE_VENDOR
IF ( NOT CPACK_RPM_PACKAGE_VENDOR )
IF ( CPACK_PACKAGE_VENDOR )
SET ( CPACK_RPM_PACKAGE_VENDOR "${CPACK_PACKAGE_VENDOR}" )
ELSE ( CPACK_PACKAGE_VENDOR )
SET ( CPACK_RPM_PACKAGE_VENDOR "unknown" )
ENDIF ( CPACK_PACKAGE_VENDOR )
ENDIF ( NOT CPACK_RPM_PACKAGE_VENDOR )
# CPACK_RPM_PACKAGE_SOURCE
# The name of the source tarball in case we generate a source RPM
# CPACK_RPM_PACKAGE_DESCRIPTION
# The variable content may be either
# - explicitly given by the user or
# - filled with the content of CPACK_PACKAGE_DESCRIPTION_FILE
# if it is defined
# - set to a default value
#
IF ( NOT CPACK_RPM_PACKAGE_DESCRIPTION )
IF ( CPACK_PACKAGE_DESCRIPTION_FILE )
FILE ( READ ${ CPACK_PACKAGE_DESCRIPTION_FILE } CPACK_RPM_PACKAGE_DESCRIPTION )
ELSE ( CPACK_PACKAGE_DESCRIPTION_FILE )
SET ( CPACK_RPM_PACKAGE_DESCRIPTION "no package description available" )
ENDIF ( CPACK_PACKAGE_DESCRIPTION_FILE )
ENDIF ( NOT CPACK_RPM_PACKAGE_DESCRIPTION )
# CPACK_RPM_COMPRESSION_TYPE
#
IF ( CPACK_RPM_COMPRESSION_TYPE )
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: User Specified RPM compression type: ${CPACK_RPM_COMPRESSION_TYPE}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
IF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "lzma" )
SET ( CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w9.lzdio" )
ENDIF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "lzma" )
IF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "xz" )
SET ( CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w7.xzdio" )
ENDIF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "xz" )
IF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "bzip2" )
SET ( CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w9.bzdio" )
ENDIF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "bzip2" )
IF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "gzip" )
SET ( CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w9.gzdio" )
ENDIF ( CPACK_RPM_COMPRESSION_TYPE STREQUAL "gzip" )
ELSE ( CPACK_RPM_COMPRESSION_TYPE )
SET ( CPACK_RPM_COMPRESSION_TYPE_TMP "" )
ENDIF ( CPACK_RPM_COMPRESSION_TYPE )
if ( CPACK_PACKAGE_RELOCATABLE )
set ( CPACK_RPM_PACKAGE_RELOCATABLE TRUE )
endif ( CPACK_PACKAGE_RELOCATABLE )
if ( CPACK_RPM_PACKAGE_RELOCATABLE )
if ( CPACK_RPM_PACKAGE_DEBUG )
message ( "CPackRPM:Debug: Trying to build a relocatable package" )
endif ( CPACK_RPM_PACKAGE_DEBUG )
if ( CPACK_SET_DESTDIR AND ( NOT CPACK_SET_DESTDIR STREQUAL "I_ON" ) )
message ( "CPackRPM:Warning: CPACK_SET_DESTDIR is set (=${CPACK_SET_DESTDIR}) while requesting a relocatable package (CPACK_RPM_PACKAGE_RELOCATABLE is set): this is not supported, the package won't be relocatable." )
else ( CPACK_SET_DESTDIR AND ( NOT CPACK_SET_DESTDIR STREQUAL "I_ON" ) )
set ( CPACK_RPM_PACKAGE_PREFIX ${ CPACK_PACKAGING_INSTALL_PREFIX } )
endif ( CPACK_SET_DESTDIR AND ( NOT CPACK_SET_DESTDIR STREQUAL "I_ON" ) )
endif ( CPACK_RPM_PACKAGE_RELOCATABLE )
# check if additional fields for RPM spec header are given
FOREACH ( _RPM_SPEC_HEADER URL REQUIRES SUGGESTS PROVIDES OBSOLETES PREFIX CONFLICTS AUTOPROV AUTOREQ AUTOREQPROV )
IF ( CPACK_RPM_PACKAGE_ ${ _RPM_SPEC_HEADER } )
STRING ( LENGTH ${ _RPM_SPEC_HEADER } _PACKAGE_HEADER_STRLENGTH )
MATH ( EXPR _PACKAGE_HEADER_STRLENGTH "${_PACKAGE_HEADER_STRLENGTH} - 1" )
STRING ( SUBSTRING ${ _RPM_SPEC_HEADER } 1 ${ _PACKAGE_HEADER_STRLENGTH } _PACKAGE_HEADER_TAIL )
STRING ( TOLOWER "${_PACKAGE_HEADER_TAIL}" _PACKAGE_HEADER_TAIL )
STRING ( SUBSTRING ${ _RPM_SPEC_HEADER } 0 1 _PACKAGE_HEADER_NAME )
SET ( _PACKAGE_HEADER_NAME "${_PACKAGE_HEADER_NAME}${_PACKAGE_HEADER_TAIL}" )
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: User defined ${_PACKAGE_HEADER_NAME}:\n ${CPACK_RPM_PACKAGE_${_RPM_SPEC_HEADER}}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
SET ( TMP_RPM_ ${ _RPM_SPEC_HEADER } "${_PACKAGE_HEADER_NAME}: ${CPACK_RPM_PACKAGE_${_RPM_SPEC_HEADER}}" )
ENDIF ( CPACK_RPM_PACKAGE_ ${ _RPM_SPEC_HEADER } )
ENDFOREACH ( _RPM_SPEC_HEADER )
# CPACK_RPM_SPEC_INSTALL_POST
# May be used to define a RPM post intallation script
# for example setting it to "/bin/true" may prevent
# rpmbuild from stripping binaries.
IF ( CPACK_RPM_SPEC_INSTALL_POST )
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: User defined CPACK_RPM_SPEC_INSTALL_POST = ${CPACK_RPM_SPEC_INSTALL_POST}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
SET ( TMP_RPM_SPEC_INSTALL_POST "%define __spec_install_post ${CPACK_RPM_SPEC_INSTALL_POST}" )
ENDIF ( CPACK_RPM_SPEC_INSTALL_POST )
# CPACK_RPM_POST_INSTALL_SCRIPT_FILE
# CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE
# May be used to embbed a post (un)installation script in the spec file.
# The refered script file(s) will be read and directly
# put after the %post or %postun section
if ( CPACK_RPM_POST_INSTALL_SCRIPT_FILE )
if ( EXISTS ${ CPACK_RPM_POST_INSTALL_SCRIPT_FILE } )
file ( READ ${ CPACK_RPM_POST_INSTALL_SCRIPT_FILE } CPACK_RPM_SPEC_POSTINSTALL )
else ( EXISTS ${ CPACK_RPM_POST_INSTALL_SCRIPT_FILE } )
message ( "CPackRPM:Warning: CPACK_RPM_POST_INSTALL_SCRIPT_FILE <${CPACK_RPM_POST_INSTALL_SCRIPT_FILE}> does not exists - ignoring" )
endif ( EXISTS ${ CPACK_RPM_POST_INSTALL_SCRIPT_FILE } )
endif ( CPACK_RPM_POST_INSTALL_SCRIPT_FILE )
if ( CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE )
if ( EXISTS ${ CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE } )
file ( READ ${ CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE } CPACK_RPM_SPEC_POSTUNINSTALL )
else ( EXISTS ${ CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE } )
message ( "CPackRPM:Warning: CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE <${CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE}> does not exists - ignoring" )
endif ( EXISTS ${ CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE } )
endif ( CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE )
# CPACK_RPM_PRE_INSTALL_SCRIPT_FILE
# CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE
# May be used to embed a pre (un)installation script in the spec file.
# The refered script file(s) will be read and directly
# put after the %pre or %preun section
if ( CPACK_RPM_PRE_INSTALL_SCRIPT_FILE )
if ( EXISTS ${ CPACK_RPM_PRE_INSTALL_SCRIPT_FILE } )
file ( READ ${ CPACK_RPM_PRE_INSTALL_SCRIPT_FILE } CPACK_RPM_SPEC_PREINSTALL )
else ( EXISTS ${ CPACK_RPM_PRE_INSTALL_SCRIPT_FILE } )
message ( "CPackRPM:Warning: CPACK_RPM_PRE_INSTALL_SCRIPT_FILE <${CPACK_RPM_PRE_INSTALL_SCRIPT_FILE}> does not exists - ignoring" )
endif ( EXISTS ${ CPACK_RPM_PRE_INSTALL_SCRIPT_FILE } )
endif ( CPACK_RPM_PRE_INSTALL_SCRIPT_FILE )
if ( CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE )
if ( EXISTS ${ CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE } )
file ( READ ${ CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE } CPACK_RPM_SPEC_PREUNINSTALL )
else ( EXISTS ${ CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE } )
message ( "CPackRPM:Warning: CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE <${CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE}> does not exists - ignoring" )
endif ( EXISTS ${ CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE } )
endif ( CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE )
# CPACK_RPM_CHANGELOG_FILE
# May be used to embed a changelog in the spec file.
# The refered file will be read and directly put after the %changelog section
if ( CPACK_RPM_CHANGELOG_FILE )
if ( EXISTS ${ CPACK_RPM_CHANGELOG_FILE } )
file ( READ ${ CPACK_RPM_CHANGELOG_FILE } CPACK_RPM_SPEC_CHANGELOG )
else ( EXISTS ${ CPACK_RPM_CHANGELOG_FILE } )
message ( SEND_ERROR "CPackRPM:Warning: CPACK_RPM_CHANGELOG_FILE <${CPACK_RPM_CHANGELOG_FILE}> does not exists - ignoring" )
endif ( EXISTS ${ CPACK_RPM_CHANGELOG_FILE } )
else ( CPACK_RPM_CHANGELOG_FILE )
set ( CPACK_RPM_SPEC_CHANGELOG "* Sun Jul 4 2010 Erk <eric.noulard@gmail.com>\n Generated by CPack RPM (no Changelog file were provided)" )
endif ( CPACK_RPM_CHANGELOG_FILE )
# CPACK_RPM_SPEC_MORE_DEFINE
# This is a generated spec rpm file spaceholder
IF ( CPACK_RPM_SPEC_MORE_DEFINE )
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: User defined more define spec line specified:\n ${CPACK_RPM_SPEC_MORE_DEFINE}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
ENDIF ( CPACK_RPM_SPEC_MORE_DEFINE )
# Now we may create the RPM build tree structure
SET ( CPACK_RPM_ROOTDIR "${CPACK_TOPLEVEL_DIRECTORY}" )
MESSAGE ( STATUS "CPackRPM:Debug: Using CPACK_RPM_ROOTDIR=${CPACK_RPM_ROOTDIR}" )
# Prepare RPM build tree
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } )
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } /tmp )
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } /BUILD )
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } /RPMS )
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } /SOURCES )
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } /SPECS )
FILE ( MAKE_DIRECTORY ${ CPACK_RPM_ROOTDIR } /SRPMS )
#SET(CPACK_RPM_FILE_NAME "${CPACK_RPM_PACKAGE_NAME}-${CPACK_RPM_PACKAGE_VERSION}-${CPACK_RPM_PACKAGE_RELEASE}-${CPACK_RPM_PACKAGE_ARCHITECTURE}.rpm")
SET ( CPACK_RPM_FILE_NAME "${CPACK_OUTPUT_FILE_NAME}" )
# it seems rpmbuild can't handle spaces in the path
# neither escaping (as below) nor putting quotes around the path seem to help
#STRING(REGEX REPLACE " " "\\\\ " CPACK_RPM_DIRECTORY "${CPACK_TOPLEVEL_DIRECTORY}")
SET ( CPACK_RPM_DIRECTORY "${CPACK_TOPLEVEL_DIRECTORY}" )
# Are we packaging components ?
IF ( CPACK_RPM_PACKAGE_COMPONENT )
SET ( CPACK_RPM_PACKAGE_COMPONENT_PART_NAME "-${CPACK_RPM_PACKAGE_COMPONENT}" )
SET ( CPACK_RPM_PACKAGE_COMPONENT_PART_PATH "/${CPACK_RPM_PACKAGE_COMPONENT}" )
SET ( WDIR "${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/${CPACK_RPM_PACKAGE_COMPONENT}" )
ELSE ( CPACK_RPM_PACKAGE_COMPONENT )
SET ( CPACK_RPM_PACKAGE_COMPONENT_PART_NAME "" )
SET ( CPACK_RPM_PACKAGE_COMPONENT_PART_PATH "" )
SET ( WDIR "${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}" )
ENDIF ( CPACK_RPM_PACKAGE_COMPONENT )
# Use files tree to construct files command (spec file)
# We should not forget to include symlinks (thus -o -type l)
# We must remove the './' due to the local search and escape the
# file name by enclosing it between double quotes (thus the sed)
# Then we must authorize any man pages extension (adding * at the end)
# because rpmbuild may automatically compress those files
EXECUTE_PROCESS ( COMMAND find . -type f -o -type l
C O M M A N D s e d s : . * / m a n . * / . * : & * :
C O M M A N D s e d s / \ \ . \ \ \ ( . * \ \ \ ) / \ " \ \ 1 \ " /
W O R K I N G _ D I R E C T O R Y " $ { W D I R } "
O U T P U T _ V A R I A B L E C P A C K _ R P M _ I N S T A L L _ F I L E S )
# In component case, replace CPACK_ABSOLUTE_DESTINATION_FILES
# with the content of CPACK_ABSOLUTE_DESTINATION_FILES_<COMPONENT>
# This must be done BEFORE the CPACK_ABSOLUTE_DESTINATION_FILES handling
if ( CPACK_RPM_PACKAGE_COMPONENT )
if ( CPACK_ABSOLUTE_DESTINATION_FILES )
set ( COMPONENT_FILES_TAG "CPACK_ABSOLUTE_DESTINATION_FILES_${CPACK_RPM_PACKAGE_COMPONENT}" )
set ( CPACK_ABSOLUTE_DESTINATION_FILES "${${COMPONENT_FILES_TAG}}" )
if ( CPACK_RPM_PACKAGE_DEBUG )
message ( "CPackRPM:Debug: Handling Absolute Destination Files ${CPACK_ABSOLUTE_DESTINATION_FILES}" )
message ( "CPackRPM:Debug: in component = ${CPACK_RPM_PACKAGE_COMPONENT}" )
endif ( CPACK_RPM_PACKAGE_DEBUG )
endif ( )
endif ( )
if ( CPACK_ABSOLUTE_DESTINATION_FILES )
IF ( CPACK_RPM_PACKAGE_DEBUG )
message ( "CPackRPM:Debug: Handling Absolute Destination Files: ${CPACK_ABSOLUTE_DESTINATION_FILES}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
# Remove trailing space
string ( STRIP "${CPACK_RPM_INSTALL_FILES}" CPACK_RPM_INSTALL_FILES_LIST )
# Transform endline separated - string into CMake List
string ( REPLACE "\n" ";" CPACK_RPM_INSTALL_FILES_LIST "${CPACK_RPM_INSTALL_FILES_LIST}" )
# Remove unecessary quotes
string ( REPLACE "\" " " " CPACK_RPM_INSTALL_FILES_LIST " ${ CPACK_RPM_INSTALL_FILES_LIST } " )
# Remove ABSOLUTE install file from INSTALL FILE LIST
list ( REMOVE_ITEM CPACK_RPM_INSTALL_FILES_LIST ${ CPACK_ABSOLUTE_DESTINATION_FILES } )
# Rebuild INSTALL_FILES
set ( CPACK_RPM_INSTALL_FILES "" )
foreach ( F IN LISTS CPACK_RPM_INSTALL_FILES_LIST )
set ( CPACK_RPM_INSTALL_FILES "${CPACK_RPM_INSTALL_FILES}\" ${ F } \"\n")
endforeach ( F )
# Build ABSOLUTE_INSTALL_FILES
set ( CPACK_RPM_ABSOLUTE_INSTALL_FILES "" )
foreach ( F IN LISTS CPACK_ABSOLUTE_DESTINATION_FILES )
set ( CPACK_RPM_ABSOLUTE_INSTALL_FILES "${CPACK_RPM_ABSOLUTE_INSTALL_FILES}%config \" ${ F } \"\n")
endforeach ( F )
IF ( CPACK_RPM_PACKAGE_DEBUG )
message ( "CPackRPM:Debug: CPACK_RPM_ABSOLUTE_INSTALL_FILES=${CPACK_RPM_ABSOLUTE_INSTALL_FILES}" )
message ( "CPackRPM:Debug: CPACK_RPM_INSTALL_FILES=${CPACK_RPM_INSTALL_FILES}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
endif ( CPACK_ABSOLUTE_DESTINATION_FILES )
# The name of the final spec file to be used by rpmbuild
SET ( CPACK_RPM_BINARY_SPECFILE "${CPACK_RPM_ROOTDIR}/SPECS/${CPACK_RPM_PACKAGE_NAME}${CPACK_RPM_PACKAGE_COMPONENT_PART_NAME}.spec" )
# Print out some debug information if we were asked for that
IF ( CPACK_RPM_PACKAGE_DEBUG )
MESSAGE ( "CPackRPM:Debug: CPACK_TOPLEVEL_DIRECTORY = ${CPACK_TOPLEVEL_DIRECTORY}" )
MESSAGE ( "CPackRPM:Debug: CPACK_TOPLEVEL_TAG = ${CPACK_TOPLEVEL_TAG}" )
MESSAGE ( "CPackRPM:Debug: CPACK_TEMPORARY_DIRECTORY = ${CPACK_TEMPORARY_DIRECTORY}" )
MESSAGE ( "CPackRPM:Debug: CPACK_OUTPUT_FILE_NAME = ${CPACK_OUTPUT_FILE_NAME}" )
MESSAGE ( "CPackRPM:Debug: CPACK_OUTPUT_FILE_PATH = ${CPACK_OUTPUT_FILE_PATH}" )
MESSAGE ( "CPackRPM:Debug: CPACK_PACKAGE_FILE_NAME = ${CPACK_PACKAGE_FILE_NAME}" )
MESSAGE ( "CPackRPM:Debug: CPACK_RPM_BINARY_SPECFILE = ${CPACK_RPM_BINARY_SPECFILE}" )
MESSAGE ( "CPackRPM:Debug: CPACK_PACKAGE_INSTALL_DIRECTORY = ${CPACK_PACKAGE_INSTALL_DIRECTORY}" )
MESSAGE ( "CPackRPM:Debug: CPACK_TEMPORARY_PACKAGE_FILE_NAME = ${CPACK_TEMPORARY_PACKAGE_FILE_NAME}" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG )
# USER generated spec file handling.
# We should generate a spec file template:
# - either because the user asked for it : CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE
# - or the user did not provide one : NOT CPACK_RPM_USER_BINARY_SPECFILE
#
IF ( CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE OR NOT CPACK_RPM_USER_BINARY_SPECFILE )
FILE ( WRITE ${ CPACK_RPM_BINARY_SPECFILE } .in
" # -*- rpm-spec -*-
B u i l d R o o t : \ @ C P A C K _ R P M _ D I R E C T O R Y \ @ / \ @ C P A C K _ P A C K A G E _ F I L E _ N A M E \ @ \ @ C P A C K _ R P M _ P A C K A G E _ C O M P O N E N T _ P A R T _ P A T H \ @
S u m m a r y : \ @ C P A C K _ R P M _ P A C K A G E _ S U M M A R Y \ @
N a m e : \ @ C P A C K _ R P M _ P A C K A G E _ N A M E \ @
V e r s i o n : \ @ C P A C K _ R P M _ P A C K A G E _ V E R S I O N \ @
R e l e a s e : \ @ C P A C K _ R P M _ P A C K A G E _ R E L E A S E \ @
L i c e n s e : \ @ C P A C K _ R P M _ P A C K A G E _ L I C E N S E \ @
G r o u p : \ @ C P A C K _ R P M _ P A C K A G E _ G R O U P \ @
V e n d o r : \ @ C P A C K _ R P M _ P A C K A G E _ V E N D O R \ @
\ @ T M P _ R P M _ U R L \ @
\ @ T M P _ R P M _ R E Q U I R E S \ @
\ @ T M P _ R P M _ P R O V I D E S \ @
\ @ T M P _ R P M _ O B S O L E T E S \ @
\ @ T M P _ R P M _ C O N F L I C T S \ @
\ @ T M P _ R P M _ A U T O P R O V \ @
\ @ T M P _ R P M _ A U T O R E Q \ @
\ @ T M P _ R P M _ A U T O R E Q P R O V \ @
\ @ T M P _ R P M _ B U I L D A R C H \ @
\ @ T M P _ R P M _ P R E F I X \ @
% d e f i n e _ r p m d i r \ @ C P A C K _ R P M _ D I R E C T O R Y \ @
% d e f i n e _ r p m f i l e n a m e \ @ C P A C K _ R P M _ F I L E _ N A M E \ @
% d e f i n e _ u n p a c k a g e d _ f i l e s _ t e r m i n a t e _ b u i l d 0
% d e f i n e _ t o p d i r \ @ C P A C K _ R P M _ D I R E C T O R Y \ @
\ @ T M P _ R P M _ S P E C _ I N S T A L L _ P O S T \ @
\ @ C P A C K _ R P M _ S P E C _ M O R E _ D E F I N E \ @
\ @ C P A C K _ R P M _ C O M P R E S S I O N _ T Y P E _ T M P \ @
% d e s c r i p t i o n
\ @ C P A C K _ R P M _ P A C K A G E _ D E S C R I P T I O N \ @
# This is a shortcutted spec file generated by CMake RPM generator
# we skip _install step because CPack does that for us.
# We do only save CPack installed tree in _prepr
# and then restore it in build.
% p r e p
m v $ R P M _ B U I L D _ R O O T \ " \ @ C P A C K _ T O P L E V E L _ D I R E C T O R Y \ @ / t m p B B r o o t \ "
#p build
% i n s t a l l
i f [ - e $ R P M _ B U I L D _ R O O T ] ;
t h e n
r m - r f $ R P M _ B U I L D _ R O O T
f i
m v \ " \ @ C P A C K _ T O P L E V E L _ D I R E C T O R Y \ @ / t m p B B r o o t \ " $ R P M _ B U I L D _ R O O T
% c l e a n
% p o s t
\ @ C P A C K _ R P M _ S P E C _ P O S T I N S T A L L \ @
% p o s t u n
\ @ C P A C K _ R P M _ S P E C _ P O S T U N I N S T A L L \ @
% p r e
\ @ C P A C K _ R P M _ S P E C _ P R E I N S T A L L \ @
% p r e u n
\ @ C P A C K _ R P M _ S P E C _ P R E U N I N S T A L L \ @
% f i l e s
% defattr ( -,root,root,- )
$ { C P A C K _ R P M _ I N S T A L L _ F I L E S }
$ { C P A C K _ R P M _ A B S O L U T E _ I N S T A L L _ F I L E S }
% c h a n g e l o g
\ @ C P A C K _ R P M _ S P E C _ C H A N G E L O G \ @
" )
# Stop here if we were asked to only generate a template USER spec file
# The generated file may then be used as a template by user who wants
# to customize their own spec file.
IF ( CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE )
MESSAGE ( FATAL_ERROR "CPackRPM: STOP here Generated USER binary spec file templare is: ${CPACK_RPM_BINARY_SPECFILE}.in" )
ENDIF ( CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE )
ENDIF ( CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE OR NOT CPACK_RPM_USER_BINARY_SPECFILE )
# After that we may either use a user provided spec file
# or generate one using appropriate variables value.
IF ( CPACK_RPM_USER_BINARY_SPECFILE )
# User may have specified SPECFILE just use it
MESSAGE ( "CPackRPM: Will use USER specified spec file: ${CPACK_RPM_USER_BINARY_SPECFILE}" )
# The user provided file is processed for @var replacement
CONFIGURE_FILE ( ${ CPACK_RPM_USER_BINARY_SPECFILE } ${ CPACK_RPM_BINARY_SPECFILE } @ONLY )
ELSE ( CPACK_RPM_USER_BINARY_SPECFILE )
# No User specified spec file, will use the generated spec file
MESSAGE ( "CPackRPM: Will use GENERATED spec file: ${CPACK_RPM_BINARY_SPECFILE}" )
# Note the just created file is processed for @var replacement
CONFIGURE_FILE ( ${ CPACK_RPM_BINARY_SPECFILE } .in ${ CPACK_RPM_BINARY_SPECFILE } @ONLY )
ENDIF ( CPACK_RPM_USER_BINARY_SPECFILE )
IF ( RPMBUILD_EXECUTABLE )
# Now call rpmbuild using the SPECFILE
EXECUTE_PROCESS (
C O M M A N D " $ { R P M B U I L D _ E X E C U T A B L E } " - b b
- - b u i l d r o o t " $ { C P A C K _ R P M _ D I R E C T O R Y } / $ { C P A C K _ P A C K A G E _ F I L E _ N A M E } $ { C P A C K _ R P M _ P A C K A G E _ C O M P O N E N T _ P A R T _ P A T H } "
" $ { C P A C K _ R P M _ B I N A R Y _ S P E C F I L E } "
W O R K I N G _ D I R E C T O R Y " $ { C P A C K _ T O P L E V E L _ D I R E C T O R Y } / $ { C P A C K _ P A C K A G E _ F I L E _ N A M E } $ { C P A C K _ R P M _ P A C K A G E _ C O M P O N E N T _ P A R T _ P A T H } "
R E S U L T _ V A R I A B L E C P A C K _ R P M B U I L D _ E X E C _ R E S U L T
E R R O R _ F I L E " $ { C P A C K _ T O P L E V E L _ D I R E C T O R Y } / r p m b u i l d $ { C P A C K _ R P M _ P A C K A G E _ C O M P O N E N T _ P A R T _ N A M E } . e r r "
O U T P U T _ F I L E " $ { C P A C K _ T O P L E V E L _ D I R E C T O R Y } / r p m b u i l d $ { C P A C K _ R P M _ P A C K A G E _ C O M P O N E N T _ P A R T _ N A M E } . o u t " )
IF ( CPACK_RPM_PACKAGE_DEBUG OR CPACK_RPMBUILD_EXEC_RESULT )
FILE ( READ ${ CPACK_TOPLEVEL_DIRECTORY } /rpmbuild ${ CPACK_RPM_PACKAGE_COMPONENT_PART_NAME } .err RPMBUILDERR )
FILE ( READ ${ CPACK_TOPLEVEL_DIRECTORY } /rpmbuild ${ CPACK_RPM_PACKAGE_COMPONENT_PART_NAME } .out RPMBUILDOUT )
MESSAGE ( "CPackRPM:Debug: You may consult rpmbuild logs in: " )
MESSAGE ( "CPackRPM:Debug: - ${CPACK_TOPLEVEL_DIRECTORY}/rpmbuild${CPACK_RPM_PACKAGE_COMPONENT_PART_NAME}.err" )
MESSAGE ( "CPackRPM:Debug: *** ${RPMBUILDERR} ***" )
MESSAGE ( "CPackRPM:Debug: - ${CPACK_TOPLEVEL_DIRECTORY}/rpmbuild${CPACK_RPM_PACKAGE_COMPONENT_PART_NAME}.out" )
MESSAGE ( "CPackRPM:Debug: *** ${RPMBUILDERR} ***" )
ENDIF ( CPACK_RPM_PACKAGE_DEBUG OR CPACK_RPMBUILD_EXEC_RESULT )
ELSE ( RPMBUILD_EXECUTABLE )
IF ( ALIEN_EXECUTABLE )
MESSAGE ( FATAL_ERROR "RPM packaging through alien not done (yet)" )
ENDIF ( ALIEN_EXECUTABLE )
ENDIF ( RPMBUILD_EXECUTABLE )