Cmake中message函数 如何优雅地输出

message函数说明

在CMake中,message()函数用于向终端输出信息。

message([<mode>] "message text" ...)函数的<mode>参数可以是以下之一:

  • (none): 等同于STATUS,但不推荐使用。
  • STATUS: 输出的信息会被发送到CMake的状态消息流,这是message()函数的默认模式。在命令行上,这些消息通常会被显示出来,但在图形界面中,它们可能会被重定向到其他地方。
  • WARNING: 输出的信息会被发送到CMake的警告消息流。这些消息会被显示出来,并且会标记为警告。
  • AUTHOR_WARNING: 这是WARNING模式的一种变体,只有在CMAKE_SUPPRESS_DEVELOPER_WARNINGS变量为FALSE时才会产生警告。
  • SEND_ERROR: 输出的信息会被发送到CMake的错误消息流,但不会立即停止CMake的处理过程。
  • FATAL_ERROR: 输出的信息会被发送到CMake的错误消息流,并立即停止CMake的处理过程。
参数使用场景底层原理优点缺点
(none)当你想输出一条普通的状态消息,但不希望给它指定任何特殊的模式时。输出的信息会被发送到CMake的状态消息流。简单易用,不需要指定模式。不推荐使用,因为它的行为可能会在未来的CMake版本中改变。
STATUS当你想输出一条状态消息,例如进度信息或配置信息时。输出的信息会被发送到CMake的状态消息流。明确表示这是一条状态消息,易于理解。在图形界面中,这些消息可能会被重定向到其他地方,不一定能被用户看到。
WARNING当你想输出一条警告消息,例如某个选项已被弃用或某个操作可能会失败时。输出的信息会被发送到CMake的警告消息流。明确表示这是一条警告消息,可以引起用户的注意。过多的警告消息可能会让用户感到困扰,忽视真正重要的警告。
AUTHOR_WARNING当你是项目的开发者,并且你想输出一条只有在开发模式下才会显示的警告消息时。输出的信息会被发送到CMake的警告消息流,但只有在CMAKE_SUPPRESS_DEVELOPER_WARNINGS变量为FALSE时才会产生警告。可以避免在用户模式下显示不必要的警告。如果CMAKE_SUPPRESS_DEVELOPER_WARNINGS变量被设置为TRUE,这些警告会被忽略。
SEND_ERROR当你遇到一个错误,但你希望CMake继续处理剩下的命令时。输出的信息会被发送到CMake的错误消息流,但不会立即停止CMake的处理过程。可以在发生错误时继续执行CMake的处理过程。由于CMake的处理过程没有立即停止,可能会导致更多的错误。
FATAL_ERROR当你遇到一个严重的错误,你希望立即停止CMake的处理过程时。输出的信息会被发送到CMake的错误消息流,并立即停止CMake的处理过程。可以在发生严重错误时立即停止CMake的处理过程,防止错误的扩散。一旦使用,CMake的处理过程会立即停止,无法执行任何后续的命令。

STATUS

在CMake中,message(STATUS "Your message")常常被用来输出构建过程中的状态信息。以下是一些具体的使用示例:

  1. 输出变量的值:
set(MY_VARIABLE "Hello, CMake!")
message(STATUS "MY_VARIABLE is: ${MY_VARIABLE}")

在这个例子中,message(STATUS "MY_VARIABLE is: ${MY_VARIABLE}")会输出一条状态消息,内容为"MY_VARIABLE is: Hello, CMake!"。${MY_VARIABLE}是CMake的变量引用语法,它会被替换为MY_VARIABLE变量的值。

  1. 输出配置信息:
option(USE_MY_LIBRARY "Use my library" ON)
message(STATUS "USE_MY_LIBRARY is set to: ${USE_MY_LIBRARY}")

