VERIFY_INTERFACE_HEADER_SETS

在 3.24 版本中添加。

用于验证目标 PUBLICINTERFACE 头文件集中的所有头文件是否可以单独包含。

当此属性设置为 true 时,并且目标是对象库、静态库、共享库、接口库或启用了导出功能的构建目标,并且目标有一个或多个 PUBLICINTERFACE 头文件集时,将创建一个名为 <target_name>_verify_interface_header_sets 的对象库目标。此验证目标在 PUBLICINTERFACE 头文件集中的每个头文件都有一个源文件。每个源文件仅包含其关联的头文件。验证目标链接原始目标以获取其所有用法需求。验证目标的 EXCLUDE_FROM_ALLDISABLE_PRECOMPILE_HEADERS 属性设置为 true,而其 AUTOMOCAUTORCCAUTOUICUNITY_BUILD 属性设置为 false。

如果头文件的 LANGUAGE 属性已设置,则该属性的值用于确定编译头文件的语言。否则,如果目标具有任何 C++ 源文件,则头文件将以 C++ 编译。否则,如果目标具有任何 C 源文件,则头文件将以 C 编译。否则,如果全局启用了 C++,则头文件将以 C++ 编译。否则,如果全局启用了 C,则头文件将以 C 编译。否则,将不编译头文件。

如果头文件的 SKIP_LINTING 属性设置为 true,则不编译该文件。

如果创建了任何验证目标,则会创建一个名为 all_verify_interface_header_sets 的顶层目标,该目标依赖于所有验证目标。

当目标创建时,如果已设置 CMAKE_VERIFY_INTERFACE_HEADER_SETS 变量的值,则此属性将由该值初始化。

如果项目希望控制此属性要验证的头文件集,它可以设置 INTERFACE_HEADER_SETS_TO_VERIFY