diff options
author | Anna Zaks <ganna@apple.com> | 2012-08-10 18:55:58 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2012-08-10 18:55:58 +0000 |
commit | 54918ba02ba900c0e0bb4fd3d749b6b1ac4e50a9 (patch) | |
tree | ebae59c4c36115a5b6dea4ea3c4a851d194ebbc6 /lib/StaticAnalyzer/Core/CallEvent.cpp | |
parent | 3f558af01643787d209a133215b0abec81b5fe30 (diff) |
[analyzer] Track if a region can be a subclass in the dynamic type info.
When object is allocated with alloc or init, we assume it cannot be a
subclass (currently used only for bifurcation purposes).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@161682 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/StaticAnalyzer/Core/CallEvent.cpp')
-rw-r--r-- | lib/StaticAnalyzer/Core/CallEvent.cpp | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/lib/StaticAnalyzer/Core/CallEvent.cpp b/lib/StaticAnalyzer/Core/CallEvent.cpp index 773600b096..6635067d0f 100644 --- a/lib/StaticAnalyzer/Core/CallEvent.cpp +++ b/lib/StaticAnalyzer/Core/CallEvent.cpp @@ -721,6 +721,7 @@ RuntimeDefinition ObjCMethodCall::getRuntimeDefinition() const { // Find the the receiver type. const ObjCObjectPointerType *ReceiverT = 0; + bool CanBeSubClassed = false; QualType SupersType = E->getSuperType(); const MemRegion *Receiver = 0; @@ -733,17 +734,25 @@ RuntimeDefinition ObjCMethodCall::getRuntimeDefinition() const { if (!Receiver) return RuntimeDefinition(); - QualType DynType = getState()->getDynamicTypeInfo(Receiver).getType(); + DynamicTypeInfo DTI = getState()->getDynamicTypeInfo(Receiver); + QualType DynType = DTI.getType(); + CanBeSubClassed = DTI.canBeASubClass(); ReceiverT = dyn_cast<ObjCObjectPointerType>(DynType); + + if (ReceiverT && CanBeSubClassed) + if (ObjCInterfaceDecl *IDecl = ReceiverT->getInterfaceDecl()) + if (!canBeOverridenInSubclass(IDecl, Sel)) + CanBeSubClassed = false; } // Lookup the method implementation. if (ReceiverT) if (ObjCInterfaceDecl *IDecl = ReceiverT->getInterfaceDecl()) { - if (canBeOverridenInSubclass(IDecl, Sel)) - return RuntimeDefinition(IDecl->lookupPrivateMethod(Sel), Receiver); + const ObjCMethodDecl *MD = IDecl->lookupPrivateMethod(Sel); + if (CanBeSubClassed) + return RuntimeDefinition(MD, Receiver); else - return RuntimeDefinition(IDecl->lookupPrivateMethod(Sel), 0); + return RuntimeDefinition(MD, 0); } } else { |