EXCLUDE_FROM_ALLΒΆ

Set this directory property to a true value on a subdirectory to exclude its targets from the "all" target of its ancestors. If excluded, running e.g. make in the parent directory will not build targets in the subdirectory by default. This does not affect the "all" target of the subdirectory itself. Running e.g. make inside the subdirectory will still build its targets.

EXCLUDE_FROM_ALL is meant for when the subdirectory contains a separate part of the project that is useful, but not necessary, such as a set of examples, or e.g. an integrated 3rd party library. Typically the subdirectory should contain its own project() command invocation so that a full build system will be generated in the subdirectory (such as a Visual Studio IDE solution file). Note that inter-target dependencies supersede this exclusion. If a target built by the parent project depends on a target in the subdirectory, the dependee target will be included in the parent project build system to satisfy the dependency.

If the EXCLUDE_FROM_ALL argument is provided, it has the following effects:

  • Targets defined in the subdirectory or below will not be included in the ALL target of the parent directory. Those targets must be built explicitly by the user, or be a dependency of another target that will be built.

  • Targets defined in the subdirectory or below will be excluded from IDE project files.

  • Any install rules defined in the subdirectory or below will be ignored when installing the parent directory.

Note that these effects are not the same as those for the EXCLUDE_FROM_ALL target property.