forked from OSchip/llvm-project
[clangd] Avoid type hierarchy crash on incomplete type
Fixes https://github.com/clangd/clangd/issues/597 Differential Revision: https://reviews.llvm.org/D92077
This commit is contained in:
parent
ae7ac2d665
commit
3d2c681f28
|
@ -1553,6 +1553,10 @@ std::vector<const CXXRecordDecl *> typeParents(const CXXRecordDecl *CXXRD) {
|
||||||
CXXRD = CTSD->getSpecializedTemplate()->getTemplatedDecl();
|
CXXRD = CTSD->getSpecializedTemplate()->getTemplatedDecl();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Can't query bases without a definition.
|
||||||
|
if (!CXXRD->hasDefinition())
|
||||||
|
return Result;
|
||||||
|
|
||||||
for (auto Base : CXXRD->bases()) {
|
for (auto Base : CXXRD->bases()) {
|
||||||
const CXXRecordDecl *ParentDecl = nullptr;
|
const CXXRecordDecl *ParentDecl = nullptr;
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,7 @@ namespace {
|
||||||
using ::testing::AllOf;
|
using ::testing::AllOf;
|
||||||
using ::testing::ElementsAre;
|
using ::testing::ElementsAre;
|
||||||
using ::testing::Field;
|
using ::testing::Field;
|
||||||
|
using ::testing::IsEmpty;
|
||||||
using ::testing::Matcher;
|
using ::testing::Matcher;
|
||||||
using ::testing::UnorderedElementsAre;
|
using ::testing::UnorderedElementsAre;
|
||||||
|
|
||||||
|
@ -318,6 +319,18 @@ struct Child3 : T {};
|
||||||
EXPECT_THAT(typeParents(Child3), ElementsAre());
|
EXPECT_THAT(typeParents(Child3), ElementsAre());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(TypeParents, IncompleteClass) {
|
||||||
|
Annotations Source(R"cpp(
|
||||||
|
class Incomplete;
|
||||||
|
)cpp");
|
||||||
|
TestTU TU = TestTU::withCode(Source.code());
|
||||||
|
auto AST = TU.build();
|
||||||
|
|
||||||
|
const CXXRecordDecl *Incomplete =
|
||||||
|
dyn_cast<CXXRecordDecl>(&findDecl(AST, "Incomplete"));
|
||||||
|
EXPECT_THAT(typeParents(Incomplete), IsEmpty());
|
||||||
|
}
|
||||||
|
|
||||||
// Parts of getTypeHierarchy() are tested in more detail by the
|
// Parts of getTypeHierarchy() are tested in more detail by the
|
||||||
// FindRecordTypeAt.* and TypeParents.* tests above. This test exercises the
|
// FindRecordTypeAt.* and TypeParents.* tests above. This test exercises the
|
||||||
// entire operation.
|
// entire operation.
|
||||||
|
|
Loading…
Reference in New Issue