<html>
 <body>
  <div style="font-family: Verdana, Arial, Helvetica, Sans-Serif;">
   <table bgcolor="#f9f3c9" width="100%" cellpadding="12" style="border: 1px #c9c399 solid; border-radius: 6px; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
    <tr>
     <td>
      This is an automatically generated e-mail. To reply, visit:
      <a href="https://git.reviewboard.kde.org/r/124674/">https://git.reviewboard.kde.org/r/124674/</a>
     </td>
    </tr>
   </table>
   <br />
 <p>Ship it!</p>
 <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">some small nitpicks, but otherwise looks again like excellent work - nice Sergey!</p></pre>
 <br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391378#file391378line609" style="color: black; font-weight: bold; text-decoration: underline;">duchain/builder.cpp</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 <tbody style="background-color: #e4d9cb; padding: 4px 8px; text-align: center;">
  <tr>
   <td colspan="4"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">struct Visitor</pre></td>
  </tr>
 </tbody>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">609</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">        <span class="n">DUChainReadLocker</span> <span class="n">lock</span><span class="p">;</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">move this down just before you return cst. that way, you don't need to lock the duchain while doing the below, potentially expensive, operations.</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391380#file391380line47" style="color: black; font-weight: bold; text-decoration: underline;">duchain/navigationwidget.cpp</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 <tbody style="background-color: #e4d9cb; padding: 4px 8px; text-align: center;">
  <tr>
   <td colspan="4"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">class DeclarationNavigationContext : public AbstractDeclarationNavigationContext</pre></td>
  </tr>
 </tbody>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">47</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">            <span class="n">modifyHtml</span><span class="p">()</span> <span class="o">+=</span> <span class="n">QStringLiteral</span><span class="p">(</span><span class="s">" <"</span><span class="p">).</span><span class="n">toHtmlEscaped</span><span class="p">();</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">why " <" and not "< "?</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391381#file391381line24" style="color: black; font-weight: bold; text-decoration: underline;">duchain/types.h</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">24</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "><span class="cp">#ifndef TYPES_H</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">rename this file to <code style="text-rendering: inherit;color: #4444cc;padding: 0;white-space: normal;margin: 0;line-height: inherit;">classspecializationtype.h</code> and adapt the include guards accordingly</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391381#file391381line66" style="color: black; font-weight: bold; text-decoration: underline;">duchain/types.h</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">66</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">    <span class="n">QList</span><span class="o"><</span><span class="n">KDevelop</span><span class="o">::</span><span class="n">IndexedType</span><span class="o">></span> <span class="n">templateParameters</span><span class="p">()</span> <span class="k">const</span><span class="p">;</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">QVector please</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391382#file391382line78" style="color: black; font-weight: bold; text-decoration: underline;">duchain/types.cpp</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">78</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">    <span class="n">FOREACH_FUNCTION</span><span class="p">(</span><span class="k">const</span> <span class="k">auto</span><span class="o">&</span> <span class="n">t</span><span class="p">,</span> <span class="n">d_func</span><span class="p">()</span><span class="o">-></span><span class="n">parameters</span><span class="p">)</span> <span class="p">{</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">rename: t -> param or parameter</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391382#file391382line88" style="color: black; font-weight: bold; text-decoration: underline;">duchain/types.cpp</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">88</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">        <span class="n">QString</span> <span class="n">result</span> <span class="o">=</span> <span class="n">StructureType</span><span class="o">::</span><span class="n">toString</span><span class="p">()</span> <span class="o">+</span> <span class="n">QStringLiteral</span><span class="p">(</span><span class="s">" <"</span><span class="p">);</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">When you just concatenate the strings, use QLatin1String here please, also below.</p>
