草庐IT

llvm-gcc

全部标签

c++ - 有没有办法在 xcode 上使用 c++0x?我想使用 gcc 4.4 或更高版本

我想使用gcc4.4或更高版本进行iphone开发。有人知道怎么做吗? 最佳答案 不,你不知道。相信我,你不会。Apple仍然使用gcc4.2.1,因为4.2.2及更高版本使用GPLv3,这意味着他们必须放弃对其平台的控制(这对iphonesdk来说是个大问题)。所以他们不升级。不幸的是,由于自定义补丁、ABI更改等原因,您也不能完全放入替换gcc。对不起。 关于c++-有没有办法在xcode上使用c++0x?我想使用gcc4.4或更高版本,我们在StackOverflow上找到一个类似

c++ - 在 VS2008 和 GCC 中编译 static const int = X 的最佳代码

我在编写需要在VisualStudio2008和GCC4.6中编译(并且还需要编译回GCC3.4)的C++代码时遇到了一个问题:staticconstint类成员。Otherquestionshavecoveredstaticconstint类成员所需的规则。特别是,标准和GCC要求变量在一个且仅一个目标文件中有定义。但是,VisualStudio在编译包含.cpp文件中的定义的代码(在Debug模式下)时会产生LNK2005错误。我试图在其中做出决定的一些方法是:使用.cpp文件中的值而不是header对其进行初始化。使用预处理器删除MSVC的定义。将其替换为枚举。用宏替换它。最后两

c++ - 有没有办法不警告 gcc 中的开关缺少 "COUNT"枚举常量?

如果带有枚举类型参数的开关缺少一些常量并且没有默认分支,则gcc-Wswitch选项会导致类似的警告warning:enumerationvalue'WHATEVER'nothandledinswitch然而,我们的许多开关是这样的:enumfoo{FOO_ONE,FOO_TWO,FOO_COUNT};其中FOO_COUNT从不作为值出现,但用于了解已定义并可能出现在变量中的值的数量。因为我们正在使用枚举值索引一个数组或对其进行位打包,并且需要检查它是否适合或其他什么。因此,处理所有值的枚举应该不包含这个常量。有没有办法保留该警告,但避免使用这种特殊值?即switch(foo){cas

c++ - 如何在 LLVM 模块中插入函数

我正在编写一个LLVMpass,我通过调用llvm::CloneFunction克隆了一些函数。现在我还想在模块中插入这些函数。我该怎么做? 最佳答案 使用Function::Create或其他方式创建一个新函数。Function的构造函数接受要插入新函数的模块。使用CloneFunctionInto将函数克隆到新函数中,或者只是复制您需要的BB。 关于c++-如何在LLVM模块中插入函数,我们在StackOverflow上找到一个类似的问题: https:/

C++ GCC 为什么这段 sfinae 代码可以用 GCC 4.7 编译,但不能用 4.8 编译?

我喜欢在模板类中使用本地类来执行类似“staticif”的构造。但是我遇到了gcc4.8不想编译我的代码的问题。但是4.7可以。这个例子:#include#include#includeusingnamespacestd;structA{voidprintA(){coutstructTest{voidprint(){structIfA{constexprIfA(T&value):value(value){}T&value;voidprint(){value.printA();}};structIfB{constexprIfB(T&value):value(value){}T&value

c++ - 带有 -isysroot 的 gcc 创建包含以等号 "="开头的包含路径并且编译失败

我正在使用适用于arm(arm-none-linux-gnueabi)的CodeSourcery工具链进行交叉编译。我使用-isysroot指向rootfs文件夹下的/usr/include文件夹,但在编译时遇到了麻烦。我已验证包含文件夹可访问。下面是gcc调用和输出。一些输出已被删除,因为我认为它不相关。预处理器提供了一个包含路径,除了以“=”开头的字符外,该路径是正确的,并指示该路径不存在。然后找不到头文件。我怎样才能让它工作?willem@jacta:~/Projects/button/Debug$arm-none-linux-gnueabi-gcc-isysroot=/home

c++ - 如何在 LLVM 中声明一个函数并在以后定义它

如何在LLVM中声明一个函数(具有特定签名)并创建对它的调用,例如llvm::Value*return=m_builder.CreateCall(function,arguments);但稍后定义函数体(必须是InlineAsm函数)?稍后我将按以下方式访问模块中的函数for(llvm::Module::iteratorit=mod->begin(),end=mod->end();it!=end;++it){if(needsImplementation(it)){llvm::InlineAsm*inlineCall=...it.body=inlineCall//Thisdoesn'te

c++ - 使用 LLVM pass 添加内在函数

我已经使用LLVM传递向输入代码添加了一个内在函数。我能够看到内部调用,但我无法弄清楚如何将代码编译到我的目标架构(x86_64)。我正在运行以下命令:clang++$(llvm-config--ldflags--libsall)ff.s-ofoo但是链接器提示undefinedreference:/tmp/ff-2ada42.o:Infunction`fact(unsignedint)':/home/rubens/Desktop/ff.cpp:9:undefinedreferenceto`llvm.x86.sse3.mwait.i32.i32'/tmp/ff-2ada42.o:Inf

c++ - 无法使用 clang 编译代码,但可以使用 gcc

我正在尝试修复一个开源C++项目中的一些错误,而原作者目前忙于他的学术生活而无法提供帮助。通过macports安装的gcc-4.9代码编译得很好。我一直在命令行上使用lldb进行调试。但是,如果可能的话,我希望使用clang编译代码,因为这样我可以同时使用Xcode和lldb并使错误更容易隔离。当我尝试使用clang编译代码时,出现以下错误:Infileincludedfrom./src/include/hash.h:25:./src/include/hash_stream.h:18:11:error:calltofunction'operator>>'thatisneithervis

c++ - LLVM/Clang 是否支持弱链接的 'weak' 属性?

简而言之:LLVM/Clang是否支持“弱”属性?我正在学习一些Arduino库源代码(更详细的是HardwareSerial.cpp),我发现了一些以前从未使用过的有趣属性weak:#ifdefined(HAVE_HWSERIAL0)voidserialEvent()__attribute__((weak));boolSerial0_available()__attribute__((weak));#endif我发现它很有趣,而且我读到如果未定义,链接器应将其设置为NULL。但是,在我使用Clang进行的测试中,我无法使用它。文件lib.cpp:#include"lib.h"#inc