<div dir="ltr">Standardizing include order would really help.  LLVM's style is documented <a href="http://llvm.org/docs/CodingStandards.html#include-style">here</a>, but to quote it:<div><br></div><div><ol class="inbox-inbox-arabic inbox-inbox-simple" id="inbox-inbox-local-private-headers" style="font-family:"lucida grande","lucida sans unicode",geneva,verdana,sans-serif;font-size:14px;line-height:21px"><li>Main Module Header</li><li>Local/Private Headers</li><li><code class="inbox-inbox-docutils inbox-inbox-literal" style="font-family:consolas,"deja vu sans mono","bitstream vera sans mono",monospace;font-size:0.95em"><span class="inbox-inbox-pre">llvm/...</span></code></li><li>System<span class="inbox-inbox-Apple-converted-space"> </span><code class="inbox-inbox-docutils inbox-inbox-literal" style="font-family:consolas,"deja vu sans mono","bitstream vera sans mono",monospace;font-size:0.95em"><span class="inbox-inbox-pre">#include</span></code>s</li></ol>So perhaps it would be reasonable for us to standardize on something like this:</div><div><br></div><div><ol class="inbox-inbox-inbox-inbox-arabic inbox-inbox-inbox-inbox-simple" id="inbox-inbox-inbox-inbox-local-private-headers" style="font-family:"lucida grande","lucida sans unicode",geneva,verdana,sans-serif;font-size:14px;line-height:21px"><li>Main Module Header</li><li>Local/Private Headers<br></li><li><code class="inbox-inbox-inbox-inbox-inbox-inbox-docutils inbox-inbox-inbox-inbox-inbox-inbox-literal" style="font-family:consolas,"deja vu sans mono","bitstream vera sans mono",monospace;font-size:0.95em"><span class="inbox-inbox-inbox-inbox-inbox-inbox-pre">lldb/...</span></code></li><li><code class="inbox-inbox-inbox-inbox-docutils inbox-inbox-inbox-inbox-literal" style="font-family:consolas,"deja vu sans mono","bitstream vera sans mono",monospace;font-size:0.95em"><span class="inbox-inbox-inbox-inbox-pre">llvm/...</span></code></li><li>System<span class="inbox-inbox-inbox-inbox-Apple-converted-space"> </span><code class="inbox-inbox-inbox-inbox-docutils inbox-inbox-inbox-inbox-literal" style="font-family:consolas,"deja vu sans mono","bitstream vera sans mono",monospace;font-size:0.95em"><span class="inbox-inbox-inbox-inbox-pre">#include</span></code>s</li></ol></div><div><span style="line-height:1.5">Putting LLDB headers before LLVM headers is a nice way to enforce "include what you use".  Otherwise you might have something like this:</span><br></div><div><span style="line-height:1.5"><br></span></div><div>// lldb.cpp</div><div><span style="line-height:1.5">#include "llvm/</span><span style="line-height:1.5">LL</span><span style="line-height:1.5">VM1.h"</span></div><div><span style="line-height:1.5">#include "lldb/lldb2</span><span style="line-height:1.5">.h</span></div><div><span style="line-height:1.5"><br></span></div><div><span style="line-height:1.5">// lldb2.h</span></div><div>llvm::MyType foo();</div><div><br></div><div>And this will work, even though lldb2.h needs to have #include "llvm/LLVM1.h"</div><div><br></div><div>So the above ordering fixes that.  clang-format won't solve this for us automatically, but it would be nice to at least move towards it.</div><div><br><div class="gmail_quote"><div dir="ltr">On Tue, Aug 9, 2016 at 2:49 PM Kate Stone <<a href="mailto:k8stone@apple.com">k8stone@apple.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word">Great catch!  If refactoring along those lines doesn’t clean up 100% of the cases then it’s worth explicitly breaking up groups of #include directives with comments.  clang-format won’t reorder any non-contiguous groups and it’s a great way to explicitly call out dependencies.<div><br></div><div>Ideally we should be focused on committing changes along these lines so that there’s <i>no</i> post-format tweaking required to build cleanly again.</div><div></div></div><div style="word-wrap:break-word"><div><br><div>
<div style="color:rgb(0,0,0);letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;word-wrap:break-word"><div style="color:rgb(0,0,0);letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;word-wrap:break-word"><div style="color:rgb(0,0,0);letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;word-wrap:break-word"><div style="color:rgb(0,0,0);letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;word-wrap:break-word"><div style="font-family:LucidaGrande;word-wrap:break-word"><div style="word-wrap:break-word"><font color="#424242" style="font-family:'Lucida Grande';font-size:x-small">Kate Stone</font><span style="font-family:'Lucida Grande';font-size:x-small"> </span><font color="#009193" style="font-family:'Lucida Grande';font-size:x-small"><a href="mailto:k8stone@apple.com" target="_blank">k8stone@apple.com</a></font></div><div style="font-family:Times;word-wrap:break-word"><font face="Lucida Grande" size="1"><font color="#009193"></font> Xcode <font color="#424242">Low Level Tools</font></font></div></div></div></div></div></div>
</div>
<br></div></div><div style="word-wrap:break-word"><div><div><blockquote type="cite"><div>On Aug 9, 2016, at 1:03 PM, Zachary Turner <<a href="mailto:zturner@google.com" target="_blank">zturner@google.com</a>> wrote:</div><br class="m_-7184276541533860991Apple-interchange-newline"></blockquote></div></div></div><div style="word-wrap:break-word"><div><div><blockquote type="cite"><div><div dir="ltr">I ran clang-format and tried to build and got a bunch of compiler errors.  Most of them are order of include errors.  I fixed everything in the attached patch.  I doubt this will apply cleanly for anyone unless you are at the exact same revision as me, but at least you can look at it and get an idea of what had to change.<div><br></div><div>The #include win32.h thing is really annoying and hard for people to remember the right incantation.  I'm going to make a file called Host/PosixApi.h which you can just include, no matter what platform you're on, and everything will just work.  That should clean up a lot of this nonsense.</div><div><br><div class="gmail_quote"><div dir="ltr">On Tue, Aug 9, 2016 at 11:10 AM Zachary Turner <<a href="mailto:zturner@google.com" target="_blank">zturner@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Another thing worth thinking about for the long term is library layering and breaking the massive dependency cycle in LLDB.  Every library currently depends on every other library.  This isn't good for build times, code size, or reusability (especially where size matters like in lldb-server).  I think the massive Python dependency was removed after my work earlier this year.  But I'm not sure what the status of that is now, and there's still the rest of LLDB.<div><br></div><div>In the future it would be nice to have a modules build of LLDB.  And sure, we could just have liblldb be one giant module, but that seems to kind of defeat the purpose of modules in the first place.</div><div><br></div><div>For unit tests in particular, it's nice to be able to link in just the set of things you need, and that's difficult / impossible right now.</div></div><br><div class="gmail_quote"><div dir="ltr">On Tue, Aug 9, 2016 at 10:00 AM Zachary Turner <<a href="mailto:zturner@google.com" target="_blank">zturner@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><div dir="ltr">On Mon, Aug 8, 2016 at 2:40 PM Kate Stone via lldb-dev <<a href="mailto:lldb-dev@lists.llvm.org" target="_blank">lldb-dev@lists.llvm.org</a>> wrote:<br></div></div></div><div dir="ltr"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div style="font-family:HelveticaNeue"><div><blockquote style="margin:0px 0px 0px 40px;border:none;padding:0px"><div><br></div></blockquote><div></div></div></div><div style="font-family:HelveticaNeue"><div><b>Near-Term Goal: Standardizing on LLVM-style clang-format Rules</b></div><div><br></div><div>We’ve heard from several in the community that would prefer to have a single code formatting style to further unify the two code bases.  Using clang-format with the default LLVM conventions would simplify code migration, editor configuration, and coding habits for developers who work in multiple LLVM projects.  There are non-trivial implications to reformatting a code base with this much history.  It can obfuscate history and impact downstream projects by complicating merges.  Ideally, it should be done once with as much advance notice as is practical.  Here’s the timeline we’re proposing:</div><div><br></div><div><b>Today</b> - mechanical reformatting proposed, comment period begins</div><div><br></div></div><blockquote style="font-family:HelveticaNeue;margin:0px 0px 0px 40px;border:none;padding:0px">To get a preview of what straightforward reformatting of the code looks like, just follow these steps to get a clean copy of the repository and reformat it:</blockquote><blockquote style="font-family:HelveticaNeue;margin:0px 0px 0px 40px;border:none;padding:0px"><ol><li>Check out a clean copy of the existing repository</li><li>Edit .clang-format in the root of the tree, remove all but the line “BasedOnStyle: LLVM”</li><li>Change your current working directory to the root of the tree to reformat</li><li>Double-check to make sure you did step 3 ;-)</li><li>Run the following shell command: "find . -name "*.[c,cpp,h] -exec clang-format -i {} +"</li></ol></blockquote><br style="font-family:HelveticaNeue"><div style="font-family:HelveticaNeue"><div><b>Aug 20th</b> - comment period closes, final schedule proposed</div><div><b>TBD (early September?)</b> - patches land in svn</div><div><br></div><div>The purpose of the comment period is to review the straightforward diffs to identify areas where comment pragmas should be used to avoid undesirable formatting (tables laid out in code are a classic example.)  It’s also a time when feedback on the final timetable can be discussed, and any unforeseen implications can be discovered.  We understand that LLDB tends toward relatively long names that may not always work well with the LLVM convention of wrapping at 80 columns.  Worst case scenarios will be evaluated to determine the desired course of action.</div></div></div></blockquote><div><br></div></div></div><div dir="ltr"><div class="gmail_quote"><div>One thing we will need to take a look at is functions which have a very deep indentation level. <span style="line-height:1.5">They have the potential to be made really ugly by clang-format.  The default indentation will be reduced from 4 to 2, so that will help, but I recall we had some lines that began very far to the right.  </span></div><div><br></div><div>Here's a little bash command shows all lines with >= 50 leading spaces, sorted in descending order by number of leading spaces.</div><div><br></div><div>grep -n '^ \+' . -r -o | awk '{t=length($0);sub(" *$","");printf("%s%d\n", $0, t-length($0));}' |  sort -t: -n -k 3 -r | awk 'BEGIN { FS = ":" } ; { if ($3 >= 50) print $0 }' </div><div><br></div><div>It's less useful than I was hoping because most of the lines are noise (line breaking in a function parameter list).</div><div><br></div><div>If there were a way to detect indentation level that would be better.  Mostly just to identify places that we should manually inspect after running clang-format.</div></div></div></blockquote></div></blockquote></div></div></div>
</div></blockquote></div></div></div><div style="word-wrap:break-word"><div><div><blockquote type="cite"><div><span id="m_-7184276541533860991cid:15670e4322ee1ba49441"><reformat.patch></span></div></blockquote></div><br></div></div></blockquote></div></div></div>