<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class="">This is my take on a couple of these - most likely the combination of how the convention was explained to me when I started work on LLDB, and then a few years of me adjusting to it, with varied success.</div><div class="">To be taken with a grain of salt, or two.</div><br class=""><div><blockquote type="cite" class=""><div class="">On Aug 19, 2014, at 10:16 AM, Zachary Turner <<a href="mailto:zturner@google.com" class="">zturner@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">I brought this up in a thread on lldb-commits, but since it is of more general interest, I want to make a thread here as well.<div class=""><br class=""></div><div class="">Can we have clear direction on LLDB coding style?  Ideally in the form of an update to <a href="http://lldb.llvm.org/" class="">lldb.llvm.org</a>, but as that might require a little more effort, even some details in a response to this thread would be a help.  Some things I've deduced from looking at the code, and other things I'm not so sure about, because of inconsistencies in the code or just no clear rule.</div>
<div class=""><br class=""></div><div class="">Indentation width: 4</div><div class="">Column limit: 140  (does this apply to comments too?  Most function-declaration comments seem to wrap at 80)</div></div></div></blockquote><div><br class=""></div><div>I don’t think there is an explicit column limit. That’s not to be taken as 300 columns being OK, but we are also not as strict as the rest of LLVM on a specific number.</div><div>I tend to wrap my function declarations when they have a lot of arguments, not so much for column limits, but for readability.</div><div>I also have a penchant for grouping options in option classes, but that’s just my personal taste, not a guideline.</div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="">Brace style: Allman</div><div class="">    if (foo)</div><div class="">
    {</div><div class="">        // code here</div><div class="">    }</div><div class=""><br class=""></div></div></div></blockquote><div><br class=""></div><div>I sometimes get away with</div><div>if (foo)</div><div><span class="Apple-tab-span" style="white-space:pre">   </span>oneLineHere();</div><div><br class=""></div><div>but yes, braces on separate line - and I believe there actually is a preference for erring on the side of having braces even in the one statement case.</div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="">Break after function return type: Always, only on declarations, only on definitions, only in headers, or never?</div><div class=""><br class=""></div><div class="">Space before function parentheses: When?</div></div></div></blockquote><div><br class=""></div><div>I do both always. Or rather, the first I do always.</div><div>The second, I tend to do it at declarations/definitions - a little less religiously at call sites</div><div>As a post-hoc rationalization, that makes it easier to look for function definitions vs usages, i.e. look for ‘Foo (‘ if you want to see where Foo is defined, for ‘Foo(‘ to see where Foo is used</div><div>In practice, I think there is enough variety in this regard that this will fail more often than it works</div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class="">
<div class=""><br class=""></div><div class="">Indent case labels inside switch: A or B below?</div><div class="">    switch (foo)</div><div class="">    {</div><div class="">        case A:</div><div class="">    case B:</div><div class="">    }</div><div class=""><br class=""></div><div class="">Indent braces inside of a case: A or B below?</div>
<div class="">    switch (foo)</div><div class="">    {</div><div class="">        case A:</div><div class="">        {</div><div class="">        }</div><div class="">        case B:</div><div class="">            {</div><div class="">            }</div><div class="">    }</div></div></div></blockquote><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">Any other rules I should be cognizant of?</div></div></div></blockquote><div><br class=""></div><div>Well, the obvious; member variables start with an m_, globals with g_, class and function names start with uppercase letters, and then go SomewhatLikeThisYouSee, member variables go instead m_likeThisForVariables.</div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class="">
</div>
_______________________________________________<br class="">lldb-dev mailing list<br class=""><a href="mailto:lldb-dev@cs.uiuc.edu" class="">lldb-dev@cs.uiuc.edu</a><br class="">http://lists.cs.uiuc.edu/mailman/listinfo/lldb-dev<br class=""></div></blockquote></div><br class=""><div class="">
<div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div style="color: rgb(0, 0, 0); letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><div class="">Thanks,</div><div class=""><i class="">- Enrico</i><br class="">📩 egranata@<font color="#ff2600" class=""></font>.com ☎️ 27683</div><div class=""><br class=""></div></div></div></div></div></div><br class="Apple-interchange-newline"><br class="Apple-interchange-newline">
</div>
<br class=""></body></html>