- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
下面是我想做的。
我想通过使用 cmake 的正确程序检测 clang 来使用 clang/clang++ 进行编译。
请告诉我可以解决我将描述的问题的正确程序。
test environment:
OS : Ubuntu 16.10 64bit
gcc : gcc (Ubuntu 6.2.0-5ubuntu12) 6.2.0 20161005
clang: 6.0.0 (self build)
cmake: 3.11.3
我做了以下程序,但无法正确检测。
我刚刚描述了 CMakeLists.txt 的检测部分。
CMakeLists.txt
function(display_vars vars prefix)
message("${prefix}")
foreach(IT ${vars})
message("${prefix}${IT} = ${${IT}}")
endforeach()
endfunction()
include(CheckCXXCompilerFlag)
set(project_name clang-test)
project(${project_name})
find_package(LLVM REQUIRED CONFIG)
include_directories( ${LLVM_INCLUDE_DIRS} )
add_definitions ( ${LLVM_DEFINITIONS} )
enable_language(CXX)
# setup compile & link flags
check_cxx_compiler_flag(-std=c++17 COMPILER_SUPPORTS_CXX17)
check_cxx_compiler_flag(-std=c++1z COMPILER_SUPPORTS_CXX1Z)
check_cxx_compiler_flag(-std=c++14 COMPILER_SUPPORTS_CXX14)
check_cxx_compiler_flag(-std=c++1y COMPILER_SUPPORTS_CXX1Y)
check_cxx_compiler_flag(-std=c++11 COMPILER_SUPPORTS_CXX11)
check_cxx_compiler_flag(-std=c++0x COMPILER_SUPPORTS_CXX0X)
# setup compile & link flags
if(COMPILER_SUPPORTS_CXX17)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++17")
elseif(COMPILER_SUPPORTS_CXX1Z)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++1z")
elseif(COMPILER_SUPPORTS_CXX14)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++14")
elseif(COMPILER_SUPPORTS_CXX1Y)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++1y")
elseif(COMPILER_SUPPORTS_CXX11)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
elseif(COMPILER_SUPPORTS_CXX0X)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x")
else()
message(FATAL_ERROR "The compiler has no C++11 support.")
endif()
set(echo_vars)
# result by find_package(LLVM REQUIRED CONFIG)
list(APPEND echo_vars LLVM_DIR LLVM_PACKAGE_VERSION LLVM_INCLUDE_DIRS LLVM_DEFINITIONS)
# detect environment
list(APPEND echo_vars
CMAKE_C_COMPILER_ID
CMAKE_C_STANDARD
CMAKE_CXX_COMPILER_ID
CMAKE_CXX_STANDARD
CMAKE_CXX_FLAGS
CMAKE_GNUtoMS
CMAKE_SYSTEM_NAME
CMAKE_COMPILER_IS_GNUC
CMAKE_COMPILER_IS_GNUCXX
CMAKE_COMPILER_IS_CLANG
CMAKE_COMPILER_IS_MINGW
CMAKE_COMPILER_IS_CYGWIN
CMAKE_GNU_COMPILER_ID
CMAKE_CLANG_COMPILER_ID)
display_vars("${echo_vars}" "env: ")
set(project_sources test.cpp)
add_executable(${project_name} ${project_sources})
测试.cpp
#include <string_view>
int main(int argc, char** argv)
{
return 0;
}
cmake -G "Unix Makefiles" ./
执行该命令时,只检测到gcc,根本检测不到clang。
which clang
> /usr/local/bin
这将被检测到。
自建的clang安装路径默认为/usr/local/。
检测日志如下,只检测到GCC。
日志
CMake suite maintained and supported by Kitware (kitware.com/cmake).
-- The C compiler identification is GNU 6.2.0
-- The CXX compiler identification is GNU 6.2.0
-- Check for working C compiler: /usr/bin/cc
-- Check for working C compiler: /usr/bin/cc -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Detecting C compile features
-- Detecting C compile features - done
-- 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
env:
env: LLVM_DIR = /usr/local/lib/cmake/llvm
env: LLVM_PACKAGE_VERSION = 6.0.0
env: LLVM_INCLUDE_DIRS = /usr/local/include
env: LLVM_DEFINITIONS = -D_GNU_SOURCE -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS
env: CMAKE_C_COMPILER_ID = GNU
env: CMAKE_C_STANDARD =
env: CMAKE_CXX_COMPILER_ID = GNU
env: CMAKE_CXX_STANDARD =
env: CMAKE_CXX_FLAGS = -std=c++17
env: CMAKE_GNUtoMS =
env: CMAKE_SYSTEM_NAME = Linux
env: CMAKE_COMPILER_IS_GNUC =
env: CMAKE_COMPILER_IS_GNUCXX = 1
env: CMAKE_COMPILER_IS_CLANG =
env: CMAKE_COMPILER_IS_MINGW =
env: CMAKE_COMPILER_IS_CYGWIN =
env: CMAKE_GNU_COMPILER_ID =
env: CMAKE_CLANG_COMPILER_ID =
-- Performing Test COMPILER_SUPPORTS_CXX17
-- Performing Test COMPILER_SUPPORTS_CXX17 - Success
-- Performing Test COMPILER_SUPPORTS_CXX1Z
-- Performing Test COMPILER_SUPPORTS_CXX1Z - Success
-- Performing Test COMPILER_SUPPORTS_CXX14
-- Performing Test COMPILER_SUPPORTS_CXX14 - Success
-- Performing Test COMPILER_SUPPORTS_CXX1Y
-- Performing Test COMPILER_SUPPORTS_CXX1Y - Success
-- Performing Test COMPILER_SUPPORTS_CXX11
-- Performing Test COMPILER_SUPPORTS_CXX11 - Success
-- Performing Test COMPILER_SUPPORTS_CXX0X
-- Performing Test COMPILER_SUPPORTS_CXX0X - Success
虽然与主题不同,但日志中有如下消息。
执行测试 COMPILER_SUPPORTS_CXX17 - 成功
这个 gcc (6.2.0) 只支持 c++ 1z。
在gcc中如下是正确的。
CXX_FLAGS = -std=c++1z
言归正传
强制指定用于检测 clang 的编译器。
cmake -G "Unix Makefiles" ./ -DCMAKE_C_COMPILER=/usr/local/bin/clang -DCMAKE_CXX_COMPILER=/usr/local/bin/clang++
新日志
CMake suite maintained and supported by Kitware (kitware.com/cmake).
-- The C compiler identification is Clang 6.0.0
-- The CXX compiler identification is Clang 6.0.0
-- Check for working C compiler: /usr/local/bin/clang
-- Check for working C compiler: /usr/local/bin/clang -- works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Detecting C compile features
-- Detecting C compile features - done
-- Check for working CXX compiler: /usr/local/bin/clang++
-- Check for working CXX compiler: /usr/local/bin/clang++ -- works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
env:
env: LLVM_DIR = /usr/local/lib/cmake/llvm
env: LLVM_PACKAGE_VERSION = 6.0.0
env: LLVM_INCLUDE_DIRS = /usr/local/include
env: LLVM_DEFINITIONS = -D_GNU_SOURCE -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS -D__STDC_LIMIT_MACROS
env: CMAKE_C_COMPILER_ID = Clang
env: CMAKE_C_STANDARD =
env: CMAKE_CXX_COMPILER_ID = Clang
env: CMAKE_CXX_STANDARD =
env: CMAKE_CXX_FLAGS = -std=c++17
env: CMAKE_GNUtoMS =
env: CMAKE_SYSTEM_NAME = Linux
env: CMAKE_COMPILER_IS_GNUC =
env: CMAKE_COMPILER_IS_GNUCXX =
env: CMAKE_COMPILER_IS_CLANG =
env: CMAKE_COMPILER_IS_MINGW =
env: CMAKE_COMPILER_IS_CYGWIN =
env: CMAKE_GNU_COMPILER_ID =
env: CMAKE_CLANG_COMPILER_ID =
-- Performing Test COMPILER_SUPPORTS_CXX17
-- Performing Test COMPILER_SUPPORTS_CXX17 - Success
-- Performing Test COMPILER_SUPPORTS_CXX1Z
-- Performing Test COMPILER_SUPPORTS_CXX1Z - Success
-- Performing Test COMPILER_SUPPORTS_CXX14
-- Performing Test COMPILER_SUPPORTS_CXX14 - Success
-- Performing Test COMPILER_SUPPORTS_CXX1Y
-- Performing Test COMPILER_SUPPORTS_CXX1Y - Success
-- Performing Test COMPILER_SUPPORTS_CXX11
-- Performing Test COMPILER_SUPPORTS_CXX11 - Success
-- Performing Test COMPILER_SUPPORTS_CXX0X
-- Performing Test COMPILER_SUPPORTS_CXX0X - Success
现在检测到了。
CMAKE_COMPILER_IS_CLANG
CMAKE_CLANG_COMPILER_ID
但是,上面的变量仍然是空的。
让我们暂时编译一个简单的文件。
将以下内容放在源文件的开头。
#include <string_view>
然后出现如下错误。
fatal error: 'string_view' file not found
#include <string_view>
^~~~~~~~~~~~~
1 error generated.
clang 6.0 支持 c++17,应该可以编译。
尝试将 include 更改为以下内容。
这是c++1z中string_view的路径。
#include <experimental/string_view>
如上描述即可成功编译。
我想过这是什么意思。
编译器是clang,但是系统包含路径是gcc使用的。
只能认为/usr/include/c++/6.2.0/experimental是在系统include路径中使用/usr/include引用的。
作为我的推理,
-DCMAKE_C_COMPILER=/usr/local/bin/clang -DCMAKE_CXX_COMPILER=/usr/local/bin/clang++
虽然上面的选项强制指定了编译器,但这并不改变没有正确检测到其他环境。
如果检测正确,系统包含路径应使用 LLVM_INCLUDE_DIRS =/usr/local/include。
此外,我认为 CMAKE 变量将如下所示。
env: CMAKE_CLANG_COMPILER_ID = 1
env: CMAKE_COMPILER_IS_CLANG = 1
似乎只是强行设置这个环境设置就麻烦了。
我认为除非cmake正确识别clang,否则影响编译的环境变量不会被正确更改。
这怎么可能?
顺便说一句,当我们在以下环境中进行测试时,
OS : Ubuntu 18.04 64bit
gcc : gcc (Ubuntu 7.3.0-16ubuntu3) 7.3.0
clang: 6.0.0 (self build)
cmake: 3.11.3
#include <string_view>
本次编译成功
但是,也许使用的系统包含路径是/usr/include/。
编译成功,因为gcc已经正式对应c++17,experimental也没有了。
我试过另一个。
sudo update-alternatives --config c++
它只识别g++
如果使用 apt install clang 等安装软件包,系统数据库中的某些内容是否会更新?
因为是自建,所以可能无法识别。
请帮帮我。
最佳答案
如果您想要所有这些奇特的 c++1z 功能,您不仅需要支持它的编译器,还需要一个标准的 C++ 库。 Clang 会选择它找到的任何库,而它恰好是 GCC 的库。
尝试安装 libc++
并将 -stdlib=libc++
标志添加到 CMAKE_CXX_FLAGS
。
关于linux - 我想通过使用 cmake 的正确程序检测 clang 来使用 clang/clang++ 进行编译,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50933490/
运行 pip install cmake 时出现上述错误在 alpine linux (WSL) 上。 完整错误: /home/user# pip install cmake Collecting c
我的项目依赖 mariadb-connector-c我正在尝试使用 cmake 自动化下载、构建和链接过程。 我目前将项目下载到一个目录中,然后尝试执行生成忍者文件并运行它们,但我根本无法运行 cma
我正在尝试像这样在 cmake 中执行 execute_process execute_process(COMMAND ${CMAKE_COMMAND} -P myScript.cmake 这仅在文件
我想知道如果我没有给它任何变量告诉它在哪里找到它,cmake 如何找到我的 llvm cmake 配置。 我是 LLVM 新手。我正在构建一个 Hello World LLVM pass。我在 Ubu
我正在开发一个使用 CMake 的项目。顶CMakeLists.txt文件包含以下行: cmake_minimum_required(VERSION 3.7.2) # Kittens will die
我正在使用 Meego 1.2 工具链使用 cmake 运行构建(长话短说)。这个特定的工具链需要使用 --sysroot 选项来查找它需要的任何库。 set (CMAKE_CXX_FLAGS "-f
我们有一些源代码处理工具,可以从多个“片段”生成原始汇编文件等内容。 当使用 make 中的这些工具时,我们可以通过让源处理工具发出“依赖文件”来确保最新的构建,就像 gcc 一样-MD 标志。 例如
如何在 MSYS2 中安装和配置“cmake”?我尝试安装以下 MSYS 包 我在运行任何 cmake 命令时都收到以下错误 '''CMakeLists.txt:5 (cmake_minimum_re
有没有办法在 CMake 中得到一个变量列表?具体来说,我想要做的是调用一个现有函数,该函数接受多个变量并检查它们的计算结果是否为 true。 在某些情况下,其中一些变量将是空列表(计算结果为 fal
我有两组测试(功能测试和单元测试),我希望能够指定通过 cmake 运行哪一组。 一组测试是我想通过“make test”运行的单元测试。 另一组测试是我想通过“制作功能测试”来运行的功能测试。 目前
我的目标是查看有关调用 g++ 的详细信息由 cmake 直接调用从命令行。我不关心 make 的输出就这个问题而言。 根据official FAQ和 the accepted answer on a
我有一个生成库的CMake项目。我已经编写了一个CMake脚本FindXXX.cmake来帮助我的图书馆的用户。这样,他们可以使用find_package(XXX)并获取所需的变量。到现在为止还挺好。
当我看到带有命名空间的 CMake 库时,它们总是在表单中Parent::Component . 如果我有一个足够大的库,那么该库的子部分可能包含组件。我想知道是否可以/适合做 ParentProje
CMake 变量和属性似乎完成了非常相似的事情,我一直无法理解它们之间的区别。 它们每个都有自己的文档部分,但两者都会影响构建系统,两者都是“预先存在的”,并且两者都可以基于其他 CMake 命令动态
我有一个包含多个子目录的 CMake 项目,例如: dir1 subdir11 subdir12 dir2 subdir21 subdir22 根 CMakeLists
如果您想将静态库链接到共享库或可执行文件,同时保持所有符号可见(例如,您可以稍后打开它以找到它们),在 Linux/BSD 上执行此操作的一种非可移植方式是使用标志-Wl,--whole-archiv
CMake 自动创建一个 FooTarget.cmake文件例如添加 install(EXPORT FooTargets FILE FooTargets.cmake NAMESPACE Foo
在CMake中,ELSE和ENDIF控制流函数将表达式作为参数。根据文档,这些是optional。那么这些目的是什么?仅仅是为了维护目的而使原始IF表达式更清晰,还是提供某些功能? 最佳答案 正如您所
我是 cmake 的新手,我发现它非常令人沮丧。我试图在构建运行时评估的文件路径中使用通配符,而不是在生成构建时。 我创建了一个构建,它使用 SWIG 为某些 C++ 代码生成 Java 包装器。我可
我可能在谷歌上搜索错误,但我无法找到 .cmake 文件的用途。 我刚刚偶然发现了一个我必须使用的项目的 CMake 工具,我很难理解它是如何工作的。我明白在包含 CMakeLists.txt 的目录
我是一名优秀的程序员,十分优秀!