mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-06 09:44:39 +00:00
DebugInfo: Make DIDerivedType accessors more strict
These accessors in `DIDerivedType` should only be called when `DbgNode` really is a `MDDerivedType`, not just a `MDDerivedTypeBase`. Assume that it is. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@234812 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b4f6438352
commit
7ca9328e16
@ -314,24 +314,21 @@ public:
|
||||
DITypeRef getTypeDerivedFrom() const { return get()->getBaseType(); }
|
||||
|
||||
/// \brief Return property node, if this ivar is associated with one.
|
||||
MDNode *getObjCProperty() const {
|
||||
if (auto *N = dyn_cast<MDDerivedType>(get()))
|
||||
return dyn_cast_or_null<MDNode>(N->getExtraData());
|
||||
return nullptr;
|
||||
MDObjCProperty *getObjCProperty() const {
|
||||
return dyn_cast_or_null<MDObjCProperty>(
|
||||
cast<MDDerivedType>(get())->getExtraData());
|
||||
}
|
||||
|
||||
DITypeRef getClassType() const {
|
||||
assert(getTag() == dwarf::DW_TAG_ptr_to_member_type);
|
||||
if (auto *N = dyn_cast<MDDerivedType>(get()))
|
||||
return MDTypeRef(N->getExtraData());
|
||||
return MDTypeRef();
|
||||
return MDTypeRef(cast<MDDerivedType>(get())->getExtraData());
|
||||
}
|
||||
|
||||
Constant *getConstant() const {
|
||||
assert((getTag() == dwarf::DW_TAG_member) && isStaticMember());
|
||||
if (auto *N = dyn_cast<MDDerivedType>(get()))
|
||||
if (auto *C = dyn_cast_or_null<ConstantAsMetadata>(N->getExtraData()))
|
||||
return C->getValue();
|
||||
assert(getTag() == dwarf::DW_TAG_member && isStaticMember());
|
||||
if (auto *C = cast_or_null<ConstantAsMetadata>(
|
||||
cast<MDDerivedType>(get())->getExtraData()))
|
||||
return C->getValue();
|
||||
|
||||
return nullptr;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user