]> granicus.if.org Git - clang/commitdiff
clang-format: [JS] Support ES6 exports of array literals.
authorDaniel Jasper <djasper@google.com>
Mon, 4 Jan 2016 15:51:56 +0000 (15:51 +0000)
committerDaniel Jasper <djasper@google.com>
Mon, 4 Jan 2016 15:51:56 +0000 (15:51 +0000)
Before:
  export default[aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa,
 bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb];
  export default[];

After:
  export default [
    aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa,
    bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb
  ];
  export default [];

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

lib/Format/TokenAnnotator.cpp
unittests/Format/FormatTestJS.cpp

index da0fdb91704571189b11b272ffad948fa081970f..635092dec3904ce813830370417e6c55f49df8c8 100644 (file)
@@ -289,7 +289,9 @@ private:
                  (Parent &&
                   Parent->isOneOf(TT_BinaryOperator, tok::at, tok::comma,
                                   tok::l_paren, tok::l_square, tok::question,
-                                  tok::colon, tok::kw_return))) {
+                                  tok::colon, tok::kw_return,
+                                  // Should only be relevant to JavaScript:
+                                  tok::kw_default))) {
         Left->Type = TT_ArrayInitializerLSquare;
       } else {
         BindingIncrease = 10;
@@ -1999,6 +2001,8 @@ bool TokenAnnotator::spaceRequiredBefore(const AnnotatedLine &Line,
     if (Left.isOneOf(Keywords.kw_let, Keywords.kw_var, TT_JsFatArrow,
                      Keywords.kw_in))
       return true;
+    if (Left.is(tok::kw_default) && Right.is(TT_ArrayInitializerLSquare))
+      return true; // For "export default [];".
     if (Left.is(Keywords.kw_is) && Right.is(tok::l_brace))
       return true;
     if (Right.isOneOf(TT_JsTypeColon, TT_JsTypeOptionalQuestion))
index d42eed6048f9eff1b311dc7422a783934a3b0118..0013e83ddd62e1ff0e18411ef830bb0daaa46151 100644 (file)
@@ -865,6 +865,11 @@ TEST_F(FormatTestJS, Modules) {
                "  // adsdasd\n"
                "  BAZ\n"
                "}");
+  verifyFormat("export default [\n"
+               "  aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa,\n"
+               "  bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb\n"
+               "];");
+  verifyFormat("export default [];");
 }
 
 TEST_F(FormatTestJS, TemplateStrings) {