1CMAKE-PACKAGES(7)                    CMake                   CMAKE-PACKAGES(7)
2
3
4

NAME

6       cmake-packages - CMake Packages Reference
7

INTRODUCTION

9       Packages  provide  dependency  information to CMake based buildsystems.
10       Packages are found with the find_package() command.  The result of  us‐
11       ing  find_package()  is  either  a set of IMPORTED targets, or a set of
12       variables corresponding to build-relevant information.
13

USING PACKAGES

15       CMake provides direct support for two forms  of  packages,  Config-file
16       Packages  and  Find-module  Packages.   Indirect support for pkg-config
17       packages is also provided via the FindPkgConfig module.  In all  cases,
18       the basic form of find_package() calls is the same:
19
20          find_package(Qt4 4.7.0 REQUIRED) # CMake provides a Qt4 find-module
21          find_package(Qt5Core 5.1.0 REQUIRED) # Qt provides a Qt5 package config file.
22          find_package(LibXml2 REQUIRED) # Use pkg-config via the LibXml2 find-module
23
24       In  cases  where  it is known that a package configuration file is pro‐
25       vided by upstream, and only that should be used, the CONFIG keyword may
26       be passed to find_package():
27
28          find_package(Qt5Core 5.1.0 CONFIG REQUIRED)
29          find_package(Qt5Gui 5.1.0 CONFIG)
30
31       Similarly, the MODULE keyword says to use only a find-module:
32
33          find_package(Qt4 4.7.0 MODULE REQUIRED)
34
35       Specifying  the  type  of package explicitly improves the error message
36       shown to the user if it is not found.
37
38       Both types of packages also support specifying components of a package,
39       either after the REQUIRED keyword:
40
41          find_package(Qt5 5.1.0 CONFIG REQUIRED Widgets Xml Sql)
42
43       or as a separate COMPONENTS list:
44
45          find_package(Qt5 5.1.0 COMPONENTS Widgets Xml Sql)
46
47       or as a separate OPTIONAL_COMPONENTS list:
48
49          find_package(Qt5 5.1.0 COMPONENTS Widgets
50                                 OPTIONAL_COMPONENTS Xml Sql
51          )
52
53       Handling  of COMPONENTS and OPTIONAL_COMPONENTS is defined by the pack‐
54       age.
55
56       By setting  the  CMAKE_DISABLE_FIND_PACKAGE_<PackageName>  variable  to
57       TRUE,  the  <PackageName> package will not be searched, and will always
58       be NOTFOUND. Likewise, setting the CMAKE_REQUIRE_FIND_PACKAGE_<Package‐
59       Name> to TRUE will make the package REQUIRED.
60
61   Config-file Packages
62       A config-file package is a set of files provided by upstreams for down‐
63       streams to use. CMake searches in a number  of  locations  for  package
64       configuration  files, as described in the find_package() documentation.
65       The most simple way for a CMake user to tell cmake(1) to  search  in  a
66       non-standard prefix for a package is to set the CMAKE_PREFIX_PATH cache
67       variable.
68
69       Config-file packages are provided by upstream vendors as part of devel‐
70       opment  packages,  that  is,  they belong with the header files and any
71       other files provided to assist downstreams in using the package.
72
73       A set of variables which provide package status  information  are  also
74       set  automatically  when  using  a  config-file package.  The <Package‐
75       Name>_FOUND variable is set to true or false, depending on whether  the
76       package  was found.  The <PackageName>_DIR cache variable is set to the
77       location of the package configuration file.
78
79   Find-module Packages
80       A find module is a file with a set of rules for  finding  the  required
81       pieces  of  a  dependency, primarily header files and libraries.  Typi‐
82       cally, a find module is needed when the  upstream  is  not  built  with
83       CMake, or is not CMake-aware enough to otherwise provide a package con‐
84       figuration file.  Unlike  a  package  configuration  file,  it  is  not
85       shipped  with  upstream, but is used by downstream to find the files by
86       guessing locations of files with platform-specific hints.
87
88       Unlike the case of an upstream-provided package configuration file,  no
89       single point of reference identifies the package as being found, so the
90       <PackageName>_FOUND variable is not automatically set by the find_pack‐
91       age()  command.   It can still be expected to be set by convention how‐
92       ever and should be set by the author  of  the  Find-module.   Similarly
93       there  is no <PackageName>_DIR variable, but each of the artifacts such
94       as library locations and header file locations provide a separate cache
95       variable.
96
97       See  the  cmake-developer(7) manual for more information about creating
98       Find-module files.
99