在这个例子中,option(USE_MY_LIBRARY "Use my library" ON)定义了一个名为USE_MY_LIBRARY的选项,初始值为ONmessage(STATUS "USE_MY_LIBRARY is set to: ${USE_MY_LIBRARY}")会输出一条状态消息,内容为"USE_MY_LIBRARY is set to: ON"或"USE_MY_LIBRARY is set to: OFF",取决于USE_MY_LIBRARY选项的值。

  1. 输出构建目标信息:
add_library(MyLibrary SHARED src/my_library.cpp)
message(STATUS "Added shared library target: MyLibrary")

在这个例子中,add_library(MyLibrary SHARED src/my_library.cpp)添加了一个名为MyLibrary的共享库目标。message(STATUS "Added shared library target: MyLibrary")会输出一条状态消息,内容为"Added shared library target: MyLibrary"。

这些状态消息在命令行上运行CMake时会被显示出来,帮助你了解CMake的处理过程。在图形界面的CMake工具(如CMake GUI或IDE的CMake集成)中,这些消息可能会被显示在专门的输出窗口或日志文件中。

WARNING

在CMake中,message(WARNING "message text")函数用于输出警告消息。这些消息会被发送到CMake的警告消息流,并在终端中显示出来。同时,这些消息会被标记为警告,这意味着它们可能会引起用户的注意,或者在某些情况下,可能会导致构建过程失败。

例如,假设你正在编写一个需要某个库才能正常工作的项目,你可以使用find_package()函数来查找这个库。如果find_package()函数没有找到这个库,你可以使用message(WARNING)函数来输出一个警告消息,告诉用户这个库没有找到:

find_package(SomeLibrary)
if(NOT SomeLibrary_FOUND)
    message(WARNING "SomeLibrary not found, some features will not be available.")
endif()

在这个例子中,如果CMake在配置过程中没有找到SomeLibrary,它会输出一个警告消息,内容为"SomeLibrary not found, some features will not be available."。这个警告消息会被发送到CMake的警告消息流,并在终端中显示出来,从而让用户知道他们可能需要安装SomeLibrary才能使用所有的功能。

请注意,message(WARNING)函数只是输出警告消息,它不会改变CMake的处理过程。如果你想在发生错误时停止CMake的处理过程,你应该使用message(FATAL_ERROR)函数。

AUTHOR_WARNING

AUTHOR_WARNING模式在CMake中用于输出开发者警告。这种模式的警告只有在CMAKE_SUPPRESS_DEVELOPER_WARNINGS变量为FALSE时才会显示。这个变量默认为FALSE,但如果你在CMakeLists.txt文件中设置了这个变量为TRUE,那么AUTHOR_WARNING模式的警告就不会显示。

这种机制可以用于区分开发者警告和用户警告。例如,如果你是一个库的开发者,你可能希望在开发过程中看到所有的警告,包括开发者警告,但是你的用户可能只关心他们需要知道的警告,不希望看到开发者警告。这时,你就可以在你的CMakeLists.txt文件中使用AUTHOR_WARNING模式来输出开发者警告,然后告诉你的用户设置CMAKE_SUPPRESS_DEVELOPER_WARNINGS变量为TRUE来隐藏这些警告。

以下是一个AUTHOR_WARNING模式的示例:

# 如果某个变量没有被设置,输出一个开发者警告
if(NOT DEFINED MY_VARIABLE)
  message(AUTHOR_WARNING "MY_VARIABLE is not defined")
endif()

在这个示例中,如果MY_VARIABLE变量没有被设置,CMake会输出一个开发者警告,内容为"MY_VARIABLE is not defined"。如果CMAKE_SUPPRESS_DEVELOPER_WARNINGS变量被设置为TRUE,这个警告就不会显示。

SEND_ERROR

SEND_ERROR模式在message()函数中用于输出错误信息,但不会立即停止CMake的处理过程。这意味着CMake会继续处理剩余的命令,直到遇到一个FATAL_ERROR或者处理完所有命令。然后,CMake会以非零状态退出,表示出现了错误。

以下是一个SEND_ERROR的示例:

