diff options
| author | Martin Probst <martin@probst.io> | 2016-06-23 19:52:32 +0000 | 
|---|---|---|
| committer | Martin Probst <martin@probst.io> | 2016-06-23 19:52:32 +0000 | 
| commit | 1b7f98042de25731eae42ff220bf423efb5b669f (patch) | |
| tree | eca6339b03b943c0fec39f3a760a50d37ecf6f3f /clang | |
| parent | b130fe7d316efb01870e99912d58ea7c5a11a329 (diff) | |
| download | bcm5719-llvm-1b7f98042de25731eae42ff220bf423efb5b669f.tar.gz bcm5719-llvm-1b7f98042de25731eae42ff220bf423efb5b669f.zip | |
clang-format: [JS] recognize more type locations.
Summary: Includes parenthesized type expressions and type aliases.
Reviewers: djasper
Subscribers: klimek, cfe-commits
Differential Revision: http://reviews.llvm.org/D21597
llvm-svn: 273603
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Format/FormatToken.h | 2 | ||||
| -rw-r--r-- | clang/lib/Format/TokenAnnotator.cpp | 11 | ||||
| -rw-r--r-- | clang/unittests/Format/FormatTestJS.cpp | 6 | 
3 files changed, 19 insertions, 0 deletions
| diff --git a/clang/lib/Format/FormatToken.h b/clang/lib/Format/FormatToken.h index 60b97f59874..43b16251362 100644 --- a/clang/lib/Format/FormatToken.h +++ b/clang/lib/Format/FormatToken.h @@ -586,6 +586,7 @@ struct AdditionalKeywords {      kw_import = &IdentTable.get("import");      kw_is = &IdentTable.get("is");      kw_let = &IdentTable.get("let"); +    kw_type = &IdentTable.get("type");      kw_var = &IdentTable.get("var");      kw_yield = &IdentTable.get("yield"); @@ -637,6 +638,7 @@ struct AdditionalKeywords {    IdentifierInfo *kw_import;    IdentifierInfo *kw_is;    IdentifierInfo *kw_let; +  IdentifierInfo *kw_type;    IdentifierInfo *kw_var;    IdentifierInfo *kw_yield; diff --git a/clang/lib/Format/TokenAnnotator.cpp b/clang/lib/Format/TokenAnnotator.cpp index 664be6fb40e..5302f13340f 100644 --- a/clang/lib/Format/TokenAnnotator.cpp +++ b/clang/lib/Format/TokenAnnotator.cpp @@ -134,6 +134,10 @@ private:      if (Left->is(TT_OverloadedOperatorLParen)) {        Contexts.back().IsExpression = false; +    } else if (Style.Language == FormatStyle::LK_JavaScript && +               Line.startsWith(Keywords.kw_type, tok::identifier)) { +      // type X = (...); +      Contexts.back().IsExpression = false;      } else if (Left->Previous &&          (Left->Previous->isOneOf(tok::kw_static_assert, tok::kw_decltype,                                   tok::kw_if, tok::kw_while, tok::l_paren, @@ -147,6 +151,10 @@ private:                                                Keywords.kw_function)))) {        // function(...) or function f(...)        Contexts.back().IsExpression = false; +    } else if (Style.Language == FormatStyle::LK_JavaScript && Left->Previous && +               Left->Previous->is(TT_JsTypeColon)) { +      // let x: (SomeType); +      Contexts.back().IsExpression = false;      } else if (Left->Previous && Left->Previous->is(tok::r_square) &&                 Left->Previous->MatchingParen &&                 Left->Previous->MatchingParen->is(TT_LambdaLSquare)) { @@ -913,6 +921,9 @@ private:    void modifyContext(const FormatToken &Current) {      if (Current.getPrecedence() == prec::Assignment &&          !Line.First->isOneOf(tok::kw_template, tok::kw_using, tok::kw_return) && +        // Type aliases use `type X = ...;` in TypeScript. +        !(Style.Language == FormatStyle::LK_JavaScript && +          Line.startsWith(Keywords.kw_type, tok::identifier)) &&          (!Current.Previous || Current.Previous->isNot(tok::kw_operator))) {        Contexts.back().IsExpression = true;        if (!Line.startsWith(TT_UnaryOperator)) { diff --git a/clang/unittests/Format/FormatTestJS.cpp b/clang/unittests/Format/FormatTestJS.cpp index 4feb55dae24..bd5a505d59e 100644 --- a/clang/unittests/Format/FormatTestJS.cpp +++ b/clang/unittests/Format/FormatTestJS.cpp @@ -914,6 +914,12 @@ TEST_F(FormatTestJS, UnionIntersectionTypes) {    verifyFormat("function(x: A|B = A | B): C&D {}");    verifyFormat("function x(path: number|string) {}");    verifyFormat("function x(): string|number {}"); +  verifyFormat("type Foo = Bar|Baz;"); +  verifyFormat("type Foo = Bar<X>|Baz;"); +  verifyFormat("type Foo = (Bar<X>|Baz);"); +  verifyFormat("let x: Bar|Baz;"); +  verifyFormat("let x: Bar<X>|Baz;"); +  verifyFormat("let x: (Foo|Bar)[];");  }  TEST_F(FormatTestJS, ClassDeclarations) { | 

