]> granicus.if.org Git - clang/commitdiff
clang-format: Fix corner case in OpenMP pragma formatting.
authorDaniel Jasper <djasper@google.com>
Wed, 7 Aug 2013 16:29:23 +0000 (16:29 +0000)
committerDaniel Jasper <djasper@google.com>
Wed, 7 Aug 2013 16:29:23 +0000 (16:29 +0000)
Before:
  #pragma omp reduction( | : var)
After:
  #pragma omp reduction(| : var)

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@187892 91177308-0d34-0410-b5e6-96231b3b80d8

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

index 67091b506818db151907c5282ecc0b76d8b840d6..4af23b01c2f8976a41008af03e77d544117738fa 100644 (file)
@@ -1236,7 +1236,8 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,
   if (Tok.isOneOf(tok::arrowstar, tok::periodstar) ||
       Tok.Previous->isOneOf(tok::arrowstar, tok::periodstar))
     return false;
-  if (Tok.Type == TT_BinaryOperator || Tok.Previous->Type == TT_BinaryOperator)
+  if ((Tok.Type == TT_BinaryOperator && !Tok.Previous->is(tok::l_paren)) ||
+      Tok.Previous->Type == TT_BinaryOperator)
     return true;
   if (Tok.Previous->Type == TT_TemplateCloser && Tok.is(tok::l_paren))
     return false;
index fe10de98fecc8b0d97cb08665ca51a70f7c44925..2b1b94c4c61cf1feb2bcd1693f0b164097267d1f 100644 (file)
@@ -5532,6 +5532,11 @@ TEST_F(FormatTest, AllmanBraceBreaking) {
                BreakBeforeBrace);
 }
 
+TEST_F(FormatTest, UnderstandsPragmas) {
+  verifyFormat("#pragma omp reduction(| : var)");
+  verifyFormat("#pragma omp reduction(+ : var)");
+}
+
 bool allStylesEqual(ArrayRef<FormatStyle> Styles) {
   for (size_t i = 1; i < Styles.size(); ++i)
     if (!(Styles[0] == Styles[i]))