From c586a48136ad82d597536e509c37c216cdac2da4 Mon Sep 17 00:00:00 2001 From: Jan Svoboda Date: Thu, 16 Oct 2025 13:38:46 -0700 Subject: [PATCH 1/2] [support] Don't require VFS in `SourceMgr` for loading includes This commit more gracefully handles situations where `SourceMgr` isn't initialized with a VFS and tries to resolve an include. That's what happens with the test case `clang -flto=thin -c test.c -o /dev/null` where test.c contains `asm(" .incbin \"foo.i\" \n");`. Propagating the actual VFS all the way is very difficult. This is a follow-up to #162903. --- llvm/lib/Support/SourceMgr.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/llvm/lib/Support/SourceMgr.cpp b/llvm/lib/Support/SourceMgr.cpp index f2bbaab23ed7b..f2ceaa0c9a669 100644 --- a/llvm/lib/Support/SourceMgr.cpp +++ b/llvm/lib/Support/SourceMgr.cpp @@ -69,11 +69,11 @@ unsigned SourceMgr::AddIncludeFile(const std::string &Filename, ErrorOr> SourceMgr::OpenIncludeFile(const std::string &Filename, std::string &IncludedFile) { - if (!FS) - reportFatalInternalError("Opening include file from SourceMgr without VFS"); + auto getFile = [this](StringRef Path) { + return FS ? FS->getBufferForFile(Path) : MemoryBuffer::getFile(Path); + }; - ErrorOr> NewBufOrErr = - FS->getBufferForFile(Filename); + ErrorOr> NewBufOrErr = getFile(Filename); SmallString<64> Buffer(Filename); // If the file didn't exist directly, see if it's in an include path. @@ -81,7 +81,7 @@ SourceMgr::OpenIncludeFile(const std::string &Filename, ++i) { Buffer = IncludeDirectories[i]; sys::path::append(Buffer, Filename); - NewBufOrErr = FS->getBufferForFile(Buffer); + NewBufOrErr = getFile(Buffer); } if (NewBufOrErr) From d330aad4cc93721b04b177683e93316981023251 Mon Sep 17 00:00:00 2001 From: Jan Svoboda Date: Thu, 16 Oct 2025 13:50:10 -0700 Subject: [PATCH 2/2] Naming --- llvm/lib/Support/SourceMgr.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/llvm/lib/Support/SourceMgr.cpp b/llvm/lib/Support/SourceMgr.cpp index f2ceaa0c9a669..299615a6c8041 100644 --- a/llvm/lib/Support/SourceMgr.cpp +++ b/llvm/lib/Support/SourceMgr.cpp @@ -69,11 +69,11 @@ unsigned SourceMgr::AddIncludeFile(const std::string &Filename, ErrorOr> SourceMgr::OpenIncludeFile(const std::string &Filename, std::string &IncludedFile) { - auto getFile = [this](StringRef Path) { + auto GetFile = [this](StringRef Path) { return FS ? FS->getBufferForFile(Path) : MemoryBuffer::getFile(Path); }; - ErrorOr> NewBufOrErr = getFile(Filename); + ErrorOr> NewBufOrErr = GetFile(Filename); SmallString<64> Buffer(Filename); // If the file didn't exist directly, see if it's in an include path. @@ -81,7 +81,7 @@ SourceMgr::OpenIncludeFile(const std::string &Filename, ++i) { Buffer = IncludeDirectories[i]; sys::path::append(Buffer, Filename); - NewBufOrErr = getFile(Buffer); + NewBufOrErr = GetFile(Buffer); } if (NewBufOrErr)