PACKAGE LAYOUT

101       A config-file package consists of a Package Configuration File and  op‐
102       tionally a Package Version File provided with the project distribution.
103
104   Package Configuration File
105       Consider a project Foo that installs the following files:
106
107          <prefix>/include/foo-1.2/foo.h
108          <prefix>/lib/foo-1.2/libfoo.a
109
110       It may also provide a CMake package configuration file:
111
112          <prefix>/lib/cmake/foo-1.2/FooConfig.cmake
113
114       with content defining IMPORTED targets, or defining variables, such as:
115
116          # ...
117          # (compute PREFIX relative to file location)
118          # ...
119          set(Foo_INCLUDE_DIRS ${PREFIX}/include/foo-1.2)
120          set(Foo_LIBRARIES ${PREFIX}/lib/foo-1.2/libfoo.a)
121
122       If another project wishes to use Foo it need only to locate the FooCon‐
123       fig.cmake file and load it to get all the information  it  needs  about
124       package  content  locations.   Since  the package configuration file is
125       provided by the package installation it already knows all the file  lo‐
126       cations.
127
128       The  find_package()  command may be used to search for the package con‐
129       figuration file.  This command constructs a set  of  installation  pre‐
130       fixes  and  searches under each prefix in several locations.  Given the
131       name Foo, it looks  for  a  file  called  FooConfig.cmake  or  foo-con‐
132       fig.cmake.   The  full  set of locations is specified in the find_pack‐
133       age() command documentation. One place it looks is:
134
135          <prefix>/lib/cmake/Foo*/
136
137       where Foo* is a case-insensitive globbing expression.  In  our  example
138       the  globbing  expression will match <prefix>/lib/cmake/foo-1.2 and the
139       package configuration file will be found.
140
141       Once found, a package configuration file is  immediately  loaded.   It,
142       together  with a package version file, contains all the information the
143       project needs to use the package.
144
145   Package Version File
146       When the find_package() command finds a candidate package configuration
147       file it looks next to it for a version file. The version file is loaded
148       to test whether the package version is an acceptable match for the ver‐
149       sion  requested.  If the version file claims compatibility the configu‐
150       ration file is accepted.  Otherwise it is ignored.
151
152       The name of the package version file must match  that  of  the  package
153       configuration  file  but has either -version or Version appended to the
154       name before the .cmake extension.  For example, the files:
155
156          <prefix>/lib/cmake/foo-1.3/foo-config.cmake
157          <prefix>/lib/cmake/foo-1.3/foo-config-version.cmake
158
159       and:
160
161          <prefix>/lib/cmake/bar-4.2/BarConfig.cmake
162          <prefix>/lib/cmake/bar-4.2/BarConfigVersion.cmake
163
164       are each pairs of package configuration files and corresponding package
165       version files.
166
167       When  the find_package() command loads a version file it first sets the
168       following variables:
169
170       PACKAGE_FIND_NAME
171              The <PackageName>
172
173       PACKAGE_FIND_VERSION
174              Full requested version string
175
176       PACKAGE_FIND_VERSION_MAJOR
177              Major version if requested, else 0
178
179       PACKAGE_FIND_VERSION_MINOR
180              Minor version if requested, else 0
181
182       PACKAGE_FIND_VERSION_PATCH
183              Patch version if requested, else 0
184
185       PACKAGE_FIND_VERSION_TWEAK
186              Tweak version if requested, else 0
187
188       PACKAGE_FIND_VERSION_COUNT
189              Number of version components, 0 to 4
190
191       The version file must use these variables to check whether it  is  com‐
192       patible or an exact match for the requested version and set the follow‐
193       ing variables with results:
194
195       PACKAGE_VERSION
196              Full provided version string
197
198       PACKAGE_VERSION_EXACT
199              True if version is exact match
200
201       PACKAGE_VERSION_COMPATIBLE
202              True if version is compatible
203
204       PACKAGE_VERSION_UNSUITABLE
205              True if unsuitable as any version
206
207       Version files are loaded in a nested scope so they are free to set  any
208       variables they wish as part of their computation. The find_package com‐
209       mand wipes out the scope when the version file has completed and it has
210       checked the output variables. When the version file claims to be an ac‐
211       ceptable match for the requested version the find_package command  sets
212       the following variables for use by the project:
213
214       <PackageName>_VERSION
215              Full provided version string
216
217       <PackageName>_VERSION_MAJOR
218              Major version if provided, else 0
219
220       <PackageName>_VERSION_MINOR
221              Minor version if provided, else 0
222
223       <PackageName>_VERSION_PATCH
224              Patch version if provided, else 0
225
226       <PackageName>_VERSION_TWEAK
227              Tweak version if provided, else 0
228
229       <PackageName>_VERSION_COUNT
230              Number of version components, 0 to 4
231
232       The  variables  report  the  version  of  the package that was actually
233       found.  The <PackageName> part of their name matches the argument given
234       to the find_package() command.
235

