草庐IT

CLANG_ARGS

全部标签

c++ - clang-format 可以为我对齐 #defines block 吗?

我有一个包含这样一些行的源文件;#defineARC_V2_LP_START0x002#defineARC_V2_LP_END0x003#defineARC_V2_STATUS320x00a所有值都很好地对齐。不幸的是,clang-format会这样做;#defineARC_V2_LP_START0x002#defineARC_V2_LP_END0x003#defineARC_V2_STATUS320x00a我找到了AlignConsecutiveDeclarations和AlignConsecutiveAssignments选项,但没有任何东西可以对齐连续的#defines。可以这样

c++ - clang-format 可以为我对齐 #defines block 吗?

我有一个包含这样一些行的源文件;#defineARC_V2_LP_START0x002#defineARC_V2_LP_END0x003#defineARC_V2_STATUS320x00a所有值都很好地对齐。不幸的是,clang-format会这样做;#defineARC_V2_LP_START0x002#defineARC_V2_LP_END0x003#defineARC_V2_STATUS320x00a我找到了AlignConsecutiveDeclarations和AlignConsecutiveAssignments选项,但没有任何东西可以对齐连续的#defines。可以这样

c++ - Clang "couldn' t 推断模板参数“而 gcc/g++ 可以。哪个是正确的?

我一直在尝试用clang编译一个项目(使用gcc/g++很好),并且编译停留在模板调用上。我尝试创建显示相同错误消息的最简单的类似代码。这里是:#include#include#includeusingnamespacestd;intA(doublein){return1;}intA(intin){return1;}templateMtest(Tinput,M(fun)(T)){returnfun(input);}intmain(intargc,constchar*argv[]){cout来自clang的错误(当然出现两次):error:nomatchingfunctionforcal

c++ - Clang "couldn' t 推断模板参数“而 gcc/g++ 可以。哪个是正确的?

我一直在尝试用clang编译一个项目(使用gcc/g++很好),并且编译停留在模板调用上。我尝试创建显示相同错误消息的最简单的类似代码。这里是:#include#include#includeusingnamespacestd;intA(doublein){return1;}intA(intin){return1;}templateMtest(Tinput,M(fun)(T)){returnfun(input);}intmain(intargc,constchar*argv[]){cout来自clang的错误(当然出现两次):error:nomatchingfunctionforcal

c++ - 到 std::function<R(ARGS...)> 的可变参数模板转换适用于 GCC 而不是 MSVC2013,为什么?

如果这是重复的,我很抱歉。但我在搜索中找不到任何内容。我可以使用c++11/c++14的任何最新功能。如有必要,我可以升级到VS2015。我正在尝试编写一个类,该类在分配时将自动转换为具有特定签名的std::function。我有适用于GCC的代码,但在MSVC2013上失败了。该代码是重新创建错误的片段。WTFMSVC?!我也知道这是有风险的代码,自动转换函数指针等,但它是用于插件库的私有(private)实现,我只想定义一次函数签名。如果有另一种方法可以编写代码,在main()中完成相同的功能并同时在两者上工作,我会全力以赴。GCCc++11工作正常-Demo#include#in

c++ - 到 std::function<R(ARGS...)> 的可变参数模板转换适用于 GCC 而不是 MSVC2013,为什么?

如果这是重复的,我很抱歉。但我在搜索中找不到任何内容。我可以使用c++11/c++14的任何最新功能。如有必要,我可以升级到VS2015。我正在尝试编写一个类,该类在分配时将自动转换为具有特定签名的std::function。我有适用于GCC的代码,但在MSVC2013上失败了。该代码是重新创建错误的片段。WTFMSVC?!我也知道这是有风险的代码,自动转换函数指针等,但它是用于插件库的私有(private)实现,我只想定义一次函数签名。如果有另一种方法可以编写代码,在main()中完成相同的功能并同时在两者上工作,我会全力以赴。GCCc++11工作正常-Demo#include#in

c++ - 可变参数模板作为模板参数 : deduction works with GCC but not with Clang

在使用GCC4.7.2和Clang3.1编译一些C++11代码时,我遇到了一个问题,即Clang无法推断出GCC成功的模板参数。在更抽象的形式中,代码如下所示:src/test.cc:structElement{};templatestructFirstContainer{};templatestructSecondContainer{};templateclassContainer>voidprocessOrdinary(Container/*elements*/){}templateclassContainer>voidprocessOrdinary(Container/*elem

c++ - 可变参数模板作为模板参数 : deduction works with GCC but not with Clang

在使用GCC4.7.2和Clang3.1编译一些C++11代码时,我遇到了一个问题,即Clang无法推断出GCC成功的模板参数。在更抽象的形式中,代码如下所示:src/test.cc:structElement{};templatestructFirstContainer{};templatestructSecondContainer{};templateclassContainer>voidprocessOrdinary(Container/*elements*/){}templateclassContainer>voidprocessOrdinary(Container/*elem

c++ - 如何制作干净的clang前端?

我正在开发一个C++源代码分析器项目,看来clang是一个不错的候选者解析工作。问题是clang严重依赖基础设施“llvm”项目,如何配置它以获得干净的前端,而无需任何面向具体机器的后端?就像LCC一样,它们为专注于解析器部分的人提供了一个“空”后端。任何建议表示赞赏。 最佳答案 我最近在Windows上做了这个。从here下载clang和llvm源代码.安装cmake和Python(与文档相反,您确实需要Python来构建clang;至少,如果cmake找不到Python运行时,它会放弃)。您还需要VS2008或VS2010。有一

c++ - 如何制作干净的clang前端?

我正在开发一个C++源代码分析器项目,看来clang是一个不错的候选者解析工作。问题是clang严重依赖基础设施“llvm”项目,如何配置它以获得干净的前端,而无需任何面向具体机器的后端?就像LCC一样,它们为专注于解析器部分的人提供了一个“空”后端。任何建议表示赞赏。 最佳答案 我最近在Windows上做了这个。从here下载clang和llvm源代码.安装cmake和Python(与文档相反,您确实需要Python来构建clang;至少,如果cmake找不到Python运行时,它会放弃)。您还需要VS2008或VS2010。有一