<div dir="ltr">I am somewhat torn with regard to adding this option. Every additional option has a certain cost associated with it (harder discovery of options, more maintenance, more combinations of options that can lead to undesired behavior, etc.).<div><br></div><div>Now, these costs aren't particularly high for the option you are suggesting, but I also don't understand the gain.</div><div><br></div><div><span style="font-size:13px">AlwaysBreakAfterReturnType is mostly implemented to support GNU style. The rationale that GNU style gives for having this style is so that it becomes easier to grep for function names, navigate between functions, etc. This rationale certainly doesn't apply if you exclude single-line functions. If you don't care about grep'ing of function names, it seems fine to use what LLVM style does and break after the return type first (before breaking anywhere else). Can you elaborate on why you think that your proposed style is useful?</span></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Dec 24, 2014 at 11:25 PM, Adam McKee <span dir="ltr"><<a href="mailto:Adam.Matthew.McKee@gmail.com" target="_blank">Adam.Matthew.McKee@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi, list :)<br>
<br>
I'm new to clang-format, and I'm really impressed with this tool. I<br>
think the value of an automated tool like this is so great, that I'll<br>
happily let it process all my code even if it doesn't do what I want<br>
100% of the time. Most of the times when it's done something<br>
different from my habit, I've decided it actually looks better, and<br>
the only reason I wasn't formatting that way was because it would be a<br>
pain to do it manually. Amazingly, there seems to only be one thing<br>
that makes me hesitate before running it on everything, and even this<br>
"issue" may not stop me from doing so. I'd like to share my use case<br>
& suggested change, and see what you think.<br>
<br>
=== MY USE CASE<br>
<br>
I want to allow one-liner functions<br>
("AllowShortFunctionsOnASingleLine"), but if a function does not fit<br>
on one line I want to "BreakAfterDefinitionReturnType". The<br>
configuration options don't seem to allow this, although they do what<br>
it says on the tin: "AlwaysBreakAfterReturnType" really means ALWAYS,<br>
but I don't want it always, I want it only if the function can't fit<br>
on a single line. Is this actually possible now, or could it be done<br>
in a future version?<br>
<br>
=== MY SUGGESTED CHANGE<br>
<br>
My suggestion would be to remove "AlwaysBreakAfterReturnType", and add<br>
"BreakAfterReturnType" with three options: "always", "never", and<br>
"multiline", where "multiline" means break after return type if the<br>
function is not eligible for writing on a single line. Is this a<br>
sensible request? For clarity, "BreakAfterReturnType=multiline" would<br>
be equivalent to "BreakAfterReturnType=always" unless<br>
"AllowShortFunctionsOnASingleLine=true".<br>
<br>
Without this change, I think I'd probably turn off<br>
"AlwaysBreakAfterReturnType", but I'd like to have my return types on<br>
their own line & (as a higher priority) have my one-liners too if<br>
possible.<br>
<br>
Thanks for any advice :) It's a great tool.<br>
<br>
-Adam<br>
_______________________________________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@cs.uiuc.edu">cfe-dev@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev</a><br>
</blockquote></div><br></div>