diff options
| author | Anders Carlsson <andersca@mac.com> | 2010-06-04 22:47:55 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2010-06-04 22:47:55 +0000 |
| commit | 76f513f86220730574c9281eb2167aabed0e0f84 (patch) | |
| tree | 437db59795cdd5fd0c86c311498be921b7a6505d /clang/lib/Sema | |
| parent | 7c015988fe8a71afe45347ce07d775c8d265c39a (diff) | |
| download | bcm5719-llvm-76f513f86220730574c9281eb2167aabed0e0f84.tar.gz bcm5719-llvm-76f513f86220730574c9281eb2167aabed0e0f84.zip | |
When deciding whether reinterpret_cast casts away constness we need to look at array qualifiers. Fixes rdar://problem/8018292.
llvm-svn: 105494
Diffstat (limited to 'clang/lib/Sema')
| -rw-r--r-- | clang/lib/Sema/SemaCXXCast.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaCXXCast.cpp b/clang/lib/Sema/SemaCXXCast.cpp index 9b955525548..5485bb3e17a 100644 --- a/clang/lib/Sema/SemaCXXCast.cpp +++ b/clang/lib/Sema/SemaCXXCast.cpp @@ -257,8 +257,13 @@ CastsAwayConstness(Sema &Self, QualType SrcType, QualType DestType) { // Find the qualifications. while (UnwrapDissimilarPointerTypes(UnwrappedSrcType, UnwrappedDestType)) { - cv1.push_back(UnwrappedSrcType.getQualifiers()); - cv2.push_back(UnwrappedDestType.getQualifiers()); + Qualifiers SrcQuals; + Self.Context.getUnqualifiedArrayType(UnwrappedSrcType, SrcQuals); + cv1.push_back(SrcQuals); + + Qualifiers DestQuals; + Self.Context.getUnqualifiedArrayType(UnwrappedDestType, DestQuals); + cv2.push_back(DestQuals); } assert(cv1.size() > 0 && "Must have at least one pointer level."); |

