mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-01 11:22:21 -06:00
When setting the installation prefix at the installation phase (`cmake --install`) using the `--prefix` option, the GNU special cases aren't applicable. This also adds a small clarification when to use the `--prefix` option at the installation phase. Briefly mentioned also the CMake presets installDir field, the CPACK_PACKAGING_INSTALL_PREFIX variable, and the $<INSTALL_PREFIX> generator expression so user has a better overview. Fixes #27343 Fixes #26338
717 lines
26 KiB
CMake
717 lines
26 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
GNUInstallDirs
|
|
--------------
|
|
|
|
This module defines the installation directory variables according to the
|
|
`GNU Coding Standards`_ and provides a command to compute
|
|
installation-related absolute paths.
|
|
|
|
Load this module in a CMake project with:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(GNUInstallDirs)
|
|
|
|
.. _`GNU Coding Standards`: https://www.gnu.org/prep/standards/html_node/Directory-Variables.html
|
|
|
|
Result Variables
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
Inclusion of this module defines the following variables:
|
|
|
|
``CMAKE_INSTALL_<dir>``
|
|
Destination for files of a given type. This value may be passed to
|
|
the ``DESTINATION`` options of :command:`install` commands for the
|
|
corresponding file type. It should be a path relative to the installation
|
|
prefix so that it can be converted to an absolute path in a relocatable way.
|
|
However, there are some `special cases`_ as documented below.
|
|
|
|
While absolute paths are allowed, they are not recommended as they
|
|
do not work with the ``cmake --install`` command's
|
|
:option:`--prefix <cmake--install --prefix>` option, or with the
|
|
:manual:`cpack <cpack(1)>` installer generators. In particular, there is no
|
|
need to make paths absolute by prepending :variable:`CMAKE_INSTALL_PREFIX`;
|
|
this prefix is used by default if the DESTINATION is a relative path.
|
|
|
|
``CMAKE_INSTALL_FULL_<dir>``
|
|
The absolute path generated from the corresponding ``CMAKE_INSTALL_<dir>``
|
|
value. If the value is not already an absolute path, an absolute path
|
|
is constructed typically by prepending the value of the
|
|
:variable:`CMAKE_INSTALL_PREFIX` variable, except in `special cases`_
|
|
as documented below.
|
|
|
|
These variables shouldn't be used in :command:`install` commands
|
|
as they do not work with the ``cmake --install`` command's
|
|
:option:`--prefix <cmake--install --prefix>` option, or with the
|
|
:manual:`cpack <cpack(1)>` installer generators.
|
|
|
|
where ``<dir>`` is one of:
|
|
|
|
``BINDIR``
|
|
user executables (``bin``)
|
|
``SBINDIR``
|
|
system admin executables (``sbin``)
|
|
``LIBEXECDIR``
|
|
program executables (``libexec``)
|
|
``SYSCONFDIR``
|
|
read-only single-machine data (``etc``)
|
|
|
|
.. versionchanged:: 4.1
|
|
If the :variable:`CMAKE_INSTALL_PREFIX` falls into the
|
|
`special cases`_, the default paths for are the absolute
|
|
path variants as described there. See policy :policy:`CMP0192`.
|
|
``SHAREDSTATEDIR``
|
|
modifiable architecture-independent data (``com``)
|
|
``LOCALSTATEDIR``
|
|
modifiable single-machine data (``var``)
|
|
|
|
.. versionchanged:: 4.1
|
|
If the :variable:`CMAKE_INSTALL_PREFIX` falls into the
|
|
`special cases`_, the default paths for are the absolute
|
|
path variants as described there. See policy :policy:`CMP0192`.
|
|
``RUNSTATEDIR``
|
|
run-time variable data (``LOCALSTATEDIR/run``)
|
|
|
|
.. versionadded:: 3.9
|
|
|
|
.. versionchanged:: 4.1
|
|
If the :variable:`CMAKE_INSTALL_PREFIX` falls into the
|
|
`special cases`_, the default paths for are the absolute
|
|
path variants as described there. See policy :policy:`CMP0192`.
|
|
``LIBDIR``
|
|
object code libraries (``lib`` or ``lib64``)
|
|
|
|
On Debian, this may be ``lib/<multiarch-tuple>`` when
|
|
:variable:`CMAKE_INSTALL_PREFIX` is ``/usr``.
|
|
|
|
.. note::
|
|
|
|
When an alternative installation prefix is specified with the
|
|
:option:`--prefix <cmake--install --prefix>` option at install time,
|
|
the special case with multi-architecture tuple is evaluated based on
|
|
the configuration-time :variable:`CMAKE_INSTALL_PREFIX`, not on the
|
|
alternative prefix value.
|
|
|
|
``INCLUDEDIR``
|
|
C header files (``include``)
|
|
``OLDINCLUDEDIR``
|
|
C header files for non-gcc (``/usr/include``)
|
|
``DATAROOTDIR``
|
|
read-only architecture-independent data root (``share``)
|
|
``DATADIR``
|
|
read-only architecture-independent data (``DATAROOTDIR``)
|
|
|
|
The ``DATADIR`` and ``DATAROOTDIR`` are treated separately so that
|
|
``DATADIR`` can be customized for project-specific data files, while
|
|
``DATAROOTDIR`` remains unchanged for standard architecture-independent
|
|
locations ``INFODIR``, ``LOCALEDIR``, ``MANDIR``, and ``DOCDIR``.
|
|
|
|
``INFODIR``
|
|
info documentation (``DATAROOTDIR/info``)
|
|
``LOCALEDIR``
|
|
locale-dependent data (``DATAROOTDIR/locale``)
|
|
``MANDIR``
|
|
man documentation (``DATAROOTDIR/man``)
|
|
``DOCDIR``
|
|
documentation root (``DATAROOTDIR/doc/PROJECT_NAME``)
|
|
|
|
If the includer does not define a value the above-shown default will be
|
|
used and the value will appear in the cache for editing by the user.
|
|
|
|
If a default value for the ``CMAKE_INSTALL_<dir>`` is used and the
|
|
:variable:`CMAKE_INSTALL_PREFIX` is changed, the new default value will
|
|
be used calculated on the new :variable:`CMAKE_INSTALL_PREFIX` value.
|
|
Using :option:`--prefix <cmake--install --prefix>` in ``cmake --install``
|
|
will not alter these values.
|
|
|
|
.. _`GNUInstallDirs special cases`:
|
|
|
|
Special Cases
|
|
^^^^^^^^^^^^^
|
|
|
|
.. versionadded:: 3.4
|
|
|
|
The following values of :variable:`CMAKE_INSTALL_PREFIX` are special:
|
|
|
|
``/``
|
|
|
|
For ``<dir>`` other than the ``SYSCONFDIR``, ``LOCALSTATEDIR`` and
|
|
``RUNSTATEDIR``, the value of ``CMAKE_INSTALL_<dir>`` is prefixed
|
|
with ``usr/`` if it is not user-specified as an absolute path.
|
|
For example, the ``INCLUDEDIR`` value ``include`` becomes ``usr/include``.
|
|
This is required by the `GNU Coding Standards`_, which state:
|
|
|
|
When building the complete GNU system, the prefix will be empty
|
|
and ``/usr`` will be a symbolic link to ``/``.
|
|
|
|
.. versionchanged:: 4.1
|
|
The ``CMAKE_INSTALL_<dir>`` variables are cached with the ``usr/`` prefix.
|
|
See policy :policy:`CMP0193`.
|
|
|
|
``/usr``
|
|
|
|
For ``<dir>`` equal to ``SYSCONFDIR``, ``LOCALSTATEDIR`` or
|
|
``RUNSTATEDIR``, the ``CMAKE_INSTALL_FULL_<dir>`` is computed by
|
|
prepending just ``/`` to the value of ``CMAKE_INSTALL_<dir>``
|
|
if it is not already an absolute path.
|
|
For example, the ``SYSCONFDIR`` value ``etc`` becomes ``/etc``.
|
|
This is required by the `GNU Coding Standards`_.
|
|
|
|
.. versionchanged:: 4.1
|
|
The default values of ``CMAKE_INSTALL_<dir>`` for ``<dir>`` equal
|
|
to ``SYSCONFDIR``, ``LOCALSTATEDIR`` and ``RUNSTATEDIR`` are the
|
|
absolute paths ``/etc``, ``/var`` and ``/var/run`` respectively.
|
|
See policy :policy:`CMP0192`.
|
|
|
|
``/opt/...``
|
|
|
|
For ``<dir>`` equal to ``SYSCONFDIR``, ``LOCALSTATEDIR`` or
|
|
``RUNSTATEDIR``, the ``CMAKE_INSTALL_FULL_<dir>`` is computed by
|
|
*appending* the prefix to the value of ``CMAKE_INSTALL_<dir>``
|
|
if it is not already an absolute path.
|
|
For example, the ``SYSCONFDIR`` value ``etc`` becomes ``/etc/opt/...``.
|
|
This is defined by the `Filesystem Hierarchy Standard`_.
|
|
|
|
This behavior does not apply to paths under ``/opt/homebrew/...``.
|
|
|
|
.. versionchanged:: 4.1
|
|
The default values of ``CMAKE_INSTALL_<dir>`` for ``<dir>`` equal
|
|
to ``SYSCONFDIR``, ``LOCALSTATEDIR`` and ``RUNSTATEDIR`` are the
|
|
absolute paths ``/etc/opt/...``, ``/var/opt/...`` and
|
|
``/var/run/opt/...`` respectively. See policy :policy:`CMP0192`.
|
|
|
|
.. note::
|
|
|
|
When an alternative installation prefix is specified with the
|
|
:option:`--prefix <cmake--install --prefix>` option at install time,
|
|
these special cases are evaluated based on the configuration-time
|
|
:variable:`CMAKE_INSTALL_PREFIX`, not on the alternative prefix value.
|
|
|
|
.. _`Filesystem Hierarchy Standard`: https://refspecs.linuxfoundation.org/FHS_3.0/fhs/index.html
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following command:
|
|
|
|
.. command:: GNUInstallDirs_get_absolute_install_dir
|
|
|
|
.. versionadded:: 3.7
|
|
|
|
Computes an absolute installation path from a given relative path:
|
|
|
|
.. code-block:: cmake
|
|
|
|
GNUInstallDirs_get_absolute_install_dir(<result-var> <input-var> <dir>)
|
|
|
|
This command takes the value from the variable ``<input-var>`` and
|
|
computes its absolute path according to GNU standard installation
|
|
directories. If the input path is relative, it is prepended with
|
|
:variable:`CMAKE_INSTALL_PREFIX` and may be adjusted for the
|
|
`special cases`_ described above.
|
|
|
|
The arguments are:
|
|
|
|
``<result-var>``
|
|
Name of the variable in which to store the computed absolute path.
|
|
|
|
``<input-var>``
|
|
Name of the variable containing the path that will be used to compute
|
|
its associated absolute installation path.
|
|
|
|
.. versionchanged:: 4.1
|
|
This variable is no longer altered. See policy :policy:`CMP0193`.
|
|
In previous CMake versions, this command modified the ``<input-var>``
|
|
variable value based on the `special cases`_.
|
|
|
|
``<dir>``
|
|
.. versionadded:: 3.20
|
|
|
|
The directory type name, e.g., ``SYSCONFDIR``, ``LOCALSTATEDIR``,
|
|
``RUNSTATEDIR``, etc. This argument determines whether `special cases`_
|
|
apply when computing the absolute path.
|
|
|
|
.. versionchanged:: 3.20
|
|
|
|
Before the ``<dir>`` argument was introduced, the directory type
|
|
could be specified by setting the ``dir`` variable prior to calling
|
|
this command. As of CMake 3.20, if the ``<dir>`` argument is provided
|
|
explicitly, the ``dir`` variable is ignored.
|
|
|
|
While this command is used internally by this module to compute the
|
|
``CMAKE_INSTALL_FULL_<dir>`` variables, it is also exposed publicly for
|
|
users to create additional custom installation path variables and compute
|
|
absolute paths where necessary, using the same logic.
|
|
|
|
See Also
|
|
^^^^^^^^
|
|
|
|
* The :command:`install` command.
|
|
#]=======================================================================]
|
|
|
|
cmake_policy(SET CMP0140 NEW)
|
|
|
|
# Note that even though we read the policy every time this file is `include`
|
|
# only the first occurrence has effect because it is used for the initialization
|
|
# of cache variables
|
|
cmake_policy(GET CMP0192 _GNUInstallDirs_CMP0192)
|
|
|
|
# Convert a cache variable to PATH type
|
|
|
|
function(_GNUInstallDirs_cache_convert_to_path var description)
|
|
get_property(cache_type CACHE ${var} PROPERTY TYPE)
|
|
if(cache_type STREQUAL "UNINITIALIZED")
|
|
file(TO_CMAKE_PATH "${${var}}" cmakepath)
|
|
set_property(CACHE ${var} PROPERTY TYPE PATH)
|
|
set_property(CACHE ${var} PROPERTY VALUE "${cmakepath}")
|
|
set_property(CACHE ${var} PROPERTY HELPSTRING "${description}")
|
|
endif()
|
|
endfunction()
|
|
|
|
# Create a cache variable with default for a path.
|
|
function(_GNUInstallDirs_cache_path var description)
|
|
set(cmake_install_var "CMAKE_INSTALL_${var}")
|
|
set(default "${_GNUInstallDirs_${var}_DEFAULT}")
|
|
# Check if we have a special way to calculate the defaults
|
|
if(COMMAND _GNUInstallDirs_${var}_get_default)
|
|
# Check if the current CMAKE_INSTALL_PREFIX is the same as before
|
|
set(install_prefix_is_same TRUE)
|
|
unset(last_default)
|
|
if(DEFINED _GNUInstallDirs_LAST_CMAKE_INSTALL_PREFIX
|
|
AND NOT _GNUInstallDirs_LAST_CMAKE_INSTALL_PREFIX STREQUAL CMAKE_INSTALL_PREFIX)
|
|
set(install_prefix_is_same FALSE)
|
|
# Recalculate what the last default would have been
|
|
cmake_language(CALL _GNUInstallDirs_${var}_get_default
|
|
last_default
|
|
"${_GNUInstallDirs_LAST_CMAKE_INSTALL_PREFIX}")
|
|
endif()
|
|
|
|
if(DEFINED CACHE{${cmake_install_var}} AND install_prefix_is_same)
|
|
# If the cache variable was already set from a previous run and the
|
|
# install prefix has not changed, we don't need to do anything
|
|
return()
|
|
else()
|
|
# Otherwise get the new default
|
|
cmake_language(CALL _GNUInstallDirs_${var}_get_default
|
|
default
|
|
"${CMAKE_INSTALL_PREFIX}")
|
|
# if the current value is the same as the cache value and the same as
|
|
# the old default, reset the value to the new default
|
|
if(${cmake_install_var} STREQUAL "$CACHE{${cmake_install_var}}"
|
|
AND DEFINED last_default
|
|
AND ${cmake_install_var} STREQUAL last_default)
|
|
set(full_description "${description} (${default})")
|
|
set_property(CACHE ${cmake_install_var} PROPERTY TYPE PATH)
|
|
set_property(CACHE ${cmake_install_var} PROPERTY VALUE "${default}")
|
|
set_property(CACHE ${cmake_install_var} PROPERTY HELPSTRING "${full_description}")
|
|
endif()
|
|
# Continue to normal flow
|
|
endif()
|
|
endif()
|
|
|
|
# Normal flow
|
|
set(full_description "${description} (${default})")
|
|
if(NOT DEFINED ${cmake_install_var})
|
|
set(${cmake_install_var} "${default}" CACHE PATH "${full_description}")
|
|
endif()
|
|
_GNUInstallDirs_cache_convert_to_path("${cmake_install_var}" "${full_description}")
|
|
endfunction()
|
|
|
|
# Create a cache variable with not default for a path, with a fallback
|
|
# when unset; used for entries slaved to other entries such as
|
|
# DATAROOTDIR.
|
|
function(_GNUInstallDirs_cache_path_fallback var description)
|
|
set(cmake_install_var "CMAKE_INSTALL_${var}")
|
|
set(default "${_GNUInstallDirs_${var}_DEFAULT}")
|
|
# Check if there is a more special way to handle the default
|
|
if(COMMAND _GNUInstallDirs_${var}_get_default)
|
|
cmake_language(CALL _GNUInstallDirs_${var}_get_default
|
|
default
|
|
"${CMAKE_INSTALL_PREFIX}")
|
|
endif()
|
|
if(NOT ${cmake_install_var})
|
|
set(${cmake_install_var} "" CACHE PATH "${description}")
|
|
set(${cmake_install_var} "${default}")
|
|
endif()
|
|
_GNUInstallDirs_cache_convert_to_path("${cmake_install_var}" "${description}")
|
|
return(PROPAGATE ${cmake_install_var})
|
|
endfunction()
|
|
|
|
# Other helpers
|
|
# Check what system we are on for LIBDIR formatting
|
|
function(_GNUInstallDirs_get_system_type_for_install out_var)
|
|
unset(${out_var})
|
|
# Check if we are building for conda
|
|
if(DEFINED ENV{CONDA_BUILD} AND DEFINED ENV{PREFIX})
|
|
set(conda_prefix "$ENV{PREFIX}")
|
|
cmake_path(ABSOLUTE_PATH conda_prefix NORMALIZE)
|
|
if("${CMAKE_INSTALL_PREFIX}" STREQUAL conda_prefix)
|
|
set(${out_var} "conda")
|
|
endif()
|
|
elseif(DEFINED ENV{CONDA_PREFIX})
|
|
set(conda_prefix "$ENV{CONDA_PREFIX}")
|
|
cmake_path(ABSOLUTE_PATH conda_prefix NORMALIZE)
|
|
if("${CMAKE_INSTALL_PREFIX}" STREQUAL conda_prefix AND
|
|
NOT ("${CMAKE_INSTALL_PREFIX}" MATCHES "^/usr/?$" OR
|
|
"${CMAKE_INSTALL_PREFIX}" MATCHES "^/usr/local/?$"))
|
|
set(${out_var} "conda")
|
|
endif()
|
|
endif()
|
|
# If we didn't detect conda from the previous step, check
|
|
# for the linux variant
|
|
if(NOT ${out_var})
|
|
if (EXISTS "/etc/alpine-release")
|
|
set(${out_var} "alpine")
|
|
elseif (EXISTS "/etc/arch-release")
|
|
set(${out_var} "arch linux")
|
|
elseif (EXISTS "/etc/debian_version")
|
|
set(${out_var} "debian")
|
|
endif()
|
|
endif()
|
|
return(PROPAGATE ${out_var})
|
|
endfunction()
|
|
|
|
# Special handler for `/`, `/usr`, `/opt/...` install prefixes
|
|
# Used for SYSCONFDIR, LOCALSTATEDIR and RUNSTATEDIR paths
|
|
function(_GNUInstallDirs_special_absolute out_var original_path install_prefix)
|
|
set(${out_var} "${original_path}")
|
|
|
|
if(install_prefix MATCHES "^/usr/?$")
|
|
set(${out_var} "/${original_path}")
|
|
elseif(install_prefix MATCHES "^/opt/" AND NOT install_prefix MATCHES "^/opt/homebrew/")
|
|
set(${out_var} "/${original_path}/${install_prefix}")
|
|
endif()
|
|
|
|
return(PROPAGATE ${out_var})
|
|
endfunction()
|
|
|
|
# Common handler for defaults that should be in /<dir>
|
|
# i.e. SYSCONFDIR and LOCALSTATEDIR
|
|
function(__GNUInstallDirs_default_in_root out_var original_path install_prefix)
|
|
if(_GNUInstallDirs_CMP0192 STREQUAL "NEW")
|
|
_GNUInstallDirs_special_absolute(${out_var}
|
|
"${original_path}" "${install_prefix}")
|
|
endif()
|
|
cmake_path(NORMAL_PATH ${out_var})
|
|
return(PROPAGATE ${out_var})
|
|
endfunction()
|
|
|
|
# Common handler for defaults that should be in usr/<dir>
|
|
function(__GNUInstallDirs_default_in_usr out_var initial_value install_prefix)
|
|
set(${out_var} "${initial_value}")
|
|
if(install_prefix STREQUAL "/")
|
|
cmake_policy(GET CMP0193 cmp0193
|
|
PARENT_SCOPE # undocumented, do not use outside of CMake
|
|
)
|
|
if(cmp0193 STREQUAL "NEW")
|
|
set(${out_var} "usr/${${out_var}}")
|
|
endif()
|
|
endif()
|
|
return(PROPAGATE ${out_var})
|
|
endfunction()
|
|
|
|
# Installation directories
|
|
#
|
|
|
|
# Set the standard default values before any special handling
|
|
set(_GNUInstallDirs_BINDIR_DEFAULT "bin")
|
|
set(_GNUInstallDirs_SBINDIR_DEFAULT "sbin")
|
|
set(_GNUInstallDirs_LIBEXECDIR_DEFAULT "libexec")
|
|
set(_GNUInstallDirs_SYSCONFDIR_DEFAULT "etc")
|
|
set(_GNUInstallDirs_SHAREDSTATEDIR_DEFAULT "com")
|
|
set(_GNUInstallDirs_LOCALSTATEDIR_DEFAULT "var")
|
|
set(_GNUInstallDirs_LIBDIR_DEFAULT "lib")
|
|
set(_GNUInstallDirs_INCLUDEDIR_DEFAULT "include")
|
|
set(_GNUInstallDirs_OLDINCLUDEDIR_DEFAULT "/usr/include")
|
|
set(_GNUInstallDirs_DATAROOTDIR_DEFAULT "share")
|
|
|
|
# Define the special defaults handling
|
|
# Signature
|
|
# _GNUInstallDirs_<Dir>_get_default(out_var install_prefix)
|
|
#
|
|
# ``out_var``
|
|
# Output variable with the calculated default
|
|
#
|
|
# ``install_prefix``
|
|
# The CMAKE_INSTALL_PREFIX used to calculate the default
|
|
|
|
function(_GNUInstallDirs_LIBDIR_get_default out_var install_prefix)
|
|
set(${out_var} "${_GNUInstallDirs_LIBDIR_DEFAULT}")
|
|
|
|
# Override this default 'lib' with 'lib64' iff:
|
|
# - we are on Linux system but NOT cross-compiling
|
|
# - we are NOT on debian
|
|
# - we are NOT building for conda
|
|
# - we are on a 64 bits system
|
|
# reason is: amd64 ABI: https://github.com/hjl-tools/x86-psABI/wiki/X86-psABI
|
|
# For Debian with multiarch, use 'lib/${CMAKE_LIBRARY_ARCHITECTURE}' if
|
|
# CMAKE_LIBRARY_ARCHITECTURE is set (which contains e.g. "i386-linux-gnu"
|
|
# and CMAKE_INSTALL_PREFIX is "/usr"
|
|
# See http://wiki.debian.org/Multiarch
|
|
if (NOT DEFINED CMAKE_SYSTEM_NAME OR NOT DEFINED CMAKE_SIZEOF_VOID_P)
|
|
message(AUTHOR_WARNING
|
|
"Unable to determine default CMAKE_INSTALL_LIBDIR directory because no target architecture is known. "
|
|
"Please enable at least one language before including GNUInstallDirs.")
|
|
endif()
|
|
if(CMAKE_SYSTEM_NAME MATCHES "^(Linux|GNU)$" AND NOT CMAKE_CROSSCOMPILING)
|
|
_GNUInstallDirs_get_system_type_for_install(system_type)
|
|
if(system_type STREQUAL "debian")
|
|
if(CMAKE_LIBRARY_ARCHITECTURE)
|
|
if("${install_prefix}" MATCHES "^/usr/?$")
|
|
set(${out_var} "lib/${CMAKE_LIBRARY_ARCHITECTURE}")
|
|
endif()
|
|
endif()
|
|
elseif(NOT DEFINED system_type)
|
|
# not debian, alpine, arch, or conda so rely on CMAKE_SIZEOF_VOID_P:
|
|
if("${CMAKE_SIZEOF_VOID_P}" EQUAL "8")
|
|
set(${out_var} "lib64")
|
|
endif()
|
|
endif()
|
|
endif()
|
|
__GNUInstallDirs_default_in_usr(${out_var} "${${out_var}}" "${install_prefix}")
|
|
|
|
return(PROPAGATE ${out_var})
|
|
endfunction()
|
|
|
|
foreach(dir IN ITEMS
|
|
SYSCONFDIR
|
|
LOCALSTATEDIR
|
|
)
|
|
# Cannot call function() directly because `dir` would not be accessible inside the function
|
|
# Using cmake_language(EVAL) to call a short wrapper function instead
|
|
cmake_language(EVAL CODE "
|
|
function(_GNUInstallDirs_${dir}_get_default out_var install_prefix)
|
|
set(\${out_var} \"\${_GNUInstallDirs_${dir}_DEFAULT}\")
|
|
__GNUInstallDirs_default_in_root(\${out_var} \"\${\${out_var}}\" \"\${install_prefix}\")
|
|
return(PROPAGATE \${out_var})
|
|
endfunction()
|
|
"
|
|
)
|
|
endforeach()
|
|
|
|
# Depends on current CMAKE_INSTALL_LOCALSTATEDIR value
|
|
function(_GNUInstallDirs_RUNSTATEDIR_get_default out_var install_prefix)
|
|
set(${out_var} "${_GNUInstallDirs_RUNSTATEDIR_DEFAULT}")
|
|
if(_GNUInstallDirs_CMP0192 STREQUAL "NEW")
|
|
# In the /opt/ case we want the install_prefix to be appended as
|
|
# LOCALSTATEDIR/run/PREFIX
|
|
if(install_prefix MATCHES "^/opt/" AND NOT install_prefix MATCHES "^/opt/homebrew/")
|
|
string(REPLACE "${install_prefix}" "/run${install_prefix}"
|
|
${out_var} "${CMAKE_INSTALL_LOCALSTATEDIR}"
|
|
)
|
|
endif()
|
|
endif()
|
|
return(PROPAGATE ${out_var})
|
|
endfunction()
|
|
|
|
# All of the other (primitive) dirs are typically in usr/<dir>.
|
|
# A special handling is needed for the `/` install_prefix
|
|
foreach(dir IN ITEMS
|
|
BINDIR
|
|
SBINDIR
|
|
LIBEXECDIR
|
|
SHAREDSTATEDIR
|
|
INCLUDEDIR
|
|
OLDINCLUDEDIR
|
|
DATAROOTDIR
|
|
# Except all the previous ones that had a special handling:
|
|
# LIBDIR, SYSCONFDIR, LOCALSTATEDIR, OLDINCLUDEDIR
|
|
)
|
|
# Cannot call function() directly because `dir` would not be accessible inside the function
|
|
# Using cmake_language(EVAL) to call a short wrapper function instead
|
|
cmake_language(EVAL CODE "
|
|
function(_GNUInstallDirs_${dir}_get_default out_var install_prefix)
|
|
set(\${out_var} \"\${_GNUInstallDirs_${dir}_DEFAULT}\")
|
|
__GNUInstallDirs_default_in_usr(\${out_var} \"\${\${out_var}}\" \"\${install_prefix}\")
|
|
return(PROPAGATE \${out_var})
|
|
endfunction()
|
|
"
|
|
)
|
|
endforeach()
|
|
|
|
_GNUInstallDirs_cache_path(BINDIR
|
|
"User executables")
|
|
_GNUInstallDirs_cache_path(SBINDIR
|
|
"System admin executables")
|
|
_GNUInstallDirs_cache_path(LIBEXECDIR
|
|
"Program executables")
|
|
_GNUInstallDirs_cache_path(SYSCONFDIR
|
|
"Read-only single-machine data")
|
|
_GNUInstallDirs_cache_path(SHAREDSTATEDIR
|
|
"Modifiable architecture-independent data")
|
|
_GNUInstallDirs_cache_path(LOCALSTATEDIR
|
|
"Modifiable single-machine data")
|
|
_GNUInstallDirs_cache_path(LIBDIR
|
|
"Object code libraries")
|
|
_GNUInstallDirs_cache_path(INCLUDEDIR
|
|
"C header files")
|
|
_GNUInstallDirs_cache_path(OLDINCLUDEDIR
|
|
"C header files for non-gcc")
|
|
_GNUInstallDirs_cache_path(DATAROOTDIR
|
|
"Read-only architecture-independent data root")
|
|
|
|
#-----------------------------------------------------------------------------
|
|
# Values whose defaults are relative to DATAROOTDIR. Store empty values in
|
|
# the cache and store the defaults in local variables if the cache values are
|
|
# not set explicitly. This auto-updates the defaults as DATAROOTDIR changes.
|
|
|
|
if(CMAKE_SYSTEM_NAME MATCHES "^(([^kF].*)?BSD|DragonFly)$")
|
|
set(_GNUInstallDirs_INFODIR_DEFAULT "info")
|
|
_GNUInstallDirs_cache_path(INFODIR
|
|
"Info documentation")
|
|
else()
|
|
set(_GNUInstallDirs_INFODIR_DEFAULT "${CMAKE_INSTALL_DATAROOTDIR}/info")
|
|
_GNUInstallDirs_cache_path_fallback(INFODIR
|
|
"Info documentation (DATAROOTDIR/info)")
|
|
endif()
|
|
|
|
if(CMAKE_SYSTEM_NAME MATCHES "^(([^k].*)?BSD|DragonFly)$" AND NOT CMAKE_SYSTEM_NAME MATCHES "^(FreeBSD)$")
|
|
set(_GNUInstallDirs_MANDIR_DEFAULT "man")
|
|
_GNUInstallDirs_cache_path(MANDIR
|
|
"Man documentation")
|
|
else()
|
|
set(_GNUInstallDirs_MANDIR_DEFAULT "${CMAKE_INSTALL_DATAROOTDIR}/man")
|
|
_GNUInstallDirs_cache_path_fallback(MANDIR
|
|
"Man documentation (DATAROOTDIR/man)")
|
|
endif()
|
|
|
|
set(_GNUInstallDirs_DATADIR_DEFAULT "${CMAKE_INSTALL_DATAROOTDIR}")
|
|
set(_GNUInstallDirs_LOCALEDIR_DEFAULT "${CMAKE_INSTALL_DATAROOTDIR}/locale")
|
|
set(_GNUInstallDirs_DOCDIR_DEFAULT "${CMAKE_INSTALL_DATAROOTDIR}/doc/${PROJECT_NAME}")
|
|
set(_GNUInstallDirs_RUNSTATEDIR_DEFAULT "${CMAKE_INSTALL_LOCALSTATEDIR}/run")
|
|
|
|
_GNUInstallDirs_cache_path_fallback(DATADIR
|
|
"Read-only architecture-independent data (DATAROOTDIR)")
|
|
_GNUInstallDirs_cache_path_fallback(LOCALEDIR
|
|
"Locale-dependent data (DATAROOTDIR/locale)")
|
|
_GNUInstallDirs_cache_path_fallback(DOCDIR
|
|
"Documentation root (DATAROOTDIR/doc/PROJECT_NAME)")
|
|
_GNUInstallDirs_cache_path_fallback(RUNSTATEDIR
|
|
"Run-time variable data (LOCALSTATEDIR/run)")
|
|
|
|
# Unset all the defaults used
|
|
foreach(dir IN ITEMS
|
|
BINDIR
|
|
SBINDIR
|
|
LIBEXECDIR
|
|
SYSCONFDIR
|
|
SHAREDSTATEDIR
|
|
LOCALSTATEDIR
|
|
LIBDIR
|
|
INCLUDEDIR
|
|
OLDINCLUDEDIR
|
|
DATAROOTDIR
|
|
DATADIR
|
|
INFODIR
|
|
MANDIR
|
|
LOCALEDIR
|
|
DOCDIR
|
|
RUNSTATEDIR
|
|
)
|
|
unset(_GNUInstallDirs_${dir}_DEFAULT)
|
|
endforeach()
|
|
|
|
# Save for next run
|
|
set(_GNUInstallDirs_LAST_CMAKE_INSTALL_PREFIX "${CMAKE_INSTALL_PREFIX}" CACHE INTERNAL "CMAKE_INSTALL_PREFIX during last run")
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
mark_as_advanced(
|
|
CMAKE_INSTALL_BINDIR
|
|
CMAKE_INSTALL_SBINDIR
|
|
CMAKE_INSTALL_LIBEXECDIR
|
|
CMAKE_INSTALL_SYSCONFDIR
|
|
CMAKE_INSTALL_SHAREDSTATEDIR
|
|
CMAKE_INSTALL_LOCALSTATEDIR
|
|
CMAKE_INSTALL_RUNSTATEDIR
|
|
CMAKE_INSTALL_LIBDIR
|
|
CMAKE_INSTALL_INCLUDEDIR
|
|
CMAKE_INSTALL_OLDINCLUDEDIR
|
|
CMAKE_INSTALL_DATAROOTDIR
|
|
CMAKE_INSTALL_DATADIR
|
|
CMAKE_INSTALL_INFODIR
|
|
CMAKE_INSTALL_LOCALEDIR
|
|
CMAKE_INSTALL_MANDIR
|
|
CMAKE_INSTALL_DOCDIR
|
|
)
|
|
|
|
function(GNUInstallDirs_get_absolute_install_dir absvar var)
|
|
set(GGAID_extra_args ${ARGN})
|
|
list(LENGTH GGAID_extra_args GGAID_extra_arg_count)
|
|
if(GGAID_extra_arg_count GREATER "0")
|
|
list(GET GGAID_extra_args 0 GGAID_dir)
|
|
else()
|
|
# Historical behavior: use ${dir} from caller's scope
|
|
set(GGAID_dir "${dir}")
|
|
message(AUTHOR_WARNING
|
|
"GNUInstallDirs_get_absolute_install_dir called without third argument. "
|
|
"Using \${dir} from the caller's scope for compatibility with CMake 3.19 and below.")
|
|
endif()
|
|
|
|
if(NOT IS_ABSOLUTE "${${var}}")
|
|
# Handle special cases:
|
|
# - CMAKE_INSTALL_PREFIX == /
|
|
# - CMAKE_INSTALL_PREFIX == /usr
|
|
# - CMAKE_INSTALL_PREFIX == /opt/...
|
|
if("${GGAID_dir}" STREQUAL "SYSCONFDIR" OR "${GGAID_dir}" STREQUAL "LOCALSTATEDIR" OR "${GGAID_dir}" STREQUAL "RUNSTATEDIR")
|
|
_GNUInstallDirs_special_absolute(${absvar} "${${var}}" "${CMAKE_INSTALL_PREFIX}")
|
|
# If the CMAKE_INSTALL_PREFIX was not special, the output
|
|
# is still not absolute, so use the default logic.
|
|
if(NOT IS_ABSOLUTE "${${absvar}}")
|
|
# Make sure we account for any trailing `/`
|
|
if(CMAKE_INSTALL_PREFIX MATCHES "/$")
|
|
set(${absvar} "${CMAKE_INSTALL_PREFIX}${${var}}")
|
|
else()
|
|
set(${absvar} "${CMAKE_INSTALL_PREFIX}/${${var}}")
|
|
endif()
|
|
endif()
|
|
elseif("${CMAKE_INSTALL_PREFIX}" STREQUAL "/")
|
|
if (NOT "${${var}}" MATCHES "^usr/")
|
|
set(${var} "usr/${${var}}")
|
|
endif()
|
|
set(${absvar} "/${${var}}")
|
|
else()
|
|
set(${absvar} "${CMAKE_INSTALL_PREFIX}/${${var}}")
|
|
endif()
|
|
else()
|
|
set(${absvar} "${${var}}")
|
|
endif()
|
|
|
|
set(return_vars ${absvar})
|
|
cmake_policy(GET CMP0193 cmp0193
|
|
PARENT_SCOPE # undocumented, do not use outside of CMake
|
|
)
|
|
if(NOT cmp0193 STREQUAL "NEW")
|
|
list(APPEND return_vars ${var})
|
|
endif()
|
|
return(PROPAGATE ${return_vars})
|
|
endfunction()
|
|
|
|
# Result directories
|
|
#
|
|
foreach(dir
|
|
BINDIR
|
|
SBINDIR
|
|
LIBEXECDIR
|
|
SYSCONFDIR
|
|
SHAREDSTATEDIR
|
|
LOCALSTATEDIR
|
|
RUNSTATEDIR
|
|
LIBDIR
|
|
INCLUDEDIR
|
|
OLDINCLUDEDIR
|
|
DATAROOTDIR
|
|
DATADIR
|
|
INFODIR
|
|
LOCALEDIR
|
|
MANDIR
|
|
DOCDIR
|
|
)
|
|
GNUInstallDirs_get_absolute_install_dir(CMAKE_INSTALL_FULL_${dir} CMAKE_INSTALL_${dir} ${dir})
|
|
endforeach()
|
|
|
|
unset(_GNUInstallDirs_CMP0192)
|