[CMake翻译]添加自定义命令和生成的文件(步骤6)

1,192 阅读2分钟

原文地址:cmake.org/cmake/help/…

原文作者:

发布时间:

假设,为了本教程的目的,我们决定永远不要使用平台logexp函数,而是想生成一个预计算值的表,以便在mysqrt函数中使用。在本节中,我们将创建该表作为构建过程的一部分,然后将该表编译到我们的应用程序中。

首先,让我们删除MathFunctions/CMakeLists.txt中对logexp函数的检查。然后从mysqrt.cxx中删除对HAVE_LOGHAVE_EXP的检查。同时,我们可以删除#include <cmath>

MathFunctions子目录中,已经提供了一个名为MakeTable.cxx的新源文件来生成表。

查看该文件后,我们可以看到,该表是以有效的C++代码生成的,而且输出文件名是作为参数传递进来的。

下一步是在MathFunctions/CMakeLists.txt文件中添加适当的命令来构建MakeTable可执行文件,然后作为构建过程的一部分运行它。要完成这个任务,需要一些命令。

首先,在MathFunctions/CMakeLists.txt文件的顶部,添加MakeTable的可执行文件,就像添加其他可执行文件一样。

add_executable(MakeTable MakeTable.cxx)

然后我们添加一个自定义命令,指定如何通过运行MakeTable来生成Table.h

add_custom_command(
  OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/Table.h
  COMMAND MakeTable ${CMAKE_CURRENT_BINARY_DIR}/Table.h
  DEPENDS MakeTable
  )

接下来我们要让CMake知道mysqrt.cxx依赖于生成的Table.h文件,这要通过将生成的Table.h添加到库MathFunctions的源列表中来实现。

add_library(MathFunctions
            mysqrt.cxx
            ${CMAKE_CURRENT_BINARY_DIR}/Table.h
            )

我们还必须将当前的二进制目录添加到include目录列表中,这样Table.h才能被mysqrt.cxx找到并收录。

target_include_directories(MathFunctions
          INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}
          PRIVATE ${CMAKE_CURRENT_BINARY_DIR}
          )

现在让我们使用生成的表。首先,修改mysqrt.cxx以包含Table.h。接下来,我们可以重写mysqrt函数以使用该表。

double mysqrt(double x)
{
  if (x <= 0) {
    return 0;
  }

  // use the table to help find an initial value
  double result = x;
  if (x >= 1 && x < 10) {
    std::cout << "Use the table to help find an initial value " << std::endl;
    result = sqrtTable[static_cast<int>(x)];
  }

  // do ten iterations
  for (int i = 0; i < 10; ++i) {
    if (result <= 0) {
      result = 0.1;
    }
    double delta = x - (result * result);
    result = result + 0.5 * delta / result;
    std::cout << "Computing sqrt of " << x << " to be " << result << std::endl;
  }

  return result;
}

运行 cmake 可执行文件或 cmake-gui 来配置项目,然后用你选择的构建工具来构建它。

当这个项目被构建时,它将首先构建MakeTable可执行文件,然后运行MakeTable产生Table.h。最后,它将编译包含Table.hmysqrt.cxx以产生MathFunctions库。

运行Tutorial可执行文件并验证它是否使用了表。


www.deepl.com 翻译