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/SemaCXXCast.cpp | |
| 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/SemaCXXCast.cpp')
| -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."); | 

