草庐IT

CLANG_ENABLE_MODULE_DEBUGGING

全部标签

c++ - 将 cmake 编译器从 clang 更改为 g++ for mac

我正在使用一个非常不方便的软件,它不支持clang。所以,我需要更改我的cmake编译器,因为我几乎到处阅读,在这里HowcanImakeCMakeuseGCCinsteadofClangonMacOSX?,我试过:cmake-DCMAKE_CXX_COMPILER=/usr/bin/g++但是还是报错CMakeErroratCMakeLists.txt:59(message):GAMBIT不支持Clang编译器。请选择另一个编译器。--配置不完整,出现错误!有什么建议吗? 最佳答案 我发现在第一次运行CMake之前设置环境变量CC

c++ - 使用 enable_if 禁用模板类的模板构造函数

当模板构造函数的参数类型与类型“MyClass匹配时,我试图使用std::enable_if禁用模板类的模板构造函数"这样我就可以使用我的其他构造函数,它允许我用另一个模板的类初始化当前模板的类。templateclassMyClass{public:MyClass(){data.fill(static_cast(0));}template//iwanttodisablethisifArgs=MyClassMyClass(Args&&...args):data{std::forward(args)...}{}templateMyClass(constMyclass&other_size

c++ - Clang 3.1 和用户定义的文字

Clang3.1声称支持用户定义的文字。我可以这样定义:intoperator""_tryit(longdoublen){returnint(n);}但是当我尝试使用它时出现错误:intm=5_tryit;Invalidsuffix'_tryit'onintegerconstant 最佳答案 5在您的情况下不能隐式转换为longdouble。您需要将其更改为5.0以使其成为longdouble或自己显式调用该函数以使隐式转换起作用:intm=5.0_tryit;或intn=operator""_tryit(5);(均使用clang版

c++ - 需要更改 clang 的包含路径

当用clang构建时,它似乎使用gcc4.4.4版本的包含文件,而我希望它使用更新的。[~]locatemove.h/home/apps/gcc_versions/gcc-4_8_install/include/c++/4.8.3/bits/move.h/usr/include/c++/4.4.4/bits/move.h/usr/local/include/c++/4.7.1/bits/move.hgcc路径:`gcc-print-prog-name=cc1plus`-vignoringnonexistentdirectory"/apps/gcc_versions/gcc-4_8_in

c++ - Visual Studio 2015 更新 1,clang 错误

在我的项目(VisualStudio2015Update1)中尝试将新的clang与VisualCodegen结合使用时,出现以下错误:clang.exe:error:cannotspecify-owhengeneratingmultipleoutputfiles这只是一个新创建的项目,带有自动生成的main。我真的不知道该怎么办。感谢任何帮助。 最佳答案 不是很清楚您在做什么,但很明显您没有在跨平台节点中使用Clang项目模板之一。我可以通过使用Win32>Win32项目模板并将项目的平台工具集选择更改为“Clang3.7”来重现

c++ - 带有 std::enable_if 和 std::is_default_constructible 的 SFINAE 用于 libc++ 中的不完整类型

我刚刚在使用SFINAE检测模板类型是否默认可构造时观察到libc++的一个奇怪问题。以下是我能够想出的一个最小示例:#include#includetemplatestructDummy;templatestructDummy{};templatestructhas_dummy:std::false_type{};templatestructhas_dummy>::value>>:std::true_type{};intmain(){std::cout{}(){}()它编译并输出预期的行true和false使用libstdc++使用g++或clang++编译时.但是,当我尝试使用li

c++ - 为什么 SFINAE (enable_if) 从类定义内部工作而不是从外部工作

过去几个小时我一直在努力解决一个非常奇怪的问题(在用SFINAE解决了5-6个其他问题之后,因为我是新手)。基本上在下面的代码中,我想让f()为所有可能的模板实例化工作,但是g()仅在N==2:#include#includetemplateclassA{public:voidf(void);voidg(void);};templateinlinevoidA::f(){std::cout::type*=nullptr>inlinevoidA::g(){std::coutobj;obj.f();obj.g();return0;}当我尝试编译它时,我收到一个关于有3个而不是两个模板参数的错

c++ - Clang 与 GCC : Single-colon in Enum usage

以下代码使用g++-std=c++11编译,但不使用clang++-std=c++11。问题在此上下文中,单冒号“运算符”的含义是什么?澄清/编辑:GCC如何解释代码?如何让GCC不编译这段代码?(这里假设Clang遵循C++标准。)是否有针对此的标志?代码用g++-std=c++11main.cpp和clang++-std=c++11main.cpp编译。我正在使用GCC4.8和Clang6.0.0(主干)。#include#includeenumDir{LEFT,RIGHT};intmain(intargc,char**argv){//Interestingline:Noticet

c++ - 转换为 `const Y` 不适用于 clang 上的 `R&&`

下面的代码可以用g++(GCC)4.7.120120721编译,但是最近构建的clang版本3.2(trunk)失败。structY{};structX{operatorconstY()const{returnY();}};voidf(Y&&y){}intmain(){f(X());return0;}将转换运算符更改为operatorY()const就足够了使代码在两个编译器上都能编译。在这种情况下,哪个编译器实际上符合标准?做什么标准实际上是这样说的?要求的逐字错误:bla.cpp:14:5:error:noviableconversionfrom'X'to'Y'f(X());^~~

c++ - Xcode 4.6/Clang 4.2 找不到 C++11 header

我试图在iOS项目中包含一些C++11header,但Xcode/Clang找不到它们。我正在尝试包括,和其他一些人。但它提示说在构建过程中找不到它们(尽管我右键单击并“跳转到定义”加载文件......)。如何让我的项目使用C++11头文件?LexicalorPreprocessorIssue'memory'filenotfoundLexicalorPreprocessorIssue'functional'filenotfound我的项目设置是:C++LanguageDialect=C++11[-std=c++11]C++StandardLibrary=libc++(LLVMC++st