summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorDevin Coughlin <dcoughlin@apple.com>2017-11-13 17:35:29 +0000
committerDevin Coughlin <dcoughlin@apple.com>2017-11-13 17:35:29 +0000
commit5df6b94381ead323b3a8b3e9035f61bfcd25df00 (patch)
tree188fc683a4e07a6572beac689b28ddc4df888bdd /llvm/lib/Analysis/ValueTracking.cpp
parent7822fd884b1b90d261a6d8337b43442650661c49 (diff)
downloadbcm5719-llvm-5df6b94381ead323b3a8b3e9035f61bfcd25df00.tar.gz
bcm5719-llvm-5df6b94381ead323b3a8b3e9035f61bfcd25df00.zip
[analyzer] ObjCGenerics: Don't warn on cast conversions involving explicit cast
The ObjCGenerics checker warns on a cast when there is no subtyping relationship between the tracked type of the value and the destination type of the cast. It does this even if the cast was explicitly written. This means the user can't write an explicit cast to silence the diagnostic. This commit treats explicit casts involving generic types as an indication from the programmer that the Objective-C type system is not rich enough to express the needed invariant. On explicit casts, the checker now removes any existing information inferred about the type arguments. Further, it no longer assumes the casted-to specialized type because the invariant the programmer specifies in the cast may only hold at a particular program point and not later ones. This prevents a suppressing cast from requiring a cascade of casts down the line. rdar://problem/33603303 Differential Revision: https://reviews.llvm.org/D39711 llvm-svn: 318054
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud