Fix crash ElementRegion::getRValueType() when the RvalueType of the ArrayRegion is a typedef and not (directly) a pointer.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62909 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/Analysis/MemRegion.cpp b/lib/Analysis/MemRegion.cpp
index 2724ed0..55c6935 100644
--- a/lib/Analysis/MemRegion.cpp
+++ b/lib/Analysis/MemRegion.cpp
@@ -108,17 +108,14 @@
}
QualType ElementRegion::getRValueType(ASTContext& C) const {
- QualType T = getArrayRegion()->getRValueType(C);
+ // Strip off typedefs from the ArrayRegion's RvalueType.
+ QualType T = getArrayRegion()->getRValueType(C)->getDesugaredType();
- if (isa<ArrayType>(T.getTypePtr())) {
- ArrayType* AT = cast<ArrayType>(T.getTypePtr());
+ if (ArrayType* AT = dyn_cast<ArrayType>(T.getTypePtr()))
return AT->getElementType();
- }
- else {
- PointerType* PtrT = cast<PointerType>(T.getTypePtr());
- QualType PTy = PtrT->getPointeeType();
- return C.getCanonicalType(PTy);
- }
+
+ PointerType* PtrT = cast<PointerType>(T.getTypePtr());
+ return C.getCanonicalType(PtrT->getPointeeType());
}
//===----------------------------------------------------------------------===//