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

Daniel Jasper djasper at google.com
Sun Jan 13 22:16:16 PST 2013


Ok, thank you. I will look into it (at a somewhat lower priority as I want
to fix all C++ constructs first). We have more problems with casts anyway.
In fact, I don't think this change modified the behavior for (struct S) {
.. } as we wouldn't have recognized that as such as cast ..




On Mon, Jan 14, 2013 at 7:07 AM, Richard Smith <richard at metafoo.co.uk>wrote:

> On Sun, Jan 13, 2013 at 10:04 PM, Daniel Jasper <djasper at google.com>wrote:
>
>> Do we have a style (guide) that says you can't put a space between ")"
>> and "{"?
>>
>
> I would expect style guides to implicitly include them in whatever they
> say about casts.
>
>
>> On Mon, Jan 14, 2013 at 1:18 AM, Richard Smith <richard at metafoo.co.uk>wrote:
>>
>>> 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/20130114/7f6bff46/attachment.html>


More information about the cfe-commits mailing list