forked from OSchip/llvm-project
clang-format: [Proto] Don't treat "operator" as keyword.
Before: optional string operator= 1; After: optional string operator = 1; llvm-svn: 240624
This commit is contained in:
parent
8677baf024
commit
23d3bcfe5b
|
@ -1876,7 +1876,12 @@ bool TokenAnnotator::spaceRequiredBetween(const AnnotatedLine &Line,
|
|||
bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,
|
||||
const FormatToken &Right) {
|
||||
const FormatToken &Left = *Right.Previous;
|
||||
if (Style.Language == FormatStyle::LK_Proto) {
|
||||
if (Right.Tok.getIdentifierInfo() && Left.Tok.getIdentifierInfo())
|
||||
return true; // Never ever merge two identifiers.
|
||||
if (Style.Language == FormatStyle::LK_Cpp) {
|
||||
if (Left.is(tok::kw_operator))
|
||||
return Right.is(tok::coloncolon);
|
||||
} else if (Style.Language == FormatStyle::LK_Proto) {
|
||||
if (Right.is(tok::period) &&
|
||||
Left.isOneOf(Keywords.kw_optional, Keywords.kw_required,
|
||||
Keywords.kw_repeated))
|
||||
|
@ -1913,8 +1918,6 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,
|
|||
Right.is(TT_TemplateOpener))
|
||||
return true;
|
||||
}
|
||||
if (Right.Tok.getIdentifierInfo() && Left.Tok.getIdentifierInfo())
|
||||
return true; // Never ever merge two identifiers.
|
||||
if (Left.is(TT_ImplicitStringLiteral))
|
||||
return Right.WhitespaceRange.getBegin() != Right.WhitespaceRange.getEnd();
|
||||
if (Line.Type == LT_ObjCMethodDecl) {
|
||||
|
@ -1937,8 +1940,6 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,
|
|||
return false;
|
||||
if (Right.isOneOf(TT_CtorInitializerColon, TT_ObjCBlockLParen))
|
||||
return true;
|
||||
if (Left.is(tok::kw_operator))
|
||||
return Right.is(tok::coloncolon);
|
||||
if (Right.is(TT_OverloadedOperatorLParen))
|
||||
return false;
|
||||
if (Right.is(tok::colon)) {
|
||||
|
|
|
@ -63,6 +63,10 @@ TEST_F(FormatTestProto, FormatsMessages) {
|
|||
"}");
|
||||
}
|
||||
|
||||
TEST_F(FormatTestProto, KeywordsInOtherLanguages) {
|
||||
verifyFormat("optional string operator = 1;");
|
||||
}
|
||||
|
||||
TEST_F(FormatTestProto, FormatsEnums) {
|
||||
verifyFormat("enum Type {\n"
|
||||
" UNKNOWN = 0;\n"
|
||||
|
|
Loading…
Reference in New Issue