From 3a2c80fe4c1f9306b7b96241117730a29e73ea8c Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Fri, 2 Apr 2010 15:43:29 +0000 Subject: [PATCH] CG/NeXT: Assert some invariants on an ivar's containing decl context that I am about to refactor based on, following some testing. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@100188 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGObjCMac.cpp | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/lib/CodeGen/CGObjCMac.cpp b/lib/CodeGen/CGObjCMac.cpp index 883ed98511..d799162fa4 100644 --- a/lib/CodeGen/CGObjCMac.cpp +++ b/lib/CodeGen/CGObjCMac.cpp @@ -78,6 +78,19 @@ static uint64_t LookupFieldBitOffset(CodeGen::CodeGenModule &CGM, FindIvarInterface(CGM.getContext(), OID, Ivar, Index); assert(Container && "Unable to find ivar container"); + // Check that the Obj-C decl contexts match what we expect. + const ObjCContainerDecl *DC = cast(Ivar->getDeclContext()); + assert(isa(DC) || isa(DC) || + isa(DC)); + if (isa(DC)) { + assert(DC == ID); + assert(Container == cast(DC)->getClassInterface()); + } else if (isa(DC)) { + assert(Container == cast(DC)->getClassInterface()); + } else { + assert(Container == DC); + } + // If we know have an implementation (and the ivar is in it) then // look up in the implementation layout. const ASTRecordLayout *RL; -- 2.40.0