On Windows loading preamble and caching global completion takes a while.
This is the way to improve it.
Please comment if I misuse something.
Details
Diff Detail
Event Timeline
Can you use a local map in TranslateStoredDiagnostics instead of storing one in the ASTUnit, or do you need to keep it around?
The whole purpose is to use it between different TranslateStoredDiagnostics calls because it scans the same files every time. And this cache allows it to reuse the source location.
include/clang/Frontend/ASTUnit.h | ||
---|---|---|
195 | You can use an llvm::StringMap instead. | |
lib/Frontend/ASTUnit.cpp | ||
1163 | Why is clear in an else here? We always create a new SourceManager in this function, so the previously cached locations will be invalid, so shouldn't we always clear the cache before TranslateStoredDiagnostics? |
include/clang/Frontend/ASTUnit.h | ||
---|---|---|
195 | I will change that | |
lib/Frontend/ASTUnit.cpp | ||
1163 | When we load diagnostics that means that preamble has not changed. Doesn't that mean that source locations can be reused? What can cause them to become invalid? I can keep cache only during TranslateStoredDiagnostics calls but in that case performance improvement is way less. But if you say that current solution is invalid I will do that |
lib/Frontend/ASTUnit.cpp | ||
---|---|---|
1163 | You're right actually, we can reuse them. We already do make that assumption that the preamble's source locations can be reused in checkAndSanitizeDiags. This code is fine then, sorry about the confusion. You should mention in the comment for the SrcLocCache that we cache only the source locations from the preamble as we can guarantee that they will stay valid when the source manager is re-created. |
LGTM with one inline request below.
I also have a question: what kind of performance benefits do you get for the preamble load times?
lib/Frontend/ASTUnit.cpp | ||
---|---|---|
2615–2616 | Please move the FileID FID declaration from above into here because we only use it in this if. |
"what kind of performance benefits do you get for the preamble load times?"
In cases where many windows headers are included preamble loading takes almost the half of reparse time. With this fix time to load preamble goes towards zero.
You can use an llvm::StringMap instead.