<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><br><div><div>On Jan 12, 2010, at 6:59 PM, Mike Stump wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><span class="Apple-style-span" style="border-collapse: separate; font-family: Helvetica; font-size: medium; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; ">Author: mrs<br>Date: Tue Jan 12 20:59:54 2010<br>New Revision: 93287<br><br>URL:<span class="Apple-converted-space"> </span><a href="http://llvm.org/viewvc/llvm-project?rev=93287&view=rev">http://llvm.org/viewvc/llvm-project?rev=93287&view=rev</a><br>Log:<br>Add an unreachable code checker.<br><br>==============================================================================<br>-<br>+/// CheckUnreachable - Check for unreachable code.<br>+void Sema::CheckUnreachable(AnalysisContext &AC) {<br>+  if (Diags.getDiagnosticLevel(diag::warn_unreachable) == Diagnostic::Ignored)<br>+    return;<br>+<br>+  CFG *cfg = AC.getCFG();<br>+  // FIXME: They should never return 0, fix that, delete this code.<br>+  if (cfg == 0)<br>+    return;<br>+  <br>+  llvm::BitVector live(cfg->getNumBlockIDs());<br>+  // Mark all live things first.<br>+  MarkLive(&cfg->getEntry(), live);<br>+<br>+  for (unsigned i = 0; i < cfg->getNumBlockIDs(); ++i) {<br>+    if (!live[i]) {<br>+      CFGBlock &b = *(cfg->begin()[i]);<br>+      if (!b.empty())<br>+        Diag(b[0].getStmt()->getLocStart(), diag::warn_unreachable);<br>+      // Avoid excessive errors by marking everything reachable from here<br>+      MarkLive(&b, live);<br>+    }<br>+  }<br>+}</span></blockquote></div><br><div>Hi Mike,</div><div><br></div><div>We talked about this in person a bit, but I thought I'd shoot you a few comments.</div><div><br></div><div>I think this loop should just iterate over the CFGBlocks using the CFG's iterator instead of iterating over block ID numbers.  The following lines look a little fragile:</div><div><br></div><div><blockquote type="cite"><span class="Apple-style-span" style="border-collapse: separate; font-family: Helvetica; font-size: medium; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-border-horizontal-spacing: 0px; -webkit-border-vertical-spacing: 0px; -webkit-text-decorations-in-effect: none; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; ">+  for (unsigned i = 0; i < cfg->getNumBlockIDs(); ++i) {<br>+    if (!live[i]) {<br>+      CFGBlock &b = *(cfg->begin()[i]);</span></blockquote><br></div><div>This makes the unnecessary assumption that the iterator is random access.  While true, this doesn't look necessary.  How about:</div><div><br></div><div>for (CFG::iterator I = cfg->begin(), E = cfg->end(); I != E; ++I) {</div><div>   CFGBlock *b = *I;</div><div>   if (!live[b->getBlockID()])</div><div><br></div><div>This is a little easier to read and makes it algorithmically clearer what you're doing.  As we discussed, this probably isn't the final solution anyway, since it won't suppress errors as expected (i.e., the CFGBlocks are not guaranteed to be in topological order), but from a coding perspective this is much cleaner.</div><div><br></div><div>- Ted</div></body></html>