clang-format: Fix unary operator recognition.
authorDaniel Jasper <djasper@google.com>
Mon, 28 Jul 2014 12:08:16 +0000 (12:08 +0000)
committerDaniel Jasper <djasper@google.com>
Mon, 28 Jul 2014 12:08:16 +0000 (12:08 +0000)
Before:
  int x = ~ * p;

After:
  int x = ~*p;

llvm-svn: 214070

clang/lib/Format/TokenAnnotator.cpp
clang/unittests/Format/FormatTest.cpp

index 5f8ce79..1ef9d1f 100644 (file)
@@ -755,7 +755,7 @@ private:
           Contexts.back().CaretFound = true;
       } else if (Current.isOneOf(tok::minusminus, tok::plusplus)) {
         Current.Type = determineIncrementUsage(Current);
-      } else if (Current.is(tok::exclaim)) {
+      } else if (Current.isOneOf(tok::exclaim, tok::tilde)) {
         Current.Type = TT_UnaryOperator;
       } else if (Current.is(tok::question)) {
         Current.Type = TT_ConditionalExpr;
index 1fdbe4d..6711447 100644 (file)
@@ -4766,6 +4766,7 @@ TEST_F(FormatTest, UnderstandsUsesOfStarAndAmp) {
   verifyIndependentOfContext("typedef void (*f)(int *a);");
   verifyIndependentOfContext("int i{a * b};");
   verifyIndependentOfContext("aaa && aaa->f();");
+  verifyIndependentOfContext("int x = ~*p;");
 
   verifyIndependentOfContext("InvalidRegions[*R] = 0;");