草庐IT

iphoneos-clang

全部标签

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++ - 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的所有警告目录

c++ - gcc 与 clang : noexcept parsed in unused template specialization when static casting

我正在尝试将函数指针静态转换为特定函数重载,但似乎clang仍会解析(未使用的)模板特化的noexcept语句,从而生成编译器错误。如果未使用相应的函数重载,GCC似乎并不关心noexcept。templatevoidfun(T)noexcept(T(1)){}voidfun(int){}voidfun(int*){}intmain(){inta;fun(&a);//callingworksfinefun(a);static_cast(&fun);//staticcastingdoesn't}https://godbolt.org/z/ixpl3f这里是哪个编译器出错了?当将函数指针转

c++ - 由于 libjsoncpp0,travis 上的 Clang 6 中断

由于以下问题,我们构建的travisci已损坏:Thefollowingpackageshaveunmetdependencies:clang-6.0:Depends:libjsoncpp0(>=0.6.0~rc2)butitisnotinstallableE:Unabletocorrectproblems,youhaveheldbrokenpackages.apt-get.diagnosticsapt-getinstallfailedsudoaptinstalllibjsoncpp0不起作用,因为libjsoncpp0不存在;我也试过sudoaptinstalllibjsoncpp-

c++ - 如何让 Clang Complete 显示函数参数?

当使用ClangComplete自动完成时,我想让它也显示函数签名。例如,如果我声明以下函数:intadd(inta,intb){intresult=a+b;returnresult;}当我启动ClangComplete时,我不仅希望函数名称在自动完成结果中弹出,而且它的参数也是如此:add(inta,intb). 最佳答案 试试这个setconceallevel=2setconcealcursor=vinletg:clang_snippets=1letg:clang_conceal_snippets=1"Thesingleonet

c++ - Clang 访问修饰符顺序和 decltype

我一直在考虑创建一个同步器助手模板类,它基于HerbSutter在这个talk中的包装器类的想法。这在msvc中不起作用(除非我们删除大括号初始化)但是当大括号初始化被删除时就没问题了。在clang/gcc(ubuntu12.10,gcc4.7.2,clang(3.2)selfbuiltwithlibc++)中,private访问修饰符似乎必须出现在public之前:这看起来有点奇怪。gcc的错误是错误:“t_”未在此范围内声明clang是error:useofundeclaredidentifier't_'autooperator()(Ff)const->decltype(f(t_)

c++ - clang++ - 将模板类名视为类范围内的模板

似乎clang++(我试过clang3.2)将模板类的名称视为实例化类,而不是类范围内任何事件的模板。比如下面的代码templateclassT>classA{};templateclassB{Amember;//^----clang++treatsBasaninstantiatedclass//butIwantittobeatemplatehere//thiscodecouldcompileing++};intmain(){Bb;return0;}我应该怎么做才能编译它? 最佳答案 C++03以这种方式解析B(称为injected