草庐IT

CLANG_ARGS

全部标签

c++ - clang 3.5 constexpr 不一致 - 使用 double 而不是 int 时出错

回答后usingboostmathconstantsinconstexpr并建议OP对constexpr变量使用boost的模板化函数而不是非模板化常量来平息clang错误,我决定尝试看看什么条件会重现clang中的错误。让我们尝试复制boost的宏扩展到的内容:namespacedouble_constants{staticconstdoublename=25;}staticconstexprdoubleSEC3=double_constants::name;这会产生以下错误(按照Coliru进行)clang++-std=c++1y-O2-Wall-pedantic-pthreadm

c++ - Clang -Wweak-vtables 和纯抽象类

关于之前关于此主题的问题:这是对我最近提出的问题的跟进:clang:noout-of-linevirtualmethoddefinitions(pureabstractC++class)并且被标记为这个问题的重复项:Whatisthemeaningofclang's-Wweak-vtables?.我认为这并没有回答我的问题,所以在这里我将重点放在令我困惑且尚未得到解答的事情上。我的场景:我正在尝试使用Clang-3.5编译以下简单的C++代码:测试.h:classA{public:A();virtual~A()=0;};测试.cc#include"test.h"A::A(){;}A::

c++ - 这段编译良好的荒谬代码是 Clang 和 GCC 中的错误吗?

这个问题在这里已经有了答案:Injectedclassnamecompilerdiscrepancy(3个答案)关闭6年前。我今天在研究模板,看看能否让编译器从其内部类之一推断出外部类的类型。我没有找到我的解决方案(我怀疑这是不可能的),但是在尝试修复错误时我遇到了非常奇怪的行为,我将其简化为以下代码片段。structA{structB{};templatestructEverythingIsFine{usingOuter=T;usingInner=typenameT::B::B::B::B::B::B;};usingItWillBeOkay=EverythingIsFine;//Pr

c++ - clang 无法在模板实例化时生成默认的移动构造函数

下面的代码(我无法制作更短的MVCE)unit.h:#includetemplatestructfoo{std::vectordata;foo(foo&&)=default;//noassemblygeneratedfoo(std::vector&&v):data(std::move(v)){}};externtemplatestructfoo;//indicatestemplateinstantiationelsewhereunit.cc:#include"unit.h"templatestructfoo;//forcestemplateintantiationma​​in.cc:#

c++ - clang 中 regex_constants 的错误实现?

如standard中所述:match_prev_avail:--first是一个有效的迭代器位置。设置后,会导致match_not_bol和match_not_bow被忽略但我运行以下代码并得到:#include#includeusingnamespacestd;intmain(){regexre0("^bcd");stringstr="abcd";std::string::iteratorstart=str.begin()+1;cout输出:010match_prev_avail似乎被match_not_bol覆盖了。 最佳答案

c++ - clang 的扫描构建不适用于简单的 cpp 文件

我无法让clang的c++-analyzer处理玩具C++文件。#includeusingnamespacestd;intmain(){intt[4];intx,y;t[5]=1;if(x)y=5;x=t[y];}makefile就是all:t.cpp$(CXX)t.cppscan-buildmake输出:scan-build:'clang'executablenotfoundin'/usr/share/clang/scan-build/bin'.scan-build:Using'clang'frompath:/usr/bin/clang/usr/share/clang/scan-bu

C++ 预处理器宏循环 __VA_ARGS__ 1 vs 2+ 参数

我正在使用这个post中的宏遍历我的论点。一切都很好!但是,有没有办法将这两个CCB_CREATE和CCB_CREATE_MORE结合起来?我需要提取第一个参数object_type来编写额外的代码。额外的object_type将使用FOR_EACH循环插入到map中。当我在使用CCB_CREATE_MORE(Type1)时只有一个参数时,编译器会提示。为了解决这个问题,我创建了另一个宏来处理CCB_CREATE(Type1)。希望找到一个巧妙的解决方案,将这两个组合成一个优雅的宏。有什么想法吗?#defineINSERT_LOADER_MAP(object_type)loader_m

c++ - 使用 GCC 编译模板友元错误,但不使用 clang

此代码使用clang3.7.1编译(没有诊断),但使用GCC5.3.0编译失败>(liveexample):#includetemplatestructA{voidfoo(){static_cast(this)->implementation();}};structCrtp:A{templatefriendstructA;private:voidimplementation(){std::coutGCC的错误信息如下:main.cpp:13:16:error:specializationof'A'afterinstantiationfriendstructA;哪个是正确的,为什么?是G

c++ - Clang claims that `member reference base type ' X' is not a structure or union`,但 X 是具有推导参数的结构模板

考虑以下代码:templatestructX{X(T){}voidfoo(){}};templatestructY{intobject=0;voidbar(){X(object).foo();}};Liveongcc.godbold.orgGCC8.2编译它,而Clang7吐出以下错误::13:18:error:memberreferencebasetype'X'isnotastructureorunionX(object).foo();~~~~~~~~~^~~~这对我来说像是一个错误。条件非常具体:如果任一结构不是模板,或者object不是成员变量,或者不涉及CTAD(类模板参数推导

c++ - gcc vs clang 在具有可变参数和相同类型的额外参数的部分特化上的行为

以下代码:#includetemplatestructA{};templatestructA{};intmain(){Aa0;Aa2;return0;}...不编译g++(版本5.1.0和5.3.0)由于:error:partialspecializationisnotmorespecializedthantheprimarytemplatebecauseitreplacesmultipleparameterswithapackexpansion...但使用clang编译.是否允许声明这样的部分特化?旁注:实际上,自A以来,特化是危险的两个编译器都无法编译(模板参数数量错误)。