Frontend: Create a virtual file for named pipe inputs.

- This ensures we see the right buffer size for the file.

llvm-svn: 168636
This commit is contained in:
Daniel Dunbar 2012-11-27 00:04:16 +00:00
parent 336368c4fd
commit db0745ab86
2 changed files with 5 additions and 4 deletions

View File

@ -620,7 +620,6 @@ bool CompilerInstance::InitializeSourceManager(const FrontendInputFile &Input,
Diags.Report(diag::err_fe_error_reading) << InputFile;
return false;
}
SourceMgr.createMainFileID(File, Kind);
// The natural SourceManager infrastructure can't currently handle named
// pipes, but we would at least like to accept them for the main
@ -632,8 +631,13 @@ bool CompilerInstance::InitializeSourceManager(const FrontendInputFile &Input,
Diags.Report(diag::err_cannot_open_file) << InputFile << ec.message();
return false;
}
// Create a new virtual file that will have the correct size.
File = FileMgr.getVirtualFile(InputFile, MB->getBufferSize(), 0);
SourceMgr.overrideFileContents(File, MB.take());
}
SourceMgr.createMainFileID(File, Kind);
} else {
OwningPtr<llvm::MemoryBuffer> SB;
if (llvm::MemoryBuffer::getSTDIN(SB)) {

View File

@ -1,8 +1,5 @@
// Check that we can operate on files from /dev/fd.
// REQUIRES: dev-fd-fs
//
// Currently, this only appears to work on Darwin's dev-fs.
// REQUIRES: system-darwin
// Check reading from named pipes. We cat the input here instead of redirecting