<html>
    <head>
      <base href="https://bugs.llvm.org/">
    </head>
    <body><table border="1" cellspacing="0" cellpadding="8">
        <tr>
          <th>Bug ID</th>
          <td><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - Bad performance on reparse"
   href="https://bugs.llvm.org/show_bug.cgi?id=34281">34281</a>
          </td>
        </tr>

        <tr>
          <th>Summary</th>
          <td>Bad performance on reparse
          </td>
        </tr>

        <tr>
          <th>Product</th>
          <td>clang
          </td>
        </tr>

        <tr>
          <th>Version</th>
          <td>4.0
          </td>
        </tr>

        <tr>
          <th>Hardware</th>
          <td>PC
          </td>
        </tr>

        <tr>
          <th>OS</th>
          <td>Linux
          </td>
        </tr>

        <tr>
          <th>Status</th>
          <td>NEW
          </td>
        </tr>

        <tr>
          <th>Severity</th>
          <td>normal
          </td>
        </tr>

        <tr>
          <th>Priority</th>
          <td>P
          </td>
        </tr>

        <tr>
          <th>Component</th>
          <td>libclang
          </td>
        </tr>

        <tr>
          <th>Assignee</th>
          <td>unassignedclangbugs@nondot.org
          </td>
        </tr>

        <tr>
          <th>Reporter</th>
          <td>jmachowinski@gmx.de
          </td>
        </tr>

        <tr>
          <th>CC</th>
          <td>klimek@google.com, llvm-bugs@lists.llvm.org
          </td>
        </tr></table>
      <p>
        <div>
        <pre>Hi,
while testing kdevelop 5, I ran into some problems with the code completion.
I debugged it and tracked it down to the reparse step in libclang taking
5 seconds in an i7-5930K.

In my concrete example, I got a cpp file that consists of 173 line of code,
with minor template usage.
This program includes a big amount of headers, that use heavy templating.

The initial parse takes 13 seconds, which is fine. What makes me wonder is
the reparse step taking so long, as everything in the headers should be
cached by the PCH.

I prepared a git repo with an example, if you want to look at the code I used,
or try it yourself.

<a href="https://github.com/jmachowinski/clangTest">https://github.com/jmachowinski/clangTest</a>

It should be noted, that I do not set CXTranslationUnit_Incomplete,
as kdevelop needs the flag to be NOT set. Setting the flag speeds up reparse
to 0.5 seconds.

Debug output :

Parse start
Precompiling preamble:   8.2960 (100.0%)   0.2760 (100.0%)   8.5720 (100.0%)  
8.5706 (100.0%)
Parsing ../test/tdot_asguard.cpp:   4.8320 (100.0%)   0.0200 (100.0%)   4.8520
(100.0%)   4.8499 (100.0%)
  ASTContext: expressions, declarations, and types: 254289451
  ASTContext: identifiers: 507904
  ASTContext: selectors: 4096
  ASTContext: side tables: 9053176
  Code completion: cached global results: 0
  SourceManager: content cache allocator: 86016
  SourceManager: malloc'ed memory buffers: 2070147
  SourceManager: mmap'ed memory buffers: 0
  SourceManager: data structures and tables: 124472904
  ExternalASTSource: malloc'ed memory buffers: 0
  ExternalASTSource: mmap'ed memory buffers: 188282552
  Preprocessor: malloc'ed memory: 306782
  Preprocessor: PreprocessingRecord: 838904
  Preprocessor: header search tables: 43
Parse took 13.4559
Cache global code completions for ../test/tdot_asguard.cpp:   0.1280 (100.0%)  
0.1280 (100.0%)   0.1267 (100.0%)
Reparsing ../test/tdot_asguard.cpp:   5.0600 (100.0%)   0.0440 (100.0%)  
5.1040 (100.0%)   5.1043 (100.0%)
  ASTContext: expressions, declarations, and types: 259532331
  ASTContext: identifiers: 2326528
  ASTContext: selectors: 4096
  ASTContext: side tables: 9151480
  Code completion: cached global results: 4063232
  SourceManager: content cache allocator: 111147
  SourceManager: malloc'ed memory buffers: 2082327
  SourceManager: mmap'ed memory buffers: 0
  SourceManager: data structures and tables: 124472904
  ExternalASTSource: malloc'ed memory buffers: 0
  ExternalASTSource: mmap'ed memory buffers: 188282552
  Preprocessor: malloc'ed memory: 8324702
  Preprocessor: PreprocessingRecord: 1775864
  Preprocessor: header search tables: 43
ReParse took 5.10452</pre>
        </div>
      </p>


      <hr>
      <span>You are receiving this mail because:</span>

      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>