|  | @@ -5,12 +5,74 @@ find_package
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |     .. contents::
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Find an external project, and load its settings.
 | 
	
		
			
				|  |  | +Find a package (usually provided by something external to the project),
 | 
	
		
			
				|  |  | +and load its package-specific details.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Search Modes
 | 
	
		
			
				|  |  | +^^^^^^^^^^^^
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +The command has two very distinct ways of conducting the search:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +**Module mode**
 | 
	
		
			
				|  |  | +  In this mode, CMake searches for a file called ``Find<PackageName>.cmake``,
 | 
	
		
			
				|  |  | +  looking first in the locations listed in the :variable:`CMAKE_MODULE_PATH`,
 | 
	
		
			
				|  |  | +  then among the :ref:`Find Modules` provided by the CMake installation.
 | 
	
		
			
				|  |  | +  If the file is found, it is read and processed by CMake.  It is responsible
 | 
	
		
			
				|  |  | +  for finding the package, checking the version, and producing any needed
 | 
	
		
			
				|  |  | +  messages.  Some Find modules provide limited or no support for versioning;
 | 
	
		
			
				|  |  | +  check the Find module's documentation.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  The ``Find<PackageName>.cmake`` file is not typically provided by the
 | 
	
		
			
				|  |  | +  package itself.  Rather, it is normally provided by something external to
 | 
	
		
			
				|  |  | +  the package, such as the operating system, CMake itself, or even the project
 | 
	
		
			
				|  |  | +  from which the ``find_package()`` command was called.  Being externally
 | 
	
		
			
				|  |  | +  provided, :ref:`Find Modules` tend to be heuristic in nature and are
 | 
	
		
			
				|  |  | +  susceptible to becoming out-of-date.  They typically search for certain
 | 
	
		
			
				|  |  | +  libraries, files and other package artifacts.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  Module mode is only supported by the
 | 
	
		
			
				|  |  | +  :ref:`basic command signature <Basic Signature>`.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +**Config mode**
 | 
	
		
			
				|  |  | +  In this mode, CMake searches for a file called
 | 
	
		
			
				|  |  | +  ``<lowercasePackageName>-config.cmake`` or ``<PackageName>Config.cmake``.
 | 
	
		
			
				|  |  | +  It will also look for ``<lowercasePackageName>-config-version.cmake`` or
 | 
	
		
			
				|  |  | +  ``<PackageName>ConfigVersion.cmake`` if version details were specified
 | 
	
		
			
				|  |  | +  (see :ref:`version selection` for an explanation of how these separate
 | 
	
		
			
				|  |  | +  version files are used).
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  In config mode, the command can be given a list of names to search for
 | 
	
		
			
				|  |  | +  as package names.  The locations where CMake searches for the config and
 | 
	
		
			
				|  |  | +  version files is considerably more complicated than for Module mode
 | 
	
		
			
				|  |  | +  (see :ref:`search procedure`).
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  The config and version files are typically installed as part of the
 | 
	
		
			
				|  |  | +  package, so they tend to be more reliable than Find modules.  They usually
 | 
	
		
			
				|  |  | +  contain direct knowledge of the package contents, so no searching or
 | 
	
		
			
				|  |  | +  heuristics are needed within the config or version files themselves.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  Config mode is supported by both the :ref:`basic <Basic Signature>` and
 | 
	
		
			
				|  |  | +  :ref:`full <Full Signature>` command signatures.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +The command arguments determine which of the above modes is used.  When the
 | 
	
		
			
				|  |  | +`basic signature`_ is used, the command searches in Module mode first.
 | 
	
		
			
				|  |  | +If the package is not found, the search falls back to Config mode.
 | 
	
		
			
				|  |  | +A user may set the :variable:`CMAKE_FIND_PACKAGE_PREFER_CONFIG` variable
 | 
	
		
			
				|  |  | +to true to reverse the priority and direct CMake to search using Config mode
 | 
	
		
			
				|  |  | +first before falling back to Module mode.  The basic signature can also be
 | 
	
		
			
				|  |  | +forced to use only Module mode with a ``MODULE`` keyword.  If the
 | 
	
		
			
				|  |  | +`full signature`_ is used, the command only searches in Config mode.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Where possible, user code should generally look for packages using the
 | 
	
		
			
				|  |  | +`basic signature`_, since that allows the package to be found with either mode.
 | 
	
		
			
				|  |  | +Project maintainers wishing to provide a config package should understand
 | 
	
		
			
				|  |  | +the bigger picture, as explained in :ref:`Full Signature` and all subsequent
 | 
	
		
			
				|  |  | +sections on this page.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. _`basic signature`:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Basic Signature and Module Mode
 | 
	
		
			
				|  |  | -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  | +Basic Signature
 | 
	
		
			
				|  |  | +^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. code-block:: cmake
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -19,10 +81,14 @@ Basic Signature and Module Mode
 | 
	
		
			
				|  |  |                 [OPTIONAL_COMPONENTS components...]
 | 
	
		
			
				|  |  |                 [NO_POLICY_SCOPE])
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Finds and loads settings from an external project.  ``<PackageName>_FOUND``
 | 
	
		
			
				|  |  | -will be set to indicate whether the package was found.  When the
 | 
	
		
			
				|  |  | -package is found package-specific information is provided through
 | 
	
		
			
				|  |  | -variables and :ref:`Imported Targets` documented by the package itself.  The
 | 
	
		
			
				|  |  | +The basic signature is supported by both Module and Config modes.
 | 
	
		
			
				|  |  | +The ``MODULE`` keyword implies that only Module mode can be used to find
 | 
	
		
			
				|  |  | +the package, with no fallback to Config mode.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Regardless of the mode used, a ``<PackageName>_FOUND`` variable will be
 | 
	
		
			
				|  |  | +set to indicate whether the package was found.  When the package is found,
 | 
	
		
			
				|  |  | +package-specific information may be provided through other variables and
 | 
	
		
			
				|  |  | +:ref:`Imported Targets` documented by the package itself.  The
 | 
	
		
			
				|  |  |  ``QUIET`` option disables informational messages, including those indicating
 | 
	
		
			
				|  |  |  that the package cannot be found if it is not ``REQUIRED``.  The ``REQUIRED``
 | 
	
		
			
				|  |  |  option stops processing with an error message if the package cannot be found.
 | 
	
	
		
			
				|  | @@ -78,36 +144,10 @@ only take the single version at the lower end of the range into account.
 | 
	
		
			
				|  |  |  See the :command:`cmake_policy` command documentation for discussion
 | 
	
		
			
				|  |  |  of the ``NO_POLICY_SCOPE`` option.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -The command has two modes by which it searches for packages: "Module"
 | 
	
		
			
				|  |  | -mode and "Config" mode.  The above signature selects Module mode.
 | 
	
		
			
				|  |  | -If no module is found the command falls back to Config mode, described
 | 
	
		
			
				|  |  | -below. This fall back is disabled if the ``MODULE`` option is given.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -In Module mode, CMake searches for a file called ``Find<PackageName>.cmake``.
 | 
	
		
			
				|  |  | -The file is first searched in the :variable:`CMAKE_MODULE_PATH`,
 | 
	
		
			
				|  |  | -then among the :ref:`Find Modules` provided by the CMake installation.
 | 
	
		
			
				|  |  | -If the file is found, it is read and processed by CMake.  It is responsible
 | 
	
		
			
				|  |  | -for finding the package, checking the version, and producing any needed
 | 
	
		
			
				|  |  | -messages.  Some find-modules provide limited or no support for versioning;
 | 
	
		
			
				|  |  | -check the module documentation.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -If the ``MODULE`` option is not specified in the above signature,
 | 
	
		
			
				|  |  | -CMake first searches for the package using Module mode. Then, if the
 | 
	
		
			
				|  |  | -package is not found, it searches again using Config mode. A user
 | 
	
		
			
				|  |  | -may set the variable :variable:`CMAKE_FIND_PACKAGE_PREFER_CONFIG` to
 | 
	
		
			
				|  |  | -``TRUE`` to direct CMake first search using Config mode before falling
 | 
	
		
			
				|  |  | -back to Module mode.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -Full Signature and Config Mode
 | 
	
		
			
				|  |  | -^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -User code should generally look for packages using the above `basic
 | 
	
		
			
				|  |  | -signature`_.  The remainder of this command documentation specifies the
 | 
	
		
			
				|  |  | -full command signature and details of the search process.  Project
 | 
	
		
			
				|  |  | -maintainers wishing to provide a package to be found by this command
 | 
	
		
			
				|  |  | -are encouraged to read on.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -The complete Config mode command signature is
 | 
	
		
			
				|  |  | +.. _`full signature`:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Full Signature
 | 
	
		
			
				|  |  | +^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  .. code-block:: cmake
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -145,18 +185,19 @@ hold the directory containing the file.  By default the command
 | 
	
		
			
				|  |  |  searches for a package with the name ``<PackageName>``.  If the ``NAMES`` option
 | 
	
		
			
				|  |  |  is given the names following it are used instead of ``<PackageName>``.
 | 
	
		
			
				|  |  |  The command searches for a file called ``<PackageName>Config.cmake`` or
 | 
	
		
			
				|  |  | -``<lower-case-package-name>-config.cmake`` for each name specified.
 | 
	
		
			
				|  |  | +``<lowercasePackageName>-config.cmake`` for each name specified.
 | 
	
		
			
				|  |  |  A replacement set of possible configuration file names may be given
 | 
	
		
			
				|  |  | -using the ``CONFIGS`` option.  The search procedure is specified below.
 | 
	
		
			
				|  |  | -Once found, the configuration file is read and processed by CMake.
 | 
	
		
			
				|  |  | +using the ``CONFIGS`` option.  The :ref:`search procedure` is specified below.
 | 
	
		
			
				|  |  | +Once found, any :ref:`version constraint <version selection>` is checked,
 | 
	
		
			
				|  |  | +and if satisfied, the configuration file is read and processed by CMake.
 | 
	
		
			
				|  |  |  Since the file is provided by the package it already knows the
 | 
	
		
			
				|  |  |  location of package contents.  The full path to the configuration file
 | 
	
		
			
				|  |  |  is stored in the cmake variable ``<PackageName>_CONFIG``.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  All configuration files which have been considered by CMake while
 | 
	
		
			
				|  |  | -searching for an installation of the package with an appropriate
 | 
	
		
			
				|  |  | -version are stored in the cmake variable ``<PackageName>_CONSIDERED_CONFIGS``,
 | 
	
		
			
				|  |  | -the associated versions in ``<PackageName>_CONSIDERED_VERSIONS``.
 | 
	
		
			
				|  |  | +searching for the package with an appropriate version are stored in the
 | 
	
		
			
				|  |  | +``<PackageName>_CONSIDERED_CONFIGS`` variable, and the associated versions
 | 
	
		
			
				|  |  | +in the ``<PackageName>_CONSIDERED_VERSIONS`` variable.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  If the package configuration file cannot be found CMake will generate
 | 
	
		
			
				|  |  |  an error describing the problem unless the ``QUIET`` argument is
 | 
	
	
		
			
				|  | @@ -166,143 +207,18 @@ fatal error is generated and the configure step stops executing.  If
 | 
	
		
			
				|  |  |  configuration file CMake will ignore it and search from scratch.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Package maintainers providing CMake package configuration files are
 | 
	
		
			
				|  |  | -encouraged to name and install them such that the `Search Procedure`_
 | 
	
		
			
				|  |  | +encouraged to name and install them such that the :ref:`search procedure`
 | 
	
		
			
				|  |  |  outlined below will find them without requiring use of additional options.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -Version Selection
 | 
	
		
			
				|  |  | -^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -When the ``[version]`` argument is given, Config mode will only find a
 | 
	
		
			
				|  |  | -version of the package that claims compatibility with the requested
 | 
	
		
			
				|  |  | -version (see :ref:`format specification <FIND_PACKAGE_VERSION_FORMAT>`). If the
 | 
	
		
			
				|  |  | -``EXACT`` option is given, only a version of the package claiming an exact match
 | 
	
		
			
				|  |  | -of the requested version may be found.  CMake does not establish any
 | 
	
		
			
				|  |  | -convention for the meaning of version numbers.  Package version
 | 
	
		
			
				|  |  | -numbers are checked by "version" files provided by the packages
 | 
	
		
			
				|  |  | -themselves.  For a candidate package configuration file
 | 
	
		
			
				|  |  | -``<config-file>.cmake`` the corresponding version file is located next
 | 
	
		
			
				|  |  | -to it and named either ``<config-file>-version.cmake`` or
 | 
	
		
			
				|  |  | -``<config-file>Version.cmake``.  If no such version file is available
 | 
	
		
			
				|  |  | -then the configuration file is assumed to not be compatible with any
 | 
	
		
			
				|  |  | -requested version.  A basic version file containing generic version
 | 
	
		
			
				|  |  | -matching code can be created using the
 | 
	
		
			
				|  |  | -:module:`CMakePackageConfigHelpers` module.  When a version file
 | 
	
		
			
				|  |  | -is found it is loaded to check the requested version number.  The
 | 
	
		
			
				|  |  | -version file is loaded in a nested scope in which the following
 | 
	
		
			
				|  |  | -variables have been defined:
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_NAME``
 | 
	
		
			
				|  |  | -  The ``<PackageName>``
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION``
 | 
	
		
			
				|  |  | -  Full requested version string
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAJOR``
 | 
	
		
			
				|  |  | -  Major version if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MINOR``
 | 
	
		
			
				|  |  | -  Minor version if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_PATCH``
 | 
	
		
			
				|  |  | -  Patch version if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_TWEAK``
 | 
	
		
			
				|  |  | -  Tweak version if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_COUNT``
 | 
	
		
			
				|  |  | -  Number of version components, 0 to 4
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -When a version range is specified, the above version variables will hold
 | 
	
		
			
				|  |  | -values based on the lower end of the version range.  This is to preserve
 | 
	
		
			
				|  |  | -compatibility with packages that have not been implemented to expect version
 | 
	
		
			
				|  |  | -ranges.  In addition, the version range will be described by the following
 | 
	
		
			
				|  |  | -variables:
 | 
	
		
			
				|  |  | +.. _`search procedure`:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_RANGE``
 | 
	
		
			
				|  |  | -  Full requested version range string
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_RANGE_MIN``
 | 
	
		
			
				|  |  | -  This specifies whether the lower end point of the version range should be
 | 
	
		
			
				|  |  | -  included or excluded.  Currently, the only supported value for this variable
 | 
	
		
			
				|  |  | -  is ``INCLUDE``.
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_RANGE_MAX``
 | 
	
		
			
				|  |  | -  This specifies whether the upper end point of the version range should be
 | 
	
		
			
				|  |  | -  included or excluded.  The supported values for this variable are
 | 
	
		
			
				|  |  | -  ``INCLUDE`` and ``EXCLUDE``.
 | 
	
		
			
				|  |  | +Config Mode Search Procedure
 | 
	
		
			
				|  |  | +^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MIN``
 | 
	
		
			
				|  |  | -  Full requested version string of the lower end point of the range
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MIN_MAJOR``
 | 
	
		
			
				|  |  | -  Major version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MIN_MINOR``
 | 
	
		
			
				|  |  | -  Minor version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MIN_PATCH``
 | 
	
		
			
				|  |  | -  Patch version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MIN_TWEAK``
 | 
	
		
			
				|  |  | -  Tweak version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MIN_COUNT``
 | 
	
		
			
				|  |  | -  Number of version components of the lower end point, 0 to 4
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAX``
 | 
	
		
			
				|  |  | -  Full requested version string of the upper end point of the range
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAX_MAJOR``
 | 
	
		
			
				|  |  | -  Major version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAX_MINOR``
 | 
	
		
			
				|  |  | -  Minor version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAX_PATCH``
 | 
	
		
			
				|  |  | -  Patch version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAX_TWEAK``
 | 
	
		
			
				|  |  | -  Tweak version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | -``PACKAGE_FIND_VERSION_MAX_COUNT``
 | 
	
		
			
				|  |  | -  Number of version components of the upper end point, 0 to 4
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -Regardless of whether a single version or a version range is specified, the
 | 
	
		
			
				|  |  | -variable ``PACKAGE_FIND_VERSION_COMPLETE`` will be defined and will hold
 | 
	
		
			
				|  |  | -the full requested version string as specified.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -The version file checks whether it satisfies the requested version and
 | 
	
		
			
				|  |  | -sets these variables:
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -``PACKAGE_VERSION``
 | 
	
		
			
				|  |  | -  Full provided version string
 | 
	
		
			
				|  |  | -``PACKAGE_VERSION_EXACT``
 | 
	
		
			
				|  |  | -  True if version is exact match
 | 
	
		
			
				|  |  | -``PACKAGE_VERSION_COMPATIBLE``
 | 
	
		
			
				|  |  | -  True if version is compatible
 | 
	
		
			
				|  |  | -``PACKAGE_VERSION_UNSUITABLE``
 | 
	
		
			
				|  |  | -  True if unsuitable as any version
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -These variables are checked by the ``find_package`` command to determine
 | 
	
		
			
				|  |  | -whether the configuration file provides an acceptable version.  They
 | 
	
		
			
				|  |  | -are not available after the ``find_package`` call returns.  If the version
 | 
	
		
			
				|  |  | -is acceptable the following variables are set:
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -``<PackageName>_VERSION``
 | 
	
		
			
				|  |  | -  Full provided version string
 | 
	
		
			
				|  |  | -``<PackageName>_VERSION_MAJOR``
 | 
	
		
			
				|  |  | -  Major version if provided, else 0
 | 
	
		
			
				|  |  | -``<PackageName>_VERSION_MINOR``
 | 
	
		
			
				|  |  | -  Minor version if provided, else 0
 | 
	
		
			
				|  |  | -``<PackageName>_VERSION_PATCH``
 | 
	
		
			
				|  |  | -  Patch version if provided, else 0
 | 
	
		
			
				|  |  | -``<PackageName>_VERSION_TWEAK``
 | 
	
		
			
				|  |  | -  Tweak version if provided, else 0
 | 
	
		
			
				|  |  | -``<PackageName>_VERSION_COUNT``
 | 
	
		
			
				|  |  | -  Number of version components, 0 to 4
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -and the corresponding package configuration file is loaded.
 | 
	
		
			
				|  |  | -When multiple package configuration files are available whose version files
 | 
	
		
			
				|  |  | -claim compatibility with the version requested it is unspecified which
 | 
	
		
			
				|  |  | -one is chosen: unless the variable :variable:`CMAKE_FIND_PACKAGE_SORT_ORDER`
 | 
	
		
			
				|  |  | -is set no attempt is made to choose a highest or closest version number.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -To control the order in which ``find_package`` checks for compatibility use
 | 
	
		
			
				|  |  | -the two variables :variable:`CMAKE_FIND_PACKAGE_SORT_ORDER` and
 | 
	
		
			
				|  |  | -:variable:`CMAKE_FIND_PACKAGE_SORT_DIRECTION`.
 | 
	
		
			
				|  |  | -For instance in order to select the highest version one can set
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -.. code-block:: cmake
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -  SET(CMAKE_FIND_PACKAGE_SORT_ORDER NATURAL)
 | 
	
		
			
				|  |  | -  SET(CMAKE_FIND_PACKAGE_SORT_DIRECTION DEC)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -before calling ``find_package``.
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -Search Procedure
 | 
	
		
			
				|  |  | -^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  | +.. note::
 | 
	
		
			
				|  |  | +  When Config mode is used, this search procedure is applied regardless of
 | 
	
		
			
				|  |  | +  whether the :ref:`full <full signature>` or :ref:`basic <basic signature>`
 | 
	
		
			
				|  |  | +  signature was given.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  CMake constructs a set of possible installation prefixes for the
 | 
	
		
			
				|  |  |  package.  Under each prefix several directories are searched for a
 | 
	
	
		
			
				|  | @@ -474,6 +390,145 @@ Every non-REQUIRED ``find_package`` call can be disabled or made REQUIRED:
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  Setting both variables to ``TRUE`` simultaneously is an error.
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +.. _`version selection`:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Config Mode Version Selection
 | 
	
		
			
				|  |  | +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +.. note::
 | 
	
		
			
				|  |  | +  When Config mode is used, this version selection process is applied
 | 
	
		
			
				|  |  | +  regardless of whether the :ref:`full <full signature>` or
 | 
	
		
			
				|  |  | +  :ref:`basic <basic signature>` signature was given.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +When the ``[version]`` argument is given, Config mode will only find a
 | 
	
		
			
				|  |  | +version of the package that claims compatibility with the requested
 | 
	
		
			
				|  |  | +version (see :ref:`format specification <FIND_PACKAGE_VERSION_FORMAT>`). If the
 | 
	
		
			
				|  |  | +``EXACT`` option is given, only a version of the package claiming an exact match
 | 
	
		
			
				|  |  | +of the requested version may be found.  CMake does not establish any
 | 
	
		
			
				|  |  | +convention for the meaning of version numbers.  Package version
 | 
	
		
			
				|  |  | +numbers are checked by "version" files provided by the packages
 | 
	
		
			
				|  |  | +themselves.  For a candidate package configuration file
 | 
	
		
			
				|  |  | +``<config-file>.cmake`` the corresponding version file is located next
 | 
	
		
			
				|  |  | +to it and named either ``<config-file>-version.cmake`` or
 | 
	
		
			
				|  |  | +``<config-file>Version.cmake``.  If no such version file is available
 | 
	
		
			
				|  |  | +then the configuration file is assumed to not be compatible with any
 | 
	
		
			
				|  |  | +requested version.  A basic version file containing generic version
 | 
	
		
			
				|  |  | +matching code can be created using the
 | 
	
		
			
				|  |  | +:module:`CMakePackageConfigHelpers` module.  When a version file
 | 
	
		
			
				|  |  | +is found it is loaded to check the requested version number.  The
 | 
	
		
			
				|  |  | +version file is loaded in a nested scope in which the following
 | 
	
		
			
				|  |  | +variables have been defined:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_NAME``
 | 
	
		
			
				|  |  | +  The ``<PackageName>``
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION``
 | 
	
		
			
				|  |  | +  Full requested version string
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAJOR``
 | 
	
		
			
				|  |  | +  Major version if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MINOR``
 | 
	
		
			
				|  |  | +  Minor version if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_PATCH``
 | 
	
		
			
				|  |  | +  Patch version if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_TWEAK``
 | 
	
		
			
				|  |  | +  Tweak version if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_COUNT``
 | 
	
		
			
				|  |  | +  Number of version components, 0 to 4
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +When a version range is specified, the above version variables will hold
 | 
	
		
			
				|  |  | +values based on the lower end of the version range.  This is to preserve
 | 
	
		
			
				|  |  | +compatibility with packages that have not been implemented to expect version
 | 
	
		
			
				|  |  | +ranges.  In addition, the version range will be described by the following
 | 
	
		
			
				|  |  | +variables:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_RANGE``
 | 
	
		
			
				|  |  | +  Full requested version range string
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_RANGE_MIN``
 | 
	
		
			
				|  |  | +  This specifies whether the lower end point of the version range should be
 | 
	
		
			
				|  |  | +  included or excluded.  Currently, the only supported value for this variable
 | 
	
		
			
				|  |  | +  is ``INCLUDE``.
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_RANGE_MAX``
 | 
	
		
			
				|  |  | +  This specifies whether the upper end point of the version range should be
 | 
	
		
			
				|  |  | +  included or excluded.  The supported values for this variable are
 | 
	
		
			
				|  |  | +  ``INCLUDE`` and ``EXCLUDE``.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MIN``
 | 
	
		
			
				|  |  | +  Full requested version string of the lower end point of the range
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MIN_MAJOR``
 | 
	
		
			
				|  |  | +  Major version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MIN_MINOR``
 | 
	
		
			
				|  |  | +  Minor version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MIN_PATCH``
 | 
	
		
			
				|  |  | +  Patch version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MIN_TWEAK``
 | 
	
		
			
				|  |  | +  Tweak version of the lower end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MIN_COUNT``
 | 
	
		
			
				|  |  | +  Number of version components of the lower end point, 0 to 4
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAX``
 | 
	
		
			
				|  |  | +  Full requested version string of the upper end point of the range
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAX_MAJOR``
 | 
	
		
			
				|  |  | +  Major version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAX_MINOR``
 | 
	
		
			
				|  |  | +  Minor version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAX_PATCH``
 | 
	
		
			
				|  |  | +  Patch version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAX_TWEAK``
 | 
	
		
			
				|  |  | +  Tweak version of the upper end point if requested, else 0
 | 
	
		
			
				|  |  | +``PACKAGE_FIND_VERSION_MAX_COUNT``
 | 
	
		
			
				|  |  | +  Number of version components of the upper end point, 0 to 4
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +Regardless of whether a single version or a version range is specified, the
 | 
	
		
			
				|  |  | +variable ``PACKAGE_FIND_VERSION_COMPLETE`` will be defined and will hold
 | 
	
		
			
				|  |  | +the full requested version string as specified.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +The version file checks whether it satisfies the requested version and
 | 
	
		
			
				|  |  | +sets these variables:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +``PACKAGE_VERSION``
 | 
	
		
			
				|  |  | +  Full provided version string
 | 
	
		
			
				|  |  | +``PACKAGE_VERSION_EXACT``
 | 
	
		
			
				|  |  | +  True if version is exact match
 | 
	
		
			
				|  |  | +``PACKAGE_VERSION_COMPATIBLE``
 | 
	
		
			
				|  |  | +  True if version is compatible
 | 
	
		
			
				|  |  | +``PACKAGE_VERSION_UNSUITABLE``
 | 
	
		
			
				|  |  | +  True if unsuitable as any version
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +These variables are checked by the ``find_package`` command to determine
 | 
	
		
			
				|  |  | +whether the configuration file provides an acceptable version.  They
 | 
	
		
			
				|  |  | +are not available after the ``find_package`` call returns.  If the version
 | 
	
		
			
				|  |  | +is acceptable the following variables are set:
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +``<PackageName>_VERSION``
 | 
	
		
			
				|  |  | +  Full provided version string
 | 
	
		
			
				|  |  | +``<PackageName>_VERSION_MAJOR``
 | 
	
		
			
				|  |  | +  Major version if provided, else 0
 | 
	
		
			
				|  |  | +``<PackageName>_VERSION_MINOR``
 | 
	
		
			
				|  |  | +  Minor version if provided, else 0
 | 
	
		
			
				|  |  | +``<PackageName>_VERSION_PATCH``
 | 
	
		
			
				|  |  | +  Patch version if provided, else 0
 | 
	
		
			
				|  |  | +``<PackageName>_VERSION_TWEAK``
 | 
	
		
			
				|  |  | +  Tweak version if provided, else 0
 | 
	
		
			
				|  |  | +``<PackageName>_VERSION_COUNT``
 | 
	
		
			
				|  |  | +  Number of version components, 0 to 4
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +and the corresponding package configuration file is loaded.
 | 
	
		
			
				|  |  | +When multiple package configuration files are available whose version files
 | 
	
		
			
				|  |  | +claim compatibility with the version requested it is unspecified which
 | 
	
		
			
				|  |  | +one is chosen: unless the variable :variable:`CMAKE_FIND_PACKAGE_SORT_ORDER`
 | 
	
		
			
				|  |  | +is set no attempt is made to choose a highest or closest version number.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +To control the order in which ``find_package`` checks for compatibility use
 | 
	
		
			
				|  |  | +the two variables :variable:`CMAKE_FIND_PACKAGE_SORT_ORDER` and
 | 
	
		
			
				|  |  | +:variable:`CMAKE_FIND_PACKAGE_SORT_DIRECTION`.
 | 
	
		
			
				|  |  | +For instance in order to select the highest version one can set
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +.. code-block:: cmake
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +  SET(CMAKE_FIND_PACKAGE_SORT_ORDER NATURAL)
 | 
	
		
			
				|  |  | +  SET(CMAKE_FIND_PACKAGE_SORT_DIRECTION DEC)
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +before calling ``find_package``.
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  Package File Interface Variables
 | 
	
		
			
				|  |  |  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
 | 
	
		
			
				|  |  |  
 |