我们已经设置了一个具有外部共享库依赖项的cmake项目。我们希望使用CPack打包项目的二进制文件和依赖项。然而,当我们试图找到目标的依赖项时,我们在windows和linux系统上得到了不同的结果。
我们看了一下GetPrerequisites模块的CMake (2.8.12),.We成功地使用了下面的CMake代码在linux上获得CMake目标(二进制)依赖项(_libFile)的完整路径,但是我们没有获得windows上依赖项的完整路径。在Windows上,变量dependency_realpath包含类似于${CMAKE_SOURCE_DIR}/DEPENDENCY_FILE的内容,这不是指向依赖项的正确路径。
string(TOUPPER "${CMAKE_BUILD_TYPE}" CONFIG)
GET_TARGET_PROPERTY(MY_BINARY_LOCATION ${BINARY} LOCATION_${CONFIG} )
GET_PREREQUISITES(${MY_BINARY_LOCATION} DEPENDENCIES 0 0 "" "")
foreach( DEPENDENCY_FILE ${DEPENDENCIES})
get_filename_component( dependency_realpath ${DEPENDENCY_FILE} REALPATH)所以问题是:为什么我们在windows和linux上的依赖位置得到不同的结果?
发布于 2014-06-24 14:18:14
get_prerequisites返回的引用不是绝对的完全路径引用,它们也不能通过简单的get_filename_component调用解析到绝对引用。(例如,在Mac上,它们可能包含@executable_path。)
但是,GetPrerequisites.cmake模块中还有一个名为gp_resolve_item的函数,可以在这里帮助您。
试试这个:
get_prerequisites(${MY_BINARY_LOCATION} DEPENDENCIES 0 0 "" "")
foreach(DEPENDENCY_FILE ${DEPENDENCIES})
gp_resolve_item("${MY_BINARY_LOCATION}" "${DEPENDENCY_FILE}" "" "" resolved_file)
message("resolved_file='${resolved_file}'")
endforeach()如果DLL名称在您的路径中,则应将它们转换为DLL的完整路径位置。如果它们位于其他目录中,则可能需要将这些参数作为“dir”参数提供给get_prerequisites和gp_resolve_item。
GetPrerequisites.cmake模块的文档如下:http://www.cmake.org/cmake/help/v3.0/module/GetPrerequisites.html
此外,还可以深入了解BundleUtilities.cmake模块,看看它如何使用GetPrerequisites。
https://stackoverflow.com/questions/24367033
复制相似问题