草庐IT

clang_complete

全部标签

c++ - 模板参数中是否禁止使用 SFINAE,还是我遇到了 clang 错误?

以下是我在实际代码中遇到的问题的简化版本。精简版:只看gcc.godbolt.org处的代码和错误/长版:继续阅读;)假设我想要一个带有模板参数setting和方法intfunc(int)的类,例如:当setting为false时,func返回其参数当setting为true时,func将其参数加倍最简单的方法是专门化类模板:templatestructA{intfunc(x)const{return2*x;}};templatestructA{intfunc(x){returnx;}};这种方法的问题是,如果我有一堆不依赖于setting的其他方法,我将不得不在两个特化中复制粘贴它们

c++ - clang ASTContext.getParents 总是返回一个空列表

我正在基于示例使用LibTooling为clang4.0编写一个工具ClangASTFrontendActionssample.给定当前语句stmt,我想在AST中获取它的直接父级。所以我尝试使用下面的代码来转储stmt的所有父级(用于测试目的):boolVisitStmt(Stmt*s){coutgetParents(currentStmt);autoit=Context->getParents(currentStmt).begin();if(it==Context->getParents(currentStmt).end())cout();parentStmt->dump();}}

c++ - 在#include <cstdint> 之后使用类型的 Clang++ -fmodules 错误

当使用-fmodules编译时,以下简单的测试用例文件给我一个编译时错误,提示来自Clang的github镜像的“master”,使用如下所示的命令。我想知道这是否是Clang的新实验模块功能的错误——可能是标准库的模块映射实现的问题——或者我做错了什么。如果我添加-fbuiltin-module-map,错误仍然出现到命令。有趣的是,如果我替换stdint.h,错误不再出现对于cstdint.#includeuint64_tfoo;这是我的编译命令,带有错误信息:anhall@leviathan:/Users/anhall/impersonal/code/llvm-reflexpr/

c++ - 未定义对 clang 中函数指针的变量模板的引用,但不是 gcc

#includestaticconstexprboolisSSE2=true;templatestaticvoid(*fp)();templatestaticvoidfoo_c(){std::coutstaticvoidfoo_sse2(){std::cout=foo_sse2;elsefp=foo_c;fp();return0;}我有一个使用变量模板的项目,它本身就是一个指向函数的指针。上面的示例代码在GCC6.3中编译和执行良好,但在clang3.9.1中给出警告和错误。$clang++"Source.cpp"-o"foo.exe"-std=c++14-O2Source.cpp:6

c++ - 具有未触及的非 constexpr 参数 : Who is correct, clang 或 gcc 的 constexpr?

我有4个测试用例,我相信它们都是有效的:constexprintf(intconst&/*unused*/){return1;}voidg(intconst&p){constexprinta=f(p);//clangerror,gccvalidintv=0;constexprintb=f(v);//clangvalid,gccvalidintconst&r=v;constexprintc=f(r);//clangerror,gccerrorintn=p;constexprintd=f(n);//clangvalid,gccvalid}intmain(){intp=0;g(p);}Cla

c++ - clang-4.0 初始化全局变量时产生冗余方法

我最近通过观察clang如何处理复杂情况来学习LLVM。我写了(顶层,不在函数中):intqaq=666;inttat=233;autohh=qaq+tat;然后我使用命令:clang-4.0003.cpp-emit-llvm-S-std=c++11clang生成如下代码:@qaq=globali32666,align4@tat=globali32233,align4@hh=globali320,align4@llvm.global_ctors=appendingglobal[1x{i32,void()*,i8*}][{i32,void()*,i8*}{i3265535,void()*

c++ - vftable[0] 存储的是第一个虚函数还是 RTTI Complete Object Locator?

我们都知道C++使用vftable来动态决定应该调用哪个虚函数。而我想弄清楚我们调用虚函数时背后的机制。我已将以下代码编译为程序集。usingnamespacestd;classAnimal{intage;public:virtualvoidspeak(){}virtualvoidwash(){}};classCat:publicAnimal{public:virtualvoidspeak(){}virtualvoidwash(){}};voidmain(){Animal*animal=newCat;animal->speak();animal->wash();}汇编代码非常庞大。我不

c++ - clang 编译的程序在 std::any_cast 期间抛出 std::bad_any_cast

我正在开发一个使用std::any的应用程序.最近我发现,当我用clang编译它时,我得到了bad_any_caststd::any_cast之一的异常我确定我正在转换为正确的类型。我添加了一些typeid(T).name()的转储至cout确保插入std::any的类型没有区别并输入我正在尝试转换到的内容。我试图编写简单的程序来演示它,但我无法重现它。值得一提的是:我正在传递一包std::any(每个内部包含不同的类型)并且只有一个有问题(它是std::map)。当我切换到boost::any时问题消失了(或者如果我使用gcc构建我的应用程序)。我已经深入了解std::any_cas

c++ - 即时编译 C++ : clang/libtooling fails to set Triple for LLVM IR

假设我想即时编译一个C++字符串:llvm::LLVMContextcontext;std::unique_ptraction=std::make_unique(&context);clang::tooling::runToolOnCode/*WithArgs*/(action.get(),"intfoo(intx){return++x;}");std::unique_ptrmodule=action->takeModule();不幸的是,当LLVM尝试转换IR时,似乎有一个异常表明Triple未设置(https://clang.llvm.org/docs/CrossCompilati

c++ - 为什么尽管使用了 -isystem,但 clang 在我的标题上报告了警告,而 gcc 没有报告?

与thisquestion稍微相关但不一样。在ArchLinux上使用clang7.0.1。我喜欢干净的代码,所以我想启用所有警告并将它们视为错误。问题是我的构建中有一些自动生成的文件不是没有警告,例如:生成/foo.hinlinevoidfoo(intunused){//warning:unusedparameter'unused'}生成/foo.cc#include"foo.h"//Thereisactualcodehere,butitdoesn'tmatter.由于这些文件是由第三方工具生成的,我不能轻易修改它们,所以我使用-isystem禁止来自generated的所有警告目录