forked from OSchip/llvm-project
[Frontend] Use vfs for directory iteration while searching PCHs. NFCI
Use the vfs lookup instead of real filesytem and handle the case where -include-pch is a directory and this dir is searched for a PCH. llvm-svn: 289459
This commit is contained in:
parent
4b75b8726d
commit
b4d56f1a4f
|
@ -288,14 +288,15 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI,
|
|||
SmallString<128> DirNative;
|
||||
llvm::sys::path::native(PCHDir->getName(), DirNative);
|
||||
bool Found = false;
|
||||
for (llvm::sys::fs::directory_iterator Dir(DirNative, EC), DirEnd;
|
||||
vfs::FileSystem &FS = *FileMgr.getVirtualFileSystem();
|
||||
for (vfs::directory_iterator Dir = FS.dir_begin(DirNative, EC), DirEnd;
|
||||
Dir != DirEnd && !EC; Dir.increment(EC)) {
|
||||
// Check whether this is an acceptable AST file.
|
||||
if (ASTReader::isAcceptableASTFile(
|
||||
Dir->path(), FileMgr, CI.getPCHContainerReader(),
|
||||
Dir->getName(), FileMgr, CI.getPCHContainerReader(),
|
||||
CI.getLangOpts(), CI.getTargetOpts(), CI.getPreprocessorOpts(),
|
||||
SpecificModuleCachePath)) {
|
||||
PPOpts.ImplicitPCHInclude = Dir->path();
|
||||
PPOpts.ImplicitPCHInclude = Dir->getName();
|
||||
Found = true;
|
||||
break;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue