[PATCH] D119426: [C++20] [Modules] Check if modulemap exists to avoid crash in implicit used C++ module
Zezheng Li via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Feb 10 04:07:00 PST 2022
ZezhengLi updated this revision to Diff 407466.
ZezhengLi added a comment.
Add endline.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D119426/new/
https://reviews.llvm.org/D119426
Files:
clang/lib/Lex/HeaderSearch.cpp
clang/test/Modules/implicit-module-with-missing-path.cpp
Index: clang/test/Modules/implicit-module-with-missing-path.cpp
===================================================================
--- /dev/null
+++ clang/test/Modules/implicit-module-with-missing-path.cpp
@@ -0,0 +1,12 @@
+// This tests that the compiler wouldn't crash if the module path misses
+
+// RUN: rm -rf %t
+// RUN: mkdir -p %t/subdir
+// RUN: echo "export module C;" >> %t/subdir/C.cppm
+// RUN: echo -e "export module B;\nimport C;" >> %t/B.cppm
+// RUN: %clang_cc1 -std=c++20 -emit-module-interface %t/subdir/C.cppm -o %t/subdir/C.pcm
+// RUN: %clang_cc1 -std=c++20 -emit-module-interface -fprebuilt-module-path=%t/subdir %t/B.cppm -o %t/B.pcm
+// RUN: %clang_cc1 -std=c++20 -fprebuilt-module-path=%t %s -fsyntax-only -verify
+
+import B;
+import C; // expected-error {{module 'C' is needed but has not been provided, and implicit use of module files is disabled}}
Index: clang/lib/Lex/HeaderSearch.cpp
===================================================================
--- clang/lib/Lex/HeaderSearch.cpp
+++ clang/lib/Lex/HeaderSearch.cpp
@@ -172,6 +172,10 @@
std::string HeaderSearch::getCachedModuleFileName(Module *Module) {
const FileEntry *ModuleMap =
getModuleMap().getModuleMapFileForUniquing(Module);
+ // The ModuleMap maybe a nullptr, when we load a cached C++ module without
+ // *.modulemap file. In this case, just return an empty string.
+ if (ModuleMap == nullptr)
+ return {};
return getCachedModuleFileName(Module->Name, ModuleMap->getName());
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D119426.407466.patch
Type: text/x-patch
Size: 1503 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20220210/01861389/attachment.bin>
More information about the cfe-commits
mailing list