CMake构建

使用CMake构建

CMake是一个工具,用于简化跨不同平台的开发项目的构建过程。CMake自动生成生成系统,如Makefiles和Visual Studio项目文件。

CMake是一个自带的第三方工具证明文件。本主题描述了如何使用CMake3.1.0带Qt 5。

开始使用CMake

开始find_package找到Qt附带的库和头文件。然后,您可以将这些库和头文件与target_link_libraries命令来构建基于Qt的库和应用程序。该命令自动添加适当的包含目录、编译定义、独立于位置的代码标志以及到qtmain.lib例如,Windows上的库。

构建GUI可执行文件

要构建helloworld GUI可执行文件,您需要以下内容:

cpp 复制代码
cmake_minimum_required(VERSION 3.1.0)

project(helloworld VERSION 1.0.0 LANGUAGES CXX)

set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)
set(CMAKE_AUTOUIC ON)

if(CMAKE_VERSION VERSION_LESS "3.7.0")
    set(CMAKE_INCLUDE_CURRENT_DIR ON)
endif()

find_package(Qt5 COMPONENTS Widgets REQUIRED)

add_executable(helloworld
    mainwindow.ui
    mainwindow.cpp
    main.cpp
    resources.qrc
)

target_link_libraries(helloworld Qt5::Widgets)

为find_package为了成功,CMake必须通过以下方式之一找到Qt安装:

设置您的CMAKE_PREFIX_PATH环境变量添加到Qt 5安装前缀。这是推荐的方式。 设置Qt5_DIR在......里CMake缓存到Qt5Config.cmake文件。

导入的库目标

加载的每个Qt模块都定义了一个CMake库目标。目标名称以Qt5::,后跟模块名。例如:Qt5::Core, Qt5::Gui。将库目标的名称传递给target_link_libraries使用各自的库。

注意:从Qt 5.15开始,CMake目标也可以作为Qt::Core, Qt::Gui,等等。这简化了编写可以在Qt 5和Qt 6上运行的CMake代码。

导入的目标使用与配置Qt时相同的配置创建。那就是:

如果Qt是用-debug开关,将创建一个带有调试配置的导入目标。 如果Qt是用-release开关,就会创建一个带有发布配置的导入目标。 如果Qt是用-debug-and-release开关,然后使用发布和调试配置创建导入的目标。 如果您的项目有自定义CMake构建配置,您必须将您的定制配置映射到debug或release Qt配置。

cpp 复制代码
find_package(Qt5 COMPONENTS Core REQUIRED)

set(CMAKE_CXX_FLAGS_COVERAGE "${CMAKE_CXX_FLAGS_RELEASE} -fprofile-arcs -ftest-coverage")

# set up a mapping so that the Release configuration for the Qt imported target is
# used in the COVERAGE CMake configuration.
set_target_properties(Qt5::Core PROPERTIES MAP_IMPORTED_CONFIG_COVERAGE "RELEASE")

CMake变量引用

模块变量

装载的Qt模块find_package设置各种变量。

注意:你很少需要直接访问这些变量。像链接一个模块这样的常见任务应该通过每个模块定义的库目标来完成。

举个例子,find_package(Qt5 COMPONENTS Widgets)成功时,将使以下变量可用:

对于找到的所有包find_package,这些变量的等价物是可用的;它们区分大小写。

安装变量

此外,还有一些变量与特定的包无关,而是与Qt安装本身有关。

CMake命令参考

DBus


相关推荐
飞哥数智坊5 小时前
分享被迫变直播:AI·Spring养虾记就这样上线了
人工智能
Mr_Lucifer8 小时前
「一句话」生成”小红书“式金句海报(CodeFlicker + quote-poster-generator)
人工智能·aigc·visual studio code
冬奇Lab8 小时前
OpenClaw 深度解析(五):模型与提供商系统
人工智能·开源·源码阅读
冬奇Lab9 小时前
一天一个开源项目(第42篇):OpenFang - 用 Rust 构建的 Agent 操作系统,16 层安全与 7 个自主 Hands
人工智能·rust·开源
IT_陈寒9 小时前
SpringBoot性能飙升200%?这5个隐藏配置你必须知道!
前端·人工智能·后端
yiyu07169 小时前
3分钟搞懂深度学习AI:反向传播:链式法则的归责游戏
人工智能·深度学习
机器之心10 小时前
OpenClaw绝配!GPT-5.4问世,AI能力开始大一统,就是太贵
人工智能·openai
机器之心10 小时前
海外华人15人团队打造,统一理解与生成的图像模型,超越Nano banana登顶图像编辑
人工智能·openai
用户5527960260510 小时前
在老版本 HPC 系统上运行 Antigravity(反重力)
人工智能