c++ - 当多个目标使用相同的源文件时,如何使用 --save-temps 保留程序集文件?

标签 c++ assembly cmake g++

如果我编译C++程序/tmp/src/main.cc

#include <iostream>

int main() {

#ifdef demo1
  std::cout << "Output from demo1\n";
#endif

#ifdef demo2
  std::cout << "Output from demo2\n";
#endif

}

使用文件 /tmp/src/CMakeLists.txt 中的构建说明

cmake_minimum_required(VERSION 3.11)
project(test_save_temps LANGUAGES CXX)

function(my_add_executable name)
  add_executable(${name})
  target_sources(${name} PRIVATE main.cc)

  # target_compile_options(${name} PRIVATE --save-temps)

  target_compile_definitions(${name} PRIVATE
    ${name}
  )
endfunction()

my_add_executable(demo1)
my_add_executable(demo2)

一切正常

ubuntu@laptop:/tmp$ mkdir /tmp/build
ubuntu@laptop:/tmp$ cd /tmp/build
ubuntu@laptop:/tmp/build$ cmake -G Ninja /tmp/src
-- The CXX compiler identification is GNU 8.2.0
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Configuring done
-- Generating done
-- Build files have been written to: /tmp/build
ubuntu@laptop:/tmp/build$ ninja
[4/4] Linking CXX executable demo1
ubuntu@laptop:/tmp/build$ ls
build.ninja  CMakeCache.txt  CMakeFiles  cmake_install.cmake  demo1  demo2  rules.ninja
ubuntu@laptop:/tmp/build$ ./demo1
Output from demo1
ubuntu@laptop:/tmp/build$ ./demo2
Output from demo2
ubuntu@laptop:/tmp/build$

但是如果我从文件 /tmp/src/CMakeLists.txt 中删除注释 激活线路

 target_compile_options(${name} PRIVATE --save-temps)

同样做

ubuntu@laptop:/tmp$ mkdir /tmp/build_with_save_temps
ubuntu@laptop:/tmp$ cd /tmp/build_with_save_temps
ubuntu@laptop:/tmp/build_with_save_temps$ cmake -G Ninja /tmp/src
-- The CXX compiler identification is GNU 8.2.0
-- Check for working CXX compiler: /usr/bin/c++
-- Check for working CXX compiler: /usr/bin/c++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-- Configuring done
-- Generating done
-- Build files have been written to: /tmp/build_with_save_temps
ubuntu@laptop:/tmp/build_with_save_temps$ ninja
[4/4] Linking CXX executable demo1
ubuntu@laptop:/tmp/build_with_save_temps$ ls
build.ninja  CMakeCache.txt  CMakeFiles  cmake_install.cmake  demo1  demo2  main.ii  main.s  rules.ninja
ubuntu@laptop:/tmp/build_with_save_temps$ ./demo1
Output from demo1
ubuntu@laptop:/tmp/build_with_save_temps$ ./demo2
Output from demo1
ubuntu@laptop:/tmp/build_with_save_temps$ find . -name '*.s'
./main.s
ubuntu@laptop:/tmp/build_with_save_temps$ 

程序 demo2 的输出不正确。

我希望在构建目录中找到两个版本的程序集文件 main.s

这里我提供一些关于我的电脑系统的额外信息

  • cmake 3.13.2
  • g++ 8.2.0
  • 忍者 1.8.2
  • Ubuntu 18.10

如何修改 /tmp/src/CMakeLists.txt 以保留两个版本的程序集文件 main.s

更新解决方案:

当我按照答案 https://stackoverflow.com/a/53811064/757777 中的建议使用 -save-temps=obj 时,一切都开始工作了由用户fritzone

我换了

target_compile_options(${name} PRIVATE --save-temps)

target_compile_options(${name} PRIVATE -save-temps=obj)

现在我得到了两个程序集文件

ubuntu@laptop:/tmp/build2$ find . -name '*.s'
./CMakeFiles/demo2.dir/main.cc.s
./CMakeFiles/demo1.dir/main.cc.s
ubuntu@laptop:/tmp/build2$

并且可执行文件 demo1demo2 按预期工作

ubuntu@laptop:/tmp/build2$ ./demo1
Output from demo1
ubuntu@laptop:/tmp/build2$ ./demo2
Output from demo2
ubuntu@laptop:/tmp/build2$

最佳答案

您需要为编译器指定-save-temps=obj 选项,以便根据目标文件保存临时文件,根据: https://gcc.gnu.org/onlinedocs/gcc/Developer-Options.html#Developer-Options

因此,您需要将 cmake 文件修改为:

target_compile_options(${name} PRIVATE -save-temps=obj)

(或类似的)以便根据您尝试编译的应用程序的名称保存临时文件。

关于c++ - 当多个目标使用相同的源文件时,如何使用 --save-temps 保留程序集文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53810792/

相关文章:

CMake:定义自定义包含路径

c++ - 通过 istream_iterator 获取值后完成 cin 流

c - %p 在 printf 中的用法?

android - 在 Android NDK 项目中从命令行运行 CMake

c++ - 当我在 C++ 中将 float 变量分配给 int 变量时会发生什么?

c - 如何将数据保存在已知内存位置一次以便在 x86 程序集中多次重用?

c++ - CMake:有没有办法将选项传递给 g++ 但不传递给 nvcc

c++ - 在 Visual C++ 中使用 WebRTC 库

java - 默认构造函数,Java 与 C++

c++ - 枚举声明错误