CREATING PACKAGES

237       Usually,  the  upstream  depends on CMake itself and can use some CMake
238       facilities for creating the package files. Consider an  upstream  which
239       provides a single shared library:
240
241          project(UpstreamLib)
242
243          set(CMAKE_INCLUDE_CURRENT_DIR ON)
244          set(CMAKE_INCLUDE_CURRENT_DIR_IN_INTERFACE ON)
245
246          set(Upstream_VERSION 3.4.1)
247
248          include(GenerateExportHeader)
249
250          add_library(ClimbingStats SHARED climbingstats.cpp)
251          generate_export_header(ClimbingStats)
252          set_property(TARGET ClimbingStats PROPERTY VERSION ${Upstream_VERSION})
253          set_property(TARGET ClimbingStats PROPERTY SOVERSION 3)
254          set_property(TARGET ClimbingStats PROPERTY
255            INTERFACE_ClimbingStats_MAJOR_VERSION 3)
256          set_property(TARGET ClimbingStats APPEND PROPERTY
257            COMPATIBLE_INTERFACE_STRING ClimbingStats_MAJOR_VERSION
258          )
259
260          install(TARGETS ClimbingStats EXPORT ClimbingStatsTargets
261            LIBRARY DESTINATION lib
262            ARCHIVE DESTINATION lib
263            RUNTIME DESTINATION bin
264            INCLUDES DESTINATION include
265          )
266          install(
267            FILES
268              climbingstats.h
269              "${CMAKE_CURRENT_BINARY_DIR}/climbingstats_export.h"
270            DESTINATION
271              include
272            COMPONENT
273              Devel
274          )
275
276          include(CMakePackageConfigHelpers)
277          write_basic_package_version_file(
278            "${CMAKE_CURRENT_BINARY_DIR}/ClimbingStats/ClimbingStatsConfigVersion.cmake"
279            VERSION ${Upstream_VERSION}
280            COMPATIBILITY AnyNewerVersion
281          )
282
283          export(EXPORT ClimbingStatsTargets
284            FILE "${CMAKE_CURRENT_BINARY_DIR}/ClimbingStats/ClimbingStatsTargets.cmake"
285            NAMESPACE Upstream::
286          )
287          configure_file(cmake/ClimbingStatsConfig.cmake
288            "${CMAKE_CURRENT_BINARY_DIR}/ClimbingStats/ClimbingStatsConfig.cmake"
289            COPYONLY
290          )
291
292          set(ConfigPackageLocation lib/cmake/ClimbingStats)
293          install(EXPORT ClimbingStatsTargets
294            FILE
295              ClimbingStatsTargets.cmake
296            NAMESPACE
297              Upstream::
298            DESTINATION
299              ${ConfigPackageLocation}
300          )
301          install(
302            FILES
303              cmake/ClimbingStatsConfig.cmake
304              "${CMAKE_CURRENT_BINARY_DIR}/ClimbingStats/ClimbingStatsConfigVersion.cmake"
305            DESTINATION
306              ${ConfigPackageLocation}
307            COMPONENT
308              Devel
309          )
310
311       The  CMakePackageConfigHelpers  module  provides a macro for creating a
312       simple ConfigVersion.cmake file.  This file sets  the  version  of  the
313       package.   It  is read by CMake when find_package() is called to deter‐
314       mine the compatibility with the requested version, and to set some ver‐
315       sion-specific   variables   <PackageName>_VERSION,   <PackageName>_VER‐
316       SION_MAJOR, <PackageName>_VERSION_MINOR etc.  The install(EXPORT)  com‐
317       mand  is  used  to  export  the targets in the ClimbingStatsTargets ex‐
318       port-set, defined previously by the install(TARGETS) command. This com‐
319       mand  generates the ClimbingStatsTargets.cmake file to contain IMPORTED
320       targets, suitable for use by downstreams and arranges to install it  to
321       lib/cmake/ClimbingStats.     The    generated   ClimbingStatsConfigVer‐
322       sion.cmake and a cmake/ClimbingStatsConfig.cmake are installed  to  the
323       same location, completing the package.
324
325       The  generated  IMPORTED targets have appropriate properties set to de‐
326       fine their usage requirements, such  as  INTERFACE_INCLUDE_DIRECTORIES,
327       INTERFACE_COMPILE_DEFINITIONS  and  other  relevant built-in INTERFACE_
328       properties.  The INTERFACE variant of user-defined properties listed in
329       COMPATIBLE_INTERFACE_STRING  and  other Compatible Interface Properties
330       are also propagated to the generated IMPORTED targets.   In  the  above
331       case,  ClimbingStats_MAJOR_VERSION is defined as a string which must be
332       compatible among the dependencies of any  depender.   By  setting  this
333       custom defined user property in this version and in the next version of
334       ClimbingStats, cmake(1) will issue a diagnostic if there is an  attempt
335       to  use  version 3 together with version 4.  Packages can choose to em‐
336       ploy such a pattern if different major versions of the package are  de‐
337       signed to be incompatible.
338
339       A  NAMESPACE with double-colons is specified when exporting the targets
340       for installation.  This convention of double-colons gives CMake a  hint
341       that the name is an IMPORTED target when it is used by downstreams with
342       the target_link_libraries() command.  This way, CMake can issue a diag‐
343       nostic if the package providing it has not yet been found.
344
345       In  this case, when using install(TARGETS) the INCLUDES DESTINATION was
346       specified.  This causes the  IMPORTED  targets  to  have  their  INTER‐
347       FACE_INCLUDE_DIRECTORIES  populated  with  the include directory in the
348       CMAKE_INSTALL_PREFIX.  When the IMPORTED target is used by  downstream,
349       it automatically consumes the entries from that property.
350
351   Creating a Package Configuration File
352       In this case, the ClimbingStatsConfig.cmake file could be as simple as:
353
354          include("${CMAKE_CURRENT_LIST_DIR}/ClimbingStatsTargets.cmake")
355
356       As  this allows downstreams to use the IMPORTED targets.  If any macros
357       should be provided by the ClimbingStats package, they should  be  in  a
358       separate  file  which  is  installed to the same location as the Climb‐
359       ingStatsConfig.cmake file, and included from there.
360
361       This can also be extended to cover dependencies:
362
363          # ...
364          add_library(ClimbingStats SHARED climbingstats.cpp)
365          generate_export_header(ClimbingStats)
366
367          find_package(Stats 2.6.4 REQUIRED)
368          target_link_libraries(ClimbingStats PUBLIC Stats::Types)
369
370       As the Stats::Types target is a  PUBLIC  dependency  of  ClimbingStats,
371       downstreams   must  also  find  the  Stats  package  and  link  to  the
372       Stats::Types library.  The Stats package should be found in the  Climb‐
373       ingStatsConfig.cmake  file  to  ensure this.  The find_dependency macro
374       from  the  CMakeFindDependencyMacro  helps  with  this  by  propagating
375       whether  the package is REQUIRED, or QUIET etc.  All REQUIRED dependen‐
376       cies of a package should be found in the Config.cmake file:
377
378          include(CMakeFindDependencyMacro)
379          find_dependency(Stats 2.6.4)
380
381          include("${CMAKE_CURRENT_LIST_DIR}/ClimbingStatsTargets.cmake")
382          include("${CMAKE_CURRENT_LIST_DIR}/ClimbingStatsMacros.cmake")
383
384       The find_dependency macro also sets ClimbingStats_FOUND to False if the
385       dependency is not found, along with a diagnostic that the ClimbingStats
386       package can not be used without the Stats package.
387
388       If COMPONENTS are specified when the  downstream  uses  find_package(),
389       they  are  listed  in  the <PackageName>_FIND_COMPONENTS variable. If a
390       particular component is non-optional, then  the  <PackageName>_FIND_RE‐
391       QUIRED_<comp>  will be true. This can be tested with logic in the pack‐
392       age configuration file:
393
394          include(CMakeFindDependencyMacro)
395          find_dependency(Stats 2.6.4)
396
397          include("${CMAKE_CURRENT_LIST_DIR}/ClimbingStatsTargets.cmake")
398          include("${CMAKE_CURRENT_LIST_DIR}/ClimbingStatsMacros.cmake")
399
400          set(_supported_components Plot Table)
401
402          foreach(_comp ${ClimbingStats_FIND_COMPONENTS})
403            if (NOT ";${_supported_components};" MATCHES ";${_comp};")
404              set(ClimbingStats_FOUND False)
405              set(ClimbingStats_NOT_FOUND_MESSAGE "Unsupported component: ${_comp}")
406            endif()
407            include("${CMAKE_CURRENT_LIST_DIR}/ClimbingStats${_comp}Targets.cmake")
408          endforeach()
409
410       Here, the ClimbingStats_NOT_FOUND_MESSAGE is set to  a  diagnosis  that
411       the  package could not be found because an invalid component was speci‐
412       fied.  This message variable can be set for any case where  the  _FOUND
413       variable is set to False, and will be displayed to the user.
414
415   Creating a Package Configuration File for the Build Tree
416       The  export(EXPORT) command creates an IMPORTED targets definition file
417       which is specific to the build-tree, and is not relocatable.  This  can
418       similarly  be used with a suitable package configuration file and pack‐
419       age version file to define a package for the build tree  which  may  be
420       used  without installation.  Consumers of the build tree can simply en‐
421       sure that the CMAKE_PREFIX_PATH contains the build  directory,  or  set
422       the ClimbingStats_DIR to <build_dir>/ClimbingStats in the cache.
423
424   Creating Relocatable Packages
425       A relocatable package must not reference absolute paths of files on the
426       machine where the package is built that will not exist on the  machines
427       where the package may be installed.
428
429       Packages created by install(EXPORT) are designed to be relocatable, us‐
430       ing paths relative to the location of the package itself.  When  defin‐
431       ing the interface of a target for EXPORT, keep in mind that the include
432       directories should be specified as relative paths which are relative to
433       the CMAKE_INSTALL_PREFIX:
434
435          target_include_directories(tgt INTERFACE
436            # Wrong, not relocatable:
437            $<INSTALL_INTERFACE:${CMAKE_INSTALL_PREFIX}/include/TgtName>
438          )
439
440          target_include_directories(tgt INTERFACE
441            # Ok, relocatable:
442            $<INSTALL_INTERFACE:include/TgtName>
443          )
444
445       The $<INSTALL_PREFIX> generator expression may be used as a placeholder
446       for the install prefix without resulting in a non-relocatable  package.
447       This is necessary if complex generator expressions are used:
448
449          target_include_directories(tgt INTERFACE
450            # Ok, relocatable:
451            $<INSTALL_INTERFACE:$<$<CONFIG:Debug>:$<INSTALL_PREFIX>/include/TgtName>>
452          )
453
454       This  also  applies  to paths referencing external dependencies.  It is
455       not advisable to populate any properties which may contain paths,  such
456       as  INTERFACE_INCLUDE_DIRECTORIES  and  INTERFACE_LINK_LIBRARIES,  with
457       paths relevant to dependencies.  For example, this code  may  not  work
458       well for a relocatable package:
459
460          target_link_libraries(ClimbingStats INTERFACE
461            ${Foo_LIBRARIES} ${Bar_LIBRARIES}
462            )
463          target_include_directories(ClimbingStats INTERFACE
464            "$<INSTALL_INTERFACE:${Foo_INCLUDE_DIRS};${Bar_INCLUDE_DIRS}>"
465            )
466
467       The  referenced  variables  may contain the absolute paths to libraries
468       and include directories as found on the machine the  package  was  made
469       on.   This would create a package with hard-coded paths to dependencies
470       and not suitable for relocation.
471
472       Ideally such dependencies should be used  through  their  own  IMPORTED
473       targets  that  have  their  own IMPORTED_LOCATION and usage requirement
474       properties such as  INTERFACE_INCLUDE_DIRECTORIES  populated  appropri‐
475       ately.   Those  imported  targets  may  then  be  used  with  the  tar‐
476       get_link_libraries() command for ClimbingStats:
477
478          target_link_libraries(ClimbingStats INTERFACE Foo::Foo Bar::Bar)
479
480       With this approach the package  references  its  external  dependencies
481       only  through  the names of IMPORTED targets.  When a consumer uses the
482       installed package, the consumer will run the appropriate find_package()
483       commands  (via  the  find_dependency macro described above) to find the
484       dependencies and populate the imported targets with  appropriate  paths
485       on their own machine.
486
487       Unfortunately  many  modules  shipped with CMake do not yet provide IM‐
488       PORTED targets because their development pre-dated this approach.  This
489       may improve incrementally over time.  Workarounds to create relocatable
490       packages using such modules include:
491
492       • When building the package, specify each Foo_LIBRARY  cache  entry  as
493         just  a  library name, e.g. -DFoo_LIBRARY=foo.  This tells the corre‐
494         sponding find module to populate the Foo_LIBRARIES with just  foo  to
495         ask  the  linker  to  search for the library instead of hard-coding a
496         path.
497
498       • Or, after installing the package  content  but  before  creating  the
499         package  installation binary for redistribution, manually replace the
500         absolute paths with placeholders for substitution by the installation
501         tool when the package is installed.
502

