aboutsummaryrefslogtreecommitdiff
path: root/lib/Format/Format.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'lib/Format/Format.cpp')
-rw-r--r--lib/Format/Format.cpp21
1 files changed, 19 insertions, 2 deletions
diff --git a/lib/Format/Format.cpp b/lib/Format/Format.cpp
index ad85a8ecf2..8fb6932db9 100644
--- a/lib/Format/Format.cpp
+++ b/lib/Format/Format.cpp
@@ -553,9 +553,19 @@ public:
Annotations[CurrentIndex].Type = TokenAnnotation::TT_BinaryOperator;
break;
case tok::kw_operator:
- if (!Tokens[Index].Tok.is(tok::l_paren))
+ if (Tokens[Index].Tok.is(tok::l_paren)) {
Annotations[Index].Type = TokenAnnotation::TT_OverloadedOperator;
- next();
+ next();
+ if (Index < Tokens.size() && Tokens[Index].Tok.is(tok::r_paren)) {
+ Annotations[Index].Type = TokenAnnotation::TT_OverloadedOperator;
+ next();
+ }
+ } else {
+ while (Index < Tokens.size() && !Tokens[Index].Tok.is(tok::l_paren)) {
+ Annotations[Index].Type = TokenAnnotation::TT_OverloadedOperator;
+ next();
+ }
+ }
break;
case tok::question:
parseConditional();
@@ -633,6 +643,13 @@ public:
if (Annotation.Type == TokenAnnotation::TT_CtorInitializerColon) {
Annotation.MustBreakBefore = true;
Annotation.SpaceRequiredBefore = true;
+ } else if (Annotation.Type == TokenAnnotation::TT_OverloadedOperator) {
+ Annotation.SpaceRequiredBefore =
+ Line.Tokens[i].Tok.is(tok::identifier) || Line.Tokens[i].Tok.is(
+ tok::kw_new) || Line.Tokens[i].Tok.is(tok::kw_delete);
+ } else if (
+ Annotations[i - 1].Type == TokenAnnotation::TT_OverloadedOperator) {
+ Annotation.SpaceRequiredBefore = false;
} else if (IsObjCMethodDecl && Line.Tokens[i].Tok.is(tok::identifier) &&
(i != e - 1) && Line.Tokens[i + 1].Tok.is(tok::colon) &&
Line.Tokens[i - 1].Tok.is(tok::identifier)) {