aboutsummaryrefslogtreecommitdiff
path: root/lib/Format/Format.cpp
diff options
context:
space:
mode:
authorNico Weber <nicolasweber@gmx.de>2013-01-10 21:30:42 +0000
committerNico Weber <nicolasweber@gmx.de>2013-01-10 21:30:42 +0000
commit7084823f8ec4367019940b26245e01684b62c7e1 (patch)
tree77181246daae0f425cc9b16e953dee250816c587 /lib/Format/Format.cpp
parentb1fc673783dd0215a1426b2c411779cd05a16a07 (diff)
Formatter: No spaces around '=' in @property lines.
Before: @property(assign, getter = isEditable) BOOL editable; Now: @property(assign, getter=isEditable) BOOL editable; It'd be nice if some Apple person could let me know if spaces are preferred around '=' in @synthesize lines (see FIXME in the test). git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@172110 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Format/Format.cpp')
-rw-r--r--lib/Format/Format.cpp13
1 files changed, 12 insertions, 1 deletions
diff --git a/lib/Format/Format.cpp b/lib/Format/Format.cpp
index d721536c76..f84d3c5bc7 100644
--- a/lib/Format/Format.cpp
+++ b/lib/Format/Format.cpp
@@ -39,6 +39,7 @@ enum TokenType {
TT_ObjCBlockLParen,
TT_ObjCDecl,
TT_ObjCMethodSpecifier,
+ TT_ObjCProperty,
TT_OverloadedOperator,
TT_PointerOrReference,
TT_PureVirtualSpecifier,
@@ -55,7 +56,8 @@ enum LineType {
LT_PreprocessorDirective,
LT_VirtualFunctionDecl,
LT_ObjCDecl, // An @interface, @implementation, or @protocol line.
- LT_ObjCMethodDecl
+ LT_ObjCMethodDecl,
+ LT_ObjCProperty // An @property line.
};
class AnnotatedToken {
@@ -841,6 +843,8 @@ public:
CurrentLineType = LT_ObjCMethodDecl;
else if (RootToken.Type == TT_ObjCDecl)
CurrentLineType = LT_ObjCDecl;
+ else if (RootToken.Type == TT_ObjCProperty)
+ CurrentLineType = LT_ObjCProperty;
if (!RootToken.Children.empty())
calculateExtraInformation(RootToken.Children[0]);
@@ -891,6 +895,10 @@ private:
case tok::objc_implementation:
case tok::objc_protocol:
Current.Type = TT_ObjCDecl;
+ break;
+ case tok::objc_property:
+ Current.Type = TT_ObjCProperty;
+ break;
default:
break;
}
@@ -1044,6 +1052,9 @@ private:
// Don't space between ':' and '('
return false;
}
+ if (CurrentLineType == LT_ObjCProperty &&
+ (Tok.is(tok::equal) || Tok.Parent->is(tok::equal)))
+ return false;
if (Tok.Type == TT_CtorInitializerColon || Tok.Type == TT_ObjCBlockLParen)
return true;