草庐IT

CMAKE_C_FLAGS_ALL

全部标签

c++ - 自定义目标的 cmake 依赖项

我使用python脚本(gen_instantiations.py)生成一个包含在另一个cpp文件(foo.cpp)中的cpp文件(autogen_instantiations.cpp)所以我希望CMake在foo.hpp或gen_instantiations.py发生变化时重新生成这个文件。按照CMakeFAQ中的说明,这是我所做的add_custom_command(COMMAND"./gen_instantiations.py"OUTPUT"autogen_instantiations.cpp"WORKING_DIRECTORY"${CMAKE_CURRENT_SOURCE_DI

c++ - 使用 g++ 和 CMake 损坏的配置文件信息

我正在尝试使用分析优化一个相当复杂的C++项目(多个源文件,链接到Boost库、GSL和OpenCV)。使用CMake,我首先编译set(CMAKE_CXX_FLAGS"-O3-ffast-math-fprofile-generate=profiling-pg-fopenmp")在使用典型输入运行生成的可执行文件后,我编译set(CMAKE_CXX_FLAGS"-O3-ffast-math-fprofile-use=profiling-fopenmp")编译失败,出现大量类似这样的错误:/n/user/projects/project_name/src/foo.cpp:Inmember

c++ - Cmake 外部库.a

我这里有一个外部库:${PROJECT_SOURCE_DIR}/thirdparty/yaml-cpp/它是由Makefile制作的:thirdparty/Makefile。我正在像这样执行该makefile:add_custom_target(yaml-cppCOMMANDmakeWORKING_DIRECTORY${CMAKE_SOURCE_DIR}/thirdparty)然后我尝试链接构​​建到thirdparty/yaml-cpp/build/libyaml-cpp.a的库。这是不起作用的部分:target_link_libraries(load_balancer_node${

c++ - 使用 CMake 将 qt header 声明为系统 header

我用CMake和qt说:find_package(Qt5COMPONENTSWidgets)另外,我想使用高警告级别并且我想将警告视为错误。所以我使用:set(CMAKE_CXX_FLAGS"${CMAKE_CXX_FLAGS}-Werror-Wall-Wextra")但是,我不关心我使用的库中的警告。因此,例如,为了包含boost,我在include_directories调用中添加了SYSTEM,这样我就不会被来自外部库的警告所困扰:include_directories(SYSTEM${Boost_INCLUDE_DIR})但这对qt不起作用,因为没有显式的include_dir

c++ - 使用 cmake、clang 和 llvm 为 visual studio 构建工具链

我在谷歌上搜索了很多,但没有找到合适的答案,所以我在这里问。要从现有代码开发一个应使用cmake和clang编译的c++项目,我需要采取哪些步骤?我还想拥有所有不错的功能,例如自动完成和使用断点进行调试以及逐步调试。 最佳答案 查看与VisualStudio集成的Windows构建的最新LLVM快照页面here.有一个安装程序和一个代码格式化插件。您不会获得自动完成功能,并且Clang/LLVM与VisualStudio中的调试无关(除了如果您使用Clang编译它可能无法工作)。另见thisinterestingblogpost在拥

c++ - Cmake 生成独立的makefile

我们正在从MPC移动到CMake。我们提供了一个带有一些示例的库。示例随makefile一起提供。问题是cmake生成的makefile包含绝对路径但不包含相对路径:#Themainalltargetall:cmake_check_build_systemcd/.../Projects/cpp_trunk&&$(CMAKE_COMMAND)-Ecmake_progress_start/.../Projects/cpp_trunk/CMakeFiles/.../Projects/cpp_trunk/samples/CMakeFiles/progress.makecd/.../Projec

c++ - 如何允许用户重新配置编译器以与 cmake 一起使用?

我想让用户运行一个cmake配置工具(例如ccmake或cmake-gui)来更改使用的编译器。这是必要的,因为我正在构建一个有时在集群上运行的跨平台程序(因此需要具有适当MPI构造的特定于集群的编译器)但有时在非MPI模式下运行。让我们假设编译器通常可以是平台期望的任何编译器(通常是gcc/g++或在最坏的情况下是MSVC),但是当我们使用MPI时,我们总是知道我们需要通过mpicc/mpicxx进行编译。我觉得下面的代码应该可以工作:cmake_minimum_required(VERSION2.4)option(USE_MPI"IsthisonanMPIsystem?"OFF)i

c++ - notify_all 崩溃后直接删除 std::condition_variable_any

我有一部分代码,其中一个线程调用如下内容:cond->notify_all();deletecond;与std::condition_variable_anycond;Afaik,这应该有效,因为Ishouldbeallowedtodeletetheconditionvariable,assoonasInotifiedallthreadswaitingonit,他们不必从wait调用中恢复。在Windows上,这有时会因错误而崩溃:mutexdestroyedwhilebusy打印到标准输出在Linux上,使用clang3.5这工作得很好,在Windows上我使用VisualStudi

c++ - X代码 6.1 : All commands in Debug menu greyed out

我目前正在使用XCode进行一些C++编程。我的问题是XCode中的调试菜单总是灰色的。添加断点也不会改变这一点。我在提问之前进行了一些搜索,答案主要是确保方案正确。我检查了是否选择了LLDB调试器,并且已将可执行文件添加到目标。我还缺少什么?谢谢 最佳答案 在您构建并运行当前方案之前,调试菜单项将被禁用。在osx10.9.5上使用xcode6.1.1,我选择“新建>项目应用程序>命令行工具”来创建一个简单的helloworld。所有调试命令都是灰色的我发现这很令人困惑,因为我习惯了visualstudio给我通过介入开始调试的选项

c++ - CMake 在 include_directories 中找不到正确的头文件/包含文件

当我尝试编译时,我再次收到“undefinedsymbolsforarchitecturex86_64”错误。我已经尝试了比我在这篇文章中实际记录的更多的东西(因为我已经忘记了我尝试过的所有内容)。这是一个非常简单的设置,应该使用CMake很容易编译...当我对此运行make时,它​​工作得很好。但我想将其转换为CMake以实现互操作性。如您所见,我在几个地方放置了“${HEADERS}”变量,我已经尝试了很多位置,但我一直收到错误。根据我放置${HEADER}的位置,它在技术上还可以生成“错误:生成多个输出文件时无法指定-o”的错误(如果它仅位于target_link_library