diff options
author | Devin Coughlin <dcoughlin@apple.com> | 2017-11-13 17:35:29 +0000 |
---|---|---|
committer | Devin Coughlin <dcoughlin@apple.com> | 2017-11-13 17:35:29 +0000 |
commit | 5df6b94381ead323b3a8b3e9035f61bfcd25df00 (patch) | |
tree | 188fc683a4e07a6572beac689b28ddc4df888bdd /openmp/testsuite/c/omp_parallel_sections_firstprivate.c | |
parent | 7822fd884b1b90d261a6d8337b43442650661c49 (diff) | |
download | bcm5719-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 'openmp/testsuite/c/omp_parallel_sections_firstprivate.c')
0 files changed, 0 insertions, 0 deletions