草庐IT

iphoneos-clang

全部标签

c++ - 如何设置 Clang 以使用 MinGW libstdc++

我一直在尝试在Windows上设置Clang。到目前为止,我幸免于使用VisualStudio和CMake进行构建,并遇到了一些其他的惊喜。但事实证明,Clang没有自带C++stdlib实现,所以我决定使用GCC4.7.0为MinGW构建的libstdc++。首先,我将搜索路径添加到我的HeaderSearchOptions。headeropts->AddPath(path,clang::frontend::IncludeDirGroup::CXXSystem,true,false,false);路径正是header所在的位置-我从Windows资源管理器中复制并粘贴了它(然后将反斜

c++ - clang++ 3.2 链接器找不到 C++ stdlib

我已经在我的Ubuntu13.04机器上安装了clang3.2,并编译和构建了libc++,一切就绪。但是,当我尝试链接我的(非常简单的)代码时,链接器报告对std::cout等的引用未定义。如果有人能建议我如何解决这个问题,我将不胜感激——我已经尝试了所有我能想到的方法。命令和输出在这里:$clang++-v-stdlib=libc++-lpthread-ldlsqlite3/sqlite3.osrc/world.o-obin/worldUbuntuclangversion3.2-1~exp9ubuntu1(tags/RELEASE_32/final)(basedonLLVM3.2)

c++ - 如何安装clang头文件?

我在我的MacOS上安装了clang(在/usr/bin/clang中),我认为它默认安装在Mac上,但是,当我尝试在脚本中包含clang头文件时,它说找不到它们Example.cpp:1:10:fatalerror:'clang/Driver/Options.h'filenotfound问题:当clang已经在MacOS系统上安装和构建时,是否有必要(如果可能,如何)安装头文件(或者clang本身是否需要与所有所需的同时重新安装)开发工具包及其头文件是否已安装)?#include"clang/Driver/Options.h"#include"clang/AST/AST.h"#inc

c++ - 可以使用 clang 将 C++17 与 CUDA 一起使用吗?

就使用nvcc而言,需要结合使用相应的gcc(我相信目前最大为5.4)。这当然会在某种程度上阻止人们在主机端使用C++17。因为C++17可以使用clang5和更高版本编译(参见here),并且也可以编译cuda代码(参见here),是不是是否可以同时使用C++17和CUDA(或者是否会出现问题,例如CUDA运行时)? 最佳答案 是的,正如您已经猜到的那样,CUDAclang前端在C++功能支持方面确实领先,甚至在设备代码方面也是如此。这已经是过去了,在NVCC之前引入了C++14特性,社区大多没有注意到。以这个C++17为例,不必

c++ - 函数指针数组的类模板参数推导适用于 clang,但不适用于 gcc

以下代码:#includetemplateautof(){}intmain(){std::array{f};}使用clang7.0编译,但使用gcc8.2失败并显示消息prog.cc:Infunction'intmain()':prog.cc:7:20:error:classtemplateargumentdeductionfailed:std::array{f};^prog.cc:7:20:error:nomatchingfunctionforcallto'array()'Infileincludedfromprog.cc:1:/opt/wandbox/gcc-8.2.0/inclu

C++11 构造函数重载解析和初始化列表 : clang++ and g++ disagree

我有一小段C++11代码,g++(4.7或4.8)拒绝编译,声称对B2b2a(x,{P(y)})的构造函数的调用不明确。Clang++对这些代码很满意,但拒绝编译B2b2b(x,{{P(y)}})而g++很乐意编译!两个编译器都非常满意以{...}或{{...}}作为参数的B1构造函数。任何C++语言律师都可以解释哪个编译器是正确的(如果有的话)以及发生了什么?代码如下:#includeusingnamespacestd;classY{};classX;templateclassP{public:P(T);};templateclassA{public:A(initializer_li

c++ - 有没有办法用 clang 在 VisitCallExpr 方法中获取 CallExpr* 的调用者?

方法getDirectCallee()可以得到调用表达式的被调用者(称为方法/函数),但是有没有办法得到调用者(调用它的方法/函数)VisitCallExpr()方法中的CallExpr*?有没有其他方法可以知道一个调用表达式的调用者? 最佳答案 处理这个问题的更好方法是使用AST匹配器。您基本上可以在AST匹配器中查找所有callExpr节点并绑定(bind)它们,同时绑定(bind)相应的调用方(CXXRecordDecl)节点以及不同的字符串。例如:CallBackFunccallBackFunc;Matchers.addMa

c++ - 我怎样才能告诉 clang-format 遵循这个约定?

我想要这个:if(!enabled){return;}转向这个:if(!enabled){return;}(换句话说,我想在一行中使用简短的if语句,但在它们周围保留{})目前我正在使用以下配置:AllowShortIfStatementsOnASingleLine:trueAllowShortLoopsOnASingleLine:trueAllowShortCaseLabelsOnASingleLine:trueAllowShortFunctionsOnASingleLine:trueAllowShortBlocksOnASingleLine:trueBreakBeforeBrace

c++ - 函数模板修改用顶级 const 声明的参数 : clang bug?

下面的代码可以在ArchLinux上的clang3.8.1-1上正确编译。这是clang错误吗?gcc对此发出正确的警告/错误。templatestructBugReproducer{usingsize_type=typenameT::size_type;intbug1(size_typecount);intbug2(size_typecount)const;staticintbug3(size_typecount);};templateintBugReproducer::bug1(size_typeconstcount){//thisisabug.mustbenotallowedco

c++ - 为什么 std::boolalpha 在使用 clang 时忽略字段宽度?

以下代码使用g++7编译器和Appleclang++给出了不同的结果。当使用std::boolalpha时,我是否在bool输出的对齐中遇到了clang中的错误,或者我是否犯了错误?#include#include#include#includetemplatevoidprint_item(std::stringname,T&item){std::ostringstreamss;ss区别在于://outputfromg++version7.2i=34(blabla)s=Hello!(blabla)d=2(blabla)b=true(blabla)//outputfromApplecla