if(NOT DEFINED REQUIRED_VARIABLE)
    message(SEND_ERROR "REQUIRED_VARIABLE is not defined")
endif()

在这个示例中,我们首先检查变量REQUIRED_VARIABLE是否已经定义。如果没有定义,我们就使用message(SEND_ERROR ...)输出一条错误信息。这条错误信息会被发送到CMake的错误消息流,并且CMake的处理过程不会立即停止。相反,CMake会继续处理剩余的命令,直到遇到一个FATAL_ERROR或者处理完所有命令。然后,CMake会以非零状态退出,表示出现了错误。

请注意,虽然SEND_ERROR不会立即停止CMake的处理过程,但它会阻止生成步骤的执行。也就是说,如果CMake在处理过程中遇到了一个SEND_ERROR,那么即使CMake成功处理了所有命令,生成步骤也不会执行。这是因为SEND_ERROR表示了一个严重的问题,需要用户的注意和修复。

FATAL_ERROR

FATAL_ERROR是CMake中message()函数的一种模式,用于输出错误消息并立即停止CMake的处理过程。当CMake遇到一个无法继续的错误时,你可以使用message(FATAL_ERROR "error message")来输出错误消息并停止处理。

例如,假设你正在编写一个需要C++11或更高版本的项目,你可以使用以下代码来检查C++编译器是否支持C++11:

if(NOT CMAKE_CXX_STANDARD OR CMAKE_CXX_STANDARD LESS 11)
    message(FATAL_ERROR "This project requires C++11 or higher!")
endif()

在这个例子中,如果CMake检测到C++编译器的标准版本小于11,它会输出错误消息"This project requires C++11 or higher!",并立即停止处理。这意味着CMake不会生成构建系统,也不会执行任何后续的CMake命令。这可以防止在不满足项目要求的情况下尝试构建项目,从而避免可能的构建错误和问题。

请注意,FATAL_ERROR应该谨慎使用,只有在确实需要立即停止CMake处理过程的情况下才应使用。在大多数情况下,使用WARNINGSEND_ERROR模式可能更合适。

CMake 中,`message()` 函数用于向用户显示消息。这非常有助于调试、传递重要信息或警告开发者某些配置选项的状态。通过不同级别的日志输出,可以让构建过程更加透明化。 ### 常见的日志级别 `message()` 支持多种日志级别,默认情况下会打印出所有类型的消息: - **STATUS**: 通常是告知性的信息,表示正常的进度更新。 ```cmake message(STATUS "正在编译版本: ${PROJECT_VERSION}") ``` - **WARNING**: 发出一个警告但不会中断构建流程。 ```cmake if(SOME_CONDITION) message(WARNING "已检测到潜在的问题,请检查相关设置") endif() ``` - **AUTHOR_WARNING**: 类似于 WARNING ,不过主要用于提醒包维护者而不是普通终端用户。(从 CMake 3.0 开始支持) - **SEND_ERROR**: 输出错误并阻止后续 cmake 配置阶段继续执行,但是不终止整个处理过程。 ```cmake if(NOT EXISTS "${REQUIRED_FILE_PATH}") message(SEND_ERROR "缺失必要的文件: ${REQUIRED_FILE_PATH}") endif() ``` - **FATAL_ERROR**: 触发致命错误立即停止一切操作。 ```cmake if(MISSING_CRITICAL_DEPENDENCY) message(FATAL_ERROR "无法找到关键依赖项!") endif() ``` - 默认模式下没有指定类型的参数将被视为 STATUS 消息。 ```cmake message("这是一个默认的信息") ``` 此外还可以结合变量来构造动态内容,如上面例子中的 `${PROJECT_VERSION}` 或 `${REQUIRED_FILE_PATH}`, 这样可以使你的脚本更具灵活性和实用性。 如果你希望完全静默地运行而不输出任何信息,则可以在调用 `cmake` 工具时加上 `-Wno-dev` 参数忽略开发相关的警告,或者根据具体需求调整最低日志等级。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

泡沫o0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值