<p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">Furthermore, think about using QTextStream, I quite like that for building strings.</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391382#file391382line106" style="color: black; font-weight: bold; text-decoration: underline;">duchain/types.cpp</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">106</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">    <span class="k">if</span><span class="p">(</span><span class="k">this</span> <span class="o">==</span> <span class="n">rhs</span><span class="p">){</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">space before (</p></pre>
 </div>
</div>
<br />
<div>
<table width="100%" border="0" bgcolor="white" style="border: 1px solid #C0C0C0; border-collapse: collapse; margin: 2px padding: 2px;">
 <thead>
  <tr>
   <th colspan="4" bgcolor="#F0F0F0" style="border-bottom: 1px solid #C0C0C0; font-size: 9pt; padding: 4px 8px; text-align: left;">
    <a href="https://git.reviewboard.kde.org/r/124674/diff/1/?file=391382#file391382line120" style="color: black; font-weight: bold; text-decoration: underline;">duchain/types.cpp</a>
    <span style="font-weight: normal;">
     (Diff revision 1)
    </span>
   </th>
  </tr>
 </thead>
 
 
 <tbody>
  <tr>
    <th bgcolor="#b1ebb0" style="border-right: 1px solid #C0C0C0;" align="right"><font size="2"></font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; "></pre></td>
    <th bgcolor="#b1ebb0" style="border-left: 1px solid #C0C0C0; border-right: 1px solid #C0C0C0;" align="right"><font size="2">120</font></th>
    <td bgcolor="#c5ffc4" width="50%"><pre style="font-size: 8pt; line-height: 140%; margin: 0; ">    <span class="n">QList</span><span class="o"><</span><span class="n">KDevelop</span><span class="o">::</span><span class="n">IndexedType</span><span class="o">></span> <span class="n">parameters</span><span class="p">;</span></pre></td>
  </tr>
 </tbody>
</table>
 <div style="margin-left: 2em;">
  <pre style="white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;"><p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">QVector as I said, and then also do</p>
<p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;"><div class="codehilite" style="background: #f8f8f8"><pre style="line-height: 125%">const auto size = d_func()->parametersSize();
QVector<IndexedType> parameters(size);
for (uint i = 0; i < size; ++i) {
    parameters[i] = d_func()->parameters()[i];
}
</pre></div>
</p>
<p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;">bonus points if you can use an algorithm instead. I think std::copy_n should do the trick:</p>
<p style="padding: 0;text-rendering: inherit;margin: 0;line-height: inherit;white-space: inherit;"><div class="codehilite" style="background: #f8f8f8"><pre style="line-height: 125%"><span style="color: #008000; font-weight: bold">const</span> <span style="color: #008000; font-weight: bold">auto</span> <span style="color: #008000; font-weight: bold">size</span> <span style="color: #666666">=</span> <span style="color: #666666">...;</span>
<span style="color: #008000; font-weight: bold">QVector</span><span style="color: #666666"><</span><span style="color: #008000; font-weight: bold">IndexedType</span><span style="color: #666666">></span> <span style="color: #008000; font-weight: bold">parameters</span><span style="color: #666666">(</span><span style="color: #008000; font-weight: bold">size</span><span style="color: #666666">);</span>
<span style="color: #008000; font-weight: bold">std</span><span style="color: #666666">:</span><span style="color: #AA22FF">:copy_n</span><span style="color: #666666">(</span><span style="color: #008000; font-weight: bold">d_func</span><span style="color: #666666">()</span><span style="color: #008000; font-weight: bold">-</span><span style="color: #666666">></span><span style="color: #008000; font-weight: bold">parameters</span><span style="color: #666666">(),</span> <span style="color: #008000; font-weight: bold">size</span><span style="color: #666666">,</span> <span style="color: #008000; font-weight: bold">parameters</span><span style="color: #0000FF; font-weight: bold">.begin</span><span style="color: #666666">());</span>
</pre></div>
</p></pre>
 </div>
</div>
<br />
<p>- Milian Wolff</p>
<br />
<p>On August 9th, 2015, 5:19 p.m. UTC, Sergey Kalinichev wrote:</p>
<table bgcolor="#fefadf" width="100%" cellspacing="0" cellpadding="12" style="border: 1px #888a85 solid; border-radius: 6px; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
 <tr>
  <td>
<div>Review request for KDevelop.</div>
<div>By Sergey Kalinichev.</div>
<p style="color: grey;"><i>Updated Aug. 9, 2015, 5:19 p.m.</i></p>
<div style="margin-top: 1.5em;">
 <b style="color: #575012; font-size: 10pt;">Repository: </b>
kdev-clang
</div>
<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Description </h1>
 <table width="100%" bgcolor="#ffffff" cellspacing="0" cellpadding="10" style="border: 1px solid #b8b5a0">
 <tr>
  <td>
   <pre style="margin: 0; padding: 0; white-space: pre-wrap; white-space: -moz-pre-wrap; white-space: -pre-wrap; white-space: -o-pre-wrap; word-wrap: break-word;">This solves two problems:
1. We didn't create type links for this type and it's parameters.
2. There were no look-ahead code competion for items with this type.</pre>
  </td>
 </tr>
</table>
<h1 style="color: #575012; font-size: 10pt; margin-top: 1.5em;">Diffs</b> </h1>
<ul style="margin-left: 3em; padding-left: 0;">
 <li>duchain/CMakeLists.txt <span style="color: grey">(a183253)</span></li>
 <li>duchain/builder.cpp <span style="color: grey">(f0b17f6)</span></li>
 <li>duchain/duchainutils.cpp <span style="color: grey">(38bd0c3)</span></li>
 <li>duchain/navigationwidget.cpp <span style="color: grey">(ef74ce2)</span></li>
 <li>duchain/types.h <span style="color: grey">(PRE-CREATION)</span></li>
 <li>duchain/types.cpp <span style="color: grey">(PRE-CREATION)</span></li>
 <li>tests/files/types.cpp <span style="color: grey">(9ddf084)</span></li>
 <li>tests/test_codecompletion.cpp <span style="color: grey">(c9624bb)</span></li>
</ul>
<p><a href="https://git.reviewboard.kde.org/r/124674/diff/" style="margin-left: 3em;">View Diff</a></p>
  </td>
 </tr>
</table>
  </div>
 </body>
</html>