...

/

Defining Components

Defining Components

Let's learn what components are and how to use them with packages.

We'll cover the following...

We'll start talking about package components by clearing up some possible confusion around the term component. Look at the full signature for find_package():

find_package(<PackageName> [version] [EXACT] [QUIET]
[MODULE]
[REQUIRED] [[COMPONENTS] [components...]]
[OPTIONAL_COMPONENTS components...]
[NO_POLICY_SCOPE])

The components that are mentioned here shouldn't be conflated with the COMPONENT keyword that's used in the install() command. They are different concepts that must be understood separately, despite sharing the same name. We'll look at this in more detail in the following subsections.

How to use components in find_package()

When we call find_package() with a list of COMPONENTS or OPTIONAL_COMPONENTS, we tell CMake that we're only interested in packages that provide them. However, it's important to realize that it's up to the package to verify this requirement, and if the package vendor doesn't add the necessary checks to the config-file mentioned in the "Creating advanced config-files" sectionUntitledConcept6, then nothing happens.

Requested components are passed to the config-file in the <package>_FIND_COMPONENTS variable (both ...