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

Kni*_*chi 5 c++ cmake add-custom-command

我试图用CMake添加一个自定义目标,为每个给定的.cpp文件执行一个命令.只有在源文件本身或其中一个包含的源文件发生更改时,才应重新执行该命令.AFAIK实现这一点我需要一个包含所有包含文件的列表,并将它们添加到属于我的自定义目标DEPENDSadd_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()
Run Code Online (Sandbox Code Playgroud)

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

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

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

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

Kni*_*chi 1

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

不,您不能在 cmake 代码中使用 cmakes 依赖项扫描器。

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

另外,我试图解决一个我并没有真正遇到的问题,因为此时我无论如何都只能在 Linux 上运行 clang-tidy 。然而,clang-tidy 也可能在 Windows 上可用,然后我可能会再次遇到问题。

总结一下评论:

  • Tambre 表示 CMake 不是编译器,因此无法做到这一点。我认为这是错误的。根据这篇文章,CMake可以解析cpp包含依赖项,因为make本身没有这样的依赖项搜索器。这对我来说是个新闻,但我主要生活在 Windows 上,所以我对 make 不太熟悉。与此同时,make 也有可能被扩展以进行自己的依赖性搜索。这也解释了为什么该IMPLICIT_DEPENDS选项仅适用于 make。

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

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

  • 这些IMPLICIT_DEPENDS选项不起作用,因为我的 cmake 代码中有错误。