草庐IT

clang_complete

全部标签

c++ - 如何确定 UBSAN 是否已使用 clang 或 gcc 编译?

我们使用以下代码来确定是否在编译时为clang和gcc指定了-fsanitize=address。我们如何确定是否指定了-fsanitize=undefined?boolisSanitized=false;#ifdefined(__has_feature)#if__has_feature(address_sanitizer)isSanitized=true;#endif#elifdefined(__SANITIZE_ADDRESS__)isSanitized=true;#endif 最佳答案 我建议您将此作为一个错误提交给ASang

c++ - 准备 vim 环境以使用 clang-format

问题:E319:Sorry,thecommandisnotavailableinthisversion问题当我运行vim环境并尝试重新格式化代码(CTRL+K)时,我在屏幕上收到此警告环境:系统:MacOSX设置:Vim:VIM-ViIMproved8.0(2016Sep12,compiledNov17201620:17:27)MacOSX(unix)versionIncludedpatches:1-91python:python--version:Python3.5.2我做什么更新vim:7.3->8.0更新python:~2.7->~3.5我更新了.vimrc文件来自map:pyf

c++ - clang:从互斥锁初始化锁引用

这个程序是clang编译的:#includeintmain(){std::mutexmtx;conststd::lock_guard&lock(mtx);return0;}其他主要编译器拒绝它(我已经尝试过gcc、msvc和icc)。这是来自gcc的错误消息:error:invalidinitializationofreferenceoftype‘conststd::lock_guard&’fromexpressionoftype‘std::mutex’其他人给出了类似的错误。clang是对还是错?这可以用一个不涉及库类的更简单的例子来重现吗?我试过了,但没有用。编辑这似乎是最小的复制

c++ - Clang 错误 – 编译器错误或缺少一些细节?

在对可变参数模板、初始化列表等进行一些试验时,我无意中发现了以下无意义的代码,触发了一条相当有趣的错误消息。首先,让我们定义一个小类,用于使用重载的operator,()进行测试:classDummy{public:Dummy(){}Dummy&operator,(int){return*this;}};现在我们按以下方式使用这个类:inttest1=(Dummy{},0);当使用clang版本6.0.0(tags/RELEASE_600/final334239)编译时,这会触发一个非常合法的错误消息(因为运算符(operator)基本上从中删除了0背面):error:noviable

c++ - 使用 SFINAE 在 GCC 和 Clang 上给出不同的结果

我正在学习如何利用SFINAE来发挥我的优势。我正在尝试使用它来根据serialize()的存在来选择函数实现在对象中运行。这是我用来确定类型是否定义了serialize()函数的代码:templateclassHasSerialize{private:typedefcharyes[1];typedefcharno[2];templatestaticyes&test(char[sizeof(&C::serialize)]);templatestaticno&test(...);public:staticconstboolvalue=sizeof(test(0))==sizeof(yes

c++ - clang 中带有 std::async 的模板函数

我正在查看std::async的示例here,如下:#include#include#include#include#includetemplateintparallel_sum(RAIterbeg,RAIterend){autolen=std::distance(beg,end);if(len,mid,end);intsum=parallel_sum(beg,mid);returnsum+handle.get();}intmain(){std::vectorv(10000,1);std::cout我尝试使用Clang3.4的网络编译器对其进行编译,结果输出的是Thesumis而不是预

c++ - std::atomic 不受 clang 支持?

我正在尝试将std::atomic与clang一起使用。但是,每当我尝试包含头文件原子(#include)时,我都会收到消息“找不到原子”。请注意,我包括-std=c++11-stdlib=libc++编译时。我错过了什么?我使用的clang版本是3.2。 最佳答案 TheversionofclangI'musingis3.2.Clang根据LLVMCXXStatus添加了跨两个不同版本的原子支持.第一个是Clang3.1,第二个是Clang3.2。我认为您可以使用以下方式检查它:#ifdefined(__clang__)#if__

c++ - gcc 和 clang 不同意 constexpr 函数

从生成器函数编写一个简单的编译时std::array工厂,我偶然发现了这个:clang++3.5.1和g++4.9.2不同意函数是否是constexpr或不。代码(这是c++14!):#include#includetemplateconstexprstd::arraymake_array_impl(GenTypegen,std::index_sequence){return{{gen(I)...}};}templateconstexprstd::arraymake_array(GenTypegen){returnmake_array_impl(gen,std::make_index_

c++ - 从 clang-format 样式中提取 emacs c 样式选项

一位同事为我正在处理的C++项目提供了一个clang格式的样式文件。我安装了clang-format.el为了能够从emacs格式化缓冲区。重新格式化按预期工作。不过,Emacs默认的c模式缩进仍然完全不同。我发现在编辑时破坏源代码格式并在以后恢复它非常令人不安。有什么方法可以读取clang格式的文件并应用相应的cc模式选项? 最佳答案 不知道有没有直接转换工具。但是,您可以尝试使用以下技巧:将项目中相当数量的C++文件连接成一个文件(例如cat*.cpp>single.cpp)将clang-format应用到single.cpp在

c++ - clang 的 uint24_t 是如何工作的?我可以在 clang/LLVM 之外使用它吗?

作为GCC用户,我刚刚注意到clang支持uint24_t类型(它在他们的stdint.h中)。这是如何运作的?我的意思是,它是纯粹在内部支持,作为一种语言扩展,还是像C++类那样实现,具有超过3个字节或16位值和另一个8位值的抽象?并且-怎么可能通过GCC来“猛拉”这样的实现并自己使用它?注意:我希望在现代C++中有一个类似uint24_t的类(或更一般的uint_t);我的替代方案是自己动手。你可以s/uint/int/g;如果你喜欢这个问题。 最佳答案 这不是可移植的或标准的。它仅适用于AVR(具有24位地址)和GCChasi