MyDeveloperDay added a comment.

In D107961#2943266 <https://reviews.llvm.org/D107961#2943266>, @owenpan wrote:

> In D107961#2943223 <https://reviews.llvm.org/D107961#2943223>, 
> @MyDeveloperDay wrote:
>
>> Did the original change make it into the 13 branch?
>
> ~~What's //the 13 branch//?~~
>
>> I'm seeing some unexpected behavior.
>>
>>   bool foo(int a, Bar) override;
>>   bool foo(int a, Bar) override; // comment
>>
>> becomes
>>
>>   bool foo(int a, Bar)
>>   override;
>>   bool foo(int a, Bar)
>>   override; // comment
>
> How can I reproduce it? The above C++ declarations should be inside a class 
> definition, no?
>
> Anyway, here is what I got:
>
>   $ cat .clang-format
>   BasedOnStyle: LLVM
>   AlwaysBreakAfterReturnType: TopLevelDefinitions
>   $ cat foo.cpp
>   typedef float Bar;
>   class A {
>     virtual bool foo(int, Bar);
>     virtual bool bar(int, Bar);
>   };
>   class B : A {
>     bool foo(int a, Bar) override;
>     bool bar(int a, Bar) override; // comment
>   };
>   $ clang -Wall -std=c++11 -c foo.cpp
>   $ clang-format foo.cpp > bar.cpp
>   $ diff foo.cpp bar.cpp
>   $ 



> The above C++ declarations should be inside a class definition, no?

Not really, we don't have to have any context of where we are (in class or 
struct). if you had  for example

  class A
  {
  #include "myfunctions.h"
  }

you still would want the code in myfunctions.h to be formatted just the same 
(less indentation)

So the following code:

  bool foo(int a, Bar)
  override;
  bool foo(int a, Bar)
  override; // comment

Failed on the 13 branch, but is fixed with @krasimir fix, but that isn't 
backported (we need to do that as a minimum I think)

With this revision that is also fixed, the following occurs if I change the 
return type

  Bar foo(int a, Bar)
  override;
  Bar foo(int a, Bar)
  override; // comment

And that doesn't feel correct to me. Well not as by default at least. From my 
perspective there seems to be a propensity to think code is K&R, but that 
should be the exception not the rule.

If that is to be the case then we need some sort of setting that means they 
need to expect it, (like the Language: XXXX) that was proposed before

I just ran this on my 4.5 million line and ended up with way more areas that 
needed clang-formatting than I think should need to (in c++ code not c code)


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D107961/new/

https://reviews.llvm.org/D107961

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to