diff options
author | Daniel Jasper <djasper@google.com> | 2016-01-04 15:51:56 +0000 |
---|---|---|
committer | Daniel Jasper <djasper@google.com> | 2016-01-04 15:51:56 +0000 |
commit | b14f6675dadcf8c85fa188d01270be89cc1457ec (patch) | |
tree | 9ec159fa7ec5d8cdcfa2faa0cb7024f8eb5e7ed2 | |
parent | e705aadd67ea76f539a27914098ec90a34def478 (diff) | |
download | bcm5719-llvm-b14f6675dadcf8c85fa188d01270be89cc1457ec.tar.gz bcm5719-llvm-b14f6675dadcf8c85fa188d01270be89cc1457ec.zip |
clang-format: [JS] Support ES6 exports of array literals.
Before:
export default[aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa,
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb];
export default[];
After:
export default [
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa,
bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb
];
export default [];
llvm-svn: 256758
-rw-r--r-- | clang/lib/Format/TokenAnnotator.cpp | 6 | ||||
-rw-r--r-- | clang/unittests/Format/FormatTestJS.cpp | 5 |
2 files changed, 10 insertions, 1 deletions
diff --git a/clang/lib/Format/TokenAnnotator.cpp b/clang/lib/Format/TokenAnnotator.cpp index da0fdb91704..635092dec39 100644 --- a/clang/lib/Format/TokenAnnotator.cpp +++ b/clang/lib/Format/TokenAnnotator.cpp @@ -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)) diff --git a/clang/unittests/Format/FormatTestJS.cpp b/clang/unittests/Format/FormatTestJS.cpp index d42eed6048f..0013e83ddd6 100644 --- a/clang/unittests/Format/FormatTestJS.cpp +++ b/clang/unittests/Format/FormatTestJS.cpp @@ -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) { |