Provided by: cmake-data_3.16.3-1ubuntu1.20.04.1_all bug

NAME

       cpack-generators - CPack Generator Reference

GENERATORS

   CPack Archive Generator
       Archive  CPack  generator  that  supports  packaging  of sources and binaries in different
       formats:

          • 7Z - 7zip - (.7z)

          • TBZ2 (.tar.bz2)

          • TGZ (.tar.gz)

          • TXZ (.tar.xz)

          • TZ (.tar.Z)

          • TZST (.tar.zst)

          • ZIP (.zip)

   Variables specific to CPack Archive generator
       CPACK_ARCHIVE_FILE_NAME

       CPACK_ARCHIVE_<component>_FILE_NAME
              Package file name without extension which is added automatically depending  on  the
              archive format.

              • Mandatory : YES

              •

                Default
                       <CPACK_PACKAGE_FILE_NAME>[-<component>].<extension>  with  spaces replaced
                       by ‘-‘

       CPACK_ARCHIVE_COMPONENT_INSTALL
              Enable component packaging for CPackArchive

              • Mandatory : NO

              • Default   : OFF

              If enabled (ON) multiple packages  are  generated.  By  default  a  single  package
              containing files of all components is generated.

   CPack Bundle Generator
       CPack Bundle generator (macOS) specific options

   Variables specific to CPack Bundle generator
       Installers  built  on  macOS  using  the Bundle generator use the aforementioned DragNDrop
       (CPACK_DMG_xxx)    variables,    plus    the    following    Bundle-specific    parameters
       (CPACK_BUNDLE_xxx).

       CPACK_BUNDLE_NAME
              The  name  of  the generated bundle. This appears in the macOS Finder as the bundle
              name. Required.

       CPACK_BUNDLE_PLIST
              Path to an macOS Property List (.plist) file that will be used  for  the  generated
              bundle.  This  assumes  that  the  caller  has  generated  or  specified  their own
              Info.plist file. Required.

       CPACK_BUNDLE_ICON
              Path to an macOS icon file that will be used as the icon for the generated  bundle.
              This  is the icon that appears in the macOS Finder for the bundle, and in the macOS
              dock when the bundle is opened. Required.

       CPACK_BUNDLE_STARTUP_COMMAND
              Path to a startup script. This is a path to an executable or script  that  will  be
              run  whenever  an  end-user double-clicks the generated bundle in the macOS Finder.
              Optional.

       CPACK_BUNDLE_APPLE_CERT_APP
              The name of your Apple supplied code signing certificate for the application.   The
              name  usually  takes  the  form  Developer  ID Application: [Name] or 3rd Party Mac
              Developer Application: [Name]. If this variable is not set the application will not
              be signed.

       CPACK_BUNDLE_APPLE_ENTITLEMENTS
              The  name  of the Property List (.plist) file that contains your Apple entitlements
              for sandboxing your application. This file is required for submission to the  macOS
              App Store.

       CPACK_BUNDLE_APPLE_CODESIGN_FILES
              A  list of additional files that you wish to be signed. You do not need to list the
              main application folder, or the main executable. You should list any frameworks and
              plugins that are included in your app bundle.

       CPACK_BUNDLE_APPLE_CODESIGN_PARAMETER
              Additional parameter that will passed to codesign.  Default value: --deep -f

       CPACK_COMMAND_CODESIGN
              Path  to the codesign(1) command used to sign applications with an Apple cert. This
              variable can be used to override the automatically detected command (or specify its
              location if the auto-detection fails to find it).

   CPack Cygwin Generator
       Cygwin CPack generator (Cygwin).

   Variables specific to CPack Cygwin generator
       The following variable is specific to installers build on and/or for Cygwin:

       CPACK_CYGWIN_PATCH_NUMBER
              The Cygwin patch number.  FIXME: This documentation is incomplete.

       CPACK_CYGWIN_PATCH_FILE
              The Cygwin patch file.  FIXME: This documentation is incomplete.

       CPACK_CYGWIN_BUILD_SCRIPT
              The Cygwin build script.  FIXME: This documentation is incomplete.

   CPack DEB Generator
       The built in (binary) CPack DEB generator (Unix only)

   Variables specific to CPack Debian (DEB) generator
       The  CPack  DEB  generator  may  be used to create DEB package using CPack.  The CPack DEB
       generator is a CPack generator thus it uses the CPACK_XXX variables used by CPack.

       The CPack DEB generator should work on any Linux host  but  it  will  produce  better  deb
       package when Debian specific tools dpkg-xxx are usable on the build system.

       The  CPack  DEB  generator  has  specific  features  which are controlled by the specifics
       CPACK_DEBIAN_XXX variables.

       CPACK_DEBIAN_<COMPONENT>_XXXX variables may be used in order to  have  component  specific
       values.   Note however that <COMPONENT> refers to the grouping name written in upper case.
       It may be either a component name or a component GROUP name.

       Here are some CPack DEB generator wiki resources that are here for  historic  reasons  and
       are no longer maintained but may still prove useful:

          • https://gitlab.kitware.com/cmake/community/wikis/doc/cpack/Configurationhttps://gitlab.kitware.com/cmake/community/wikis/doc/cpack/PackageGenerators#deb-unix-only

       List of CPack DEB generator specific variables:

       CPACK_DEB_COMPONENT_INSTALL
              Enable component packaging for CPackDEB

              • Mandatory : NO

              • Default   : OFF

              If enabled (ON) multiple packages  are  generated.  By  default  a  single  package
              containing files of all components is generated.

       CPACK_DEBIAN_PACKAGE_NAME

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_NAME
              Set Package control field (variable is automatically transformed to lower case).

              • Mandatory : YES

              • Default   :

                • CPACK_PACKAGE_NAME for non-component based installations

                • CPACK_DEBIAN_PACKAGE_NAME   suffixed   with  -<COMPONENT>  for  component-based
                  installations.

              See https://www.debian.org/doc/debian-policy/ch-controlfields.html#s-f-Source

       CPACK_DEBIAN_FILE_NAME

       CPACK_DEBIAN_<COMPONENT>_FILE_NAME
              Package file name.

              • Mandatory : YES

              • Default   : <CPACK_PACKAGE_FILE_NAME>[-<component>].deb

              This may be set to DEB-DEFAULT to allow the CPack DEB generator to generate package
              file name by itself in deb format:

                 <PackageName>_<VersionNumber>-<DebianRevisionNumber>_<DebianArchitecture>.deb

              Alternatively provided package file name must end with either .deb or .ipk suffix.

              NOTE:
                 Preferred setting of this variable is DEB-DEFAULT but for backward compatibility
                 with the CPack DEB generator in CMake prior  to  version  3.6  this  feature  is
                 disabled by default.

              NOTE:
                 By  using  non  default filenames duplicate names may occur. Duplicate files get
                 overwritten and it is up to the packager to set the variables in a  manner  that
                 will prevent such errors.

       CPACK_DEBIAN_PACKAGE_EPOCH
              The Debian package epoch

              • Mandatory : No

              • Default   : -

              Optional  number  that  should  be  incremented when changing versioning schemas or
              fixing mistakes in the version numbers of older packages.

       CPACK_DEBIAN_PACKAGE_VERSION
              The Debian package version

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_VERSION

              This variable may contain only alphanumerics (A-Za-z0-9) and the characters . + - ~
              (full   stop,   plus,   hyphen,   tilde)   and   should  start  with  a  digit.  If
              CPACK_DEBIAN_PACKAGE_RELEASE is not set then hyphens are not allowed.

              NOTE:
                 For backward compatibility with CMake 3.9  and  lower  a  failed  test  of  this
                 variable’s  content  is  not a hard error when both CPACK_DEBIAN_PACKAGE_RELEASE
                 and CPACK_DEBIAN_PACKAGE_EPOCH variables are  not  set.  An  author  warning  is
                 reported instead.

       CPACK_DEBIAN_PACKAGE_RELEASE
              The Debian package release - Debian revision number.

              • Mandatory : No

              • Default   : -

              This  is the numbering of the DEB package itself, i.e. the version of the packaging
              and not the version of the  content  (see  CPACK_DEBIAN_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_DEBIAN_PACKAGE_ARCHITECTURE

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_ARCHITECTURE
              The Debian package architecture

              • Mandatory : YES

              • Default   : Output of dpkg --print-architecture (or i386 if dpkg is not found)

       CPACK_DEBIAN_PACKAGE_DEPENDS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_DEPENDS
              Sets the Debian dependencies of this package.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_DEPENDS for component-based installations.

              NOTE:
                 If       CPACK_DEBIAN_PACKAGE_SHLIBDEPS       or        more        specifically
                 CPACK_DEBIAN_<COMPONENT>_PACKAGE_SHLIBDEPS   is  set  for  this  component,  the
                 discovered        dependencies        will        be         appended         to
                 CPACK_DEBIAN_<COMPONENT>_PACKAGE_DEPENDS                instead               of
                 CPACK_DEBIAN_PACKAGE_DEPENDS. If CPACK_DEBIAN_<COMPONENT>_PACKAGE_DEPENDS is  an
                 empty  string,  only  the  automatically discovered dependencies will be set for
                 this component.

              Example:

                 set(CPACK_DEBIAN_PACKAGE_DEPENDS "libc6 (>= 2.3.1-6), libc6 (< 2.4)")

       CPACK_DEBIAN_ENABLE_COMPONENT_DEPENDS
              Sets inter component dependencies if listed with CPACK_COMPONENT_<compName>_DEPENDS
              variables.

              • Mandatory : NO

              • Default   : -

       CPACK_DEBIAN_PACKAGE_MAINTAINER
              The Debian package maintainer

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_CONTACT

       CPACK_DEBIAN_PACKAGE_DESCRIPTION

       CPACK_DEBIAN_<COMPONENT>_DESCRIPTION
              The Debian package description

              • Mandatory : YES

              • Default   :

                • CPACK_DEBIAN_<COMPONENT>_DESCRIPTION  (component based installers only) if set,
                  or CPACK_DEBIAN_PACKAGE_DESCRIPTION if set, or

                • CPACK_COMPONENT_<compName>_DESCRIPTION (component  based  installers  only)  if
                  set, or CPACK_PACKAGE_DESCRIPTION if set, or

                • content of the file specified in CPACK_PACKAGE_DESCRIPTION_FILE if set

              If after that description is not set, CPACK_PACKAGE_DESCRIPTION_SUMMARY going to be
              used if set. Otherwise, CPACK_PACKAGE_DESCRIPTION_SUMMARY  will  be  added  as  the
              first line of description as defined in Debian Policy Manual.

       CPACK_DEBIAN_PACKAGE_SECTION

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_SECTION
              Set Section control field e.g. admin, devel, doc, …

              • Mandatory : YES

              • Default   : “devel”

              See https://www.debian.org/doc/debian-policy/ch-archive.html#s-subsections

       CPACK_DEBIAN_ARCHIVE_TYPE
              The archive format used for creating the Debian package.

              • Mandatory : YES

              • Default   : “gnutar”

              Possible value is:

              • gnutar

              NOTE:
                 This  variable  previously  defaulted  to  the  paxr  value,  but dpkg has never
                 supported that tar format. For backwards compatibility the paxr  value  will  be
                 mapped to gnutar and a deprecation message will be emitted.

       CPACK_DEBIAN_COMPRESSION_TYPE
              The compression used for creating the Debian package.

              • Mandatory : YES

              • Default   : “gzip”

              Possible values are:

              • lzma

              • xz

              • bzip2

              • gzip

       CPACK_DEBIAN_PACKAGE_PRIORITY

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_PRIORITY
              Set Priority control field e.g. required, important, standard, optional, extra

              • Mandatory : YES

              • Default   : “optional”

              See https://www.debian.org/doc/debian-policy/ch-archive.html#s-priorities

       CPACK_DEBIAN_PACKAGE_HOMEPAGE
              The  URL  of  the  web site for this package, preferably (when applicable) the site
              from which the  original  source  can  be  obtained  and  any  additional  upstream
              documentation or information may be found.

              • Mandatory : NO

              • Default   : CMAKE_PROJECT_HOMEPAGE_URL

              NOTE:
                 The  content  of  this  field is a simple URL without any surrounding characters
                 such as <>.

       CPACK_DEBIAN_PACKAGE_SHLIBDEPS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_SHLIBDEPS
              May be set to ON  in  order  to  use  dpkg-shlibdeps  to  generate  better  package
              dependency list.

              • Mandatory : NO

              • Default   :

                • CPACK_DEBIAN_PACKAGE_SHLIBDEPS if set or

                • OFF

              NOTE:
                 You  may  need  set  CMAKE_INSTALL_RPATH to an appropriate value if you use this
                 feature, because if you don’t dpkg-shlibdeps may fail to find  your  own  shared
                 libs.                                                                        See
                 https://gitlab.kitware.com/cmake/community/wikis/doc/cmake/RPATH-handling

       CPACK_DEBIAN_PACKAGE_DEBUG
              May be set when invoking cpack in order to trace debug information during the CPack
              DEB generator run.

              • Mandatory : NO

              • Default   : -

       CPACK_DEBIAN_PACKAGE_PREDEPENDS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_PREDEPENDS
              Sets  the  Pre-Depends  field  of the Debian package.  Like Depends, except that it
              also forces dpkg to  complete  installation  of  the  packages  named  before  even
              starting the installation of the package which declares the pre-dependency.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_PREDEPENDS for component-based installations.

              See http://www.debian.org/doc/debian-policy/ch-relationships.html#s-binarydeps

       CPACK_DEBIAN_PACKAGE_ENHANCES

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_ENHANCES
              Sets  the  Enhances  field of the Debian package.  Similar to Suggests but works in
              the opposite direction: declares that a package can enhance  the  functionality  of
              another package.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_ENHANCES for component-based installations.

              See http://www.debian.org/doc/debian-policy/ch-relationships.html#s-binarydeps

       CPACK_DEBIAN_PACKAGE_BREAKS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_BREAKS
              Sets  the  Breaks  field of the Debian package.  When a binary package (P) declares
              that it breaks other packages (B), dpkg  will  not  allow  the  package  (P)  which
              declares  Breaks  be  unpacked  unless  the  packages  that  will be broken (B) are
              deconfigured first.  As long as the  package  (P)  is  configured,  the  previously
              deconfigured packages (B) cannot be reconfigured again.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_BREAKS for component-based installations.

              See https://www.debian.org/doc/debian-policy/ch-relationships.html#s-breaks

       CPACK_DEBIAN_PACKAGE_CONFLICTS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_CONFLICTS
              Sets the Conflicts field of the Debian package.  When one binary package declares a
              conflict with another using a Conflicts field, dpkg  will  not  allow  them  to  be
              unpacked on the system at the same time.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_CONFLICTS for component-based installations.

              See https://www.debian.org/doc/debian-policy/ch-relationships.html#s-conflicts

              NOTE:
                 This  is  a  stronger restriction than Breaks, which prevents the broken package
                 from being configured while the breaking package is in the “Unpacked” state  but
                 allows both packages to be unpacked at the same time.

       CPACK_DEBIAN_PACKAGE_PROVIDES

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_PROVIDES
              Sets  the  Provides  field  of  the Debian package.  A virtual package is one which
              appears in the Provides control field of another package.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_PROVIDES for component-based installations.

              See https://www.debian.org/doc/debian-policy/ch-relationships.html#s-virtual

       CPACK_DEBIAN_PACKAGE_REPLACES

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_REPLACES
              Sets the Replaces field of the Debian  package.   Packages  can  declare  in  their
              control  file  that  they  should  overwrite  files  in  certain other packages, or
              completely replace other packages.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_REPLACES for component-based installations.

              See http://www.debian.org/doc/debian-policy/ch-relationships.html#s-binarydeps

       CPACK_DEBIAN_PACKAGE_RECOMMENDS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_RECOMMENDS
              Sets the Recommends field of the Debian package.   Allows  packages  to  declare  a
              strong, but not absolute, dependency on other packages.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_RECOMMENDS for component-based installations.

              See http://www.debian.org/doc/debian-policy/ch-relationships.html#s-binarydeps

       CPACK_DEBIAN_PACKAGE_SUGGESTS

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_SUGGESTS
              Sets  the  Suggests  field  of  the  Debian  package.  Allows packages to declare a
              suggested package install grouping.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_SUGGESTS for component-based installations.

              See http://www.debian.org/doc/debian-policy/ch-relationships.html#s-binarydeps

       CPACK_DEBIAN_PACKAGE_GENERATE_SHLIBS

              • Mandatory : NO

              • Default   : OFF

              Allows to generate shlibs control file automatically. Compatibility is  defined  by
              CPACK_DEBIAN_PACKAGE_GENERATE_SHLIBS_POLICY variable value.

              NOTE:
                 Libraries  are  only  considered if they have both library name and version set.
                 This can be done by  setting  SOVERSION  property  with  set_target_properties()
                 command.

       CPACK_DEBIAN_PACKAGE_GENERATE_SHLIBS_POLICY
              Compatibility policy for auto-generated shlibs control file.

              • Mandatory : NO

              • Default   : “=”

              Defines  compatibility  policy  for  auto-generated  shlibs control file.  Possible
              values: “=”, “>=”

              See
              https://www.debian.org/doc/debian-policy/ch-sharedlibs.html#s-sharedlibs-shlibdeps

       CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_CONTROL_EXTRA
              This  variable  allow  advanced  user  to  add custom script to the control.tar.gz.
              Typical usage is for conffiles, postinst, postrm, prerm.

              • Mandatory : NO

              • Default   : -

              Usage:

                 set(CPACK_DEBIAN_PACKAGE_CONTROL_EXTRA
                     "${CMAKE_CURRENT_SOURCE_DIR}/prerm;${CMAKE_CURRENT_SOURCE_DIR}/postrm")

              NOTE:
                 The original permissions of the files will be used in the final  package  unless
                 the   variable   CPACK_DEBIAN_PACKAGE_CONTROL_STRICT_PERMISSION   is   set.   In
                 particular, the scripts should have the proper  executable  flag  prior  to  the
                 generation of the package.

       CPACK_DEBIAN_PACKAGE_CONTROL_STRICT_PERMISSION

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_CONTROL_STRICT_PERMISSION
              This  variable  indicates  if the Debian policy on control files should be strictly
              followed.

              • Mandatory : NO

              • Default   : FALSE

              Usage:

                 set(CPACK_DEBIAN_PACKAGE_CONTROL_STRICT_PERMISSION TRUE)

              NOTE:
                 This overrides the permissions on the original files, following the rules set by
                 Debian                                                                    policy
                 https://www.debian.org/doc/debian-policy/ch-files.html#s-permissions-owners

       CPACK_DEBIAN_PACKAGE_SOURCE

       CPACK_DEBIAN_<COMPONENT>_PACKAGE_SOURCE
              Sets the Source field of the binary Debian package.  When the binary  package  name
              is   not  the  same  as  the  source  package  name  (in  particular  when  several
              components/binaries are generated from one source) the source from which the binary
              has been generated should be indicated with the field Source.

              • Mandatory : NO

              • Default   :

                • An empty string for non-component based installations

                • CPACK_DEBIAN_PACKAGE_SOURCE for component-based installations.

              See https://www.debian.org/doc/debian-policy/ch-controlfields.html#s-f-Source

              NOTE:
                 This  value  is  not  interpreted.  It  is possible to pass an optional revision
                 number of the referenced source package as well.

   Packaging of debug information
       Dbgsym packages contain debug symbols for debugging packaged binaries.

       Dbgsym packaging has its own set of variables:

       CPACK_DEBIAN_DEBUGINFO_PACKAGE

       CPACK_DEBIAN_<component>_DEBUGINFO_PACKAGE
              Enable generation of dbgsym .ddeb package(s).

              • Mandatory : NO

              • Default   : OFF

       NOTE:
          Binaries  must  contain  debug  symbols  before  packaging  so  use  either  Debug   or
          RelWithDebInfo for CMAKE_BUILD_TYPE variable value.

   Building Debian packages on Windows
       To communicate UNIX file permissions from the install stage to the CPack DEB generator the
       “cmake_mode_t” NTFS alternate data stream (ADT) is used.

       When a filesystem without ADT support is used only owner  read/write  permissions  can  be
       preserved.

   Reproducible packages
       The  environment variable SOURCE_DATE_EPOCH may be set to a UNIX timestamp, defined as the
       number of seconds, excluding leap seconds, since 01 Jan 1970 00:00:00 UTC.   If  set,  the
       CPack DEB generator will use its value for timestamps in the package.

   CPack DragNDrop Generator
       The DragNDrop CPack generator (macOS) creates a DMG image.

   Variables specific to CPack DragNDrop generator
       The following variables are specific to the DragNDrop installers built on macOS:

       CPACK_DMG_VOLUME_NAME
              The volume name of the generated disk image. Defaults to CPACK_PACKAGE_FILE_NAME.

       CPACK_DMG_FORMAT
              The  disk  image  format.  Common  values  are  UDRO  (UDIF  read-only), UDZO (UDIF
              zlib-compressed) or UDBZ (UDIF bzip2-compressed).  Refer  to  hdiutil(1)  for  more
              information on other available formats. Defaults to UDZO.

       CPACK_DMG_DS_STORE
              Path  to  a  custom  .DS_Store file. This .DS_Store file can be used to specify the
              Finder window position/geometry and layout (such as hidden toolbars,  placement  of
              the  icons  etc.).  This file has to be generated by the Finder (either manually or
              through AppleScript) using a normal folder from which the .DS_Store file  can  then
              be extracted.

       CPACK_DMG_DS_STORE_SETUP_SCRIPT
              Path  to  a  custom  AppleScript  file.   This  AppleScript  is  used to generate a
              .DS_Store file which specifies the Finder window position/geometry and layout (such
              as  hidden  toolbars,  placement  of  the  icons  etc.).   By  specifying  a custom
              AppleScript there is no need to use CPACK_DMG_DS_STORE, as the  .DS_Store  that  is
              generated by the AppleScript will be packaged.

       CPACK_DMG_BACKGROUND_IMAGE
              Path  to  an  image file to be used as the background.  This file will be copied to
              .background/background.<ext>, where <ext> is the  original  image  file  extension.
              The     background     image     is     installed    into    the    image    before
              CPACK_DMG_DS_STORE_SETUP_SCRIPT is executed or CPACK_DMG_DS_STORE is installed.  By
              default no background image is set.

       CPACK_DMG_DISABLE_APPLICATIONS_SYMLINK
              Default  behaviour  is  to include a symlink to /Applications in the DMG.  Set this
              option to ON to avoid adding the symlink.

       CPACK_DMG_SLA_DIR
              Directory where license and menu files for different languages are stored.  Setting
              this causes CPack to look for a <language>.menu.txt and <language>.license.txt file
              for every language defined in CPACK_DMG_SLA_LANGUAGES. If both  this  variable  and
              CPACK_RESOURCE_FILE_LICENSE  are  set,  CPack will only look for the menu files and
              use the same license file for all languages.

       CPACK_DMG_SLA_LANGUAGES
              Languages for which a license agreement is provided  when  mounting  the  generated
              DMG.  A menu file consists of 9 lines of text. The first line is is the name of the
              language itself,  uppercase,  in  English  (e.g.  German).   The  other  lines  are
              translations of the following strings:

              • Agree

              • Disagree

              • Print

              • Save…

              • You  agree  to  the  terms  of  the  License Agreement when you click the “Agree”
                button.

              • Software License Agreement

              • This text cannot be saved. The disk may be full or locked, or  the  file  may  be
                locked.

              • Unable to print. Make sure you have selected a printer.

              For  every  language in this list, CPack will try to find files <language>.menu.txt
              and <language>.license.txt in the  directory  specified  by  the  CPACK_DMG_SLA_DIR
              variable.

       CPACK_COMMAND_HDIUTIL
              Path  to  the hdiutil(1) command used to operate on disk image files on macOS. This
              variable can be used to override the automatically detected command (or specify its
              location if the auto-detection fails to find it).

       CPACK_COMMAND_SETFILE
              Path  to  the  SetFile(1)  command  used  to  set  extended attributes on files and
              directories on macOS. This variable can  be  used  to  override  the  automatically
              detected command (or specify its location if the auto-detection fails to find it).

       CPACK_COMMAND_REZ
              Path to the Rez(1) command used to compile resources on macOS. This variable can be
              used to override the automatically detected command (or specify its location if the
              auto-detection fails to find it).

   CPack External Generator
       CPack provides many generators to create packages for a variety of platforms and packaging
       systems. The intention is for  CMake/CPack  to  be  a  complete  end-to-end  solution  for
       building  and  packaging a software project. However, it may not always be possible to use
       CPack for the entire packaging process, due to either technical  limitations  or  policies
       that  require  the  use  of  certain tools. For this reason, CPack provides the “External”
       generator, which allows external packaging software to  take  advantage  of  some  of  the
       functionality provided by CPack, such as component installation and the dependency graph.

   Integration with External Packaging Tools
       The  CPack  External  generator  generates  a  .json  file  containing  the CPack internal
       metadata, which gives external software  information  on  how  to  package  the  software.
       External  packaging  software  may  itself  invoke  CPack, consume the generated metadata,
       install and package files as required.

       Alternatively CPack can invoke an external packaging software through an  optional  custom
       CMake script in CPACK_EXTERNAL_PACKAGE_SCRIPT instead.

       Staging  of  installation files may also optionally be taken care of by the generator when
       enabled through the CPACK_EXTERNAL_ENABLE_STAGING variable.

   JSON Format
       The JSON metadata file contains a list of  CPack  components  and  component  groups,  the
       various  options  passed  to  cpack_add_component()  and  cpack_add_component_group(), the
       dependencies between the components and component groups, and various other options passed
       to CPack.

       The   JSON’s   root   object  will  always  provide  two  fields:  formatVersionMajor  and
       formatVersionMinor, which are always integers that  describe  the  output  format  of  the
       generator.  Backwards-compatible  changes  to the output format (for example, adding a new
       field  that  didn’t  exist  before)  cause  the  minor  version  to  be  incremented,  and
       backwards-incompatible  changes  (for  example,  deleting a field or changing its meaning)
       cause the major version to be incremented and the minor version reset  to  0.  The  format
       version  is  always  of  the format major.minor. In other words, it always has exactly two
       parts, separated by a period.

       You can request one or more specific versions of the output format as described below with
       CPACK_EXTERNAL_REQUESTED_VERSIONS.  The  output  format  will  have  a  major version that
       exactly matches the requested major version, and a minor version that is greater  than  or
       equal   to   the   requested   minor   version.   If   no   version   is   requested  with
       CPACK_EXTERNAL_REQUESTED_VERSIONS, the latest known major  version  is  used  by  default.
       Currently, the only supported format is 1.0, which is described below.

   Version 1.0
       In  addition  to  the  standard  format  fields, format version 1.0 provides the following
       fields in the root:

       components
              The components field is an object with component names  as  the  keys  and  objects
              describing  the  components as the values. The component objects have the following
              fields:

              name   The name of the component. This is  always  the  same  as  the  key  in  the
                     components object.

              displayName
                     The value of the DISPLAY_NAME field passed to cpack_add_component().

              description
                     The value of the DESCRIPTION field passed to cpack_add_component().

              isHidden
                     True if HIDDEN was passed to cpack_add_component(), false if it was not.

              isRequired
                     True if REQUIRED was passed to cpack_add_component(), false if it was not.

              isDisabledByDefault
                     True if DISABLED was passed to cpack_add_component(), false if it was not.

              group  Only present if GROUP was passed to cpack_add_component(). If so, this field
                     is a string value containing the component’s group.

              dependencies
                     An array of components the component depends on. This contains the values in
                     the DEPENDS argument passed to cpack_add_component(). If no DEPENDS argument
                     was passed, this is an empty list.

              installationTypes
                     An array of installation types the component is part of. This  contains  the
                     values  in the INSTALL_TYPES argument passed to cpack_add_component(). If no
                     INSTALL_TYPES argument was passed, this is an empty list.

              isDownloaded
                     True if DOWNLOADED was passed to cpack_add_component(), false if it was not.

              archiveFile
                     The name of the archive  file  passed  with  the  ARCHIVE_FILE  argument  to
                     cpack_add_component().  If  no  ARCHIVE_FILE argument was passed, this is an
                     empty string.

       componentGroups
              The componentGroups field is an object with component group names as the  keys  and
              objects  describing the component groups as the values. The component group objects
              have the following fields:

              name   The name of the component group. This is always the same as the key  in  the
                     componentGroups object.

              displayName
                     The value of the DISPLAY_NAME field passed to cpack_add_component_group().

              description
                     The value of the DESCRIPTION field passed to cpack_add_component_group().

              parentGroup
                     Only  present  if PARENT_GROUP was passed to cpack_add_component_group(). If
                     so, this field is a string value containing  the  component  group’s  parent
                     group.

              isExpandedByDefault
                     True  if EXPANDED was passed to cpack_add_component_group(), false if it was
                     not.

              isBold True if BOLD_TITLE was passed to cpack_add_component_group(),  false  if  it
                     was not.

              components
                     An  array  of  names  of  components  that  are  direct members of the group
                     (components that have this group as their GROUP).  Components  of  subgroups
                     are not included.

              subgroups
                     An  array  of  names  of  component  groups  that are subgroups of the group
                     (groups that have this group as their PARENT_GROUP).

       installationTypes
              The installationTypes field is an object with installation type names as  the  keys
              and  objects describing the installation types as the values. The installation type
              objects have the following fields:

              name   The name of the installation type. This is always the same as the key in the
                     installationTypes object.

              displayName
                     The value of the DISPLAY_NAME field passed to cpack_add_install_type().

              index  The integer index of the installation type in the list.

       projects
              The  projects field is an array of objects describing CMake projects which comprise
              the   CPack   project.   The   values   in   this   field    are    derived    from
              CPACK_INSTALL_CMAKE_PROJECTS.  In  most  cases, this will be only a single project.
              The project objects have the following fields:

              projectName
                     The project name passed to CPACK_INSTALL_CMAKE_PROJECTS.

              component
                     The name of the component or component set which comprises the project.

              directory
                     The build directory of the  CMake  project.  This  is  the  directory  which
                     contains the cmake_install.cmake script.

              subDirectory
                     The subdirectory to install the project into inside the CPack package.

       packageName
              The package name given in CPACK_PACKAGE_NAME. Only present if this option is set.

       packageVersion
              The  package version given in CPACK_PACKAGE_VERSION. Only present if this option is
              set.

       packageDescriptionFile
              The package description file given in CPACK_PACKAGE_DESCRIPTION_FILE. Only  present
              if this option is set.

       packageDescriptionSummary
              The  package  description  summary given in CPACK_PACKAGE_DESCRIPTION_SUMMARY. Only
              present if this option is set.

       buildConfig
              The build configuration given to CPack with the -C option.  Only  present  if  this
              option is set.

       defaultDirectoryPermissions
              The          default         directory         permissions         given         in
              CPACK_INSTALL_DEFAULT_DIRECTORY_PERMISSIONS. Only present if this option is set.

       setDestdir
              True if CPACK_SET_DESTDIR is true, false if it is not.

       packagingInstallPrefix
              The  install  prefix  given  in  CPACK_PACKAGING_INSTALL_PREFIX.  Only  present  if
              CPACK_SET_DESTDIR is true.

       stripFiles
              True if CPACK_STRIP_FILES is true, false if it is not.

       warnOnAbsoluteInstallDestination
              True if CPACK_WARN_ON_ABSOLUTE_INSTALL_DESTINATION is true, false if it is not.

       errorOnAbsoluteInstallDestination
              True if CPACK_ERROR_ON_ABSOLUTE_INSTALL_DESTINATION is true, false if it is not.

   Variables specific to CPack External generator
       CPACK_EXTERNAL_REQUESTED_VERSIONS
              This  variable  is  used  to  request  a  specific  version  of  the CPack External
              generator. It is a list of major.minor values, separated by semicolons.

              If this variable is set to a non-empty value, the  CPack  External  generator  will
              iterate  through each item in the list to search for a version that it knows how to
              generate. Requested versions should be listed in order of descending preference  by
              the client software, as the first matching version in the list will be generated.

              The  generator  knows  how  to generate the version if it has a versioned generator
              whose major version exactly matches the requested major version,  and  whose  minor
              version  is  greater  than or equal to the requested minor version. For example, if
              CPACK_EXTERNAL_REQUESTED_VERSIONS contains 1.0, and the  CPack  External  generator
              knows how to generate 1.1, it will generate 1.1.  If the generator doesn’t know how
              to generate a version in the list, it skips the version and looks at the next  one.
              If  it  doesn’t  know  how  to  generate any of the requested versions, an error is
              thrown.

              If this variable is not set,  or  is  empty,  the  CPack  External  generator  will
              generate the highest major and minor version that it knows how to generate.

              If an invalid version is encountered in CPACK_EXTERNAL_REQUESTED_VERSIONS (one that
              doesn’t match major.minor, where major and minor are integers), it is ignored.

       CPACK_EXTERNAL_ENABLE_STAGING
              This variable can be set to true to enable optional installation into  a  temporary
              staging  area  which  can  then  be picked up and packaged by an external packaging
              tool.  The top level directory used by CPack for  the  current  packaging  task  is
              contained  in CPACK_TOPLEVEL_DIRECTORY.  It is automatically cleaned up on each run
              before packaging is initiated and can be used for custom temporary  files  required
              by   the   external   packaging   tool.    It   also   contains  the  staging  area
              CPACK_TEMPORARY_DIRECTORY into which CPack performs the installation  when  staging
              is enabled.

       CPACK_EXTERNAL_PACKAGE_SCRIPT
              This variable can optionally specify the full path to a CMake script file to be run
              as part of the CPack invocation.  It is invoked after (optional) staging took place
              and  may  run  an  external  packaging tool. The script has access to the variables
              defined by the CPack config file.

   CPack FreeBSD Generator
       The built in (binary) CPack FreeBSD (pkg) generator (Unix only)

   Variables specific to CPack FreeBSD (pkg) generator
       The CPack FreeBSD generator may be used to create pkg(8) packages – these may be  used  on
       FreeBSD,  DragonflyBSD,  NetBSD,  OpenBSD,  but  also  on  Linux  or OSX, depending on the
       installed package-management tools – using CPack.

       The CPack FreeBSD generator is a CPack generator and uses the CPACK_XXX variables used  by
       CPack.  It  tries to re-use packaging information that may already be specified for Debian
       packages for the CPack DEB Generator. It also tries to re-use  RPM  packaging  information
       when Debian does not specify.

       The CPack FreeBSD generator should work on any host with libpkg installed. The packages it
       produces are specific to the host architecture and ABI.

       The CPack FreeBSD generator sets package-metadata through CPACK_FREEBSD_XXX variables. The
       CPack  FreeBSD  generator,  unlike  the  CPack  Deb  generator, does not specially support
       componentized packages; a single package  is  created  from  all  the  software  artifacts
       created through CMake.

       All of the variables can be set specifically for FreeBSD packaging in the CPackConfig file
       or in CMakeLists.txt, but most of them have  defaults  that  use  general  settings  (e.g.
       CMAKE_PROJECT_NAME)  or Debian-specific variables when those make sense (e.g. the homepage
       of an upstream project is usually unchanged by the flavor of packaging). When there is  no
       Debian  information  to  fall  back on, but the RPM packaging has it, fall back to the RPM
       information (e.g. package license).

       CPACK_FREEBSD_PACKAGE_NAME
              Sets the package name (in  the  package  manifest,  but  also  affects  the  output
              filename).

              • Mandatory: YES

              • Default:

                • CPACK_PACKAGE_NAME   (this   is   always   set   by   CPack  itself,  based  on
                  CMAKE_PROJECT_NAME).

       CPACK_FREEBSD_PACKAGE_COMMENT
              Sets the package comment. This is the short  description  displayed  by  pkg(8)  in
              standard “pkg info” output.

              • Mandatory: YES

              • Default:

                • CPACK_PACKAGE_DESCRIPTION_SUMMARY  (this  is  always  set  by  CPack itself, if
                  nothing else sets it explicitly).

                • PROJECT_DESCRIPTION (this  can  be  set  with  the  DESCRIPTION  parameter  for
                  project()).

       CPACK_FREEBSD_PACKAGE_DESCRIPTION
              Sets the package description. This is the long description of the package, given by
              “pkg info” with a specific package as argument.

              • Mandatory: YES

              • Default:

                • CPACK_DEBIAN_PACKAGE_DESCRIPTION (this may be set already for Debian packaging,
                  so we may as well re-use it).

       CPACK_FREEBSD_PACKAGE_WWW
              The  URL  of  the  web site for this package, preferably (when applicable) the site
              from which the  original  source  can  be  obtained  and  any  additional  upstream
              documentation or information may be found.

              • Mandatory: YES

              • Default:

                 • CMAKE_PROJECT_HOMEPAGE_URL,      or      if      that      is     not     set,
                   CPACK_DEBIAN_PACKAGE_HOMEPAGE (this may be set already for  Debian  packaging,
                   so we may as well re-use it).

       CPACK_FREEBSD_PACKAGE_LICENSE
              The license, or licenses, which apply to this software package. This must be one or
              more license-identifiers that pkg  recognizes  as  acceptable  license  identifiers
              (e.g. “GPLv2”).

              • Mandatory: YES

              • Default:

                • CPACK_RPM_PACKAGE_LICENSE

       CPACK_FREEBSD_PACKAGE_LICENSE_LOGIC
              This variable is only of importance if there is more than one license.  The default
              is “single”, which is only applicable to a single license.  Other acceptable values
              are  determined  by  pkg  –  those  are  “dual” or “multi” – meaning choice (OR) or
              simultaneous (AND) application of the licenses.

              • Mandatory: NO

              • Default: single

       CPACK_FREEBSD_PACKAGE_MAINTAINER
              The FreeBSD maintainer (e.g. kde@freebsd.org) of this package.

              • Mandatory: YES

              • Default: none

       CPACK_FREEBSD_PACKAGE_ORIGIN
              The origin (ports label) of this package; for packages built by  CPack  outside  of
              the ports system this is of less importance. The default puts the package somewhere
              under misc/, as a stopgap.

              • Mandatory: YES

              • Default: misc/<package name>

       CPACK_FREEBSD_PACKAGE_CATEGORIES
              The ports categories where this package lives (if it were to be built from  ports).
              If none is set a single category is determined based on the package origin.

              • Mandatory: YES

              • Default: derived from ORIGIN

       CPACK_FREEBSD_PACKAGE_DEPS
              A  list of package origins that should be added as package dependencies.  These are
              in the form <category>/<packagename>, e.g.  x11/libkonq.   No  version  information
              needs to be provided (this is not included in the manifest).

              • Mandatory: NO

              • Default: empty

   CPack IFW Generator
       See CPackIFW for details on the CPackIFW module.

   Overview
       CPack  IFW  generator  helps  you  to  create  online  and  offline  binary cross-platform
       installers with a graphical user interface.

       CPack IFW generator prepares project installation and  generates  configuration  and  meta
       information for QtIFW tools.

       The  QtIFW  provides  a  set of tools and utilities to create installers for the supported
       desktop Qt platforms: Linux, Microsoft Windows, and macOS.

       You should also install QtIFW to use CPack IFW generator.

   Hints
       Generally, the CPack IFW generator automatically finds QtIFW tools, but if you don’t use a
       default  path  for  installation of the QtIFW tools, the path may be specified in either a
       CMake or an environment variable:

       CPACK_IFW_ROOT
              An CMake variable which specifies the location of the QtIFW tool suite.

              The variable will be cached  in  the  CPackConfig.cmake  file  and  used  at  CPack
              runtime.

       QTIFWDIR
              An environment variable which specifies the location of the QtIFW tool suite.

       NOTE:
          The   specified   path   should   not   contain   “bin”   at   the  end  (for  example:
          “D:\DevTools\QtIFW2.0.5”).

       The CPACK_IFW_ROOT variable has a higher priority and overrides the value of the  QTIFWDIR
       variable.

   Internationalization
       Some  variables  and command arguments support internationalization via CMake script. This
       is an optional feature.

       Installers created by QtIFW tools have built-in support for internationalization and  many
       phrases are localized to many languages, but this does not apply to the description of the
       your components and groups that will be distributed.

       Localization of the description of your components and groups is useful for users of  your
       installers.

       A  localized  variable  or argument can contain a single default value, and a set of pairs
       the name of the locale and the localized value.

       For example:

          set(LOCALIZABLE_VARIABLE "Default value"
            en "English value"
            en_US "American value"
            en_GB "Great Britain value"
            )

   Variables
       You can use the following variables to change behavior of CPack IFW generator.

   Debug
       CPACK_IFW_VERBOSE
              Set to ON to enable addition debug output.  By default is OFF.

   Package
       CPACK_IFW_PACKAGE_TITLE
              Name  of  the  installer  as  displayed  on  the  title  bar.   By   default   used
              CPACK_PACKAGE_DESCRIPTION_SUMMARY.

       CPACK_IFW_PACKAGE_PUBLISHER
              Publisher of the software (as shown in the Windows Control Panel).  By default used
              CPACK_PACKAGE_VENDOR.

       CPACK_IFW_PRODUCT_URL
              URL to a page that contains product information on your web site.

       CPACK_IFW_PACKAGE_ICON
              Filename for a custom installer icon. The actual file is  ‘.icns’  (macOS),  ‘.ico’
              (Windows). No functionality on Unix.

       CPACK_IFW_PACKAGE_WINDOW_ICON
              Filename for a custom window icon in PNG format for the Installer application.

       CPACK_IFW_PACKAGE_LOGO
              Filename for a logo is used as QWizard::LogoPixmap.

       CPACK_IFW_PACKAGE_WATERMARK
              Filename for a watermark is used as QWizard::WatermarkPixmap.

       CPACK_IFW_PACKAGE_BANNER
              Filename for a banner is used as QWizard::BannerPixmap.

       CPACK_IFW_PACKAGE_BACKGROUND
              Filename for an image used as QWizard::BackgroundPixmap (only used by MacStyle).

       CPACK_IFW_PACKAGE_WIZARD_STYLE
              Wizard style to be used (“Modern”, “Mac”, “Aero” or “Classic”).

       CPACK_IFW_PACKAGE_STYLE_SHEET
              Filename for a stylesheet.

       CPACK_IFW_PACKAGE_WIZARD_DEFAULT_WIDTH
              Default width of the wizard in pixels. Setting a banner image will override this.

       CPACK_IFW_PACKAGE_WIZARD_DEFAULT_HEIGHT
              Default  height  of  the  wizard in pixels. Setting a watermark image will override
              this.

       CPACK_IFW_PACKAGE_TITLE_COLOR
              Color of the titles and subtitles (takes an HTML color code, such as “#88FF33”).

       CPACK_IFW_PACKAGE_START_MENU_DIRECTORY
              Name of the default program group for the product in the Windows Start menu.

              By default used CPACK_IFW_PACKAGE_NAME.

       CPACK_IFW_TARGET_DIRECTORY
              Default    target    directory    for    installation.      By     default     used
              “@ApplicationsDir@/CPACK_PACKAGE_INSTALL_DIRECTORY”

              You can use predefined variables.

       CPACK_IFW_ADMIN_TARGET_DIRECTORY
              Default target directory for installation with administrator rights.

              You can use predefined variables.

       CPACK_IFW_PACKAGE_GROUP
              The group, which will be used to configure the root package

       CPACK_IFW_PACKAGE_NAME
              The root package name, which will be used if configuration group is not specified

       CPACK_IFW_PACKAGE_MAINTENANCE_TOOL_NAME
              Filename  of the generated maintenance tool.  The platform-specific executable file
              extension is appended.

              By default used QtIFW defaults (maintenancetool).

       CPACK_IFW_PACKAGE_REMOVE_TARGET_DIR
              Set to OFF if the target directory should not be deleted when uninstalling.

              Is ON by default

       CPACK_IFW_PACKAGE_MAINTENANCE_TOOL_INI_FILE
              Filename for the configuration of the generated maintenance tool.

              By default used QtIFW defaults (maintenancetool.ini).

       CPACK_IFW_PACKAGE_ALLOW_NON_ASCII_CHARACTERS
              Set to ON if the installation path can contain non-ASCII characters.

              Is ON for QtIFW less 2.0 tools.

       CPACK_IFW_PACKAGE_ALLOW_SPACE_IN_PATH
              Set to OFF if the installation path cannot contain space characters.

              Is ON for QtIFW less 2.0 tools.

       CPACK_IFW_PACKAGE_CONTROL_SCRIPT
              Filename for a custom installer control script.

       CPACK_IFW_PACKAGE_RESOURCES
              List of additional resources (‘.qrc’ files) to include in the installer binary.

              You can use cpack_ifw_add_package_resources() command to resolve relative paths.

       CPACK_IFW_PACKAGE_FILE_EXTENSION
              The target binary extension.

              On Linux, the name of the target binary is automatically extended with  ‘.run’,  if
              you do not specify the extension.

              On  Windows,  the  target  is  created as an application with the extension ‘.exe’,
              which is automatically added, if not supplied.

              On Mac, the target is created as an DMG disk image with the extension ‘.dmg’, which
              is automatically added, if not supplied.

       CPACK_IFW_REPOSITORIES_ALL
              The list of remote repositories.

              The  default  value  of  this  variable  is  computed  by  CPack  and  contains all
              repositories added with command cpack_ifw_add_repository() or updated with  command
              cpack_ifw_update_repository().

       CPACK_IFW_DOWNLOAD_ALL
              If  this  is ON all components will be downloaded.  By default is OFF or used value
              from CPACK_DOWNLOAD_ALL if set

   Components
       CPACK_IFW_RESOLVE_DUPLICATE_NAMES
              Resolve duplicate names when installing components with groups.

       CPACK_IFW_PACKAGES_DIRECTORIES
              Additional  prepared  packages  dirs  that  will  be  used  to  resolve   dependent
              components.

       CPACK_IFW_REPOSITORIES_DIRECTORIES
              Additional  prepared  repository  dirs  that  will  be  used  to resolve and repack
              dependent components. This feature available only since QtIFW 3.1.

   Tools
       CPACK_IFW_FRAMEWORK_VERSION
              The version of used QtIFW tools.

       CPACK_IFW_BINARYCREATOR_EXECUTABLE
              The path to “binarycreator” command line client.

              This variable is cached and may be configured if needed.

       CPACK_IFW_REPOGEN_EXECUTABLE
              The path to “repogen” command line client.

              This variable is cached and may be configured if needed.

       CPACK_IFW_INSTALLERBASE_EXECUTABLE
              The path to “installerbase” installer executable base.

              This variable is cached and may be configured if needed.

       CPACK_IFW_DEVTOOL_EXECUTABLE
              The path to “devtool” command line client.

              This variable is cached and may be configured if needed.

   Online installer
       By default CPack IFW generator makes offline installer. This  means  that  all  components
       will be packaged into a binary file.

       To   make   a   component   downloaded,   you   must   set   the   DOWNLOADED   option  in
       cpack_add_component().

       Then you would use the command cpack_configure_downloads().  If you  set  ALL  option  all
       components will be downloaded.

       You  also  can  use command cpack_ifw_add_repository() and variable CPACK_IFW_DOWNLOAD_ALL
       for more specific configuration.

       CPack IFW generator creates “repository” dir in current binary dir. You would copy content
       of this dir to specified site (url).

   See Also
       Qt Installer Framework Manual:

       • Index page: http://doc.qt.io/qtinstallerframework/index.html

       • Component Scripting: http://doc.qt.io/qtinstallerframework/scripting.html

       • Predefined                                                                    Variables:
         http://doc.qt.io/qtinstallerframework/scripting.html#predefined-variables

       • Promoting Updates: http://doc.qt.io/qtinstallerframework/ifw-updates.html

       Download Qt Installer Framework for you platform from Qt site:
              http://download.qt.io/official_releases/qt-installer-framework

   CPack NSIS Generator
       CPack Nullsoft Scriptable Install System (NSIS) generator specific options

   Variables specific to CPack NSIS generator
       The following variables are specific to the graphical installers built on Windows Nullsoft
       Scriptable Install System.

       CPACK_NSIS_INSTALL_ROOT
              The  default installation directory presented to the end user by the NSIS installer
              is under this  root  dir.  The  full  directory  presented  to  the  end  user  is:
              ${CPACK_NSIS_INSTALL_ROOT}/${CPACK_PACKAGE_INSTALL_DIRECTORY}

       CPACK_NSIS_MUI_ICON
              An icon filename.  The name of a *.ico file used as the main icon for the generated
              install program.

       CPACK_NSIS_MUI_UNIICON
              An icon filename.  The name of a *.ico file used as the main icon for the generated
              uninstall program.

       CPACK_NSIS_INSTALLER_MUI_ICON_CODE
              undocumented.

       CPACK_NSIS_MUI_WELCOMEFINISHPAGE_BITMAP
              The filename of a bitmap to use as the NSIS MUI_WELCOMEFINISHPAGE_BITMAP.

       CPACK_NSIS_MUI_UNWELCOMEFINISHPAGE_BITMAP
              The filename of a bitmap to use as the NSIS MUI_UNWELCOMEFINISHPAGE_BITMAP.

       CPACK_NSIS_EXTRA_PREINSTALL_COMMANDS
              Extra  NSIS  commands  that  will be added to the beginning of the install Section,
              before your install tree is available on the target system.

       CPACK_NSIS_EXTRA_INSTALL_COMMANDS
              Extra NSIS commands that will be added to the end of  the  install  Section,  after
              your install tree is available on the target system.

       CPACK_NSIS_EXTRA_UNINSTALL_COMMANDS
              Extra  NSIS  commands  that  will  be  added  to the uninstall Section, before your
              install tree is removed from the target system.

       CPACK_NSIS_COMPRESSOR
              The arguments that will be passed to the NSIS SetCompressor command.

       CPACK_NSIS_ENABLE_UNINSTALL_BEFORE_INSTALL
              Ask about uninstalling previous versions first.  If this is  set  to  ON,  then  an
              installer  will  look  for previous installed versions and if one is found, ask the
              user whether to uninstall it before proceeding with the install.

       CPACK_NSIS_MODIFY_PATH
              Modify PATH toggle.  If this is set to ON, then an extra page will  appear  in  the
              installer  that  will allow the user to choose whether the program directory should
              be added to the system PATH variable.

       CPACK_NSIS_DISPLAY_NAME
              The display name string that appears in the Windows  Apps  &  features  in  Control
              Panel

       CPACK_NSIS_PACKAGE_NAME
              The title displayed at the top of the installer.

       CPACK_NSIS_INSTALLED_ICON_NAME
              A path to the executable that contains the installer icon.

       CPACK_NSIS_HELP_LINK
              URL to a web site providing assistance in installing your application.

       CPACK_NSIS_URL_INFO_ABOUT
              URL to a web site providing more information about your application.

       CPACK_NSIS_CONTACT
              Contact information for questions and comments about the installation process.

       CPACK_NSIS_<compName>_INSTALL_DIRECTORY
              Custom  install  directory  for  the  specified  component  <compName>  instead  of
              $INSTDIR.

       CPACK_NSIS_CREATE_ICONS_EXTRA
              Additional NSIS commands for creating Start Menu shortcuts.

       CPACK_NSIS_DELETE_ICONS_EXTRA
              Additional NSIS commands to uninstall Start Menu shortcuts.

       CPACK_NSIS_EXECUTABLES_DIRECTORY
              Creating NSIS Start Menu links assumes that they are in bin unless this variable is
              set.   For  example,  you would set this to exec if your executables are in an exec
              directory.

       CPACK_NSIS_MUI_FINISHPAGE_RUN
              Specify an executable to add an option to run  on  the  finish  page  of  the  NSIS
              installer.

       CPACK_NSIS_MENU_LINKS
              Specify  links in [application] menu.  This should contain a list of pair link link
              name. The link may be a URL or a path relative to installation prefix.  Like:

                 set(CPACK_NSIS_MENU_LINKS
                     "doc/cmake-@CMake_VERSION_MAJOR@.@CMake_VERSION_MINOR@/cmake.html"
                     "CMake Help" "https://cmake.org" "CMake Web Site")

   CPack NuGet Generator
       When build a NuGet package there is no direct way to control an output filename due a lack
       of  the  corresponding  CLI  option  of NuGet, so there is no CPACK_NUGET_PACKAGE_FILENAME
       variable. To form the output  filename  NuGet  uses  the  package  name  and  the  version
       according to its built-in rules.

       Also,  be aware that including a top level directory (CPACK_INCLUDE_TOPLEVEL_DIRECTORY) is
       ignored by this generator.

   Variables specific to CPack NuGet generator
       The CPack NuGet generator may be used to create NuGet  packages  using  CPack.  The  CPack
       NuGet generator is a CPack generator thus it uses the CPACK_XXX variables used by CPack.

       The  CPack  NuGet  generator  has  specific features which are controlled by the specifics
       CPACK_NUGET_XXX variables. In the “one per group”  mode  (see  CPACK_COMPONENTS_GROUPING),
       <compName>  placeholder  in the variables below would contain a group name (uppercased and
       turned into a “C” identifier).

       List of CPack NuGet generator specific variables:

       CPACK_NUGET_COMPONENT_INSTALL
              Enable component packaging for CPack NuGet generator

              • Mandatory : NO

              • Default   : OFF

       CPACK_NUGET_PACKAGE_NAME

       CPACK_NUGET_<compName>_PACKAGE_NAME
              The NUGET package name.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_NAME

       CPACK_NUGET_PACKAGE_VERSION

       CPACK_NUGET_<compName>_PACKAGE_VERSION
              The NuGet package version.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_VERSION

       CPACK_NUGET_PACKAGE_DESCRIPTION

       CPACK_NUGET_<compName>_PACKAGE_DESCRIPTION
              A long description of the package for UI display.

              • Mandatory : YES

              •

                Default :CPACK_COMPONENT_<compName>_DESCRIPTION,

                       • CPACK_COMPONENT_GROUP_<groupName>_DESCRIPTION,

                       • CPACK_PACKAGE_DESCRIPTION

       CPACK_NUGET_PACKAGE_AUTHORS

       CPACK_NUGET_<compName>_PACKAGE_AUTHORS
              A  comma-separated  list  of  packages  authors,  matching  the  profile  names  on
              nuget.org.  These  are  displayed in the NuGet Gallery on nuget.org and are used to
              cross-reference packages by the same authors.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_VENDOR

       CPACK_NUGET_PACKAGE_TITLE

       CPACK_NUGET_<compName>_PACKAGE_TITLE
              A human-friendly title of  the  package,  typically  used  in  UI  displays  as  on
              nuget.org  and  the Package Manager in Visual Studio. If not specified, the package
              ID is used.

              • Mandatory : NO

              •

                Default :CPACK_COMPONENT_<compName>_DISPLAY_NAME,

                       • CPACK_COMPONENT_GROUP_<groupName>_DISPLAY_NAME

       CPACK_NUGET_PACKAGE_OWNERS

       CPACK_NUGET_<compName>_PACKAGE_OWNERS
              A comma-separated list of the package creators using profile  names  on  nuget.org.
              This  is  often  the  same  list  as  in authors, and is ignored when uploading the
              package to nuget.org.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_HOMEPAGE_URL

       CPACK_NUGET_<compName>_PACKAGE_HOMEPAGE_URL
              A URL for the package’s home page, often shown in UI displays as well as nuget.org.

              • Mandatory : NO

              • Default   : CPACK_PACKAGE_HOMEPAGE_URL

       CPACK_NUGET_PACKAGE_LICENSEURL

       CPACK_NUGET_<compName>_PACKAGE_LICENSEURL
              A URL for the package’s license, often shown in UI displays as well as nuget.org.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_ICONURL

       CPACK_NUGET_<compName>_PACKAGE_ICONURL
              A URL for a 64x64 image with transparency background to use as  the  icon  for  the
              package in UI display.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_DESCRIPTION_SUMMARY

       CPACK_NUGET_<compName>_PACKAGE_DESCRIPTION_SUMMARY
              A  short description of the package for UI display. If omitted, a truncated version
              of description is used.

              • Mandatory : NO

              • Default   : CPACK_PACKAGE_DESCRIPTION_SUMMARY

       CPACK_NUGET_PACKAGE_RELEASE_NOTES

       CPACK_NUGET_<compName>_PACKAGE_RELEASE_NOTES
              A description of the changes made in this release of the package, often used in  UI
              like  the  Updates tab of the Visual Studio Package Manager in place of the package
              description.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_COPYRIGHT

       CPACK_NUGET_<compName>_PACKAGE_COPYRIGHT
              Copyright details for the package.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_TAGS

       CPACK_NUGET_<compName>_PACKAGE_TAGS
              A space-delimited list of tags and keywords  that  describe  the  package  and  aid
              discoverability of packages through search and filtering.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_DEPENDENCIES

       CPACK_NUGET_<compName>_PACKAGE_DEPENDENCIES
              A list of package dependencies.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_DEPENDENCIES_<dependency>_VERSION

       CPACK_NUGET_<compName>_PACKAGE_DEPENDENCIES_<dependency>_VERSION
              A  version  specification  for  the particular dependency, where <dependency> is an
              item of the dependency list (see above) transformed with MAKE_C_IDENTIFIER function
              of string() command.

              • Mandatory : NO

              • Default   : -

       CPACK_NUGET_PACKAGE_DEBUG
              Enable debug messages while executing CPack NuGet generator.

              • Mandatory : NO

              • Default   : OFF

   CPack PackageMaker Generator
       PackageMaker CPack generator (macOS).

   Variables specific to CPack PackageMaker generator
       The following variable is specific to installers built on Mac macOS using PackageMaker:

       CPACK_OSX_PACKAGE_VERSION
              The  version  of macOS that the resulting PackageMaker archive should be compatible
              with. Different versions of macOS support different features.  For  example,  CPack
              can  only  build  component-based  installers for macOS 10.4 or newer, and can only
              build installers that download component son-the-fly for macOS 10.5  or  newer.  If
              left  blank,  this  value will be set to the minimum version of macOS that supports
              the requested features. Set this variable to some value (e.g., 10.4)  only  if  you
              want to guarantee that your installer will work on that version of macOS, and don’t
              mind missing extra features available in the installer shipping with later versions
              of macOS.

   CPack productbuild Generator
       productbuild CPack generator (macOS).

   Variables specific to CPack productbuild generator
       The following variable is specific to installers built on Mac macOS using ProductBuild:

       CPACK_COMMAND_PRODUCTBUILD
              Path  to  the  productbuild(1)  command  used to generate a product archive for the
              macOS Installer or Mac App Store.  This  variable  can  be  used  to  override  the
              automatically detected command (or specify its location if the auto-detection fails
              to find it).

       CPACK_PRODUCTBUILD_IDENTITY_NAME
              Adds a digital signature to the resulting package.

       CPACK_PRODUCTBUILD_KEYCHAIN_PATH
              Specify a specific keychain to search for the signing identity.

       CPACK_COMMAND_PKGBUILD
              Path to the pkgbuild(1) command used to generate  an  macOS  component  package  on
              macOS.   This  variable  can be used to override the automatically detected command
              (or specify its location if the auto-detection fails to find it).

       CPACK_PKGBUILD_IDENTITY_NAME
              Adds a digital signature to the resulting package.

       CPACK_PKGBUILD_KEYCHAIN_PATH
              Specify a specific keychain to search for the signing identity.

       CPACK_PREFLIGHT_<COMP>_SCRIPT
              Full path to a file that will be used as the preinstall script for the named <COMP>
              component’s  package, where <COMP> is the uppercased component name.  No preinstall
              script is added if this variable is not defined for a given component.

       CPACK_POSTFLIGHT_<COMP>_SCRIPT
              Full path to a file that will be used as  the  postinstall  script  for  the  named
              <COMP>  component’s  package,  where  <COMP>  is the uppercased component name.  No
              postinstall script is added if this variable is not defined for a given component.

       CPACK_PRODUCTBUILD_RESOURCES_DIR
              If specified the productbuild generator copies files from this directory (including
              subdirectories)   to   the   Resources   directory.   This   is   done  before  the
              CPACK_RESOURCE_FILE_WELCOME,            CPACK_RESOURCE_FILE_README,             and
              CPACK_RESOURCE_FILE_LICENSE files are copied.

   CPack RPM Generator
       The built in (binary) CPack RPM generator (Unix only)

   Variables specific to CPack RPM generator
       The  CPack  RPM  generator  may be used to create RPM packages using CPack.  The CPack RPM
       generator is a CPack generator thus it uses the CPACK_XXX variables used by CPack.

       The CPack RPM generator has specific  features  which  are  controlled  by  the  specifics
       CPACK_RPM_XXX variables.

       CPACK_RPM_<COMPONENT>_XXXX  variables  may  be  used  in  order to have component specific
       values.  Note however that <COMPONENT> refers to the grouping name written in upper  case.
       It  may  be  either  a  component  name or a component GROUP name. Usually those variables
       correspond to RPM spec file entities. One may  find  information  about  spec  files  here
       http://www.rpm.org/wiki/Docs

       NOTE:
          <COMPONENT>  part  of  variables is preferred to be in upper case (e.g. if component is
          named  foo  then  use  CPACK_RPM_FOO_XXXX  variable  name  format)  as  is  with  other
          CPACK_<COMPONENT>_XXXX  variables.  For the purposes of back compatibility (CMake/CPack
          version 3.5 and lower) support for same cased component (e.g.  fOo  would  be  used  as
          CPACK_RPM_fOo_XXXX)  is  still  supported  for  variables  defined in older versions of
          CMake/CPack but is not guaranteed for variables that will be added in the  future.  For
          the sake of back compatibility same cased component variables also override upper cased
          versions where both are present.

       Here are some CPack RPM generator wiki resources that are here for  historic  reasons  and
       are no longer maintained but may still prove useful:

          • https://gitlab.kitware.com/cmake/community/wikis/doc/cpack/Configurationhttps://gitlab.kitware.com/cmake/community/wikis/doc/cpack/PackageGenerators#rpm-unix-only

       List of CPack RPM generator specific variables:

       CPACK_RPM_COMPONENT_INSTALL
              Enable component packaging for CPack RPM generator

              • Mandatory : NO

              • Default   : OFF

              If enabled (ON) multiple packages  are  generated.  By  default  a  single  package
              containing files of all components is generated.

       CPACK_RPM_PACKAGE_SUMMARY

       CPACK_RPM_<component>_PACKAGE_SUMMARY
              The RPM package summary.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_DESCRIPTION_SUMMARY

       CPACK_RPM_PACKAGE_NAME

       CPACK_RPM_<component>_PACKAGE_NAME
              The RPM package name.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_NAME

       CPACK_RPM_FILE_NAME

       CPACK_RPM_<component>_FILE_NAME
              Package file name.

              • Mandatory : YES

              •

                Default
                       <CPACK_PACKAGE_FILE_NAME>[-<component>].rpm with spaces replaced by ‘-‘

              This may be set to RPM-DEFAULT to allow rpmbuild tool to generate package file name
              by itself.  Alternatively provided package file name must end with .rpm suffix.

              NOTE:
                 By using user provided spec file, rpm macro extensions such  as  for  generating
                 debuginfo packages or by simply using multiple components more than one rpm file
                 may be generated, either from a single spec file or  from  multiple  spec  files
                 (each  component execution produces its own spec file).  In such cases duplicate
                 file names may occur as a result of this variable setting or spec  file  content
                 structure.  Duplicate  files get overwritten and it is up to the packager to set
                 the variables in a manner that will prevent such errors.

       CPACK_RPM_MAIN_COMPONENT
              Main component that is packaged without component suffix.

              • Mandatory : NO

              • Default   : -

              This variable can be set to any component or group name so that component or  group
              rpm package is generated without component suffix in filename and package name.

       CPACK_RPM_PACKAGE_EPOCH
              The RPM package epoch

              • Mandatory : No

              • Default   : -

              Optional  number  that  should  be  incremented when changing versioning schemas or
              fixing mistakes in the version numbers of older packages.

       CPACK_RPM_PACKAGE_VERSION
              The RPM package version.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_VERSION

       CPACK_RPM_PACKAGE_ARCHITECTURE

       CPACK_RPM_<component>_PACKAGE_ARCHITECTURE
              The RPM package architecture.

              • Mandatory : YES

              • Default   : Native architecture output by uname -m

              This may be set to noarch if you know you are building a noarch package.

       CPACK_RPM_PACKAGE_RELEASE
              The RPM package release.

              • Mandatory : YES

              • Default   : 1

              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.

       NOTE:
          This  is  the  string that goes into the RPM Release: field. Some distros (e.g. Fedora,
          CentOS) require 1%{?dist} format and not just a number.  %{?dist} part can be added  by
          setting CPACK_RPM_PACKAGE_RELEASE_DIST.

       CPACK_RPM_PACKAGE_RELEASE_DIST
              The dist tag that is added  RPM Release: field.

              • Mandatory : NO

              • Default   : OFF

              This  is the reported %{dist} tag from the current distribution or empty %{dist} if
              RPM macro is not set. If this variable is set then RPM Release: field value is  set
              to ${CPACK_RPM_PACKAGE_RELEASE}%{?dist}.

       CPACK_RPM_PACKAGE_LICENSE
              The RPM package license policy.

              • Mandatory : YES

              • Default   : “unknown”

       CPACK_RPM_PACKAGE_GROUP

       CPACK_RPM_<component>_PACKAGE_GROUP
              The RPM package group.

              • Mandatory : YES

              • Default   : “unknown”

       CPACK_RPM_PACKAGE_VENDOR
              The RPM package vendor.

              • Mandatory : YES

              • Default   : CPACK_PACKAGE_VENDOR if set or “unknown”

       CPACK_RPM_PACKAGE_URL

       CPACK_RPM_<component>_PACKAGE_URL
              The projects URL.

              • Mandatory : NO

              • Default   : CMAKE_PROJECT_HOMEPAGE_URL

       CPACK_RPM_PACKAGE_DESCRIPTION

       CPACK_RPM_<component>_PACKAGE_DESCRIPTION
              RPM package description.

              • Mandatory : YES

              • Default  :  CPACK_COMPONENT_<compName>_DESCRIPTION  (component  based  installers
                only) if set, CPACK_PACKAGE_DESCRIPTION_FILE if set or  “no  package  description
                available”

       CPACK_RPM_COMPRESSION_TYPE
              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 values are:

              • lzma

              • xz

              • bzip2

              • gzip

       CPACK_RPM_PACKAGE_AUTOREQ

       CPACK_RPM_<component>_PACKAGE_AUTOREQ
              RPM spec autoreq field.

              • Mandatory : NO

              • Default   : -

              May  be  used  to  enable  (1,  yes)  or disable (0, no) automatic shared libraries
              dependency detection. Dependencies are added to requires list.

              NOTE:
                 By default automatic dependency detection is enabled by rpm generator.

       CPACK_RPM_PACKAGE_AUTOPROV

       CPACK_RPM_<component>_PACKAGE_AUTOPROV
              RPM spec autoprov field.

              • Mandatory : NO

              • Default   : -

              May be used to enable (1, yes) or disable  (0,  no)  automatic  listing  of  shared
              libraries that are provided by the package.  Shared libraries are added to provides
              list.

              NOTE:
                 By default automatic provides detection is enabled by rpm generator.

       CPACK_RPM_PACKAGE_AUTOREQPROV

       CPACK_RPM_<component>_PACKAGE_AUTOREQPROV
              RPM spec autoreqprov field.

              • Mandatory : NO

              • Default   : -

              Variable  enables/disables  autoreq  and  autoprov   at   the   same   time.    See
              CPACK_RPM_PACKAGE_AUTOREQ and CPACK_RPM_PACKAGE_AUTOPROV for more details.

              NOTE:
                 By default automatic detection feature is enabled by rpm.

       CPACK_RPM_PACKAGE_REQUIRES

       CPACK_RPM_<component>_PACKAGE_REQUIRES
              RPM spec requires field.

              • 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_CONFLICTS

       CPACK_RPM_<component>_PACKAGE_CONFLICTS
              RPM spec conflicts field.

              • Mandatory : NO

              • Default   : -

              May be used to set negative  RPM  dependencies  (conflicts).  Note  that  you  must
              enclose the complete requires string between quotes, for example:

                 set(CPACK_RPM_PACKAGE_CONFLICTS "libxml2")

              The conflicting package list of an RPM file could be printed with:

                 rpm -qp --conflicts file.rpm

       CPACK_RPM_PACKAGE_REQUIRES_PRE

       CPACK_RPM_<component>_PACKAGE_REQUIRES_PRE
              RPM spec requires(pre) field.

              • Mandatory : NO

              • Default   : -

              May  be used to set RPM preinstall dependencies (requires(pre)). Note that you must
              enclose the complete requires string between quotes, for example:

                 set(CPACK_RPM_PACKAGE_REQUIRES_PRE "shadow-utils, initscripts")

       CPACK_RPM_PACKAGE_REQUIRES_POST

       CPACK_RPM_<component>_PACKAGE_REQUIRES_POST
              RPM spec requires(post) field.

              • Mandatory : NO

              • Default   : -

              May be used to set RPM postinstall dependencies  (requires(post)).  Note  that  you
              must enclose the complete requires string between quotes, for example:

                 set(CPACK_RPM_PACKAGE_REQUIRES_POST "shadow-utils, initscripts")

       CPACK_RPM_PACKAGE_REQUIRES_POSTUN

       CPACK_RPM_<component>_PACKAGE_REQUIRES_POSTUN
              RPM spec requires(postun) field.

              • Mandatory : NO

              • Default   : -

              May be used to set RPM postuninstall dependencies (requires(postun)). Note that you
              must enclose the complete requires string between quotes, for example:

                 set(CPACK_RPM_PACKAGE_REQUIRES_POSTUN "shadow-utils, initscripts")

       CPACK_RPM_PACKAGE_REQUIRES_PREUN

       CPACK_RPM_<component>_PACKAGE_REQUIRES_PREUN
              RPM spec requires(preun) field.

              • Mandatory : NO

              • Default   : -

              May be used to set RPM preuninstall dependencies (requires(preun)). Note  that  you
              must enclose the complete requires string between quotes, for example:

                 set(CPACK_RPM_PACKAGE_REQUIRES_PREUN "shadow-utils, initscripts")

       CPACK_RPM_PACKAGE_SUGGESTS

       CPACK_RPM_<component>_PACKAGE_SUGGESTS
              RPM spec suggest field.

              • 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

       CPACK_RPM_<component>_PACKAGE_PROVIDES
              RPM spec provides field.

              • 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

       CPACK_RPM_<component>_PACKAGE_OBSOLETES
              RPM spec obsoletes field.

              • Mandatory : NO

              • Default   : -

              May be used to set RPM packages that are obsoleted by this one.

       CPACK_RPM_PACKAGE_RELOCATABLE
              build a relocatable RPM.

              • Mandatory : NO

              • Default   : CPACK_PACKAGE_RELOCATABLE

              If  this variable is set to TRUE or ON, the CPack RPM generator 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
              Deprecated - use CPACK_RPM_SPEC_MORE_DEFINE instead.

              • Mandatory : NO

              • Default   : -

              • Deprecated: YES

              May  be  used to override the __spec_install_post section within the generated spec
              file.  This affects the install step during package creation,  not  during  package
              installation.   For  adding operations to be performed during package installation,
              use CPACK_RPM_POST_INSTALL_SCRIPT_FILE instead.

       CPACK_RPM_SPEC_MORE_DEFINE
              RPM extended spec definitions lines.

              • Mandatory : NO

              • Default   : -

              May be used to add any %define lines to the generated spec file.  An example of its
              use  is  to  prevent  stripping of executables (but note that this may also disable
              other default post install processing):

                 set(CPACK_RPM_SPEC_MORE_DEFINE "%define __spec_install_post /bin/true")

       CPACK_RPM_PACKAGE_DEBUG
              Toggle CPack RPM generator debug output.

              • 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

       CPACK_RPM_<componentName>_USER_BINARY_SPECFILE
              A user provided spec file.

              • Mandatory : NO

              • Default   : -

              May  be  set  by the user in order to specify a USER binary spec file to be used by
              the CPack RPM generator instead of generating the file.  The specified file will be
              processed by configure_file( @ONLY).

       CPACK_RPM_GENERATE_USER_BINARY_SPECFILE_TEMPLATE
              Spec file 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
              Path to file containing pre (un)install script.

              • Mandatory : NO

              • Default   : -

              May  be used to embed a pre (un)installation script in the spec file.  The referred
              script file (or both) will be read and  directly  put  after  the  %pre  or  %preun
              section If CPACK_RPM_COMPONENT_INSTALL is set to ON the (un)install script for each
              component can be overridden with CPACK_RPM_<COMPONENT>_PRE_INSTALL_SCRIPT_FILE  and
              CPACK_RPM_<COMPONENT>_PRE_UNINSTALL_SCRIPT_FILE.   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
              Path to file containing post (un)install script.

              • Mandatory : NO

              • Default   : -

              May be used to embed a post (un)installation script in the spec file.  The referred
              script  file  (or  both)  will  be read and directly put after the %post or %postun
              section.  If CPACK_RPM_COMPONENT_INSTALL is set to ON the  (un)install  script  for
              each           component          can          be          overridden          with
              CPACK_RPM_<COMPONENT>_POST_INSTALL_SCRIPT_FILE                                  and
              CPACK_RPM_<COMPONENT>_POST_UNINSTALL_SCRIPT_FILE.   One  may verify which scriptlet
              has been included with:

                 rpm -qp --scripts  package.rpm

       CPACK_RPM_USER_FILELIST

       CPACK_RPM_<COMPONENT>_USER_FILELIST

              • Mandatory : NO

              • Default   : -

              May be used to explicitly specify %(<directive>) file line in the spec  file.  Like
              %config(noreplace)  or any other directive that be found in the %files section. You
              can   have   multiple   directives   per   line,   as    in    %attr(600,root,root)
              %config(noreplace).  Since  the CPack RPM generator is generating the list of files
              (and     directories)      the      user      specified      files      of      the
              CPACK_RPM_<COMPONENT>_USER_FILELIST  list  will be removed from the generated list.
              If referring to directories do not add a trailing slash.

       CPACK_RPM_CHANGELOG_FILE
              RPM changelog file.

              • Mandatory : NO

              • Default   : -

              May be used to embed a changelog in the spec file.  The referred file will be  read
              and directly put after the %changelog section.

       CPACK_RPM_EXCLUDE_FROM_AUTO_FILELIST
              list of path to be excluded.

              • Mandatory : NO

              •

                Default
                       /etc   /etc/init.d   /usr   /usr/bin   /usr/include  /usr/lib  /usr/libx32
                       /usr/lib64 /usr/share /usr/share/aclocal /usr/share/doc

              May be used to exclude path (directories or files) from the auto-generated list  of
              paths  discovered  by  CPack  RPM.  The  default value contains a reasonable set of
              values if the variable is not defined by the user. If the variable  is  defined  by
              the user then the CPack RPM generator will NOT any of the default path. If you want
              to   add   some   path    to    the    default    list    then    you    can    use
              CPACK_RPM_EXCLUDE_FROM_AUTO_FILELIST_ADDITION variable.

       CPACK_RPM_EXCLUDE_FROM_AUTO_FILELIST_ADDITION
              additional list of path to be excluded.

              • Mandatory : NO

              • Default   : -

              May  be  used  to  add  more  exclude  path (directories or files) from the initial
              default list of excluded paths. See CPACK_RPM_EXCLUDE_FROM_AUTO_FILELIST.

       CPACK_RPM_RELOCATION_PATHS
              Packages relocation paths list.

              • Mandatory : NO

              • Default   : -

              May be used to specify more than one relocation path per relocatable RPM.  Variable
              contains  a  list of relocation paths that if relative are prefixed by the value of
              CPACK_RPM_<COMPONENT>_PACKAGE_PREFIX      or      by       the       value       of
              CPACK_PACKAGING_INSTALL_PREFIX  if the component version is not provided.  Variable
              is not component based as its content can be used to set a  different  path  prefix
              for e.g. binary dir and documentation dir at the same time.  Only prefixes that are
              required by a certain component are  added  to  that  component  -  component  must
              contain  at  least one file/directory/symbolic link with CPACK_RPM_RELOCATION_PATHS
              prefix for a certain relocation path to be added.  Package  will  not  contain  any
              relocation  paths  if  there  are no files/directories/symbolic links on any of the
              provided prefix locations.  Packages that either  do  not  contain  any  relocation
              paths or contain files/directories/symbolic links that are outside relocation paths
              print out an AUTHOR_WARNING that RPM will be partially relocatable.

       CPACK_RPM_<COMPONENT>_PACKAGE_PREFIX
              Per component relocation path install prefix.

              • Mandatory : NO

              • Default   : CPACK_PACKAGING_INSTALL_PREFIX

              May be used to set per component CPACK_PACKAGING_INSTALL_PREFIX for relocatable RPM
              packages.

       CPACK_RPM_NO_INSTALL_PREFIX_RELOCATION

       CPACK_RPM_NO_<COMPONENT>_INSTALL_PREFIX_RELOCATION
              Removal of default install prefix from relocation paths list.

              • Mandatory : NO

              •

                Default
                       CPACK_PACKAGING_INSTALL_PREFIX or CPACK_RPM_<COMPONENT>_PACKAGE_PREFIX are
                       treated as one of relocation paths

              May     be     used     to      remove      CPACK_PACKAGING_INSTALL_PREFIX      and
              CPACK_RPM_<COMPONENT>_PACKAGE_PREFIX from relocatable RPM prefix paths.

       CPACK_RPM_ADDITIONAL_MAN_DIRS

              • Mandatory : NO

              • Default   : -

              May  be  used  to  set  additional man dirs that could potentially be compressed by
              brp-compress RPM macro. Variable content must be a list of regular expressions that
              point  to  directories  containing man files or to man files directly. Note that in
              order to compress man pages a path must also be present in brp-compress RPM  script
              and  that  brp-compress  script must be added to RPM configuration by the operating
              system.

              Regular expressions that are added by default  were  taken  from  brp-compress  RPM
              macro:

              • /usr/man/man.*

              • /usr/man/.*/man.*

              • /usr/info.*

              • /usr/share/man/man.*

              • /usr/share/man/.*/man.*

              • /usr/share/info.*

              • /usr/kerberos/man.*

              • /usr/X11R6/man/man.*

              • /usr/lib/perl5/man/man.*

              • /usr/share/doc/.*/man/man.*

              • /usr/lib/.*/man/man.*

       CPACK_RPM_DEFAULT_USER

       CPACK_RPM_<compName>_DEFAULT_USER
              default user ownership of RPM content

              • Mandatory : NO

              • Default   : root

              Value should be user name and not UID.  Note that <compName> must be in upper-case.

       CPACK_RPM_DEFAULT_GROUP

       CPACK_RPM_<compName>_DEFAULT_GROUP
              default group ownership of RPM content

              • Mandatory : NO

              • Default   : root

              Value  should  be  group  name  and  not  GID.   Note  that  <compName>  must be in
              upper-case.

       CPACK_RPM_DEFAULT_FILE_PERMISSIONS

       CPACK_RPM_<compName>_DEFAULT_FILE_PERMISSIONS
              default permissions used for packaged files

              • Mandatory : NO

              • Default   : - (system default)

              Accepted values are lists with PERMISSIONS. Valid permissions are:

              • OWNER_READ

              • OWNER_WRITE

              • OWNER_EXECUTE

              • GROUP_READ

              • GROUP_WRITE

              • GROUP_EXECUTE

              • WORLD_READ

              • WORLD_WRITE

              • WORLD_EXECUTE

              Note that <compName> must be in upper-case.

       CPACK_RPM_DEFAULT_DIR_PERMISSIONS

       CPACK_RPM_<compName>_DEFAULT_DIR_PERMISSIONS
              default permissions used for packaged directories

              • Mandatory : NO

              • Default   : - (system default)

              Accepted values are lists with PERMISSIONS. Valid permissions are the same  as  for
              CPACK_RPM_DEFAULT_FILE_PERMISSIONS.  Note that <compName> must be in upper-case.

       CPACK_RPM_INSTALL_WITH_EXEC
              force execute permissions on programs and shared libraries

              • Mandatory : NO

              • Default   : - (system default)

              Force  set  owner,  group  and  world  execute  permissions  on programs and shared
              libraries. This can be used for creating valid rpm  packages  on  systems  such  as
              Debian where shared libraries do not have execute permissions set.

       NOTE:
          Programs and shared libraries without execute permissions are ignored during separation
          of debug symbols from the binary for debuginfo packages.

   Packaging of Symbolic Links
       The CPack RPM generator supports packaging of symbolic links:

          execute_process(COMMAND ${CMAKE_COMMAND}
            -E create_symlink <relative_path_location> <symlink_name>)
          install(FILES ${CMAKE_CURRENT_BINARY_DIR}/<symlink_name>
            DESTINATION <symlink_location> COMPONENT libraries)

       Symbolic links will be optimized (paths will be shortened if possible) before being  added
       to  the  package  or  if  multiple  relocation  paths are detected, a post install symlink
       relocation script will be generated.

       Symbolic links may point to locations that are not packaged by the same package (either  a
       different component or even not packaged at all) but those locations will be treated as if
       they were a part of the package while determining if symlink should be either  created  or
       present in a post install script - depending on relocation paths.

       Symbolic  links  that  point to locations outside packaging path produce a warning and are
       treated as non relocatable permanent symbolic links.

       Currently there are a few limitations though:

       • For component based packaging component interdependency is not checked  when  processing
         symbolic  links. Symbolic links pointing to content of a different component are treated
         the same way as if pointing to location that will not be packaged.

       • Symbolic links pointing to a location through one or more  intermediate  symbolic  links
         will  not  be  handled  differently  - if the intermediate symbolic link(s) is also on a
         relocatable path, relocating it during package installation may cause  initial  symbolic
         link to point to an invalid location.

   Packaging of debug information
       Debuginfo packages contain debug symbols and sources for debugging packaged binaries.

       Debuginfo RPM packaging has its own set of variables:

       CPACK_RPM_DEBUGINFO_PACKAGE

       CPACK_RPM_<component>_DEBUGINFO_PACKAGE
              Enable generation of debuginfo RPM package(s).

              • Mandatory : NO

              • Default   : OFF

       NOTE:
          Binaries   must  contain  debug  symbols  before  packaging  so  use  either  Debug  or
          RelWithDebInfo for CMAKE_BUILD_TYPE variable value.

       NOTE:
          Packages generated from packages without binary files, with binary  files  but  without
          execute permissions or without debug symbols will cause packaging termination.

       CPACK_BUILD_SOURCE_DIRS
              Provides  locations  of  root  directories of source files from which binaries were
              built.

              • Mandatory : YES if CPACK_RPM_DEBUGINFO_PACKAGE is set

              • Default   : -

       NOTE:
          For  CMake  project  CPACK_BUILD_SOURCE_DIRS  is   set   by   default   to   point   to
          CMAKE_SOURCE_DIR and CMAKE_BINARY_DIR paths.

       NOTE:
          Sources  with  path  prefixes  that  do  not  fall  under  any  location  provided with
          CPACK_BUILD_SOURCE_DIRS will not be present in debuginfo package.

       CPACK_RPM_BUILD_SOURCE_DIRS_PREFIX

       CPACK_RPM_<component>_BUILD_SOURCE_DIRS_PREFIX
              Prefix of location where sources will be placed during package installation.

              • Mandatory : YES if CPACK_RPM_DEBUGINFO_PACKAGE is set

              •

                Default
                       “/usr/src/debug/<CPACK_PACKAGE_FILE_NAME>”  and  for  component  packaging
                       “/usr/src/debug/<CPACK_PACKAGE_FILE_NAME>-<component>”

       NOTE:
          Each source path prefix is additionally suffixed by src_<index> where index is index of
          the    path    used    from    CPACK_BUILD_SOURCE_DIRS    variable.    This    produces
          <CPACK_RPM_BUILD_SOURCE_DIRS_PREFIX>/src_<index>  replacement path.  Limitation is that
          replaced path part must  be  shorter  or  of  equal  length  than  the  length  of  its
          replacement. If that is not the case either CPACK_RPM_BUILD_SOURCE_DIRS_PREFIX variable
          has to be set to a shorter path or source directories must be placed on a longer path.

       CPACK_RPM_DEBUGINFO_EXCLUDE_DIRS
              Directories containing sources that should be excluded from debuginfo packages.

              • Mandatory : NO

              • Default   : “/usr /usr/src /usr/src/debug”

              Listed paths are owned by other RPM packages and should therefore not be deleted on
              debuginfo package uninstallation.

       CPACK_RPM_DEBUGINFO_EXCLUDE_DIRS_ADDITION
              Paths that should be appended to CPACK_RPM_DEBUGINFO_EXCLUDE_DIRS for exclusion.

              • Mandatory : NO

              • Default   : -

       CPACK_RPM_DEBUGINFO_SINGLE_PACKAGE
              Create a single debuginfo package even if components packaging is set.

              • Mandatory : NO

              • Default   : OFF

              When  this  variable  is  enabled  it  produces  a single debuginfo package even if
              component packaging is enabled.

              When using this feature in combination with components packaging and there is  more
              than one component this variable requires CPACK_RPM_MAIN_COMPONENT to be set.

       NOTE:
          If   none   of   the  CPACK_RPM_<component>_DEBUGINFO_PACKAGE  variables  is  set  then
          CPACK_RPM_DEBUGINFO_PACKAGE     is     automatically      set      to      ON      when
          CPACK_RPM_DEBUGINFO_SINGLE_PACKAGE is set.

       CPACK_RPM_DEBUGINFO_FILE_NAME

       CPACK_RPM_<component>_DEBUGINFO_FILE_NAME
              Debuginfo package file name.

              • Mandatory : NO

              • Default   : rpmbuild tool generated package file name

              Alternatively  provided  debuginfo  package file name must end with .rpm suffix and
              should differ from file names of other generated packages.

              Variable may contain  @cpack_component@  placeholder  which  will  be  replaced  by
              component  name  if  component  packaging  is  enabled  otherwise  it  deletes  the
              placeholder.

              Setting the variable  to  RPM-DEFAULT  may  be  used  to  explicitly  set  filename
              generation to default.

       NOTE:
          CPACK_RPM_FILE_NAME  also supports rpmbuild tool generated package file name - disabled
          by default but can be enabled by setting the variable to RPM-DEFAULT.

   Packaging of sources (SRPM)
       SRPM packaging is enabled by  setting  CPACK_RPM_PACKAGE_SOURCES  variable  while  usually
       using  CPACK_INSTALLED_DIRECTORIES variable to provide directory containing CMakeLists.txt
       and source files.

       For CMake projects SRPM package would be produced by executing:

          cpack -G RPM --config ./CPackSourceConfig.cmake

       NOTE:
          Produced SRPM package is expected to be built with  cmake(1)  executable  and  packaged
          with  cpack(1)  executable so CMakeLists.txt has to be located in root source directory
          and must be able to generate binary rpm packages by executing cpack -G command. The two
          executables  as  well  as  rpmbuild  must  also  be  present when generating binary rpm
          packages from the produced SRPM package.

       Once the SRPM package is generated it can be used to generate binary packages by  creating
       a directory structure for rpm generation and executing rpmbuild tool:

          mkdir -p build_dir/{BUILD,BUILDROOT,RPMS,SOURCES,SPECS,SRPMS}
          rpmbuild --define "_topdir <path_to_build_dir>" --rebuild <SRPM_file_name>

       Generated packages will be located in build_dir/RPMS directory or its sub directories.

       NOTE:
          SRPM  package  internally  uses  CPack/RPM  generator  to  generate  binary packages so
          CMakeScripts.txt can decide during the SRPM to binary rpm generation step what  content
          the  package(s)  should  have  as  well  as  how they should be packaged (monolithic or
          components). CMake can decide this for e.g. by reading environment variables set by the
          package manager before starting the process of generating binary rpm packages. This way
          a single SRPM package can be used to produce different binary rpm packages on different
          platforms depending on the platform’s packaging rules.

       Source RPM packaging has its own set of variables:

       CPACK_RPM_PACKAGE_SOURCES
              Should the content be packaged as a source rpm (default is binary rpm).

              • Mandatory : NO

              • Default   : OFF

       NOTE:
          For   cmake   projects   CPACK_RPM_PACKAGE_SOURCES   variable   is   set   to   OFF  in
          CPackConfig.cmake and ON in CPackSourceConfig.cmake generated files.

       CPACK_RPM_SOURCE_PKG_BUILD_PARAMS
              Additional command-line parameters provided to cmake(1) executable.

              • Mandatory : NO

              • Default   : -

       CPACK_RPM_SOURCE_PKG_PACKAGING_INSTALL_PREFIX
              Packaging install prefix that would be provided  in  CPACK_PACKAGING_INSTALL_PREFIX
              variable for producing binary RPM packages.

              • Mandatory : YES

              • Default   : “/”

       CPACK_RPM_BUILDREQUIRES
              List of source rpm build dependencies.

              • Mandatory : NO

              • Default   : -

              May  be  used  to  set source RPM build dependencies (BuildRequires). Note that you
              must enclose the complete build requirements string between quotes, for example:

                 set(CPACK_RPM_BUILDREQUIRES "python >= 2.5.0, cmake >= 2.8")

   CPack WIX Generator
       CPack WIX generator specific options

   Variables specific to CPack WIX generator
       The following variables are specific to the installers built on Windows using WiX.

       CPACK_WIX_UPGRADE_GUID
              Upgrade GUID (Product/@UpgradeCode)

              Will be automatically generated unless explicitly provided.

              It should be explicitly set to a  constant  generated  globally  unique  identifier
              (GUID) to allow your installers to replace existing installations that use the same
              GUID.

              You may for example explicitly set this variable  in  your  CMakeLists.txt  to  the
              value  that  has been generated per default.  You should not use GUIDs that you did
              not generate yourself or which may belong to other projects.

              A GUID shall have the following fixed length syntax:

                 XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX

              (each X represents an uppercase hexadecimal digit)

       CPACK_WIX_PRODUCT_GUID
              Product GUID (Product/@Id)

              Will be automatically generated unless explicitly provided.

              If explicitly provided this will set the Product Id of your installer.

              The installer will abort if it detects a pre-existing installation  that  uses  the
              same GUID.

              The GUID shall use the syntax described for CPACK_WIX_UPGRADE_GUID.

       CPACK_WIX_LICENSE_RTF
              RTF License File

              If CPACK_RESOURCE_FILE_LICENSE has an .rtf extension it is used as-is.

              If  CPACK_RESOURCE_FILE_LICENSE has an .txt extension it is implicitly converted to
              RTF by the WIX Generator.  The expected encoding of the .txt file is UTF-8.

              With CPACK_WIX_LICENSE_RTF you can override  the  license  file  used  by  the  WIX
              Generator  in  case  CPACK_RESOURCE_FILE_LICENSE is in an unsupported format or the
              .txt -> .rtf conversion does not work as expected.

       CPACK_WIX_PRODUCT_ICON
              The Icon shown next to the program name in Add/Remove programs.

              If set, this icon is used in place of the default icon.

       CPACK_WIX_UI_REF
              This variable allows you to override the Id of  the  <UIRef>  element  in  the  WiX
              template.

              The  default  is WixUI_InstallDir in case no CPack components have been defined and
              WixUI_FeatureTree otherwise.

       CPACK_WIX_UI_BANNER
              The bitmap will appear at the top of all installer pages other than the welcome and
              completion dialogs.

              If set, this image will replace the default banner image.

              This image must be 493 by 58 pixels.

       CPACK_WIX_UI_DIALOG
              Background bitmap used on the welcome and completion dialogs.

              If this variable is set, the installer will replace the default dialog image.

              This image must be 493 by 312 pixels.

       CPACK_WIX_PROGRAM_MENU_FOLDER
              Start menu folder name for launcher.

              If this variable is not set, it will be initialized with CPACK_PACKAGE_NAME

              If  this  variable is set to ., then application shortcuts will be created directly
              in the start menu and the uninstaller shortcut will be omitted.

       CPACK_WIX_CULTURES
              Language(s) of the installer

              Languages are compiled into the WixUI  extension  library.   To  use  them,  simply
              provide  the  name of the culture.  If you specify more than one culture identifier
              in a comma or semicolon delimited list, the first one that is found will  be  used.
              You      can      find      a      list      of     supported     languages     at:
              http://wix.sourceforge.net/manual-wix3/WixUI_localization.htm

       CPACK_WIX_TEMPLATE
              Template file for WiX generation

              If this variable is set, the specified template will be used to  generate  the  WiX
              wxs file.  This should be used if further customization of the output is required.

              If  this  variable is not set, the default MSI template included with CMake will be
              used.

       CPACK_WIX_PATCH_FILE
              Optional list of XML files with fragments to be inserted into generated WiX sources

              This optional variable can be used to specify an XML file that  the  WIX  generator
              will use to inject fragments into its generated source files.

              Patch  files  understood  by  the  CPack WIX generator roughly follow this RELAX NG
              compact schema:

                 start = CPackWiXPatch

                 CPackWiXPatch = element CPackWiXPatch { CPackWiXFragment* }

                 CPackWiXFragment = element CPackWiXFragment
                 {
                     attribute Id { string },
                     fragmentContent*
                 }

                 fragmentContent = element * - CPackWiXFragment
                 {
                     (attribute * { text } | text | fragmentContent)*
                 }

              Currently fragments can be  injected  into  most  Component,  File,  Directory  and
              Feature elements.

              The following additional special Ids can be used:

              • #PRODUCT for the <Product> element.

              • #PRODUCTFEATURE for the root <Feature> element.

              The following example illustrates how this works.

              Given that the WIX generator creates the following XML element:

                 <Component Id="CM_CP_applications.bin.my_libapp.exe" Guid="*"/>

              The following XML patch file may be used to inject an Environment element into it:

                 <CPackWiXPatch>
                   <CPackWiXFragment Id="CM_CP_applications.bin.my_libapp.exe">
                     <Environment Id="MyEnvironment" Action="set"
                       Name="MyVariableName" Value="MyVariableValue"/>
                   </CPackWiXFragment>
                 </CPackWiXPatch>

       CPACK_WIX_EXTRA_SOURCES
              Extra WiX source files

              This  variable  provides  an  optional  list  of extra WiX source files (.wxs) that
              should be compiled and linked.  The full path to source files is required.

       CPACK_WIX_EXTRA_OBJECTS
              Extra WiX object files or libraries

              This variable provides an optional list of extra WiX object  (.wixobj)  and/or  WiX
              library (.wixlib) files.  The full path to objects and libraries is required.

       CPACK_WIX_EXTENSIONS
              This  variable provides a list of additional extensions for the WiX tools light and
              candle.

       CPACK_WIX_<TOOL>_EXTENSIONS
              This is the tool specific version of CPACK_WIX_EXTENSIONS.  <TOOL>  can  be  either
              LIGHT or CANDLE.

       CPACK_WIX_<TOOL>_EXTRA_FLAGS
              This list variable allows you to pass additional flags to the WiX tool <TOOL>.

              Use  it at your own risk.  Future versions of CPack may generate flags which may be
              in conflict with your own flags.

              <TOOL> can be either LIGHT or CANDLE.

       CPACK_WIX_CMAKE_PACKAGE_REGISTRY
              If this variable is set the generated installer will create an entry in the windows
              registry  key  HKEY_LOCAL_MACHINE\Software\Kitware\CMake\Packages\<PackageName> The
              value for <PackageName> is provided by this variable.

              Assuming you also install a CMake configuration file this will  allow  other  CMake
              projects to find your package with the find_package() command.

       CPACK_WIX_PROPERTY_<PROPERTY>
              This  variable  can  be  used to provide a value for the Windows Installer property
              <PROPERTY>

              The following list contains some example properties that can be used  to  customize
              information under “Programs and Features” (also known as “Add or Remove Programs”)

              • ARPCOMMENTS - Comments

              • ARPHELPLINK - Help and support information URL

              • ARPURLINFOABOUT - General information URL

              • ARPURLUPDATEINFO - Update information URL

              • ARPHELPTELEPHONE - Help and support telephone number

              • ARPSIZE - Size (in kilobytes) of the application

       CPACK_WIX_ROOT_FEATURE_TITLE
              Sets  the  name  of  the  root  install  feature  in  the  WIX  installer.  Same as
              CPACK_COMPONENT_<compName>_DISPLAY_NAME for components.

       CPACK_WIX_ROOT_FEATURE_DESCRIPTION
              Sets the description of the root install feature in  the  WIX  installer.  Same  as
              CPACK_COMPONENT_<compName>_DESCRIPTION for components.

       CPACK_WIX_SKIP_PROGRAM_FOLDER
              If  this  variable  is  set  to true, the default install location of the generated
              package will be CPACK_PACKAGE_INSTALL_DIRECTORY  directly.   The  install  location
              will not be located relatively below ProgramFiles or ProgramFiles64.

                 NOTE:
                     Installers  created  with  this  feature do not take differences between the
                     system on which the installer  is  created  and  the  system  on  which  the
                     installer might be used into account.

                     It is therefore possible that the installer e.g. might try to install onto a
                     drive that is unavailable or unintended or a path that does not  follow  the
                     localization  or  convention  of  the  system  on  which the installation is
                     performed.

       CPACK_WIX_ROOT_FOLDER_ID
              This variable allows specification of a  custom  root  folder  ID.   The  generator
              specific  <64>  token  can  be  used  for folder IDs that come in 32-bit and 64-bit
              variants.  In 32-bit builds the token will expand empty while in 64-bit  builds  it
              will expand to 64.

              When unset generated installers will default installing to ProgramFiles<64>Folder.

       CPACK_WIX_ROOT
              This  variable  can optionally be set to the root directory of a custom WiX Toolset
              installation.

              When unspecified CPack will try to locate a WiX Toolset installation  via  the  WIX
              environment variable instead.

COPYRIGHT

       2000-2022 Kitware, Inc. and Contributors