[PATCH] D124166: [clangd] Correctly identify self-contained headers included rercursively
Kirill Bobyrev via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Thu Apr 21 08:00:49 PDT 2022
This revision was automatically updated to reflect the committed changes.
Closed by commit rGe1c0d2fb8272: [clangd] Correctly identify self-contained headers included rercursively (authored by kbobyrev).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D124166/new/
https://reviews.llvm.org/D124166
Files:
clang-tools-extra/clangd/Headers.cpp
clang-tools-extra/clangd/unittests/HeadersTests.cpp
clang-tools-extra/clangd/unittests/IncludeCleanerTests.cpp
Index: clang-tools-extra/clangd/unittests/IncludeCleanerTests.cpp
===================================================================
--- clang-tools-extra/clangd/unittests/IncludeCleanerTests.cpp
+++ clang-tools-extra/clangd/unittests/IncludeCleanerTests.cpp
@@ -538,6 +538,38 @@
EXPECT_THAT(Unused, IsEmpty());
}
+TEST(IncludeCleaner, RecursiveInclusion) {
+ TestTU TU;
+ TU.Code = R"cpp(
+ #include "foo.h"
+
+ void baz() {
+ foo();
+ }
+ )cpp";
+ TU.AdditionalFiles["foo.h"] = R"cpp(
+ #ifndef FOO_H
+ #define FOO_H
+
+ void foo() {}
+
+ #include "bar.h"
+
+ #endif
+ )cpp";
+ TU.AdditionalFiles["bar.h"] = guard(R"cpp(
+ #include "foo.h"
+ )cpp");
+ ParsedAST AST = TU.build();
+
+ auto ReferencedFiles = findReferencedFiles(
+ findReferencedLocations(AST), AST.getIncludeStructure(),
+ AST.getCanonicalIncludes(), AST.getSourceManager());
+ EXPECT_THAT(AST.getDiagnostics(), llvm::ValueIs(IsEmpty()));
+ auto Unused = computeUnusedIncludes(AST);
+ EXPECT_THAT(Unused, IsEmpty());
+}
+
} // namespace
} // namespace clangd
} // namespace clang
Index: clang-tools-extra/clangd/unittests/HeadersTests.cpp
===================================================================
--- clang-tools-extra/clangd/unittests/HeadersTests.cpp
+++ clang-tools-extra/clangd/unittests/HeadersTests.cpp
@@ -383,6 +383,7 @@
#include "nonguarded.h"
#include "pp_depend.h"
#include "pragmaguarded.h"
+#include "recursive.h"
)cpp";
FS.Files["pragmaguarded.h"] = R"cpp(
#pragma once
@@ -400,10 +401,19 @@
# error You have to have PP directive set to include this one!
#endif
)cpp";
+ FS.Files["recursive.h"] = R"cpp(
+ #ifndef RECURSIVE_H
+ #define RECURSIVE_H
+
+ #include "recursive.h"
+
+ #endif // RECURSIVE_H
+)cpp";
auto Includes = collectIncludes();
EXPECT_TRUE(Includes.isSelfContained(getID("pragmaguarded.h", Includes)));
EXPECT_TRUE(Includes.isSelfContained(getID("includeguarded.h", Includes)));
+ EXPECT_TRUE(Includes.isSelfContained(getID("recursive.h", Includes)));
EXPECT_FALSE(Includes.isSelfContained(getID("nonguarded.h", Includes)));
EXPECT_FALSE(Includes.isSelfContained(getID("pp_depend.h", Includes)));
}
Index: clang-tools-extra/clangd/Headers.cpp
===================================================================
--- clang-tools-extra/clangd/Headers.cpp
+++ clang-tools-extra/clangd/Headers.cpp
@@ -106,10 +106,17 @@
InBuiltinFile = false;
// At file exit time HeaderSearchInfo is valid and can be used to
// determine whether the file was a self-contained header or not.
- if (const FileEntry *FE = SM.getFileEntryForID(PrevFID))
- if (!isSelfContainedHeader(FE, PrevFID, SM, HeaderInfo))
+ if (const FileEntry *FE = SM.getFileEntryForID(PrevFID)) {
+ // isSelfContainedHeader only returns true once the full header-guard
+ // structure has been seen, i.e. when exiting the *outer* copy of the
+ // file. So last result wins.
+ if (isSelfContainedHeader(FE, PrevFID, SM, HeaderInfo))
+ Out->NonSelfContained.erase(
+ *Out->getID(SM.getFileEntryForID(PrevFID)));
+ else
Out->NonSelfContained.insert(
*Out->getID(SM.getFileEntryForID(PrevFID)));
+ }
break;
}
case PPCallbacks::RenameFile:
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D124166.424206.patch
Type: text/x-patch
Size: 3346 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20220421/967aad98/attachment-0001.bin>
More information about the cfe-commits
mailing list