• CMake中message的使用


          CMake中的message命令用于记录消息,其格式如下:

    1. message([] "message text" ...) # General messages
    2. message( "message text" ...) # Reporting checks

          1.General messages:在日志中记录指定的消息文本。如果给出了多个消息字符串(message string),则将它们连接成一条消息,字符串之间没有分隔符
          可选的关键字确定消息的类型,这会影响消息的处理方式:
          (1).FATAL_ERROR:CMake Error,停止处理和生成。
          (2).SEND_ERROR:CMake Error,继续处理,但跳过生成。
          (3).WARNING:CMake Warning,继续处理。
          (4).AUTHOR_WARNING:CMake Warning(dev),继续处理。
          (5).DEPRECATION:如果分别启用了CMAKE_ERROR_DEPRECATED或CMAKE_WARN_DEPRECATED,则CMake弃用(Deprecation)Error或Warning,否则没有消息。
          (6).(none)或NOTICE:重要的消息打印到stderr以引起用户的注意。
          (7).STATUS:project用户可能感兴趣的主要信息。理想情况下,这些信息应该简明扼要,不超过一行,但仍然信息丰富。
          (8).VERBOSE:针对project用户的详细信息消息。这些消息应提供在大多数情况下不感兴趣的额外详细信息。
          (9).DEBUG:构建项目的其他用户通常不会对这些消息感兴趣。
          (10).TRACE:低级的细粒度消息,使用此日志级别的消息通常只是临时的,一般在发布项目、打包文件之前被删除。
          --log-level命令行选项可用于控制显示哪些消息。若不指定,默认不会显示verbose, debug, trace消息。也可通过CMAKE_MESSAGE_LOG_LEVEL变量设置。

    1. message("csdn addr:" "https://blog.csdn.net/fengbingchun") # csdn addr:https://blog.csdn.net/fengbingchun
    2. message(SEND_ERROR "wow, send error") # CMake Error at test_message.cmake:10 (message):
    3. # wow, send error
    4. message(WARNING "wow, warning") # CMake Warning at test_message.cmake:13 (message):
    5. # wow, warning
    6. message(AUTHOR_WARNING "wow, author warning") # CMake Warning (dev) at test_message.cmake:16 (message):
    7. # wow, author warning
    8. message(DEPRECATION "wow, deprecation") # CMake Deprecation Warning at test_message.cmake:19 (message):
    9. # wow, deprecation
    10. message(NOTICE "github addr:https://github.com/fengbingchun") # github addr:https://github.com/fengbingchun
    11. message("github addr:https://github.com/fengbingchun") # github addr:https://github.com/fengbingchun
    12. message(STATUS "wow, status") # -- wow, status
    13. # --log-level命令行选项可用于控制显示哪些消息,如:
    14. # --log-level=trace,会显示verbose,debug,trace
    15. # --log-level=verbose,仅会显示verbose
    16. message(VERBOSE "wow, verbose") # -- wow, verbose
    17. message(DEBUG "wow, debug")
    18. message(TRACE "wow, trace")
    19. message(FATAL_ERROR "wow, fatal error") # CMake Error at test_message.cmake:34 (message):
    20. # wow, fatal error

          2.Reporting checks:CMake输出中的一个常见模式是一条消息表明某种检查的开始,然后是另一条消息报告检查的结果。这可以使用message命令的CHECK_...关键字形式可以更强大、更方便地表达这一点。其中必须是以下之一:
          (1).CHECK_START:记录关于将要执行的检查的简明信息。
          (2).CHECK_PASS:记录检查的成功结果。
          (3).CHECK_FAIL:记录检查的不成功结果。
          检查消息(check message)始终以STATUS日志级别报告。检查可能是嵌套的,每个CHECK_START都应该有一个匹配的CHECK_PASS或CHECK_FAIL。如果需要,CMAKE_MESSAGE_INDENT变量也可用于向嵌套检查添加缩进

    1. message(CHECK_START "Finding my things")
    2. list(APPEND CMAKE_MESSAGE_INDENT " ")
    3. unset(missingComponents)
    4. message(CHECK_START "Finding partA")
    5. # ... do check, assume we find A
    6. message(CHECK_PASS "found")
    7. message(CHECK_START "Finding partB")
    8. # ... do check, assume we don't find B
    9. list(APPEND missingComponents B)
    10. message(CHECK_FAIL "not found")
    11. list(POP_BACK CMAKE_MESSAGE_INDENT)
    12. if(missingComponents)
    13. message(CHECK_FAIL "missing components: ${missingComponents}")
    14. else()
    15. message(CHECK_PASS "all components found")
    16. endif()

          执行上述测试代码需要3个文件:build.sh, CMakeLists.txt, test_message.cmake

          build.sh内容如下:

    1. #! /bin/bash
    2. # supported input parameters(cmake commands)
    3. params=(function macro cmake_parse_arguments \
    4. find_library find_path find_file find_program find_package \
    5. cmake_policy cmake_minimum_required project include \
    6. string list set foreach message option if)
    7. usage()
    8. {
    9. echo "Error: $0 needs to have an input parameter"
    10. echo "supported input parameters:"
    11. for param in ${params[@]}; do
    12. echo " $0 ${param}"
    13. done
    14. exit -1
    15. }
    16. if [ $# != 1 ]; then
    17. usage
    18. fi
    19. flag=0
    20. for param in ${params[@]}; do
    21. if [ $1 == ${param} ]; then
    22. flag=1
    23. break
    24. fi
    25. done
    26. if [ ${flag} == 0 ]; then
    27. echo "Error: parameter \"$1\" is not supported"
    28. usage
    29. exit -1
    30. fi
    31. if [[ ! -d "build" ]]; then
    32. mkdir build
    33. cd build
    34. else
    35. cd build
    36. fi
    37. echo "==== test $1 ===="
    38. # test_set.cmake: cmake -DTEST_CMAKE_FEATURE=$1 --log-level=verbose ..
    39. # test_option.cmake: cmake -DTEST_CMAKE_FEATURE=$1 -DBUILD_PYTORCH=ON ..
    40. cmake -DTEST_CMAKE_FEATURE=$1 ..
    41. # It can be executed directly on the terminal, no need to execute build.sh, for example: cmake -P test_set.cmake

          CMakeLists.txt内容如下:

    1. cmake_minimum_required(VERSION 3.22)
    2. project(cmake_feature_usage)
    3. message("#### current cmake version: ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}.${CMAKE_PATCH_VERSION}")
    4. include(test_${TEST_CMAKE_FEATURE}.cmake)
    5. message("==== test finish ====")

          test_message.cmake:为上面的所有示例代码

          可能的执行结果如下图所示:

          GitHubhttps://github.com/fengbingchun/Linux_Code_Test

  • 相关阅读:
    CPVT(ICLR 2023)论文解读
    Linux根文件系统说明和常用命令
    mutex互斥锁 - linux内核锁(四)
    机器视觉系统选型-环形光源分类及应用场景
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    数据库设计三范式
    小程序的多种特性
    不调用三方收费接口,照样实现了识别图片为文字的功能
    elment-ui中el-table刷新
    TikTok怎么开启社交电商?
  • 原文地址:https://blog.csdn.net/fengbingchun/article/details/127823890