ExternalProject_Add何时构建?

时间:2014-07-01 11:14:40

标签: windows cmake openssl 64-bit external-project

我想构建openssl并将我的项目链接到它。在我的项目中,我有一个名为net的库,它是使用openssl的部分。所以在我的net \ CMakeList中,我添加了

include_directories(
    ../
  + ../../../ext/openssl/inc32/
)
add_library(net STATIC ${sources})
+ ADD_DEPENDENCIES(net openssl)

在用于组织所有外部库的ext文件夹中,我在名为openssl的文件夹中有一个全新的解压缩openssl源代码。然后我编辑了ext \ CmakeList

message(STATUS "Configuring OpenSSL")
set(openssl_dir openssl)
if (CMAKE_CL_64)
include(ExternalProject)

set(OPENSSL_CONFIGURE perl\ Configure\ VC-WIN64A)
set(OPENSSL_MAKE  ms\\do_win64a\ &&\ nmake\ -f\ ms\\ntdll.mak)

ExternalProject_Add(openssl
    PREFIX openssl
    #-- Download Step ----------
    SOURCE_DIR ${CMAKE_SOURCE_DIR}/ext/openssl
    #--Configure step ----------
        CONFIGURE_COMMAND ${OPENSSL_CONFIGURE}
    #--Build Step ----------
    BUILD_COMMAND ${OPENSSL_MAKE}
    BUILD_IN_SOURCE 1
    #--install Step ----------
    INSTALL_COMMAND ""} 
)

endif()

当我构建时,编译器抱怨它无法找到包含文件,并且根本没有构建openssl源代码,因为没有out32dll和inc32。

我的问题是:ExternalProject_Add何时实际构建项目?如果我根据openssl创建我的网库,这是否意味着当我构建网络时,它需要先检查并构建openssl?

2 个答案:

答案 0 :(得分:2)

ExternalProject在内部使用add_custom_target创建项目并根据其文档

  

默认情况下,没有任何内容取决于自定义目标。使用ADD_DEPENDENCIES   向其他目标添加依赖关系。

因此,如果没有项目依赖它,默认情况下不会构建它。

  1. 当这个ExternalProject_Add实际构建项目时?

    在构建时(不是在cmake时间)。

  2. 如果我使我的网络库依赖于openssl,这是否意味着当我构建网络时,它需要先检查并构建openssl?

    没有。由于你创建了依赖项,cmake将处理它,openssl将在你的库之前构建。

  3. PS:还有很多工作要做。由于cmake不知道openssl结果的位置,因此您的项目可能会遇到链接错误。以下是a good example的答案"What is the best way to build boost with cmake"。它使用add_library IMPORTED GLOBALset_target_properties IMPORTED_LOCATION_*来解决问题

答案 1 :(得分:1)

安装错过

首先,我认为您错过了安装步骤。见documentation

  

nmake -f" ms \ ntdll.mak"安装

ExternalProject_Add的简化版本是:

ExternalProject_Add(
    OpenSSL
    URL https://github.com/openssl/openssl/archive/OpenSSL_1_0_1h.tar.gz
    CONFIGURE_COMMAND perl Configure VC-WIN64A "--prefix=${CMAKE_INSTALL_PREFIX}"
    BUILD_COMMAND "ms\\do_win64a.bat"
    COMMAND nmake -f "ms\\ntdll.mak"
    BUILD_IN_SOURCE 1
    INSTALL_COMMAND nmake -f "ms\\ntdll.mak" install
)

查找OpenSSL

其次,如果要查找openssl库和标头,则需要使用find_package(OpenSSL)命令:

find_package(OpenSSL REQUIRED)
message("Libs: ${OPENSSL_LIBRARIES}")
message("Includes: ${OPENSSL_INCLUDE_DIR}")

构建

现在,如果您将所有这些命令放在一个项目中,配置步骤将失败:)因为它不是ExternalProject设计的方式。必须首先配置由少数或一个ExternalProject_Add命令生成的超级构建,然后构建步骤将安装来自外部存档的库。这将与您的项目冲突,因为无法找到openssl库 - 它们尚未由superbuild安装。

修复

拆分cmake代码。首先运行superbuild(即下载并安装openssl):

> cmake -Hsuperbuild -B_builds\superbuild "-GVisual Studio 12 2013 Win64" -DCMAKE_INSTALL_PREFIX=ext\install
# note, no ext\install directory yet
> cmake --build _builds\superbuild
# install done, libraries can be found in ext\install

然后构建your project,请注意在配置步骤中找到的库:

> cmake -Huse -B_builds\use "-GVisual Studio 12 2013 Win64" -DCMAKE_INSTALL_PREFIX=ext\install
-- Found OpenSSL: .../ext/install/lib/ssleay32.lib;.../ext/install/lib/libeay32.lib (found version "1.0.1h")
Libs: .../ext/install/lib/ssleay32.lib;.../ext/install/lib/libeay32.lib
Includes: .../ext/install/include
> cmake --build _builds\use
# OK

实验

我有一个实验项目,在一个命令中包含所有这些噪音(在Visual Studio 2013上测试过Windows):

hunter_add_package(OpenSSL)
find_package(OpenSSL REQUIRED)