• CMake中while/continue/break的使用


          CMake中的while命令用于在条件为true时评估(evaluate)一组命令,其格式如下:

    1. while()
    2. endwhile()

          在while和匹配的endwhile之间的所有命令都被记录下来而不被调用。一旦评估了endwhile,只要为true,就会调用记录的命令列表。
          while中的与if命令中的具有相同语法和相同的逻辑进行评估
          命令break和continue提供了从正常控制流中退出的方法。

    1. set(var 1)
    2. while(${var} LESS 4)
    3. message("var: ${var}")
    4. math(EXPR var "${var}+1")
    5. endwhile()

          CMake中的continue命令用于continue到foreach或while循环的顶部(top),其格式如下:

    continue()

          continue命令允许cmake脚本中止foreach或while循环的当前迭代的其余部分,并从下一次迭代的顶部开始

    1. set(var 1)
    2. while(${var} LESS 4)
    3. message("var: ${var}")
    4. math(EXPR var "${var}+1")
    5. if(${var} EQUAL 3)
    6. continue()
    7. endif()
    8. message("after math, var: ${var}")
    9. endwhile()

          CMake中的break命令用于从foreach或while循环中中断(break),其格式如下:从当前的foreach或while循环中退出

    break()
    1. set(var 1)
    2. while(${var} LESS 4)
    3. message("var: ${var}")
    4. math(EXPR var "${var}+1")
    5. if(${var} EQUAL 3)
    6. break()
    7. endif()
    8. message("after math, var: ${var}")
    9. endwhile()
    10. message("var: ${var}")

          执行上述测试代码需要3个文件:build.sh, CMakeLists.txt, test_while.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 while return \
    7. math file)
    8. usage()
    9. {
    10. echo "Error: $0 needs to have an input parameter"
    11. echo "supported input parameters:"
    12. for param in ${params[@]}; do
    13. echo " $0 ${param}"
    14. done
    15. exit -1
    16. }
    17. if [ $# != 1 ]; then
    18. usage
    19. fi
    20. flag=0
    21. for param in ${params[@]}; do
    22. if [ $1 == ${param} ]; then
    23. flag=1
    24. break
    25. fi
    26. done
    27. if [ ${flag} == 0 ]; then
    28. echo "Error: parameter \"$1\" is not supported"
    29. usage
    30. exit -1
    31. fi
    32. if [[ ! -d "build" ]]; then
    33. mkdir build
    34. cd build
    35. else
    36. cd build
    37. fi
    38. echo "==== test $1 ===="
    39. # test_set.cmake: cmake -DTEST_CMAKE_FEATURE=$1 --log-level=verbose ..
    40. # test_option.cmake: cmake -DTEST_CMAKE_FEATURE=$1 -DBUILD_PYTORCH=ON ..
    41. cmake -DTEST_CMAKE_FEATURE=$1 ..
    42. # 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_while.cmake:为上面的所有示例代码

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

          GitHubhttps://github.com/fengbingchun/Linux_Code_Test

  • 相关阅读:
    L1-030 一帮一 C++解法
    机器学习知识经验分享之一:卷积神经网络介绍
    【十问十答】回归模型知识点
    JavaScript -- 06.函数知识汇总
    python高阶函数心得笔记,python高阶函数知识
    logback1.3.x配置详解与实践
    探秘高逼格艺术二维码的制作过程-AI绘画图生图
    Qt基础之四十六:Qt界面中嵌入第三方程序的一点心得
    TortoiseGit安装和配置详细说明
    STM32:GPIO功能描述和工作方式
  • 原文地址:https://blog.csdn.net/fengbingchun/article/details/127946892