PACKAGE REGISTRY

504       CMake  provides  two  central  locations to register packages that have
505       been built or installed anywhere on a system:
506
507User Package Registry
508
509System Package Registry
510
511       The registries are especially useful to help projects find packages  in
512       non-standard install locations or directly in their own build trees.  A
513       project may populate either the user or system registry (using its  own
514       means, see below) to refer to its location.  In either case the package
515       should store at the registered location a  Package  Configuration  File
516       (<PackageName>Config.cmake)  and  optionally  a  Package  Version  File
517       (<PackageName>ConfigVersion.cmake).
518
519       The find_package() command searches the two package registries  as  two
520       of  the  search steps specified in its documentation.  If it has suffi‐
521       cient permissions it also removes stale package registry  entries  that
522       refer  to  directories  that  do not exist or do not contain a matching
523       package configuration file.
524
525   User Package Registry
526       The User Package Registry is stored in a per-user  location.   The  ex‐
527       port(PACKAGE)  command  may be used to register a project build tree in
528       the user package registry.  CMake currently provides  no  interface  to
529       add  install  trees  to  the user package registry.  Installers must be
530       manually taught to register their packages if desired.
531
532       On Windows the user package registry is stored in the Windows  registry
533       under a key in HKEY_CURRENT_USER.
534
535       A <PackageName> may appear under registry key:
536
537          HKEY_CURRENT_USER\Software\Kitware\CMake\Packages\<PackageName>
538
539       as  a  REG_SZ  value, with arbitrary name, that specifies the directory
540       containing the package configuration file.
541
542       On UNIX platforms the user package registry is stored in the user  home
543       directory  under  ~/.cmake/packages.   A <PackageName> may appear under
544       the directory:
545
546          ~/.cmake/packages/<PackageName>
547
548       as a file, with arbitrary name, whose content specifies  the  directory
549       containing the package configuration file.
550
551   System Package Registry
552       The System Package Registry is stored in a system-wide location.  CMake
553       currently provides no interface to add to the system package  registry.
554       Installers  must  be  manually taught to register their packages if de‐
555       sired.
556
557       On Windows the system package registry is stored in  the  Windows  reg‐
558       istry  under  a  key in HKEY_LOCAL_MACHINE.  A <PackageName> may appear
559       under registry key:
560
561          HKEY_LOCAL_MACHINE\Software\Kitware\CMake\Packages\<PackageName>
562
563       as a REG_SZ value, with arbitrary name, that  specifies  the  directory
564       containing the package configuration file.
565
566       There is no system package registry on non-Windows platforms.
567
568   Disabling the Package Registry
569       In  some cases using the Package Registries is not desirable. CMake al‐
570       lows one to disable them using the following variables:
571
572       • The export(PACKAGE) command does not populate the user  package  reg‐
573         istry when CMP0090 is set to NEW unless the CMAKE_EXPORT_PACKAGE_REG‐
574         ISTRY variable explicitly enables it.  When CMP0090 is not set to NEW
575         then  export(PACKAGE)  populates the user package registry unless the
576         CMAKE_EXPORT_NO_PACKAGE_REGISTRY variable explicitly disables it.
577
578CMAKE_FIND_USE_PACKAGE_REGISTRY disables the User Package Registry in
579         all the find_package() calls when set to FALSE.
580
581       • Deprecated  CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY  disables the User
582         Package Registry in all the find_package() calls when  set  to  TRUE.
583         This  variable  is  ignored  when CMAKE_FIND_USE_PACKAGE_REGISTRY has
584         been set.
585
586CMAKE_FIND_PACKAGE_NO_SYSTEM_PACKAGE_REGISTRY  disables  the   System
587         Package Registry in all the find_package() calls.
588
589   Package Registry Example
590       A  simple convention for naming package registry entries is to use con‐
591       tent hashes.  They are  deterministic  and  unlikely  to  collide  (ex‐
592       port(PACKAGE)  uses this approach).  The name of an entry referencing a
593       specific directory is simply the content hash of the directory path it‐
594       self.
595
596       If a project arranges for package registry entries to exist, such as:
597
598          > reg query HKCU\Software\Kitware\CMake\Packages\MyPackage
599          HKEY_CURRENT_USER\Software\Kitware\CMake\Packages\MyPackage
600           45e7d55f13b87179bb12f907c8de6fc4 REG_SZ c:/Users/Me/Work/lib/cmake/MyPackage
601           7b4a9844f681c80ce93190d4e3185db9 REG_SZ c:/Users/Me/Work/MyPackage-build
602
603       or:
604
605          $ cat ~/.cmake/packages/MyPackage/7d1fb77e07ce59a81bed093bbee945bd
606          /home/me/work/lib/cmake/MyPackage
607          $ cat ~/.cmake/packages/MyPackage/f92c1db873a1937f3100706657c63e07
608          /home/me/work/MyPackage-build
609
610       then the CMakeLists.txt code:
611
612          find_package(MyPackage)
613
614       will  search  the  registered locations for package configuration files
615       (MyPackageConfig.cmake).  The search order among package  registry  en‐
616       tries  for  a single package is unspecified and the entry names (hashes
617       in this example) have no meaning.   Registered  locations  may  contain
618       package version files (MyPackageConfigVersion.cmake) to tell find_pack‐
619       age() whether a specific location  is  suitable  for  the  version  re‐
620       quested.
621
622   Package Registry Ownership
623       Package  registry entries are individually owned by the project instal‐
624       lations that they reference.  A package installer  is  responsible  for
625       adding  its  own entry and the corresponding uninstaller is responsible
626       for removing it.
627
628       The export(PACKAGE) command populates the user  package  registry  with
629       the  location  of a project build tree.  Build trees tend to be deleted
630       by developers and have no "uninstall" event that could trigger  removal
631       of their entries.  In order to keep the registries clean the find_pack‐
632       age() command automatically removes stale entries it encounters  if  it
633       has  sufficient  permissions.  CMake provides no interface to remove an
634       entry referencing an existing build tree once export(PACKAGE) has  been
635       invoked.   However,  if  the  project removes its package configuration
636       file from the build tree then the entry referencing the  location  will
637       be considered stale.
638
640       2000-2021 Kitware, Inc. and Contributors
641
642
643
644
6453.22.0                           Dec 02, 2021                CMAKE-PACKAGES(7)
Impressum