qt_ifcodegen_extend_target

通过从 qface IDL 文件生成的文件扩展目标。

此命令在 Qt6 包的 InterfaceFramework 组件中定义。

使用以下命令加载软件包:

find_package(Qt6 REQUIRED COMPONENTS InterfaceFramework)

概述

qt_ifcodegen_extend_target(
    target
    IDL_FILES idl_files
    TEMPLATE template
    [ANNOTATION_FILES ...]
    [IMPORT_PATH ...]
    [OUTPUT_DIR output_dir]
    [EXTRA_HEADERS_OUTPUT_DIR extra_headers_output_dir]
    [EXTRA_TEMPLATE_SEARCH_PATH ...]
    [PREFIX prefix]
    [VERBOSE]
    [NO_GENERATE]
)

如果禁用了 无版本命令,则使用 qt6_ifcodegen_extend_target() 代替。它支持与此命令相同的参数集。

描述

通过调用 ifcodegen,通过 qface IDL 文件生成的文件扩展 目标。如何扩展 目标 由模板和生成的 CMake 文件定义。

使用 IDL_FILES 指定输入 IDL 文件,而 TEMPLATE 指定用于生成的 ifcodegen 模板。提供的模板可以是模板文件夹的路径,也可以是位于模板搜索路径中的模板的名称。使用 EXTRA_TEMPLATE_SEARCH_PATH 参数,可以扩展搜索路径。如果您想为代码生成使用自己的模板,这特别有用。作为函数参数的替代方案,可以使用全局 CMake 变量 QT_IFCODEGEN_TEMPLATE_SEARCH_PATH 指定所有 ifcodegen 函数调用额外搜索路径。

通过 ANNOTATION_FILES 参数传递额外的标注文件。

可以使用 IMPORT_PATH 将依赖此 IDL 文件的 IDL 文件的搜索路径添加到其中。其他 IDL 文件仍然需要独立生成和构建。

OUTPUT_DIR 指定生成文件要写入的目录,默认为 CMAKE_CURRENT_BINARY_DIR

EXTRA_HEADER_OUTPUT_DIR 用于提供一个额外的目录,其中将复制所有生成的头文件。

默认情况下,所有由 ifcodegen 生成的日志消息都被丢弃。要显示它们,您可以使用 VERBOSE 参数,设置 IFCODEGEN_VERBOSE 变量,或者将 CMAKE_MESSAGE_LOG_LEVEL 设置为 VERBOSE

有关生成器命令行参数的更多详细信息,请参阅 使用生成器

可以使用 PREFIX 将此命令与 qt_ifcodegen_import_variables 结合使用,并使用 prefix 暴露所有变量。

使用 NO_GENERATE 可以跳过调用 ifcodegen。通常只在您确信文件已生成后才需要,例如在使用 qt_ifcodegen_generate 之前。

有关生成器命令行参数的更多详细信息,请参阅 使用生成器

示例

find_package(Qt6 COMPONENTS InterfaceFramework)

qt6_add_library(AdressBook)

# Generate code and extend the AddressBook target
# with the generated files
qt6_ifcodegen_extend_target(AdressBook
    IDL_FILES addressbook.qface
    TEMPLATE frontend
)

target_link_libraries(AdressBook PUBLIC
    Qt::Core
    Qt::InterfaceFramework
    Qt::InterfaceFrameworkPrivate
    Qt::Qml
    Qt::Quick
)

© 2024 Qt公司有限公司。本文件中包含的文档贡献均为各自所有者的版权。提供的文档受自由软件基金会发布的《GNU自由文档许可证》第1.3版条款的许可。Qt及其相关标志是芬兰以及世界各地的Qt公司有限公司的商标。其他所有商标均为其各自所有者的财产。