9

clang-format 有 2 个选项,称为BinPackParametersBinPackArguments。它们似乎控制函数声明和函数调用的缩进方式。

BinPackParameters似乎为函数声明提供了预期的结果,但BinPackArguments似乎不像人们对函数调用所期望的那样工作。

这是一个简单的测试文件:

#include <stdbool.h>

void function_with_a_huge_name_that_should_just_not_be(unsigned int a, char *b, unsigned int c, unsigned int d, unsigned int e)
{
    return;
}

int main()
{
    function_with_a_huge_name_that_should_just_not_be(13, "bb", 1234234, 4324324, 2355345);
}

这就是它的格式:

#include <stdbool.h>

void function_with_a_huge_name_that_should_just_not_be(unsigned int a,
    char *b,
    unsigned int c,
    unsigned int d,
    unsigned int e)
{
    return;
}

int main()
{
    function_with_a_huge_name_that_should_just_not_be(
        13, "bb", 1234234, 4324324, 2355345);
}

我的.clang-format文件如下:

---
AccessModifierOffset: -2
AlignAfterOpenBracket: false
AlignEscapedNewlinesLeft: false
AlignOperands:   true
AlignTrailingComments: true
AllowAllParametersOfDeclarationOnNextLine: false
AllowShortBlocksOnASingleLine: false
AllowShortCaseLabelsOnASingleLine: false
AllowShortIfStatementsOnASingleLine: false
AllowShortLoopsOnASingleLine: false
AllowShortFunctionsOnASingleLine: Inline
AlwaysBreakAfterDefinitionReturnType: false
AlwaysBreakBeforeMultilineStrings: false
AlwaysBreakTemplateDeclarations: false
BinPackParameters: false
BinPackArguments: false
BreakBeforeBinaryOperators: None
BreakBeforeBraces: Linux
BreakBeforeTernaryOperators: true
BreakConstructorInitializersBeforeComma: true
ColumnLimit:     80
CommentPragmas:  '^ IWYU pragma:'
ConstructorInitializerAllOnOneLineOrOnePerLine: true
ConstructorInitializerIndentWidth: 4
ContinuationIndentWidth: 4
Cpp11BracedListStyle: false
DerivePointerAlignment: false
IndentCaseLabels: false
IndentWidth:     4
IndentWrappedFunctionNames: false
IndentFunctionDeclarationAfterType: false
KeepEmptyLinesAtTheStartOfBlocks: false
Language:        Cpp
MaxEmptyLinesToKeep: 2
NamespaceIndentation: None
ObjCBlockIndentWidth: 2
ObjCSpaceAfterProperty: false
ObjCSpaceBeforeProtocolList: true
PenaltyBreakBeforeFirstCallParameter: 19
PenaltyBreakComment: 300
PenaltyBreakString: 1000
PenaltyBreakFirstLessLess: 120
PenaltyExcessCharacter: 1000000
PenaltyReturnTypeOnItsOwnLine: 60
PointerAlignment: Right
SpaceAfterCStyleCast: false
SpaceBeforeAssignmentOperators: true
SpaceBeforeParens: ControlStatements
SpaceInEmptyParentheses: false
SpacesBeforeTrailingComments: 2
SpacesInAngles:  false
SpacesInCStyleCastParentheses: false
SpacesInContainerLiterals: false
SpacesInParentheses: false
SpacesInSquareBrackets: false
Standard:        Auto
TabWidth:        4
UseTab:          Never

我的 clang 格式版本是:3.6.0 (tags/RELEASE_360/final)

如果两者都BinPackParametersBinPackArguments假,我会期望函数调用的缩进与函数声明的缩进相同。

知道我做错了什么吗?

4

3 回答 3

3

我不认为你做错了什么。发生的情况是 clang-format 意识到您调用函数的行长于列限制(设置中的 80 个字符)。您AlignAfterOpenBracket设置为 false,因此 clang-format 将参数放在新行上(请注意,AlignAfterOpenBracket在更高版本的 clang-format 中获得了更多可能性)。

您已将这两个设置都BinPack...设置为 false,但是还有一个附加设置可以控制函数声明与函数调用AllowAllParametersOfDeclarationOnNextLine(在您的示例中设置为 false)。对于函数声明,如果所有参数与函数名不在同一行,这将导致所有参数位于不同的行。对于函数调用,没有相应的设置。

在你的情况下,你给函数的参数放在函数名之后的下一行。第二行的长度 < 80,因此 clang-format 不再对其进行任何处理。如果参数行比您的列限制长,clang-format 会将它们放在单独的行上。

所以答案是,从 3.9 版开始,没有办法配置 clang-format 以将每个参数放在单独的行上,如果它们适合一行的话。

于 2016-01-17T19:27:49.993 回答
1

尝试设置ColumnLimit为 0。看起来此选项“覆盖”或具有更高的优先级BinPackParametersBinPackArguments选项。

于 2015-05-15T22:03:23.787 回答
0

BinPack* 选项设置为 false 将强制参数/参数要么全部在一行上,要么每个在单独的行上。两种情况都允许,但不能混合,例如。不允许在一行中使用两个参数,而在另一行中使用其余参数是不允许的。

clang-format 似乎为每种情况分别选择 all-on-one-line 与 each-on-separate-line 格式。

于 2015-12-16T16:19:24.793 回答