CPackRPM.cmake 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594
  1. # - The builtin (binary) CPack RPM generator (Unix only)
  2. # CPackRPM may be used to create RPM package using CPack.
  3. # CPackRPM is a CPack generator thus it uses the CPACK_XXX variables
  4. # used by CPack : http://www.cmake.org/Wiki/CMake:CPackConfiguration
  5. #
  6. # However CPackRPM has specific features which are controlled by
  7. # the specifics CPACK_RPM_XXX variables. You'll find a detailed usage on
  8. # the wiki:
  9. # http://www.cmake.org/Wiki/CMake:CPackPackageGenerators#RPM_.28Unix_Only.29
  10. # However as a handy reminder here comes the list of specific variables:
  11. #
  12. # CPACK_RPM_PACKAGE_SUMMARY
  13. # Mandatory : YES
  14. # Default : CPACK_PACKAGE_DESCRIPTION_SUMMARY
  15. # The RPM package summary
  16. # CPACK_RPM_PACKAGE_NAME
  17. # Mandatory : YES
  18. # Default : CPACK_PACKAGE_NAME
  19. # The RPM package name
  20. # CPACK_RPM_PACKAGE_VERSION
  21. # Mandatory : YES
  22. # Default : CPACK_PACKAGE_VERSION
  23. # The RPM package version
  24. # CPACK_RPM_PACKAGE_ARCHITECTURE
  25. # Mandatory : NO
  26. # Default : -
  27. # The RPM package architecture. This may be set to "noarch" if you
  28. # know you are building a noarch package.
  29. # CPACK_RPM_PACKAGE_RELEASE
  30. # Mandatory : YES
  31. # Default : 1
  32. # The RPM package release. This is the numbering of the RPM package
  33. # itself, i.e. the version of the packaging and not the version of the
  34. # content (see CPACK_RPM_PACKAGE_VERSION). One may change the default
  35. # value if the previous packaging was buggy and/or you want to put here
  36. # a fancy Linux distro specific numbering.
  37. # CPACK_RPM_PACKAGE_LICENSE
  38. # Mandatory : YES
  39. # Default : "unknown"
  40. # The RPM package license policy.
  41. # CPACK_RPM_PACKAGE_GROUP
  42. # Mandatory : YES
  43. # Default : "unknown"
  44. # The RPM package group.
  45. # CPACK_RPM_PACKAGE_VENDOR
  46. # Mandatory : YES
  47. # Default : CPACK_PACKAGE_VENDOR if set or "unknown"
  48. # The RPM package vendor.
  49. # CPACK_RPM_PACKAGE_URL
  50. # Mandatory : NO
  51. # Default : -
  52. # The projects URL.
  53. # CPACK_RPM_PACKAGE_DESCRIPTION
  54. # Mandatory : YES
  55. # Default : CPACK_PACKAGE_DESCRIPTION_FILE if set or "no package description available"
  56. # CPACK_RPM_COMPRESSION_TYPE
  57. # Mandatory : NO
  58. # Default : -
  59. # May be used to override RPM compression type to be used
  60. # to build the RPM. For example some Linux distribution now default
  61. # to lzma or xz compression whereas older cannot use such RPM.
  62. # Using this one can enforce compression type to be used.
  63. # Possible value are: lzma, xz, bzip2 and gzip.
  64. # CPACK_RPM_PACKAGE_REQUIRES
  65. # Mandatory : NO
  66. # Default : -
  67. # May be used to set RPM dependencies (requires).
  68. # Note that you must enclose the complete requires string between quotes,
  69. # for example:
  70. # set(CPACK_RPM_PACKAGE_REQUIRES "python >= 2.5.0, cmake >= 2.8")
  71. # CPACK_RPM_PACKAGE_SUGGESTS
  72. # Mandatory : NO
  73. # Default : -
  74. # May be used to set weak RPM dependencies (suggests).
  75. # Note that you must enclose the complete requires string between quotes.
  76. # CPACK_RPM_PACKAGE_PROVIDES
  77. # Mandatory : NO
  78. # Default : -
  79. # May be used to set RPM dependencies (provides).
  80. # CPACK_RPM_PACKAGE_OBSOLETES
  81. # Mandatory : NO
  82. # Default : -
  83. # May be used to set RPM packages that are obsoleted by this one.
  84. # CPACK_RPM_PACKAGE_RELOCATABLE
  85. # Mandatory : NO
  86. # Default : -
  87. # If this variable is set to TRUE or ON CPackRPM will try
  88. # to build a relocatable RPM package. A relocatable RPM may
  89. # be installed using rpm --prefix or --relocate in order to
  90. # install it at an alternate place see rpm(8).
  91. # Note that currently this may fail if the package contains
  92. # files installed with absolute path or CPACK_SET_DESTDIR is set to ON.
  93. # If CPACK_SET_DESTDIR is set then you will get a warning message
  94. # but if there is file installed with absolute path you'll get
  95. # unexpected behavior.
  96. # CPACK_RPM_SPEC_INSTALL_POST
  97. # Mandatory : NO
  98. # Default : -
  99. # May be used to set an RPM post-install command inside the spec file.
  100. # For example setting it to "/bin/true" may be used to prevent
  101. # rpmbuild to strip binaries.
  102. # CPACK_RPM_SPEC_MORE_DEFINE
  103. # Mandatory : NO
  104. # Default : -
  105. # May be used to add any %define lines to the generated spec file.
  106. # CPACK_RPM_PACKAGE_DEBUG
  107. # Mandatory : NO
  108. # Default : -
  109. # May be set when invoking cpack in order to trace debug information
  110. # during CPack RPM run. For example you may launch CPack like this
  111. # cpack -D CPACK_RPM_PACKAGE_DEBUG=1 -G RPM
  112. # CPACK_RPM_USER_BINARY_SPECFILE
  113. # Mandatory : NO
  114. # Default : -
  115. # May be set by the user in order to specify a USER binary spec file
  116. # to be used by CPackRPM instead of generating the file.
  117. # The specified file will be processed by CONFIGURE_FILE( @ONLY).
  118. # CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE
  119. # Mandatory : NO
  120. # Default : -
  121. # If set CPack will generate a template for USER specified binary
  122. # spec file and stop with an error. For example launch CPack like this
  123. # cpack -D CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE=1 -G RPM
  124. # The user may then use this file in order to hand-craft is own
  125. # binary spec file which may be used with CPACK_RPM_USER_BINARY_SPECFILE.
  126. # CPACK_RPM_PRE_INSTALL_SCRIPT_FILE
  127. # CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE
  128. # Mandatory : NO
  129. # Default : -
  130. # May be used to embbed a pre (un)installation script in the spec file.
  131. # The refered script file(s) will be read and directly
  132. # put after the %pre or %preun section
  133. # One may verify which scriptlet has been included with
  134. # rpm -qp --scripts package.rpm
  135. # CPACK_RPM_POST_INSTALL_SCRIPT_FILE
  136. # CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE
  137. # Mandatory : NO
  138. # Default : -
  139. # May be used to embbed a post (un)installation script in the spec file.
  140. # The refered script file(s) will be read and directly
  141. # put after the %post or %postun section
  142. # One may verify which scriptlet has been included with
  143. # rpm -qp --scripts package.rpm
  144. # CPACK_RPM_CHANGELOG_FILE
  145. # Mandatory : NO
  146. # Default : -
  147. # May be used to embbed a changelog in the spec file.
  148. # The refered file will be read and directly put after the %changelog
  149. # section.
  150. #=============================================================================
  151. # Copyright 2007-2009 Kitware, Inc.
  152. #
  153. # Distributed under the OSI-approved BSD License (the "License");
  154. # see accompanying file Copyright.txt for details.
  155. #
  156. # This software is distributed WITHOUT ANY WARRANTY; without even the
  157. # implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  158. # See the License for more information.
  159. #=============================================================================
  160. # (To distributed this file outside of CMake, substitute the full
  161. # License text for the above reference.)
  162. # Author: Eric Noulard with the help of Alexander Neundorf.
  163. IF(CMAKE_BINARY_DIR)
  164. MESSAGE(FATAL_ERROR "CPackRPM.cmake may only be used by CPack internally.")
  165. ENDIF(CMAKE_BINARY_DIR)
  166. IF(NOT UNIX)
  167. MESSAGE(FATAL_ERROR "CPackRPM.cmake may only be used under UNIX.")
  168. ENDIF(NOT UNIX)
  169. # rpmbuild is the basic command for building RPM package
  170. # it may be a simple (symbolic) link to rpm command.
  171. FIND_PROGRAM(RPMBUILD_EXECUTABLE rpmbuild)
  172. # Check version of the rpmbuild tool this would be easier to
  173. # track bugs with users and CPackRPM debug mode.
  174. # We may use RPM version in order to check for available version dependent features
  175. IF(RPMBUILD_EXECUTABLE)
  176. execute_process(COMMAND ${RPMBUILD_EXECUTABLE} --version
  177. OUTPUT_VARIABLE _TMP_VERSION
  178. ERROR_QUIET
  179. OUTPUT_STRIP_TRAILING_WHITESPACE)
  180. string(REGEX REPLACE "^.*\ " ""
  181. RPMBUILD_EXECUTABLE_VERSION
  182. ${_TMP_VERSION})
  183. IF(CPACK_RPM_PACKAGE_DEBUG)
  184. MESSAGE("CPackRPM:Debug: rpmbuild version is <${RPMBUILD_EXECUTABLE_VERSION}>")
  185. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  186. ENDIF(RPMBUILD_EXECUTABLE)
  187. IF(NOT RPMBUILD_EXECUTABLE)
  188. MESSAGE(FATAL_ERROR "RPM package requires rpmbuild executable")
  189. ENDIF(NOT RPMBUILD_EXECUTABLE)
  190. # We may use RPM version in the future in order
  191. # to shut down warning about space in buildtree
  192. # some recent RPM version should support space in different places.
  193. # not checked [yet].
  194. IF(CPACK_TOPLEVEL_DIRECTORY MATCHES ".* .*")
  195. MESSAGE(FATAL_ERROR "${RPMBUILD_EXECUTABLE} can't handle paths with spaces, use a build directory without spaces for building RPMs.")
  196. ENDIF(CPACK_TOPLEVEL_DIRECTORY MATCHES ".* .*")
  197. # If rpmbuild is found
  198. # we try to discover alien since we may be on non RPM distro like Debian.
  199. # In this case we may try to to use more advanced features
  200. # like generating RPM directly from DEB using alien.
  201. # FIXME feature not finished (yet)
  202. FIND_PROGRAM(ALIEN_EXECUTABLE alien)
  203. IF(ALIEN_EXECUTABLE)
  204. MESSAGE(STATUS "alien found, we may be on a Debian based distro.")
  205. ENDIF(ALIEN_EXECUTABLE)
  206. #
  207. # Use user-defined RPM specific variables value
  208. # or generate reasonable default value from
  209. # CPACK_xxx generic values.
  210. # The variables comes from the needed (mandatory or not)
  211. # values found in the RPM specification file aka ".spec" file.
  212. # The variables which may/should be defined are:
  213. #
  214. # CPACK_RPM_PACKAGE_SUMMARY (mandatory)
  215. IF(NOT CPACK_RPM_PACKAGE_SUMMARY)
  216. # if neither var is defined lets use the name as summary
  217. IF(NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY)
  218. STRING(TOLOWER "${CPACK_PACKAGE_NAME}" CPACK_RPM_PACKAGE_SUMMARY)
  219. ELSE(NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY)
  220. SET(CPACK_RPM_PACKAGE_SUMMARY ${CPACK_PACKAGE_DESCRIPTION_SUMMARY})
  221. ENDIF(NOT CPACK_PACKAGE_DESCRIPTION_SUMMARY)
  222. ENDIF(NOT CPACK_RPM_PACKAGE_SUMMARY)
  223. # CPACK_RPM_PACKAGE_NAME (mandatory)
  224. IF(NOT CPACK_RPM_PACKAGE_NAME)
  225. STRING(TOLOWER "${CPACK_PACKAGE_NAME}" CPACK_RPM_PACKAGE_NAME)
  226. ENDIF(NOT CPACK_RPM_PACKAGE_NAME)
  227. # CPACK_RPM_PACKAGE_VERSION (mandatory)
  228. IF(NOT CPACK_RPM_PACKAGE_VERSION)
  229. IF(NOT CPACK_PACKAGE_VERSION)
  230. MESSAGE(FATAL_ERROR "RPM package requires a package version")
  231. ENDIF(NOT CPACK_PACKAGE_VERSION)
  232. SET(CPACK_RPM_PACKAGE_VERSION ${CPACK_PACKAGE_VERSION})
  233. ENDIF(NOT CPACK_RPM_PACKAGE_VERSION)
  234. # Replace '-' in version with '_'
  235. # '-' character is an Illegal RPM version character
  236. # it is illegal because it is used to separate
  237. # RPM "Version" from RPM "Release"
  238. STRING(REPLACE "-" "_" CPACK_RPM_PACKAGE_VERSION ${CPACK_RPM_PACKAGE_VERSION})
  239. # CPACK_RPM_PACKAGE_ARCHITECTURE (optional)
  240. IF(CPACK_RPM_PACKAGE_ARCHITECTURE)
  241. SET(TMP_RPM_BUILDARCH "Buildarch: ${CPACK_RPM_PACKAGE_ARCHITECTURE}")
  242. IF(CPACK_RPM_PACKAGE_DEBUG)
  243. MESSAGE("CPackRPM:Debug: using user-specified build arch = ${CPACK_RPM_PACKAGE_ARCHITECTURE}")
  244. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  245. ELSE(CPACK_RPM_PACKAGE_ARCHITECTURE)
  246. SET(TMP_RPM_BUILDARCH "")
  247. ENDIF(CPACK_RPM_PACKAGE_ARCHITECTURE)
  248. # CPACK_RPM_PACKAGE_RELEASE
  249. # The RPM release is the numbering of the RPM package ITSELF
  250. # this is the version of the PACKAGING and NOT the version
  251. # of the CONTENT of the package.
  252. # You may well need to generate a new RPM package release
  253. # without changing the version of the packaged software.
  254. # This is the case when the packaging is buggy (not) the software :=)
  255. # If not set, 1 is a good candidate
  256. IF(NOT CPACK_RPM_PACKAGE_RELEASE)
  257. SET(CPACK_RPM_PACKAGE_RELEASE 1)
  258. ENDIF(NOT CPACK_RPM_PACKAGE_RELEASE)
  259. # CPACK_RPM_PACKAGE_LICENSE
  260. IF(NOT CPACK_RPM_PACKAGE_LICENSE)
  261. SET(CPACK_RPM_PACKAGE_LICENSE "unknown")
  262. ENDIF(NOT CPACK_RPM_PACKAGE_LICENSE)
  263. # CPACK_RPM_PACKAGE_GROUP
  264. IF(NOT CPACK_RPM_PACKAGE_GROUP)
  265. SET(CPACK_RPM_PACKAGE_GROUP "unknown")
  266. ENDIF(NOT CPACK_RPM_PACKAGE_GROUP)
  267. # CPACK_RPM_PACKAGE_VENDOR
  268. IF(NOT CPACK_RPM_PACKAGE_VENDOR)
  269. IF(CPACK_PACKAGE_VENDOR)
  270. SET(CPACK_RPM_PACKAGE_VENDOR "${CPACK_PACKAGE_VENDOR}")
  271. ELSE(CPACK_PACKAGE_VENDOR)
  272. SET(CPACK_RPM_PACKAGE_VENDOR "unknown")
  273. ENDIF(CPACK_PACKAGE_VENDOR)
  274. ENDIF(NOT CPACK_RPM_PACKAGE_VENDOR)
  275. # CPACK_RPM_PACKAGE_SOURCE
  276. # The name of the source tarball in case we generate a source RPM
  277. # CPACK_RPM_PACKAGE_DESCRIPTION
  278. # The variable content may be either
  279. # - explicitly given by the user or
  280. # - filled with the content of CPACK_PACKAGE_DESCRIPTION_FILE
  281. # if it is defined
  282. # - set to a default value
  283. #
  284. IF (NOT CPACK_RPM_PACKAGE_DESCRIPTION)
  285. IF (CPACK_PACKAGE_DESCRIPTION_FILE)
  286. FILE(READ ${CPACK_PACKAGE_DESCRIPTION_FILE} CPACK_RPM_PACKAGE_DESCRIPTION)
  287. ELSE (CPACK_PACKAGE_DESCRIPTION_FILE)
  288. SET(CPACK_RPM_PACKAGE_DESCRIPTION "no package description available")
  289. ENDIF (CPACK_PACKAGE_DESCRIPTION_FILE)
  290. ENDIF (NOT CPACK_RPM_PACKAGE_DESCRIPTION)
  291. # CPACK_RPM_COMPRESSION_TYPE
  292. #
  293. IF (CPACK_RPM_COMPRESSION_TYPE)
  294. IF(CPACK_RPM_PACKAGE_DEBUG)
  295. MESSAGE("CPackRPM:Debug: User Specified RPM compression type: ${CPACK_RPM_COMPRESSION_TYPE}")
  296. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  297. IF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "lzma")
  298. SET(CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w9.lzdio")
  299. ENDIF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "lzma")
  300. IF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "xz")
  301. SET(CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w7.xzdio")
  302. ENDIF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "xz")
  303. IF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "bzip2")
  304. SET(CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w9.bzdio")
  305. ENDIF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "bzip2")
  306. IF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "gzip")
  307. SET(CPACK_RPM_COMPRESSION_TYPE_TMP "%define _binary_payload w9.gzdio")
  308. ENDIF(CPACK_RPM_COMPRESSION_TYPE STREQUAL "gzip")
  309. ELSE(CPACK_RPM_COMPRESSION_TYPE)
  310. SET(CPACK_RPM_COMPRESSION_TYPE_TMP "")
  311. ENDIF(CPACK_RPM_COMPRESSION_TYPE)
  312. if(CPACK_RPM_PACKAGE_RELOCATABLE)
  313. if(CPACK_RPM_PACKAGE_DEBUG)
  314. message("CPackRPM:Debug: Trying to build a relocatable package")
  315. endif(CPACK_RPM_PACKAGE_DEBUG)
  316. if(CPACK_SET_DESTDIR)
  317. message(SEND_ERROR "CPackRPM:Warning: CPACK_SET_DESTDIR is set while requesting a relocatable package (CPACK_RPM_PACKAGE_RELOCATABLE is set): this is not supported, the package won't be relocatable.")
  318. else(CPACK_SET_DESTDIR)
  319. set(CPACK_RPM_PACKAGE_PREFIX ${CPACK_PACKAGING_INSTALL_PREFIX})
  320. endif(CPACK_SET_DESTDIR)
  321. endif(CPACK_RPM_PACKAGE_RELOCATABLE)
  322. # check if additional fields for RPM spec header are given
  323. FOREACH(_RPM_SPEC_HEADER URL REQUIRES SUGGESTS PROVIDES OBSOLETES PREFIX)
  324. IF(CPACK_RPM_PACKAGE_${_RPM_SPEC_HEADER})
  325. STRING(LENGTH ${_RPM_SPEC_HEADER} _PACKAGE_HEADER_STRLENGTH)
  326. MATH(EXPR _PACKAGE_HEADER_STRLENGTH "${_PACKAGE_HEADER_STRLENGTH} - 1")
  327. STRING(SUBSTRING ${_RPM_SPEC_HEADER} 1 ${_PACKAGE_HEADER_STRLENGTH} _PACKAGE_HEADER_TAIL)
  328. STRING(TOLOWER "${_PACKAGE_HEADER_TAIL}" _PACKAGE_HEADER_TAIL)
  329. STRING(SUBSTRING ${_RPM_SPEC_HEADER} 0 1 _PACKAGE_HEADER_NAME)
  330. SET(_PACKAGE_HEADER_NAME "${_PACKAGE_HEADER_NAME}${_PACKAGE_HEADER_TAIL}")
  331. IF(CPACK_RPM_PACKAGE_DEBUG)
  332. MESSAGE("CPackRPM:Debug: User defined ${_PACKAGE_HEADER_NAME}:\n ${CPACK_RPM_PACKAGE_${_RPM_SPEC_HEADER}}")
  333. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  334. SET(TMP_RPM_${_RPM_SPEC_HEADER} "${_PACKAGE_HEADER_NAME}: ${CPACK_RPM_PACKAGE_${_RPM_SPEC_HEADER}}")
  335. ENDIF(CPACK_RPM_PACKAGE_${_RPM_SPEC_HEADER})
  336. ENDFOREACH(_RPM_SPEC_HEADER)
  337. # CPACK_RPM_SPEC_INSTALL_POST
  338. # May be used to define a RPM post intallation script
  339. # for example setting it to "/bin/true" may prevent
  340. # rpmbuild from stripping binaries.
  341. IF(CPACK_RPM_SPEC_INSTALL_POST)
  342. IF(CPACK_RPM_PACKAGE_DEBUG)
  343. MESSAGE("CPackRPM:Debug: User defined CPACK_RPM_SPEC_INSTALL_POST = ${CPACK_RPM_SPEC_INSTALL_POST}")
  344. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  345. SET(TMP_RPM_SPEC_INSTALL_POST "%define __spec_install_post ${CPACK_RPM_SPEC_INSTALL_POST}")
  346. ENDIF(CPACK_RPM_SPEC_INSTALL_POST)
  347. # CPACK_RPM_POST_INSTALL_SCRIPT_FILE
  348. # CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE
  349. # May be used to embbed a post (un)installation script in the spec file.
  350. # The refered script file(s) will be read and directly
  351. # put after the %post or %postun section
  352. if(CPACK_RPM_POST_INSTALL_SCRIPT_FILE)
  353. if(EXISTS ${CPACK_RPM_POST_INSTALL_SCRIPT_FILE})
  354. file(READ ${CPACK_RPM_POST_INSTALL_SCRIPT_FILE} CPACK_RPM_SPEC_POSTINSTALL)
  355. else(EXISTS ${CPACK_RPM_POST_INSTALL_SCRIPT_FILE})
  356. message("CPackRPM:Warning: CPACK_RPM_POST_INSTALL_SCRIPT_FILE <${CPACK_RPM_POST_INSTALL_SCRIPT_FILE}> does not exists - ignoring")
  357. endif(EXISTS ${CPACK_RPM_POST_INSTALL_SCRIPT_FILE})
  358. endif(CPACK_RPM_POST_INSTALL_SCRIPT_FILE)
  359. if(CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE)
  360. if(EXISTS ${CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE})
  361. file(READ ${CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE} CPACK_RPM_SPEC_POSTUNINSTALL)
  362. else(EXISTS ${CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE})
  363. message("CPackRPM:Warning: CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE <${CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE}> does not exists - ignoring")
  364. endif(EXISTS ${CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE})
  365. endif(CPACK_RPM_POST_UNINSTALL_SCRIPT_FILE)
  366. # CPACK_RPM_PRE_INSTALL_SCRIPT_FILE
  367. # CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE
  368. # May be used to embed a pre (un)installation script in the spec file.
  369. # The refered script file(s) will be read and directly
  370. # put after the %pre or %preun section
  371. if(CPACK_RPM_PRE_INSTALL_SCRIPT_FILE)
  372. if(EXISTS ${CPACK_RPM_PRE_INSTALL_SCRIPT_FILE})
  373. file(READ ${CPACK_RPM_PRE_INSTALL_SCRIPT_FILE} CPACK_RPM_SPEC_PREINSTALL)
  374. else(EXISTS ${CPACK_RPM_PRE_INSTALL_SCRIPT_FILE})
  375. message("CPackRPM:Warning: CPACK_RPM_PRE_INSTALL_SCRIPT_FILE <${CPACK_RPM_PRE_INSTALL_SCRIPT_FILE}> does not exists - ignoring")
  376. endif(EXISTS ${CPACK_RPM_PRE_INSTALL_SCRIPT_FILE})
  377. endif(CPACK_RPM_PRE_INSTALL_SCRIPT_FILE)
  378. if(CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE)
  379. if(EXISTS ${CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE})
  380. file(READ ${CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE} CPACK_RPM_SPEC_PREUNINSTALL)
  381. else(EXISTS ${CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE})
  382. message("CPackRPM:Warning: CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE <${CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE}> does not exists - ignoring")
  383. endif(EXISTS ${CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE})
  384. endif(CPACK_RPM_PRE_UNINSTALL_SCRIPT_FILE)
  385. # CPACK_RPM_CHANGELOG_FILE
  386. # May be used to embed a changelog in the spec file.
  387. # The refered file will be read and directly put after the %changelog section
  388. if(CPACK_RPM_CHANGELOG_FILE)
  389. if(EXISTS ${CPACK_RPM_CHANGELOG_FILE})
  390. file(READ ${CPACK_RPM_CHANGELOG_FILE} CPACK_RPM_SPEC_CHANGELOG)
  391. else(EXISTS ${CPACK_RPM_CHANGELOG_FILE})
  392. message(SEND_ERROR "CPackRPM:Warning: CPACK_RPM_CHANGELOG_FILE <${CPACK_RPM_CHANGELOG_FILE}> does not exists - ignoring")
  393. endif(EXISTS ${CPACK_RPM_CHANGELOG_FILE})
  394. else(CPACK_RPM_CHANGELOG_FILE)
  395. set(CPACK_RPM_SPEC_CHANGELOG "* Sun Jul 4 2010 Erk <[email protected]>\n Generated by CPack RPM (no Changelog file were provided)")
  396. endif(CPACK_RPM_CHANGELOG_FILE)
  397. # CPACK_RPM_SPEC_MORE_DEFINE
  398. # This is a generated spec rpm file spaceholder
  399. IF(CPACK_RPM_SPEC_MORE_DEFINE)
  400. IF(CPACK_RPM_PACKAGE_DEBUG)
  401. MESSAGE("CPackRPM:Debug: User defined more define spec line specified:\n ${CPACK_RPM_SPEC_MORE_DEFINE}")
  402. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  403. ENDIF(CPACK_RPM_SPEC_MORE_DEFINE)
  404. # Now we may create the RPM build tree structure
  405. SET(CPACK_RPM_ROOTDIR "${CPACK_TOPLEVEL_DIRECTORY}")
  406. MESSAGE(STATUS "CPackRPM:Debug: Using CPACK_RPM_ROOTDIR=${CPACK_RPM_ROOTDIR}")
  407. # Prepare RPM build tree
  408. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR})
  409. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR}/tmp)
  410. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR}/BUILD)
  411. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR}/RPMS)
  412. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR}/SOURCES)
  413. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR}/SPECS)
  414. FILE(MAKE_DIRECTORY ${CPACK_RPM_ROOTDIR}/SRPMS)
  415. #SET(CPACK_RPM_FILE_NAME "${CPACK_RPM_PACKAGE_NAME}-${CPACK_RPM_PACKAGE_VERSION}-${CPACK_RPM_PACKAGE_RELEASE}-${CPACK_RPM_PACKAGE_ARCHITECTURE}.rpm")
  416. SET(CPACK_RPM_FILE_NAME "${CPACK_OUTPUT_FILE_NAME}")
  417. # it seems rpmbuild can't handle spaces in the path
  418. # neither escaping (as below) nor putting quotes around the path seem to help
  419. #STRING(REGEX REPLACE " " "\\\\ " CPACK_RPM_DIRECTORY "${CPACK_TOPLEVEL_DIRECTORY}")
  420. SET(CPACK_RPM_DIRECTORY "${CPACK_TOPLEVEL_DIRECTORY}")
  421. # Use files tree to construct files command (spec file)
  422. # We should not forget to include symlinks (thus -o -type l)
  423. # We must remove the './' due to the local search and escape the
  424. # file name by enclosing it between double quotes (thus the sed)
  425. # Then we must authorize any man pages extension (adding * at the end)
  426. # because rpmbuild may automatically compress those files
  427. EXECUTE_PROCESS(COMMAND find -type f -o -type l
  428. COMMAND sed {s:.*/man.*/.*:&*:}
  429. COMMAND sed {s/\\.\\\(.*\\\)/\"\\1\"/}
  430. WORKING_DIRECTORY "${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}"
  431. OUTPUT_VARIABLE CPACK_RPM_INSTALL_FILES)
  432. # The name of the final spec file to be used by rpmbuild
  433. SET(CPACK_RPM_BINARY_SPECFILE "${CPACK_RPM_ROOTDIR}/SPECS/${CPACK_RPM_PACKAGE_NAME}.spec")
  434. # Print out some debug information if we were asked for that
  435. IF(CPACK_RPM_PACKAGE_DEBUG)
  436. MESSAGE("CPackRPM:Debug: CPACK_TOPLEVEL_DIRECTORY = ${CPACK_TOPLEVEL_DIRECTORY}")
  437. MESSAGE("CPackRPM:Debug: CPACK_TOPLEVEL_TAG = ${CPACK_TOPLEVEL_TAG}")
  438. MESSAGE("CPackRPM:Debug: CPACK_TEMPORARY_DIRECTORY = ${CPACK_TEMPORARY_DIRECTORY}")
  439. MESSAGE("CPackRPM:Debug: CPACK_OUTPUT_FILE_NAME = ${CPACK_OUTPUT_FILE_NAME}")
  440. MESSAGE("CPackRPM:Debug: CPACK_OUTPUT_FILE_PATH = ${CPACK_OUTPUT_FILE_PATH}")
  441. MESSAGE("CPackRPM:Debug: CPACK_PACKAGE_FILE_NAME = ${CPACK_PACKAGE_FILE_NAME}")
  442. MESSAGE("CPackRPM:Debug: CPACK_RPM_BINARY_SPECFILE = ${CPACK_RPM_BINARY_SPECFILE}")
  443. MESSAGE("CPackRPM:Debug: CPACK_PACKAGE_INSTALL_DIRECTORY = ${CPACK_PACKAGE_INSTALL_DIRECTORY}")
  444. MESSAGE("CPackRPM:Debug: CPACK_TEMPORARY_PACKAGE_FILE_NAME = ${CPACK_TEMPORARY_PACKAGE_FILE_NAME}")
  445. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  446. # USER generated spec file handling.
  447. # We should generate a spec file template:
  448. # - either because the user asked for it : CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE
  449. # - or the user did not provide one : NOT CPACK_RPM_USER_BINARY_SPECFILE
  450. #
  451. IF(CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE OR NOT CPACK_RPM_USER_BINARY_SPECFILE)
  452. FILE(WRITE ${CPACK_RPM_BINARY_SPECFILE}.in
  453. "# -*- rpm-spec -*-
  454. BuildRoot: \@CPACK_RPM_DIRECTORY\@/\@CPACK_PACKAGE_FILE_NAME\@
  455. Summary: \@CPACK_RPM_PACKAGE_SUMMARY\@
  456. Name: \@CPACK_RPM_PACKAGE_NAME\@
  457. Version: \@CPACK_RPM_PACKAGE_VERSION\@
  458. Release: \@CPACK_RPM_PACKAGE_RELEASE\@
  459. License: \@CPACK_RPM_PACKAGE_LICENSE\@
  460. Group: \@CPACK_RPM_PACKAGE_GROUP\@
  461. Vendor: \@CPACK_RPM_PACKAGE_VENDOR\@
  462. \@TMP_RPM_URL\@
  463. \@TMP_RPM_REQUIRES\@
  464. \@TMP_RPM_PROVIDES\@
  465. \@TMP_RPM_OBSOLETES\@
  466. \@TMP_RPM_BUILDARCH\@
  467. \@TMP_RPM_PREFIX\@
  468. %define _rpmdir \@CPACK_RPM_DIRECTORY\@
  469. %define _rpmfilename \@CPACK_RPM_FILE_NAME\@
  470. %define _unpackaged_files_terminate_build 0
  471. %define _topdir \@CPACK_RPM_DIRECTORY\@
  472. \@TMP_RPM_SPEC_INSTALL_POST\@
  473. \@CPACK_RPM_SPEC_MORE_DEFINE\@
  474. \@CPACK_RPM_COMPRESSION_TYPE_TMP\@
  475. %description
  476. \@CPACK_RPM_PACKAGE_DESCRIPTION\@
  477. # This is a shortcutted spec file generated by CMake RPM generator
  478. # we skip _install step because CPack does that for us.
  479. # We do only save CPack installed tree in _prepr
  480. # and then restore it in build.
  481. %prep
  482. mv $RPM_BUILD_ROOT \@CPACK_TOPLEVEL_DIRECTORY\@/tmpBBroot
  483. #p build
  484. %install
  485. if [ -e $RPM_BUILD_ROOT ];
  486. then
  487. mv \@CPACK_TOPLEVEL_DIRECTORY\@/tmpBBroot/* $RPM_BUILD_ROOT
  488. else
  489. mv \@CPACK_TOPLEVEL_DIRECTORY\@/tmpBBroot $RPM_BUILD_ROOT
  490. fi
  491. %clean
  492. %post
  493. \@CPACK_RPM_SPEC_POSTINSTALL\@
  494. %postun
  495. \@CPACK_RPM_SPEC_POSTUNINSTALL\@
  496. %pre
  497. \@CPACK_RPM_SPEC_PREINSTALL\@
  498. %preun
  499. \@CPACK_RPM_SPEC_PREUNINSTALL\@
  500. %files
  501. %defattr(-,root,root,-)
  502. ${CPACK_RPM_INSTALL_FILES}
  503. %changelog
  504. \@CPACK_RPM_SPEC_CHANGELOG\@
  505. ")
  506. # Stop here if we were asked to only generate a template USER spec file
  507. # The generated file may then be used as a template by user who wants
  508. # to customize their own spec file.
  509. IF(CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE)
  510. MESSAGE(FATAL_ERROR "CPackRPM: STOP here Generated USER binary spec file templare is: ${CPACK_RPM_BINARY_SPECFILE}.in")
  511. ENDIF(CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE)
  512. ENDIF(CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE OR NOT CPACK_RPM_USER_BINARY_SPECFILE)
  513. # After that we may either use a user provided spec file
  514. # or generate one using appropriate variables value.
  515. IF(CPACK_RPM_USER_BINARY_SPECFILE)
  516. # User may have specified SPECFILE just use it
  517. MESSAGE("CPackRPM: Will use USER specified spec file: ${CPACK_RPM_USER_BINARY_SPECFILE}")
  518. # The user provided file is processed for @var replacement
  519. CONFIGURE_FILE(${CPACK_RPM_USER_BINARY_SPECFILE} ${CPACK_RPM_BINARY_SPECFILE} @ONLY)
  520. ELSE(CPACK_RPM_USER_BINARY_SPECFILE)
  521. # No User specified spec file, will use the generated spec file
  522. MESSAGE("CPackRPM: Will use GENERATED spec file: ${CPACK_RPM_BINARY_SPECFILE}")
  523. # Note the just created file is processed for @var replacement
  524. CONFIGURE_FILE(${CPACK_RPM_BINARY_SPECFILE}.in ${CPACK_RPM_BINARY_SPECFILE} @ONLY)
  525. ENDIF(CPACK_RPM_USER_BINARY_SPECFILE)
  526. IF(RPMBUILD_EXECUTABLE)
  527. # Now call rpmbuild using the SPECFILE
  528. EXECUTE_PROCESS(
  529. COMMAND "${RPMBUILD_EXECUTABLE}" -bb
  530. --buildroot "${CPACK_RPM_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}"
  531. "${CPACK_RPM_BINARY_SPECFILE}"
  532. WORKING_DIRECTORY "${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}"
  533. ERROR_FILE "${CPACK_TOPLEVEL_DIRECTORY}/rpmbuild.err"
  534. OUTPUT_FILE "${CPACK_TOPLEVEL_DIRECTORY}/rpmbuild.out")
  535. IF(CPACK_RPM_PACKAGE_DEBUG)
  536. MESSAGE("CPackRPM:Debug: You may consult rpmbuild logs in: ")
  537. MESSAGE("CPackRPM:Debug: - ${CPACK_TOPLEVEL_DIRECTORY}/rpmbuild.err")
  538. MESSAGE("CPackRPM:Debug: - ${CPACK_TOPLEVEL_DIRECTORY}/rpmbuild.out")
  539. ENDIF(CPACK_RPM_PACKAGE_DEBUG)
  540. ELSE(RPMBUILD_EXECUTABLE)
  541. IF(ALIEN_EXECUTABLE)
  542. MESSAGE(FATAL_ERROR "RPM packaging through alien not done (yet)")
  543. ENDIF(ALIEN_EXECUTABLE)
  544. ENDIF(RPMBUILD_EXECUTABLE)