This is an archive of the discontinued LLVM Phabricator instance.

[Preamble] Invalidate preamble when missing headers become present.
ClosedPublic

Authored by sammccall on Apr 11 2020, 7:35 AM.

Details

Summary

To avoid excessive extra stat()s, only check the possible locations of
headers that weren't found at all (leading to a compile error).
For headers that *were* found, we don't check for files earlier on the
search path that could override them.

Diff Detail

Event Timeline

sammccall created this revision.Apr 11 2020, 7:35 AM
Herald added a project: Restricted Project. · View Herald TranscriptApr 11 2020, 7:35 AM

At first I thought this would be easy to test via clang/test/PCH, but the outer layers of PrecompiledPreamble seem to be totally distinct from PCHGenerator etc. This is only used in ASTUnit and clangd.
Maybe it's reachable in libclang but I couldn't easily work out how.

It is unfortunate that we are testing PrecompiledPreamble through clangd rather than its own unittest :/

clang/lib/Frontend/PrecompiledPreamble.cpp
101

is there a common recovery logic implemented in clang that makes this logic worth it?
because none of the existing clients seems to be implementing it.

I would rather check for File == nullptr in InclusionDirective and maybe put a fixme saying that this might still be set by a "recovering ppcallback".

Up to you though.

137

nit: braces

590

i believe it can also be provided by an overridefile. maybe also check this above while going over RemappedFiles. i.e:

for(... &R : ..RemappedFiles) {
   if(!stat(R.second)) return false;
   // A missing file has been remapped into an existing file.
   if(MissingFiles.count(R.first)) return false;
 ....
}
591

i am not sure if this works in all cases.

Assume there's a mapped buffer for "a.h", which is relative to main file.

I suppose this will be recorded with fullpath in MissingFiles, hence this lookup will fail.

sammccall updated this revision to Diff 266822.May 28 2020, 5:21 AM
sammccall marked 6 inline comments as done.

Finally address comments

clang/lib/Frontend/PrecompiledPreamble.cpp
101

Done. I think a fixme is disingenuous though if we deliberately un-fixed it :-)
Left a non-committal comment.

590

Decided to just add a new set containing abs paths for everything that got overridden.

mostly LG, sorry for not noticing regularfile check(or maybe forgetting a discussion ...) at previous revision

clang/lib/Frontend/PrecompiledPreamble.cpp
108

um, shouldn't this be

if (File != nullptr)
  return;

? as we are only interested in not-found files?

538

128 seems to be more widely used :P

596

what about others? at least symlinks ?

sammccall marked 5 inline comments as done.May 28 2020, 7:06 AM
sammccall added inline comments.
clang/lib/Frontend/PrecompiledPreamble.cpp
108

Yeah, I guess I should have run the tests :-)

596

RealFileSystem::status() resolves symlinks (calls fs::status() with no resolve arg, defaults to true). That's the most important case, and other VFSes that support symlinks should really do the same for compatibility.

sammccall updated this revision to Diff 266868.May 28 2020, 7:13 AM
sammccall marked 2 inline comments as done.

address comments

kadircet accepted this revision.May 28 2020, 1:18 PM

LGTM, thanks! Let's build more preambles !

This revision is now accepted and ready to land.May 28 2020, 1:18 PM
This revision was automatically updated to reflect the committed changes.