[cfe-commits] r172349 - in /cfe/trunk: lib/Format/Format.cpp unittests/Format/FormatTest.cpp

Richard Smith richard at metafoo.co.uk
Sun Jan 13 16:18:26 PST 2013


On Sun, Jan 13, 2013 at 12:01 AM, Daniel Jasper <djasper at google.com> wrote:

> Author: djasper
> Date: Sun Jan 13 02:01:36 2013
> New Revision: 172349
>
> URL: http://llvm.org/viewvc/llvm-project?rev=172349&view=rev
> Log:
> Improve identification of c-style casts.
>
> A ")" before any of "=", "{" or ";" won't be a cast. This fixes issues
> with the formatting of unnamed parameters.
>

What about C99 compound literals? e.g. (struct S){1, 2, 3}


> Before: void f(int *){}
> After:  void f(int *) {}
>
> Modified:
>     cfe/trunk/lib/Format/Format.cpp
>     cfe/trunk/unittests/Format/FormatTest.cpp
>
> Modified: cfe/trunk/lib/Format/Format.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Format/Format.cpp?rev=172349&r1=172348&r2=172349&view=diff
>
> ==============================================================================
> --- cfe/trunk/lib/Format/Format.cpp (original)
> +++ cfe/trunk/lib/Format/Format.cpp Sun Jan 13 02:01:36 2013
> @@ -976,7 +976,11 @@
>            Current.Type = TT_BlockComment;
>        } else if (Current.is(tok::r_paren) &&
>                   (Current.Parent->Type == TT_PointerOrReference ||
> -                  Current.Parent->Type == TT_TemplateCloser)) {
> +                  Current.Parent->Type == TT_TemplateCloser) &&
> +                 (Current.Children.empty() ||
> +                  (Current.Children[0].isNot(tok::equal) &&
> +                   Current.Children[0].isNot(tok::semi) &&
> +                   Current.Children[0].isNot(tok::l_brace)))) {
>          // FIXME: We need to get smarter and understand more cases of
> casts.
>          Current.Type = TT_CastRParen;
>        } else if (Current.is(tok::at) && Current.Children.size()) {
>
> Modified: cfe/trunk/unittests/Format/FormatTest.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/Format/FormatTest.cpp?rev=172349&r1=172348&r2=172349&view=diff
>
> ==============================================================================
> --- cfe/trunk/unittests/Format/FormatTest.cpp (original)
> +++ cfe/trunk/unittests/Format/FormatTest.cpp Sun Jan 13 02:01:36 2013
> @@ -1045,9 +1045,6 @@
>    verifyFormat("A<int **> a;");
>    verifyFormat("A<int *, int *> a;");
>    verifyFormat("A<int **, int **> a;");
> -  verifyFormat("Type *A = static_cast<Type *>(P);");
> -  verifyFormat("Type *A = (Type *)P;");
> -  verifyFormat("Type *A = (vector<Type *, int *>)P;");
>
>    verifyFormat(
>        "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa(\n"
> @@ -1062,6 +1059,25 @@
>    verifyGoogleFormat("int a = b ? *c : *d;");
>  }
>
> +TEST_F(FormatTest, FormatsCasts) {
> +  verifyFormat("Type *A = static_cast<Type *>(P);");
> +  verifyFormat("Type *A = (Type *)P;");
> +  verifyFormat("Type *A = (vector<Type *, int *>)P;");
> +  verifyFormat("int a = (int)(2.0f);");
> +
> +  // FIXME: These also need to be identified.
> +  verifyFormat("int a = (int) 2.0f;");
> +  verifyFormat("int a = (int) * b;");
> +
> +  // These are not casts.
> +  verifyFormat("void f(int *) {}");
> +  verifyFormat("void f(int *);");
> +  verifyFormat("void f(int *) = 0;");
> +  verifyFormat("void f(SmallVector<int>) {}");
> +  verifyFormat("void f(SmallVector<int>);");
> +  verifyFormat("void f(SmallVector<int>) = 0;");
> +}
> +
>  TEST_F(FormatTest, FormatsFunctionTypes) {
>    // FIXME: Determine the cases that need a space after the return type
> and fix.
>    verifyFormat("A<bool()> a;");
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20130113/8330103c/attachment.html>


More information about the cfe-commits mailing list