[clang] [clang] Fix array types comparison in getCommonSugaredType (PR #131649)
Serge Pavlov via cfe-commits
cfe-commits at lists.llvm.org
Wed Mar 19 09:59:45 PDT 2025
================
@@ -14171,6 +14171,15 @@ static QualType getCommonSugarTypeNode(ASTContext &Ctx, const Type *X,
static auto unwrapSugar(SplitQualType &T, Qualifiers &QTotal) {
SmallVector<SplitQualType, 8> R;
while (true) {
+ if (const auto *ATy = dyn_cast<ArrayType>(T.Ty)) {
+ // C++ 9.3.3.4p3: Any type of the form "cv-qualifier-seq array of N U" is
+ // adjusted to "array of N cv-qualifier-seq U".
+ // C23 6.7.3p10: If the specification of an array type includes any type
+ // qualifiers, both the array and the element type are so-qualified.
+ //
+ // To simplify comparison remove the redundant qualifiers from the array.
+ T.Quals.removeCVRQualifiers(Qualifiers::Const | Qualifiers::Volatile);
----------------
spavloff wrote:
In the updated version, only qualifiers found in element type are removed.
https://github.com/llvm/llvm-project/pull/131649
More information about the cfe-commits
mailing list