我可以在我的cmake代码中手动使用CMake的cpp文件依赖项扫描程序吗?

时间:2017-04-21 15:49:32

标签: c++ cmake add-custom-command

我正在尝试使用CMake添加一个自定义目标,该目标为每个给定的.cpp文件执行一个命令。只有在源文件本身或其中一个包含的源文件发生更改时,才应重新执行该命令。 AFAIK要实现此目的,我需要列出所有包含的文件,并将其添加到属于我的自定义目标的DEPENDS次调用的add_custom_command()选项中。

那么是否有内置的方法来获取包含文件的列表?

我知道IMPLICIT_DEPENDS函数的add_custom_command()选项,但它仅适用于Makefile生成器。我想为所有发电机做这项工作。

感谢您的时间

修改

根据要求,我将发布一些cmake代码来展示我想要实现的目标。 我想添加一个自定义目标,在所有给定的.cpp文件上运行clang-tidy。当逐步构建自定义目标时,只要更改.cpp文件或其直接或间接包含的头文件之一,就应重新运行clang-tidy命令。就像重新运行编译器一样。

# ----------------------------------------------------------------------------------------
# mainTargetName The name of the target that shall be analyzed
# files A list of all the main targets .cpp files
#
function( addStaticAnalysisTarget mainTargetName files )

    set(targetName runStaticAnalysis_${mainTargetName})
    set(command "clang-tidy-4.0 -checks=* -p ${CMAKE_BINARY_DIR}")

    foreach( file ${files}  )

        get_filename_component( baseName ${file} NAME_WE)
        set(stampFile ${CMAKE_CURRENT_BINARY_DIR}/analyze_${baseName}.stamp )
        set(fullFile ${CMAKE_CURRENT_SOURCE_DIR}/${file})
        set(commandWithFile "${command} ${fullFile}")
        separate_arguments_for_platform( commandList ${commandWithFile})

        add_custom_command(
            OUTPUT ${stampFile}
            DEPENDS "${fullFile}"
            IMPLICIT_DEPENDS CXX "${fullFile}"
            COMMAND ${commandList}
            COMMAND cmake -E touch "${stampFile}"       # without creating a file as a touch-stone the command will always be re-run.
            WORKING_DIRECTORY ${CPPCODEBASE_ROOT_DIR}
            COMMENT "${commandWithFile}"
            VERBATIM
        )

        list(APPEND stampFiles ${stampFile})

    endforeach()
    set_source_files_properties(${stampFiles} PROPERTIES GENERATED TRUE)   # make the stamp files known to cmake as generated files.

    add_custom_target(
        ${targetName}
        DEPENDS ${stampFiles}
    )

endfunction()

问题在于它似乎不起作用。当我更改包含的文件时,不会为受影响的文件重新运行clang-tidy。 我在这个例子中使用了“Unix Makefile”生成器,所以它应该至少与make一起工作。任何提示为什么不呢?

我希望通过以某种方式在cmake时间获取文件依赖关系然后将它们添加到''''DEPENDS'''列表中,我可以实现所有生成器的所需行为。但是每次运行命令时都必须执行依赖项扫描,因此无法在cmake时间完成。这意味着必须通过cmake实现扫描,而目前不是。

有类似问题的家伙: https://gitlab.kitware.com/cmake/cmake/issues/16830

编辑2: 我认为IMPLICIT_DEPENDS选项无法正常工作的问题是因为我没有使用正确的文件名。我在代码剪切中更改了它,但我还没有测试它是否在项目中有效。

1 个答案:

答案 0 :(得分:0)

我认为我的问题的答案是......

不,你不能在cmake代码中使用cmakes依赖扫描程序。

这是有道理的,因为这个问题无法在cmake时解决,因为.cpp文件的依赖关系可能会在没有重新运行cmake的情况下发生变化。 这个问题必须在cmake本身的时候解决。这是在使用IMPLICIT_DEPENDS选项时完成的。

另外,我试图解决一个我没有真正拥有的问题,因为在这一点上我只能在linux上运行clang-tidy。但是,在Windows上也可以使用clang-tidy,然后我可能会再次遇到问题。

总结评论:

  • Tambre表示CMake不是编译器,因此不能这样做。 我认为这是错误的。根据这个article,CMake可以解析cpp包含依赖关系,因为make没有这样的依赖搜索器本身。这对我来说是新闻,但我主要生活在Windows上,所以我对make并不熟悉。也可能在此期间扩展make以进行自己的依赖性搜索。这也解释了为什么IMPLICIT_DEPENDS选项仅适用于make。

  • Florian指出,没有必要为运行clang-tidy创建自己的自定义目标。相反,可以使用CXX_CLANG_TIDY目标属性在编译后为每个文件运行clang-tidy。但是,这意味着静态分析无法与构建分离,这可能导致不可接受的构建时间。

  • cmake -E cmake_depends命令行,可用于在cmake时检索依赖项。但如上所述,我错误地认为我需要在cmake时间使用依赖项,而我在运行时需要它们。

  • IMPLICIT_DEPENDS选项不起作用,因为我的cmake代码出错了。